@eldrforge/kodrdriv 1.2.5 → 1.2.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,11 +3,11 @@ import { execute as execute$1 } from './commit.js';
3
3
  import { hasStagedChanges } from '../content/diff.js';
4
4
  import { execute as execute$2 } from './release.js';
5
5
  import { getDryRunLogger, getLogger } from '../logging.js';
6
- import { runWithDryRunSupport, run, validateGitRef, runSecure } from '../util/child.js';
6
+ import { runWithDryRunSupport, run, runSecure, validateGitRef } from '../util/child.js';
7
7
  import { getCurrentBranchName, findOpenPullRequestByHeadRef, createPullRequest, waitForPullRequestChecks, mergePullRequest, createRelease, closeMilestoneForVersion, getWorkflowsTriggeredByRelease, waitForReleaseWorkflows } from '../util/github.js';
8
8
  import { create } from '../util/storage.js';
9
9
  import { calculateTargetVersion, checkIfTagExists, confirmVersionInteractively, getOutputPath } from '../util/general.js';
10
- import { DEFAULT_OUTPUT_DIRECTORY } from '../constants.js';
10
+ import { DEFAULT_OUTPUT_DIRECTORY, KODRDRIV_DEFAULTS } from '../constants.js';
11
11
  import { safeJsonParse, validatePackageJson } from '../util/validation.js';
12
12
  import { safeSyncBranchWithRemote, localBranchExists, isBranchInSyncWithRemote } from '../util/git.js';
13
13
 
@@ -340,7 +340,7 @@ const execute = async (runConfig)=>{
340
340
  if (pr) {
341
341
  logger.info(`Found existing pull request for branch: ${pr.html_url}`);
342
342
  } else {
343
- var _runConfig_publish4, _runConfig_publish5, _runConfig_publish6;
343
+ var _runConfig_publish4, _runConfig_publish5, _runConfig_publish6, _runConfig_publish7;
344
344
  logger.info('No open pull request found, starting new release publishing process...');
345
345
  // STEP 1: Prepare for release (update dependencies and run prepublish checks) with NO version bump yet
346
346
  logger.verbose('Preparing for release: switching from workspace to remote dependencies.');
@@ -377,19 +377,19 @@ const execute = async (runConfig)=>{
377
377
  logger.info('Would determine target version and update package.json');
378
378
  newVersion = '1.0.0'; // Mock version for dry run
379
379
  } else {
380
- var _runConfig_publish7, _runConfig_publish8;
380
+ var _runConfig_publish8, _runConfig_publish9;
381
381
  const packageJsonContents = await storage.readFile('package.json', 'utf-8');
382
382
  const parsed = safeJsonParse(packageJsonContents, 'package.json');
383
383
  const packageJson = validatePackageJson(parsed, 'package.json');
384
384
  const currentVersion = packageJson.version;
385
- const targetVersionInput = ((_runConfig_publish7 = runConfig.publish) === null || _runConfig_publish7 === void 0 ? void 0 : _runConfig_publish7.targetVersion) || 'patch';
385
+ const targetVersionInput = ((_runConfig_publish8 = runConfig.publish) === null || _runConfig_publish8 === void 0 ? void 0 : _runConfig_publish8.targetVersion) || 'patch';
386
386
  const proposedVersion = calculateTargetVersion(currentVersion, targetVersionInput);
387
387
  const targetTagName = `v${proposedVersion}`;
388
388
  const tagExists = await checkIfTagExists(targetTagName);
389
389
  if (tagExists) {
390
390
  throw new Error(`Tag ${targetTagName} already exists. Please choose a different version or delete the existing tag.`);
391
391
  }
392
- if ((_runConfig_publish8 = runConfig.publish) === null || _runConfig_publish8 === void 0 ? void 0 : _runConfig_publish8.interactive) {
392
+ if ((_runConfig_publish9 = runConfig.publish) === null || _runConfig_publish9 === void 0 ? void 0 : _runConfig_publish9.interactive) {
393
393
  newVersion = await confirmVersionInteractively(currentVersion, proposedVersion, targetVersionInput);
394
394
  const confirmedTagName = `v${newVersion}`;
395
395
  const confirmedTagExists = await checkIfTagExists(confirmedTagName);
@@ -418,12 +418,12 @@ const execute = async (runConfig)=>{
418
418
  }
419
419
  }
420
420
  logger.info('Generating release notes...');
421
- // Create a modified config for release notes generation that includes the publish --from and --interactive options
421
+ // Create a modified config for release notes generation that includes the publish --from, --interactive, and --from-main options
422
422
  const releaseConfig = {
423
423
  ...runConfig
424
424
  };
425
- if (((_runConfig_publish5 = runConfig.publish) === null || _runConfig_publish5 === void 0 ? void 0 : _runConfig_publish5.from) || ((_runConfig_publish6 = runConfig.publish) === null || _runConfig_publish6 === void 0 ? void 0 : _runConfig_publish6.interactive)) {
426
- // Pass the publish --from and --interactive options to the release config
425
+ if (((_runConfig_publish5 = runConfig.publish) === null || _runConfig_publish5 === void 0 ? void 0 : _runConfig_publish5.from) || ((_runConfig_publish6 = runConfig.publish) === null || _runConfig_publish6 === void 0 ? void 0 : _runConfig_publish6.interactive) || ((_runConfig_publish7 = runConfig.publish) === null || _runConfig_publish7 === void 0 ? void 0 : _runConfig_publish7.fromMain)) {
426
+ // Pass the publish options to the release config
427
427
  releaseConfig.release = {
428
428
  ...runConfig.release,
429
429
  ...runConfig.publish.from && {
@@ -431,6 +431,9 @@ const execute = async (runConfig)=>{
431
431
  },
432
432
  ...runConfig.publish.interactive && {
433
433
  interactive: runConfig.publish.interactive
434
+ },
435
+ ...runConfig.publish.fromMain && {
436
+ fromMain: runConfig.publish.fromMain
434
437
  }
435
438
  };
436
439
  if (runConfig.publish.from) {
@@ -439,6 +442,9 @@ const execute = async (runConfig)=>{
439
442
  if (runConfig.publish.interactive) {
440
443
  logger.verbose('Interactive mode enabled for release notes generation');
441
444
  }
445
+ if (runConfig.publish.fromMain) {
446
+ logger.verbose('Forcing comparison against main branch for release notes');
447
+ }
442
448
  }
443
449
  const releaseSummary = await execute$2(releaseConfig);
444
450
  if (isDryRun) {
@@ -475,12 +481,12 @@ const execute = async (runConfig)=>{
475
481
  }
476
482
  logger.info(`Waiting for PR #${pr.number} checks to complete...`);
477
483
  if (!isDryRun) {
478
- var _runConfig_publish9, _runConfig_publish10, _runConfig_publish11;
484
+ var _runConfig_publish10, _runConfig_publish11, _runConfig_publish12;
479
485
  // Configure timeout and user confirmation behavior
480
- const timeout = ((_runConfig_publish9 = runConfig.publish) === null || _runConfig_publish9 === void 0 ? void 0 : _runConfig_publish9.checksTimeout) || 300000; // 5 minutes default
481
- const senditMode = ((_runConfig_publish10 = runConfig.publish) === null || _runConfig_publish10 === void 0 ? void 0 : _runConfig_publish10.sendit) || false;
486
+ const timeout = ((_runConfig_publish10 = runConfig.publish) === null || _runConfig_publish10 === void 0 ? void 0 : _runConfig_publish10.checksTimeout) || KODRDRIV_DEFAULTS.publish.checksTimeout;
487
+ const senditMode = ((_runConfig_publish11 = runConfig.publish) === null || _runConfig_publish11 === void 0 ? void 0 : _runConfig_publish11.sendit) || false;
482
488
  // sendit flag overrides skipUserConfirmation - if sendit is true, skip confirmation
483
- const skipUserConfirmation = senditMode || ((_runConfig_publish11 = runConfig.publish) === null || _runConfig_publish11 === void 0 ? void 0 : _runConfig_publish11.skipUserConfirmation) || false;
489
+ const skipUserConfirmation = senditMode || ((_runConfig_publish12 = runConfig.publish) === null || _runConfig_publish12 === void 0 ? void 0 : _runConfig_publish12.skipUserConfirmation) || false;
484
490
  await waitForPullRequestChecks(pr.number, {
485
491
  timeout,
486
492
  skipUserConfirmation
@@ -512,6 +518,25 @@ const execute = async (runConfig)=>{
512
518
  }
513
519
  // Switch to target branch and pull latest changes
514
520
  logger.info(`Checking out target branch: ${targetBranch}...`);
521
+ // Check for uncommitted changes and stash them if necessary
522
+ let hasStashedChanges = false;
523
+ if (!isDryRun) {
524
+ const { stdout: statusOutput } = await runSecure('git', [
525
+ 'status',
526
+ '--porcelain'
527
+ ]);
528
+ if (statusOutput.trim()) {
529
+ logger.info('📦 Stashing uncommitted changes before checkout...');
530
+ await runSecure('git', [
531
+ 'stash',
532
+ 'push',
533
+ '-m',
534
+ 'kodrdriv: stash before checkout target branch'
535
+ ]);
536
+ hasStashedChanges = true;
537
+ logger.info('✅ Successfully stashed uncommitted changes');
538
+ }
539
+ }
515
540
  try {
516
541
  await runWithDryRunSupport(`git checkout ${targetBranch}`, isDryRun);
517
542
  await runWithDryRunSupport(`git pull origin ${targetBranch}`, isDryRun);
@@ -535,6 +560,20 @@ const execute = async (runConfig)=>{
535
560
  throw error;
536
561
  }
537
562
  }
563
+ // Restore stashed changes if we stashed them
564
+ if (hasStashedChanges) {
565
+ logger.info('📦 Restoring previously stashed changes...');
566
+ try {
567
+ await runSecure('git', [
568
+ 'stash',
569
+ 'pop'
570
+ ]);
571
+ logger.info('✅ Successfully restored stashed changes');
572
+ } catch (stashError) {
573
+ logger.warn(`⚠️ Warning: Could not restore stashed changes: ${stashError.message}`);
574
+ logger.warn(' Your changes are still available in the git stash. Run "git stash list" to see them.');
575
+ }
576
+ }
538
577
  // Now create and push the tag on the target branch
539
578
  logger.info('Creating release tag...');
540
579
  let tagName;
@@ -618,9 +657,9 @@ const execute = async (runConfig)=>{
618
657
  }
619
658
  logger.info('Creating GitHub release...');
620
659
  if (isDryRun) {
621
- var _runConfig_publish12;
660
+ var _runConfig_publish13;
622
661
  logger.info('Would read package.json version and create GitHub release with retry logic');
623
- const milestonesEnabled = !((_runConfig_publish12 = runConfig.publish) === null || _runConfig_publish12 === void 0 ? void 0 : _runConfig_publish12.noMilestones);
662
+ const milestonesEnabled = !((_runConfig_publish13 = runConfig.publish) === null || _runConfig_publish13 === void 0 ? void 0 : _runConfig_publish13.noMilestones);
624
663
  if (milestonesEnabled) {
625
664
  logger.info('Would close milestone for released version');
626
665
  } else {
@@ -636,11 +675,11 @@ const execute = async (runConfig)=>{
636
675
  let retries = 3;
637
676
  while(retries > 0){
638
677
  try {
639
- var _runConfig_publish13;
678
+ var _runConfig_publish14;
640
679
  await createRelease(tagName, releaseTitle, releaseNotesContent);
641
680
  logger.info(`GitHub release created successfully for tag: ${tagName}`);
642
681
  // Close milestone for this version if enabled
643
- const milestonesEnabled = !((_runConfig_publish13 = runConfig.publish) === null || _runConfig_publish13 === void 0 ? void 0 : _runConfig_publish13.noMilestones);
682
+ const milestonesEnabled = !((_runConfig_publish14 = runConfig.publish) === null || _runConfig_publish14 === void 0 ? void 0 : _runConfig_publish14.noMilestones);
644
683
  if (milestonesEnabled) {
645
684
  logger.info('🏁 Closing milestone for released version...');
646
685
  const version = tagName.replace(/^v/, ''); // Remove 'v' prefix if present
@@ -673,12 +712,12 @@ const execute = async (runConfig)=>{
673
712
  if (isDryRun) {
674
713
  logger.info('Would monitor GitHub Actions workflows triggered by release');
675
714
  } else {
676
- var _runConfig_publish14, _runConfig_publish15, _runConfig_publish16, _runConfig_publish17;
677
- const workflowTimeout = ((_runConfig_publish14 = runConfig.publish) === null || _runConfig_publish14 === void 0 ? void 0 : _runConfig_publish14.releaseWorkflowsTimeout) || 600000; // 10 minutes default
678
- const senditMode = ((_runConfig_publish15 = runConfig.publish) === null || _runConfig_publish15 === void 0 ? void 0 : _runConfig_publish15.sendit) || false;
679
- const skipUserConfirmation = senditMode || ((_runConfig_publish16 = runConfig.publish) === null || _runConfig_publish16 === void 0 ? void 0 : _runConfig_publish16.skipUserConfirmation) || false;
715
+ var _runConfig_publish15, _runConfig_publish16, _runConfig_publish17, _runConfig_publish18;
716
+ const workflowTimeout = ((_runConfig_publish15 = runConfig.publish) === null || _runConfig_publish15 === void 0 ? void 0 : _runConfig_publish15.releaseWorkflowsTimeout) || KODRDRIV_DEFAULTS.publish.releaseWorkflowsTimeout;
717
+ const senditMode = ((_runConfig_publish16 = runConfig.publish) === null || _runConfig_publish16 === void 0 ? void 0 : _runConfig_publish16.sendit) || false;
718
+ const skipUserConfirmation = senditMode || ((_runConfig_publish17 = runConfig.publish) === null || _runConfig_publish17 === void 0 ? void 0 : _runConfig_publish17.skipUserConfirmation) || false;
680
719
  // Get workflow names - either from config or auto-detect
681
- let workflowNames = (_runConfig_publish17 = runConfig.publish) === null || _runConfig_publish17 === void 0 ? void 0 : _runConfig_publish17.releaseWorkflowNames;
720
+ let workflowNames = (_runConfig_publish18 = runConfig.publish) === null || _runConfig_publish18 === void 0 ? void 0 : _runConfig_publish18.releaseWorkflowNames;
682
721
  if (!workflowNames || workflowNames.length === 0) {
683
722
  logger.info('No specific workflow names configured, auto-detecting workflows triggered by release events...');
684
723
  try {
@@ -1 +1 @@
1
- {"version":3,"file":"publish.js","sources":["../../src/commands/publish.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nimport path from 'path';\nimport * as Commit from './commit';\nimport * as Diff from '../content/diff';\nimport * as Release from './release';\n\nimport { getLogger, getDryRunLogger } from '../logging';\nimport { Config, PullRequest } from '../types';\nimport { run, runWithDryRunSupport, runSecure, validateGitRef } from '../util/child';\nimport * as GitHub from '../util/github';\nimport { create as createStorage } from '../util/storage';\nimport { incrementPatchVersion, getOutputPath, calculateTargetVersion, checkIfTagExists, confirmVersionInteractively } from '../util/general';\nimport { DEFAULT_OUTPUT_DIRECTORY } from '../constants';\nimport { safeJsonParse, validatePackageJson } from '../util/validation';\nimport { isBranchInSyncWithRemote, safeSyncBranchWithRemote, localBranchExists } from '../util/git';\n\nconst scanNpmrcForEnvVars = async (storage: any): Promise<string[]> => {\n const logger = getLogger();\n const npmrcPath = path.join(process.cwd(), '.npmrc');\n const envVars: string[] = [];\n\n if (await storage.exists(npmrcPath)) {\n try {\n const npmrcContent = await storage.readFile(npmrcPath, 'utf-8');\n // Match environment variable patterns like ${VAR_NAME} or $VAR_NAME\n const envVarMatches = npmrcContent.match(/\\$\\{([^}]+)\\}|\\$([A-Z_][A-Z0-9_]*)/g);\n\n if (envVarMatches) {\n for (const match of envVarMatches) {\n // Extract variable name from ${VAR_NAME} or $VAR_NAME format\n const varName = match.replace(/\\$\\{|\\}|\\$/g, '');\n if (varName && !envVars.includes(varName)) {\n envVars.push(varName);\n }\n }\n }\n\n } catch (error: any) {\n logger.warn(`Failed to read .npmrc file at ${npmrcPath}: ${error.message}`);\n logger.verbose('This may affect environment variable detection for publishing');\n }\n } else {\n logger.debug('.npmrc file not found, skipping environment variable scan');\n }\n\n return envVars;\n};\n\nconst validateEnvironmentVariables = (requiredEnvVars: string[], isDryRun: boolean): void => {\n const logger = getDryRunLogger(isDryRun);\n const missingEnvVars: string[] = [];\n\n for (const envVar of requiredEnvVars) {\n if (!process.env[envVar]) {\n missingEnvVars.push(envVar);\n }\n }\n\n if (missingEnvVars.length > 0) {\n if (isDryRun) {\n logger.warn(`Missing required environment variables: ${missingEnvVars.join(', ')}`);\n } else {\n logger.error(`Missing required environment variables: ${missingEnvVars.join(', ')}`);\n throw new Error(`Missing required environment variables: ${missingEnvVars.join(', ')}. Please set these environment variables before running publish.`);\n }\n }\n};\n\nconst runPrechecks = async (runConfig: Config): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage({ log: logger.info });\n\n logger.info('Running prechecks...');\n\n // Check if we're in a git repository\n try {\n if (isDryRun) {\n logger.info('Would check git repository with: git rev-parse --git-dir');\n } else {\n await run('git rev-parse --git-dir');\n }\n\n } catch (error: any) {\n if (!isDryRun) {\n // Preserve the original error message to help with debugging\n const originalMessage = error.message || error.toString();\n throw new Error(`Not in a git repository or git command failed: ${originalMessage}. Please run this command from within a git repository.`);\n }\n }\n\n // Check for uncommitted changes\n logger.info('Checking for uncommitted changes...');\n try {\n if (isDryRun) {\n logger.info('Would check git status with: git status --porcelain');\n } else {\n const { stdout } = await run('git status --porcelain');\n if (stdout.trim()) {\n throw new Error('Working directory has uncommitted changes. Please commit or stash your changes before running publish.');\n }\n }\n\n } catch (error: any) {\n if (!isDryRun) {\n // Preserve the original error message to help with debugging\n const originalMessage = error.message || error.toString();\n throw new Error(`Failed to check git status: ${originalMessage}. Please ensure you are in a valid git repository and try again.`);\n }\n }\n\n // Check that we're not running from the target branch\n logger.info('Checking current branch...');\n const targetBranch = runConfig.publish?.targetBranch || 'main';\n if (isDryRun) {\n logger.info(`Would verify current branch is not the target branch (${targetBranch})`);\n } else {\n const currentBranch = await GitHub.getCurrentBranchName();\n if (currentBranch === targetBranch) {\n throw new Error(`Cannot run publish from the target branch '${targetBranch}'. Please switch to a different branch before running publish.`);\n }\n }\n\n // Check target branch sync with remote\n logger.info(`Checking target branch '${targetBranch}' sync with remote...`);\n if (isDryRun) {\n logger.info(`Would verify target branch '${targetBranch}' is in sync with remote origin`);\n } else {\n // Only check if local target branch exists (it's okay if it doesn't exist locally)\n const targetBranchExists = await localBranchExists(targetBranch);\n if (targetBranchExists) {\n const syncStatus = await isBranchInSyncWithRemote(targetBranch);\n\n if (!syncStatus.inSync) {\n logger.error(`❌ Target branch '${targetBranch}' is not in sync with remote.`);\n logger.error('');\n\n if (syncStatus.error) {\n logger.error(` Error: ${syncStatus.error}`);\n } else if (syncStatus.localSha && syncStatus.remoteSha) {\n logger.error(` Local: ${syncStatus.localSha.substring(0, 8)}`);\n logger.error(` Remote: ${syncStatus.remoteSha.substring(0, 8)}`);\n }\n\n logger.error('');\n logger.error('📋 To resolve this issue:');\n logger.error(` 1. Switch to the target branch: git checkout ${targetBranch}`);\n logger.error(` 2. Pull the latest changes: git pull origin ${targetBranch}`);\n logger.error(' 3. Resolve any merge conflicts if they occur');\n logger.error(' 4. Switch back to your feature branch and re-run publish');\n logger.error('');\n logger.error('💡 Alternatively, run \"kodrdriv publish --sync-target\" to attempt automatic sync.');\n\n throw new Error(`Target branch '${targetBranch}' is not in sync with remote. Please sync the branch before running publish.`);\n } else {\n logger.info(`✅ Target branch '${targetBranch}' is in sync with remote.`);\n }\n } else {\n logger.info(`ℹ️ Target branch '${targetBranch}' does not exist locally - will be created when needed.`);\n }\n }\n\n // Check if prepublishOnly script exists in package.json\n logger.info('Checking for prepublishOnly script...');\n const packageJsonPath = path.join(process.cwd(), 'package.json');\n\n if (!await storage.exists(packageJsonPath)) {\n if (!isDryRun) {\n throw new Error('package.json not found in current directory.');\n } else {\n logger.warn('package.json not found in current directory.');\n }\n } else {\n let packageJson;\n try {\n const packageJsonContents = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContents, packageJsonPath);\n packageJson = validatePackageJson(parsed, packageJsonPath);\n\n } catch (error) {\n if (!isDryRun) {\n throw new Error('Failed to parse package.json. Please ensure it contains valid JSON.');\n } else {\n logger.warn('Failed to parse package.json. Please ensure it contains valid JSON.');\n }\n }\n\n if (packageJson && !packageJson.scripts?.prepublishOnly) {\n if (!isDryRun) {\n throw new Error('prepublishOnly script is required in package.json but was not found. Please add a prepublishOnly script that runs your pre-flight checks (e.g., clean, lint, build, test).');\n } else {\n logger.warn('prepublishOnly script is required in package.json but was not found.');\n }\n }\n }\n\n // Check required environment variables\n logger.verbose('Checking required environment variables...');\n const coreRequiredEnvVars = runConfig.publish?.requiredEnvVars || [];\n const npmrcEnvVars = isDryRun ? [] : await scanNpmrcForEnvVars(storage); // Skip .npmrc scan in dry run\n const allRequiredEnvVars = [...new Set([...coreRequiredEnvVars, ...npmrcEnvVars])];\n\n if (allRequiredEnvVars.length > 0) {\n logger.verbose(`Required environment variables: ${allRequiredEnvVars.join(', ')}`);\n validateEnvironmentVariables(allRequiredEnvVars, isDryRun);\n } else {\n logger.verbose('No required environment variables specified.');\n }\n\n logger.info('All prechecks passed.');\n};\n\n// Helper: deep-sort object keys for stable comparison\nconst sortObjectKeys = (value: any): any => {\n if (Array.isArray(value)) {\n return value.map(sortObjectKeys);\n }\n if (value && typeof value === 'object') {\n const sorted: any = {};\n Object.keys(value).sort().forEach((key) => {\n sorted[key] = sortObjectKeys(value[key]);\n });\n return sorted;\n }\n return value;\n};\n\n// Determine if there are substantive changes compared to the target branch (beyond just version bump)\nconst isReleaseNecessaryComparedToTarget = async (targetBranch: string, isDryRun: boolean): Promise<{ necessary: boolean; reason: string }> => {\n const logger = getDryRunLogger(isDryRun);\n\n // We compare current HEAD branch to the provided target branch\n const currentBranch = await GitHub.getCurrentBranchName();\n\n // If branches are identical, nothing to release\n const { stdout: namesStdout } = await runSecure('git', ['diff', '--name-only', `${targetBranch}..${currentBranch}`]);\n const changedFiles = namesStdout.split('\\n').map(s => s.trim()).filter(Boolean);\n\n if (changedFiles.length === 0) {\n // No definitive signal; proceed with publish rather than skipping\n return { necessary: true, reason: 'No detectable changes via diff; proceeding conservatively' };\n }\n\n // If any files changed other than package.json or package-lock.json, a release is necessary\n const nonVersionFiles = changedFiles.filter(f => f !== 'package.json' && f !== 'package-lock.json');\n if (nonVersionFiles.length > 0) {\n return { necessary: true, reason: `Changed files beyond version bump: ${nonVersionFiles.join(', ')}` };\n }\n\n // Only package.json and/or package-lock.json changed. Verify package.json change is only the version field\n try {\n // Read package.json content from both branches\n const { stdout: basePkgStdout } = await runSecure('git', ['show', `${targetBranch}:package.json`]);\n const { stdout: headPkgStdout } = await runSecure('git', ['show', `${currentBranch}:package.json`]);\n\n const basePkg = validatePackageJson(safeJsonParse(basePkgStdout, `${targetBranch}:package.json`), `${targetBranch}:package.json`);\n const headPkg = validatePackageJson(safeJsonParse(headPkgStdout, `${currentBranch}:package.json`), `${currentBranch}:package.json`);\n\n const { version: _baseVersion, ...baseWithoutVersion } = basePkg;\n const { version: _headVersion, ...headWithoutVersion } = headPkg;\n\n const baseSorted = sortObjectKeys(baseWithoutVersion);\n const headSorted = sortObjectKeys(headWithoutVersion);\n\n const equalExceptVersion = JSON.stringify(baseSorted) === JSON.stringify(headSorted);\n if (equalExceptVersion) {\n return { necessary: false, reason: 'Only version changed in package.json (plus lockfile)' };\n }\n\n // Other fields changed inside package.json\n return { necessary: true, reason: 'package.json changes beyond version field' };\n } catch (error: any) {\n // Conservative: if we cannot prove it is only a version change, proceed with release\n logger.verbose(`Could not conclusively compare package.json changes: ${error.message}`);\n return { necessary: true, reason: 'Could not compare package.json safely' };\n }\n};\n\nconst handleTargetBranchSyncRecovery = async (runConfig: Config): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const targetBranch = runConfig.publish?.targetBranch || 'main';\n\n logger.info(`🔄 Attempting to sync target branch '${targetBranch}' with remote...`);\n\n if (isDryRun) {\n logger.info(`Would attempt to sync '${targetBranch}' with remote`);\n return;\n }\n\n const syncResult = await safeSyncBranchWithRemote(targetBranch);\n\n if (syncResult.success) {\n logger.info(`✅ Successfully synced '${targetBranch}' with remote.`);\n logger.info('You can now re-run the publish command.');\n } else if (syncResult.conflictResolutionRequired) {\n logger.error(`❌ Failed to sync '${targetBranch}': conflicts detected.`);\n logger.error('');\n logger.error('📋 Manual conflict resolution required:');\n logger.error(` 1. Switch to the target branch: git checkout ${targetBranch}`);\n logger.error(` 2. Pull and resolve conflicts: git pull origin ${targetBranch}`);\n logger.error(' 3. Commit the resolved changes');\n logger.error(' 4. Switch back to your feature branch and re-run publish');\n logger.error('');\n throw new Error(`Target branch '${targetBranch}' has conflicts that require manual resolution.`);\n } else {\n logger.error(`❌ Failed to sync '${targetBranch}': ${syncResult.error}`);\n throw new Error(`Failed to sync target branch: ${syncResult.error}`);\n }\n};\n\nexport const execute = async (runConfig: Config): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage({ log: logger.info });\n const targetBranch = runConfig.publish?.targetBranch || 'main';\n\n // Handle --sync-target flag\n if (runConfig.publish?.syncTarget) {\n await handleTargetBranchSyncRecovery(runConfig);\n return; // Exit after sync operation\n }\n\n // Run prechecks before starting any work\n await runPrechecks(runConfig);\n\n // Early check: determine if a release is necessary compared to target branch\n logger.info('Evaluating if a release is necessary compared to target branch...');\n try {\n const necessity = await isReleaseNecessaryComparedToTarget(targetBranch, isDryRun);\n if (!necessity.necessary) {\n logger.info(`Skipping publish: ${necessity.reason}.`);\n // Emit a machine-readable marker so tree mode can detect skip and avoid propagating versions\n logger.info('KODRDRIV_PUBLISH_SKIPPED');\n return;\n } else {\n logger.verbose(`Proceeding with publish: ${necessity.reason}.`);\n }\n } catch (error: any) {\n // On unexpected errors, proceed with publish to avoid false negatives blocking releases\n logger.verbose(`Release necessity check encountered an issue (${error.message}). Proceeding with publish.`);\n }\n\n logger.info('Starting release process...');\n\n\n let pr: PullRequest | null = null;\n\n if (isDryRun) {\n logger.info('Would check for existing pull request');\n logger.info('Assuming no existing PR found for demo purposes');\n } else {\n const branchName = await GitHub.getCurrentBranchName();\n pr = await GitHub.findOpenPullRequestByHeadRef(branchName);\n }\n\n if (pr) {\n logger.info(`Found existing pull request for branch: ${pr.html_url}`);\n } else {\n logger.info('No open pull request found, starting new release publishing process...');\n\n // STEP 1: Prepare for release (update dependencies and run prepublish checks) with NO version bump yet\n logger.verbose('Preparing for release: switching from workspace to remote dependencies.');\n\n logger.verbose('Updating dependencies to latest versions from registry');\n const updatePatterns = runConfig.publish?.dependencyUpdatePatterns;\n if (updatePatterns && updatePatterns.length > 0) {\n logger.verbose(`Updating dependencies matching patterns: ${updatePatterns.join(', ')}`);\n const patternsArg = updatePatterns.join(' ');\n await runWithDryRunSupport(`npm update ${patternsArg}`, isDryRun);\n } else {\n logger.verbose('No dependency update patterns specified, updating all dependencies');\n await runWithDryRunSupport('npm update', isDryRun);\n }\n\n logger.info('Running prepublishOnly script...');\n await runWithDryRunSupport('npm run prepublishOnly', isDryRun, {}, true); // Use inherited stdio\n\n // STEP 2: Commit dependency updates if any (still no version bump)\n logger.verbose('Staging dependency updates for commit');\n await runWithDryRunSupport('git add package.json package-lock.json', isDryRun);\n\n logger.verbose('Checking for staged dependency updates...');\n if (isDryRun) {\n logger.verbose('Would create dependency update commit if changes are staged');\n } else {\n if (await Diff.hasStagedChanges()) {\n logger.verbose('Staged dependency changes found, creating commit...');\n await Commit.execute(runConfig);\n } else {\n logger.verbose('No dependency changes to commit, skipping commit.');\n }\n }\n\n // STEP 3: Determine and set target version AFTER checks and dependency commit\n logger.info('Determining target version...');\n let newVersion: string;\n\n if (isDryRun) {\n logger.info('Would determine target version and update package.json');\n newVersion = '1.0.0'; // Mock version for dry run\n } else {\n const packageJsonContents = await storage.readFile('package.json', 'utf-8');\n const parsed = safeJsonParse(packageJsonContents, 'package.json');\n const packageJson = validatePackageJson(parsed, 'package.json');\n const currentVersion = packageJson.version;\n\n const targetVersionInput = runConfig.publish?.targetVersion || 'patch';\n const proposedVersion = calculateTargetVersion(currentVersion, targetVersionInput);\n\n const targetTagName = `v${proposedVersion}`;\n const tagExists = await checkIfTagExists(targetTagName);\n if (tagExists) {\n throw new Error(`Tag ${targetTagName} already exists. Please choose a different version or delete the existing tag.`);\n }\n\n if (runConfig.publish?.interactive) {\n newVersion = await confirmVersionInteractively(currentVersion, proposedVersion, targetVersionInput);\n const confirmedTagName = `v${newVersion}`;\n const confirmedTagExists = await checkIfTagExists(confirmedTagName);\n if (confirmedTagExists) {\n throw new Error(`Tag ${confirmedTagName} already exists. Please choose a different version or delete the existing tag.`);\n }\n } else {\n newVersion = proposedVersion;\n }\n\n logger.info(`Bumping version from ${currentVersion} to ${newVersion}`);\n packageJson.version = newVersion;\n await storage.writeFile('package.json', JSON.stringify(packageJson, null, 2) + '\\n', 'utf-8');\n logger.info(`Version updated in package.json: ${newVersion}`);\n }\n\n // STEP 4: Commit version bump as a separate commit\n logger.verbose('Staging version bump for commit');\n await runWithDryRunSupport('git add package.json package-lock.json', isDryRun);\n\n if (isDryRun) {\n logger.verbose('Would create version bump commit');\n } else {\n if (await Diff.hasStagedChanges()) {\n logger.verbose('Creating version bump commit...');\n await Commit.execute(runConfig);\n } else {\n logger.verbose('No version changes to commit.');\n }\n }\n\n logger.info('Generating release notes...');\n // Create a modified config for release notes generation that includes the publish --from and --interactive options\n const releaseConfig = { ...runConfig };\n if (runConfig.publish?.from || runConfig.publish?.interactive) {\n // Pass the publish --from and --interactive options to the release config\n releaseConfig.release = {\n ...runConfig.release,\n ...(runConfig.publish.from && { from: runConfig.publish.from }),\n ...(runConfig.publish.interactive && { interactive: runConfig.publish.interactive })\n };\n if (runConfig.publish.from) {\n logger.verbose(`Using custom 'from' reference for release notes: ${runConfig.publish.from}`);\n }\n if (runConfig.publish.interactive) {\n logger.verbose('Interactive mode enabled for release notes generation');\n }\n }\n const releaseSummary = await Release.execute(releaseConfig);\n\n if (isDryRun) {\n logger.info('Would write release notes to RELEASE_NOTES.md and RELEASE_TITLE.md in output directory');\n } else {\n const outputDirectory = runConfig.outputDirectory || DEFAULT_OUTPUT_DIRECTORY;\n await storage.ensureDirectory(outputDirectory);\n\n const releaseNotesPath = getOutputPath(outputDirectory, 'RELEASE_NOTES.md');\n const releaseTitlePath = getOutputPath(outputDirectory, 'RELEASE_TITLE.md');\n\n await storage.writeFile(releaseNotesPath, releaseSummary.body, 'utf-8');\n await storage.writeFile(releaseTitlePath, releaseSummary.title, 'utf-8');\n logger.info(`Release notes and title generated and saved to ${releaseNotesPath} and ${releaseTitlePath}.`);\n }\n\n logger.info('Pushing to origin...');\n // Get current branch name and push explicitly to avoid pushing to wrong remote/branch\n const currentBranch = await GitHub.getCurrentBranchName();\n await runWithDryRunSupport(`git push origin ${currentBranch}`, isDryRun);\n\n logger.info('Creating pull request...');\n if (isDryRun) {\n logger.info('Would get commit title and create PR with GitHub API');\n pr = { number: 123, html_url: 'https://github.com/mock/repo/pull/123', labels: [] } as PullRequest;\n } else {\n const { stdout: commitTitle } = await run('git log -1 --pretty=%B');\n pr = await GitHub.createPullRequest(commitTitle, 'Automated release PR.', await GitHub.getCurrentBranchName());\n if (!pr) {\n throw new Error('Failed to create pull request.');\n }\n logger.info(`Pull request created: ${pr.html_url}`);\n }\n }\n\n logger.info(`Waiting for PR #${pr!.number} checks to complete...`);\n if (!isDryRun) {\n // Configure timeout and user confirmation behavior\n const timeout = runConfig.publish?.checksTimeout || 300000; // 5 minutes default\n const senditMode = runConfig.publish?.sendit || false;\n // sendit flag overrides skipUserConfirmation - if sendit is true, skip confirmation\n const skipUserConfirmation = senditMode || runConfig.publish?.skipUserConfirmation || false;\n\n await GitHub.waitForPullRequestChecks(pr!.number, {\n timeout,\n skipUserConfirmation\n });\n }\n\n const mergeMethod = runConfig.publish?.mergeMethod || 'squash';\n if (isDryRun) {\n logger.info(`Would merge PR #${pr!.number} using ${mergeMethod} method`);\n } else {\n try {\n await GitHub.mergePullRequest(pr!.number, mergeMethod, false); // Don't delete branch\n } catch (error: any) {\n // Check if this is a merge conflict error\n if (error.message && (\n error.message.includes('not mergeable') ||\n error.message.includes('Pull Request is not mergeable') ||\n error.message.includes('merge conflict')\n )) {\n logger.error(`❌ Pull Request #${pr!.number} has merge conflicts that need to be resolved.`);\n logger.error('');\n logger.error('📋 To resolve this issue:');\n logger.error(` 1. Visit the Pull Request: ${pr!.html_url}`);\n logger.error(' 2. Resolve the merge conflicts through GitHub\\'s web interface or locally');\n logger.error(' 3. Once conflicts are resolved, re-run the publish command');\n logger.error('');\n logger.error('💡 The command will automatically detect the existing PR and continue from where it left off.');\n throw new Error(`Merge conflicts detected in PR #${pr!.number}. Please resolve conflicts and re-run the command.`);\n } else {\n // Re-throw other merge errors\n throw error;\n }\n }\n }\n\n // Switch to target branch and pull latest changes\n logger.info(`Checking out target branch: ${targetBranch}...`);\n\n try {\n await runWithDryRunSupport(`git checkout ${targetBranch}`, isDryRun);\n await runWithDryRunSupport(`git pull origin ${targetBranch}`, isDryRun);\n } catch (error: any) {\n // Check if this is a merge conflict or sync issue\n if (!isDryRun && (error.message.includes('conflict') ||\n error.message.includes('CONFLICT') ||\n error.message.includes('diverged') ||\n error.message.includes('non-fast-forward'))) {\n\n logger.error(`❌ Failed to sync target branch '${targetBranch}' with remote.`);\n logger.error('');\n logger.error('📋 Recovery options:');\n logger.error(` 1. Run 'kodrdriv publish --sync-target' to attempt automatic resolution`);\n logger.error(` 2. Manually resolve conflicts:`);\n logger.error(` - git checkout ${targetBranch}`);\n logger.error(` - git pull origin ${targetBranch}`);\n logger.error(` - Resolve any conflicts and commit`);\n logger.error(` - Re-run your original publish command`);\n logger.error('');\n logger.error('💡 The publish process has been stopped to prevent data loss.');\n\n throw new Error(`Target branch '${targetBranch}' sync failed. Use recovery options above to resolve.`);\n } else {\n // Re-throw other errors\n throw error;\n }\n }\n\n // Now create and push the tag on the target branch\n logger.info('Creating release tag...');\n let tagName: string;\n if (isDryRun) {\n logger.info('Would read package.json version and create git tag');\n tagName = 'v1.0.0'; // Mock version for dry run\n } else {\n const packageJsonContents = await storage.readFile('package.json', 'utf-8');\n const { version } = safeJsonParse(packageJsonContents, 'package.json');\n tagName = `v${version}`;\n\n // Check if tag already exists locally\n try {\n // Validate tag name to prevent injection\n if (!validateGitRef(tagName)) {\n throw new Error(`Invalid tag name: ${tagName}`);\n }\n const { stdout } = await runSecure('git', ['tag', '-l', tagName]);\n if (stdout.trim() === tagName) {\n logger.info(`Tag ${tagName} already exists locally, skipping tag creation`);\n } else {\n await runSecure('git', ['tag', tagName]);\n logger.info(`Created local tag: ${tagName}`);\n }\n } catch (error) {\n // If git tag -l fails, create the tag anyway\n await runSecure('git', ['tag', tagName]);\n logger.info(`Created local tag: ${tagName}`);\n }\n\n // Check if tag exists on remote before pushing\n let tagWasPushed = false;\n try {\n const { stdout } = await runSecure('git', ['ls-remote', 'origin', `refs/tags/${tagName}`]);\n if (stdout.trim()) {\n logger.info(`Tag ${tagName} already exists on remote, skipping push`);\n } else {\n await runSecure('git', ['push', 'origin', tagName]);\n logger.info(`Pushed tag to remote: ${tagName}`);\n tagWasPushed = true;\n }\n } catch (error) {\n // If ls-remote fails, try to push anyway (might be a new remote)\n try {\n await runSecure('git', ['push', 'origin', tagName]);\n logger.info(`Pushed tag to remote: ${tagName}`);\n tagWasPushed = true;\n } catch (pushError: any) {\n if (pushError.message && pushError.message.includes('already exists')) {\n logger.info(`Tag ${tagName} already exists on remote, continuing...`);\n } else {\n throw pushError;\n }\n }\n }\n\n // If we just pushed a new tag, wait for GitHub to process it\n if (tagWasPushed) {\n logger.verbose('Waiting for GitHub to process the pushed tag...');\n await new Promise(resolve => setTimeout(resolve, 5000)); // 5 second delay\n }\n }\n\n logger.info('Creating GitHub release...');\n if (isDryRun) {\n logger.info('Would read package.json version and create GitHub release with retry logic');\n const milestonesEnabled = !runConfig.publish?.noMilestones;\n if (milestonesEnabled) {\n logger.info('Would close milestone for released version');\n } else {\n logger.info('Would skip milestone closure (--no-milestones)');\n }\n } else {\n const outputDirectory = runConfig.outputDirectory || DEFAULT_OUTPUT_DIRECTORY;\n const releaseNotesPath = getOutputPath(outputDirectory, 'RELEASE_NOTES.md');\n const releaseTitlePath = getOutputPath(outputDirectory, 'RELEASE_TITLE.md');\n\n const releaseNotesContent = await storage.readFile(releaseNotesPath, 'utf-8');\n const releaseTitle = await storage.readFile(releaseTitlePath, 'utf-8');\n\n // Create release with retry logic to handle GitHub tag processing delays\n let retries = 3;\n while (retries > 0) {\n try {\n await GitHub.createRelease(tagName, releaseTitle, releaseNotesContent);\n logger.info(`GitHub release created successfully for tag: ${tagName}`);\n\n // Close milestone for this version if enabled\n const milestonesEnabled = !runConfig.publish?.noMilestones;\n if (milestonesEnabled) {\n logger.info('🏁 Closing milestone for released version...');\n const version = tagName.replace(/^v/, ''); // Remove 'v' prefix if present\n await GitHub.closeMilestoneForVersion(version);\n } else {\n logger.debug('Milestone integration disabled via --no-milestones');\n }\n\n break; // Success - exit retry loop\n } catch (error: any) {\n // Check if this is a tag-not-found error that we can retry\n const isTagNotFoundError = error.message && (\n error.message.includes('not found') ||\n error.message.includes('does not exist') ||\n error.message.includes('Reference does not exist')\n );\n\n if (isTagNotFoundError && retries > 1) {\n logger.verbose(`Tag ${tagName} not yet available on GitHub, retrying in 3 seconds... (${retries - 1} retries left)`);\n await new Promise(resolve => setTimeout(resolve, 3000));\n retries--;\n } else if (isTagNotFoundError) {\n // Tag not found error and we're out of retries\n throw new Error(`Tag ${tagName} was not found on GitHub after ${3 - retries + 1} attempts. This may indicate a problem with tag creation or GitHub synchronization.`);\n } else {\n // Not a tag-not-found error - re-throw the original error\n throw error;\n }\n }\n }\n }\n\n // Wait for release workflows to complete (if enabled)\n const waitForWorkflows = runConfig.publish?.waitForReleaseWorkflows !== false; // default to true\n if (waitForWorkflows) {\n logger.info('Waiting for release workflows...');\n if (isDryRun) {\n logger.info('Would monitor GitHub Actions workflows triggered by release');\n } else {\n const workflowTimeout = runConfig.publish?.releaseWorkflowsTimeout || 600000; // 10 minutes default\n const senditMode = runConfig.publish?.sendit || false;\n const skipUserConfirmation = senditMode || runConfig.publish?.skipUserConfirmation || false;\n\n // Get workflow names - either from config or auto-detect\n let workflowNames = runConfig.publish?.releaseWorkflowNames;\n\n if (!workflowNames || workflowNames.length === 0) {\n logger.info('No specific workflow names configured, auto-detecting workflows triggered by release events...');\n try {\n workflowNames = await GitHub.getWorkflowsTriggeredByRelease();\n if (workflowNames.length === 0) {\n logger.info('No workflows found that are triggered by release events.');\n } else {\n logger.info(`Auto-detected release workflows: ${workflowNames.join(', ')}`);\n }\n } catch (error: any) {\n logger.warn(`Failed to auto-detect release workflows: ${error.message}`);\n workflowNames = undefined; // Fall back to monitoring all workflows\n }\n }\n\n await GitHub.waitForReleaseWorkflows(tagName, {\n timeout: workflowTimeout,\n workflowNames,\n skipUserConfirmation\n });\n }\n } else {\n logger.verbose('Skipping waiting for release workflows (disabled in config).');\n }\n\n // Switch to target branch\n logger.info(`Switching to target branch: ${targetBranch}`);\n await runWithDryRunSupport(`git checkout ${targetBranch}`, isDryRun);\n\n logger.info('Publish process complete.');\n};\n"],"names":["scanNpmrcForEnvVars","storage","logger","getLogger","npmrcPath","path","join","process","cwd","envVars","exists","npmrcContent","readFile","envVarMatches","match","varName","replace","includes","push","error","warn","message","verbose","debug","validateEnvironmentVariables","requiredEnvVars","isDryRun","getDryRunLogger","missingEnvVars","envVar","env","length","Error","runPrechecks","runConfig","dryRun","createStorage","log","info","run","originalMessage","toString","stdout","trim","targetBranch","publish","currentBranch","GitHub","targetBranchExists","localBranchExists","syncStatus","isBranchInSyncWithRemote","inSync","localSha","remoteSha","substring","packageJsonPath","packageJson","packageJsonContents","parsed","safeJsonParse","validatePackageJson","scripts","prepublishOnly","coreRequiredEnvVars","npmrcEnvVars","allRequiredEnvVars","Set","sortObjectKeys","value","Array","isArray","map","sorted","Object","keys","sort","forEach","key","isReleaseNecessaryComparedToTarget","namesStdout","runSecure","changedFiles","split","s","filter","Boolean","necessary","reason","nonVersionFiles","f","basePkgStdout","headPkgStdout","basePkg","headPkg","version","_baseVersion","baseWithoutVersion","_headVersion","headWithoutVersion","baseSorted","headSorted","equalExceptVersion","JSON","stringify","handleTargetBranchSyncRecovery","syncResult","safeSyncBranchWithRemote","success","conflictResolutionRequired","execute","syncTarget","necessity","pr","branchName","html_url","updatePatterns","dependencyUpdatePatterns","patternsArg","runWithDryRunSupport","Diff","Commit","newVersion","currentVersion","targetVersionInput","targetVersion","proposedVersion","calculateTargetVersion","targetTagName","tagExists","checkIfTagExists","interactive","confirmVersionInteractively","confirmedTagName","confirmedTagExists","writeFile","releaseConfig","from","release","releaseSummary","Release","outputDirectory","DEFAULT_OUTPUT_DIRECTORY","ensureDirectory","releaseNotesPath","getOutputPath","releaseTitlePath","body","title","number","labels","commitTitle","timeout","checksTimeout","senditMode","sendit","skipUserConfirmation","mergeMethod","tagName","validateGitRef","tagWasPushed","pushError","Promise","resolve","setTimeout","milestonesEnabled","noMilestones","releaseNotesContent","releaseTitle","retries","isTagNotFoundError","waitForWorkflows","waitForReleaseWorkflows","workflowTimeout","releaseWorkflowsTimeout","workflowNames","releaseWorkflowNames","undefined"],"mappings":"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"}
1
+ {"version":3,"file":"publish.js","sources":["../../src/commands/publish.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\nimport path from 'path';\nimport * as Commit from './commit';\nimport * as Diff from '../content/diff';\nimport * as Release from './release';\n\nimport { getLogger, getDryRunLogger } from '../logging';\nimport { Config, PullRequest } from '../types';\nimport { run, runWithDryRunSupport, runSecure, validateGitRef } from '../util/child';\nimport * as GitHub from '../util/github';\nimport { create as createStorage } from '../util/storage';\nimport { incrementPatchVersion, getOutputPath, calculateTargetVersion, checkIfTagExists, confirmVersionInteractively } from '../util/general';\nimport { DEFAULT_OUTPUT_DIRECTORY, KODRDRIV_DEFAULTS } from '../constants';\nimport { safeJsonParse, validatePackageJson } from '../util/validation';\nimport { isBranchInSyncWithRemote, safeSyncBranchWithRemote, localBranchExists } from '../util/git';\n\nconst scanNpmrcForEnvVars = async (storage: any): Promise<string[]> => {\n const logger = getLogger();\n const npmrcPath = path.join(process.cwd(), '.npmrc');\n const envVars: string[] = [];\n\n if (await storage.exists(npmrcPath)) {\n try {\n const npmrcContent = await storage.readFile(npmrcPath, 'utf-8');\n // Match environment variable patterns like ${VAR_NAME} or $VAR_NAME\n const envVarMatches = npmrcContent.match(/\\$\\{([^}]+)\\}|\\$([A-Z_][A-Z0-9_]*)/g);\n\n if (envVarMatches) {\n for (const match of envVarMatches) {\n // Extract variable name from ${VAR_NAME} or $VAR_NAME format\n const varName = match.replace(/\\$\\{|\\}|\\$/g, '');\n if (varName && !envVars.includes(varName)) {\n envVars.push(varName);\n }\n }\n }\n\n } catch (error: any) {\n logger.warn(`Failed to read .npmrc file at ${npmrcPath}: ${error.message}`);\n logger.verbose('This may affect environment variable detection for publishing');\n }\n } else {\n logger.debug('.npmrc file not found, skipping environment variable scan');\n }\n\n return envVars;\n};\n\nconst validateEnvironmentVariables = (requiredEnvVars: string[], isDryRun: boolean): void => {\n const logger = getDryRunLogger(isDryRun);\n const missingEnvVars: string[] = [];\n\n for (const envVar of requiredEnvVars) {\n if (!process.env[envVar]) {\n missingEnvVars.push(envVar);\n }\n }\n\n if (missingEnvVars.length > 0) {\n if (isDryRun) {\n logger.warn(`Missing required environment variables: ${missingEnvVars.join(', ')}`);\n } else {\n logger.error(`Missing required environment variables: ${missingEnvVars.join(', ')}`);\n throw new Error(`Missing required environment variables: ${missingEnvVars.join(', ')}. Please set these environment variables before running publish.`);\n }\n }\n};\n\nconst runPrechecks = async (runConfig: Config): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage({ log: logger.info });\n\n logger.info('Running prechecks...');\n\n // Check if we're in a git repository\n try {\n if (isDryRun) {\n logger.info('Would check git repository with: git rev-parse --git-dir');\n } else {\n await run('git rev-parse --git-dir');\n }\n\n } catch (error: any) {\n if (!isDryRun) {\n // Preserve the original error message to help with debugging\n const originalMessage = error.message || error.toString();\n throw new Error(`Not in a git repository or git command failed: ${originalMessage}. Please run this command from within a git repository.`);\n }\n }\n\n // Check for uncommitted changes\n logger.info('Checking for uncommitted changes...');\n try {\n if (isDryRun) {\n logger.info('Would check git status with: git status --porcelain');\n } else {\n const { stdout } = await run('git status --porcelain');\n if (stdout.trim()) {\n throw new Error('Working directory has uncommitted changes. Please commit or stash your changes before running publish.');\n }\n }\n\n } catch (error: any) {\n if (!isDryRun) {\n // Preserve the original error message to help with debugging\n const originalMessage = error.message || error.toString();\n throw new Error(`Failed to check git status: ${originalMessage}. Please ensure you are in a valid git repository and try again.`);\n }\n }\n\n // Check that we're not running from the target branch\n logger.info('Checking current branch...');\n const targetBranch = runConfig.publish?.targetBranch || 'main';\n if (isDryRun) {\n logger.info(`Would verify current branch is not the target branch (${targetBranch})`);\n } else {\n const currentBranch = await GitHub.getCurrentBranchName();\n if (currentBranch === targetBranch) {\n throw new Error(`Cannot run publish from the target branch '${targetBranch}'. Please switch to a different branch before running publish.`);\n }\n }\n\n // Check target branch sync with remote\n logger.info(`Checking target branch '${targetBranch}' sync with remote...`);\n if (isDryRun) {\n logger.info(`Would verify target branch '${targetBranch}' is in sync with remote origin`);\n } else {\n // Only check if local target branch exists (it's okay if it doesn't exist locally)\n const targetBranchExists = await localBranchExists(targetBranch);\n if (targetBranchExists) {\n const syncStatus = await isBranchInSyncWithRemote(targetBranch);\n\n if (!syncStatus.inSync) {\n logger.error(`❌ Target branch '${targetBranch}' is not in sync with remote.`);\n logger.error('');\n\n if (syncStatus.error) {\n logger.error(` Error: ${syncStatus.error}`);\n } else if (syncStatus.localSha && syncStatus.remoteSha) {\n logger.error(` Local: ${syncStatus.localSha.substring(0, 8)}`);\n logger.error(` Remote: ${syncStatus.remoteSha.substring(0, 8)}`);\n }\n\n logger.error('');\n logger.error('📋 To resolve this issue:');\n logger.error(` 1. Switch to the target branch: git checkout ${targetBranch}`);\n logger.error(` 2. Pull the latest changes: git pull origin ${targetBranch}`);\n logger.error(' 3. Resolve any merge conflicts if they occur');\n logger.error(' 4. Switch back to your feature branch and re-run publish');\n logger.error('');\n logger.error('💡 Alternatively, run \"kodrdriv publish --sync-target\" to attempt automatic sync.');\n\n throw new Error(`Target branch '${targetBranch}' is not in sync with remote. Please sync the branch before running publish.`);\n } else {\n logger.info(`✅ Target branch '${targetBranch}' is in sync with remote.`);\n }\n } else {\n logger.info(`ℹ️ Target branch '${targetBranch}' does not exist locally - will be created when needed.`);\n }\n }\n\n // Check if prepublishOnly script exists in package.json\n logger.info('Checking for prepublishOnly script...');\n const packageJsonPath = path.join(process.cwd(), 'package.json');\n\n if (!await storage.exists(packageJsonPath)) {\n if (!isDryRun) {\n throw new Error('package.json not found in current directory.');\n } else {\n logger.warn('package.json not found in current directory.');\n }\n } else {\n let packageJson;\n try {\n const packageJsonContents = await storage.readFile(packageJsonPath, 'utf-8');\n const parsed = safeJsonParse(packageJsonContents, packageJsonPath);\n packageJson = validatePackageJson(parsed, packageJsonPath);\n\n } catch (error) {\n if (!isDryRun) {\n throw new Error('Failed to parse package.json. Please ensure it contains valid JSON.');\n } else {\n logger.warn('Failed to parse package.json. Please ensure it contains valid JSON.');\n }\n }\n\n if (packageJson && !packageJson.scripts?.prepublishOnly) {\n if (!isDryRun) {\n throw new Error('prepublishOnly script is required in package.json but was not found. Please add a prepublishOnly script that runs your pre-flight checks (e.g., clean, lint, build, test).');\n } else {\n logger.warn('prepublishOnly script is required in package.json but was not found.');\n }\n }\n }\n\n // Check required environment variables\n logger.verbose('Checking required environment variables...');\n const coreRequiredEnvVars = runConfig.publish?.requiredEnvVars || [];\n const npmrcEnvVars = isDryRun ? [] : await scanNpmrcForEnvVars(storage); // Skip .npmrc scan in dry run\n const allRequiredEnvVars = [...new Set([...coreRequiredEnvVars, ...npmrcEnvVars])];\n\n if (allRequiredEnvVars.length > 0) {\n logger.verbose(`Required environment variables: ${allRequiredEnvVars.join(', ')}`);\n validateEnvironmentVariables(allRequiredEnvVars, isDryRun);\n } else {\n logger.verbose('No required environment variables specified.');\n }\n\n logger.info('All prechecks passed.');\n};\n\n// Helper: deep-sort object keys for stable comparison\nconst sortObjectKeys = (value: any): any => {\n if (Array.isArray(value)) {\n return value.map(sortObjectKeys);\n }\n if (value && typeof value === 'object') {\n const sorted: any = {};\n Object.keys(value).sort().forEach((key) => {\n sorted[key] = sortObjectKeys(value[key]);\n });\n return sorted;\n }\n return value;\n};\n\n// Determine if there are substantive changes compared to the target branch (beyond just version bump)\nconst isReleaseNecessaryComparedToTarget = async (targetBranch: string, isDryRun: boolean): Promise<{ necessary: boolean; reason: string }> => {\n const logger = getDryRunLogger(isDryRun);\n\n // We compare current HEAD branch to the provided target branch\n const currentBranch = await GitHub.getCurrentBranchName();\n\n // If branches are identical, nothing to release\n const { stdout: namesStdout } = await runSecure('git', ['diff', '--name-only', `${targetBranch}..${currentBranch}`]);\n const changedFiles = namesStdout.split('\\n').map(s => s.trim()).filter(Boolean);\n\n if (changedFiles.length === 0) {\n // No definitive signal; proceed with publish rather than skipping\n return { necessary: true, reason: 'No detectable changes via diff; proceeding conservatively' };\n }\n\n // If any files changed other than package.json or package-lock.json, a release is necessary\n const nonVersionFiles = changedFiles.filter(f => f !== 'package.json' && f !== 'package-lock.json');\n if (nonVersionFiles.length > 0) {\n return { necessary: true, reason: `Changed files beyond version bump: ${nonVersionFiles.join(', ')}` };\n }\n\n // Only package.json and/or package-lock.json changed. Verify package.json change is only the version field\n try {\n // Read package.json content from both branches\n const { stdout: basePkgStdout } = await runSecure('git', ['show', `${targetBranch}:package.json`]);\n const { stdout: headPkgStdout } = await runSecure('git', ['show', `${currentBranch}:package.json`]);\n\n const basePkg = validatePackageJson(safeJsonParse(basePkgStdout, `${targetBranch}:package.json`), `${targetBranch}:package.json`);\n const headPkg = validatePackageJson(safeJsonParse(headPkgStdout, `${currentBranch}:package.json`), `${currentBranch}:package.json`);\n\n const { version: _baseVersion, ...baseWithoutVersion } = basePkg;\n const { version: _headVersion, ...headWithoutVersion } = headPkg;\n\n const baseSorted = sortObjectKeys(baseWithoutVersion);\n const headSorted = sortObjectKeys(headWithoutVersion);\n\n const equalExceptVersion = JSON.stringify(baseSorted) === JSON.stringify(headSorted);\n if (equalExceptVersion) {\n return { necessary: false, reason: 'Only version changed in package.json (plus lockfile)' };\n }\n\n // Other fields changed inside package.json\n return { necessary: true, reason: 'package.json changes beyond version field' };\n } catch (error: any) {\n // Conservative: if we cannot prove it is only a version change, proceed with release\n logger.verbose(`Could not conclusively compare package.json changes: ${error.message}`);\n return { necessary: true, reason: 'Could not compare package.json safely' };\n }\n};\n\nconst handleTargetBranchSyncRecovery = async (runConfig: Config): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const targetBranch = runConfig.publish?.targetBranch || 'main';\n\n logger.info(`🔄 Attempting to sync target branch '${targetBranch}' with remote...`);\n\n if (isDryRun) {\n logger.info(`Would attempt to sync '${targetBranch}' with remote`);\n return;\n }\n\n const syncResult = await safeSyncBranchWithRemote(targetBranch);\n\n if (syncResult.success) {\n logger.info(`✅ Successfully synced '${targetBranch}' with remote.`);\n logger.info('You can now re-run the publish command.');\n } else if (syncResult.conflictResolutionRequired) {\n logger.error(`❌ Failed to sync '${targetBranch}': conflicts detected.`);\n logger.error('');\n logger.error('📋 Manual conflict resolution required:');\n logger.error(` 1. Switch to the target branch: git checkout ${targetBranch}`);\n logger.error(` 2. Pull and resolve conflicts: git pull origin ${targetBranch}`);\n logger.error(' 3. Commit the resolved changes');\n logger.error(' 4. Switch back to your feature branch and re-run publish');\n logger.error('');\n throw new Error(`Target branch '${targetBranch}' has conflicts that require manual resolution.`);\n } else {\n logger.error(`❌ Failed to sync '${targetBranch}': ${syncResult.error}`);\n throw new Error(`Failed to sync target branch: ${syncResult.error}`);\n }\n};\n\nexport const execute = async (runConfig: Config): Promise<void> => {\n const isDryRun = runConfig.dryRun || false;\n const logger = getDryRunLogger(isDryRun);\n const storage = createStorage({ log: logger.info });\n const targetBranch = runConfig.publish?.targetBranch || 'main';\n\n // Handle --sync-target flag\n if (runConfig.publish?.syncTarget) {\n await handleTargetBranchSyncRecovery(runConfig);\n return; // Exit after sync operation\n }\n\n // Run prechecks before starting any work\n await runPrechecks(runConfig);\n\n // Early check: determine if a release is necessary compared to target branch\n logger.info('Evaluating if a release is necessary compared to target branch...');\n try {\n const necessity = await isReleaseNecessaryComparedToTarget(targetBranch, isDryRun);\n if (!necessity.necessary) {\n logger.info(`Skipping publish: ${necessity.reason}.`);\n // Emit a machine-readable marker so tree mode can detect skip and avoid propagating versions\n logger.info('KODRDRIV_PUBLISH_SKIPPED');\n return;\n } else {\n logger.verbose(`Proceeding with publish: ${necessity.reason}.`);\n }\n } catch (error: any) {\n // On unexpected errors, proceed with publish to avoid false negatives blocking releases\n logger.verbose(`Release necessity check encountered an issue (${error.message}). Proceeding with publish.`);\n }\n\n logger.info('Starting release process...');\n\n\n let pr: PullRequest | null = null;\n\n if (isDryRun) {\n logger.info('Would check for existing pull request');\n logger.info('Assuming no existing PR found for demo purposes');\n } else {\n const branchName = await GitHub.getCurrentBranchName();\n pr = await GitHub.findOpenPullRequestByHeadRef(branchName);\n }\n\n if (pr) {\n logger.info(`Found existing pull request for branch: ${pr.html_url}`);\n } else {\n logger.info('No open pull request found, starting new release publishing process...');\n\n // STEP 1: Prepare for release (update dependencies and run prepublish checks) with NO version bump yet\n logger.verbose('Preparing for release: switching from workspace to remote dependencies.');\n\n logger.verbose('Updating dependencies to latest versions from registry');\n const updatePatterns = runConfig.publish?.dependencyUpdatePatterns;\n if (updatePatterns && updatePatterns.length > 0) {\n logger.verbose(`Updating dependencies matching patterns: ${updatePatterns.join(', ')}`);\n const patternsArg = updatePatterns.join(' ');\n await runWithDryRunSupport(`npm update ${patternsArg}`, isDryRun);\n } else {\n logger.verbose('No dependency update patterns specified, updating all dependencies');\n await runWithDryRunSupport('npm update', isDryRun);\n }\n\n logger.info('Running prepublishOnly script...');\n await runWithDryRunSupport('npm run prepublishOnly', isDryRun, {}, true); // Use inherited stdio\n\n // STEP 2: Commit dependency updates if any (still no version bump)\n logger.verbose('Staging dependency updates for commit');\n await runWithDryRunSupport('git add package.json package-lock.json', isDryRun);\n\n logger.verbose('Checking for staged dependency updates...');\n if (isDryRun) {\n logger.verbose('Would create dependency update commit if changes are staged');\n } else {\n if (await Diff.hasStagedChanges()) {\n logger.verbose('Staged dependency changes found, creating commit...');\n await Commit.execute(runConfig);\n } else {\n logger.verbose('No dependency changes to commit, skipping commit.');\n }\n }\n\n // STEP 3: Determine and set target version AFTER checks and dependency commit\n logger.info('Determining target version...');\n let newVersion: string;\n\n if (isDryRun) {\n logger.info('Would determine target version and update package.json');\n newVersion = '1.0.0'; // Mock version for dry run\n } else {\n const packageJsonContents = await storage.readFile('package.json', 'utf-8');\n const parsed = safeJsonParse(packageJsonContents, 'package.json');\n const packageJson = validatePackageJson(parsed, 'package.json');\n const currentVersion = packageJson.version;\n\n const targetVersionInput = runConfig.publish?.targetVersion || 'patch';\n const proposedVersion = calculateTargetVersion(currentVersion, targetVersionInput);\n\n const targetTagName = `v${proposedVersion}`;\n const tagExists = await checkIfTagExists(targetTagName);\n if (tagExists) {\n throw new Error(`Tag ${targetTagName} already exists. Please choose a different version or delete the existing tag.`);\n }\n\n if (runConfig.publish?.interactive) {\n newVersion = await confirmVersionInteractively(currentVersion, proposedVersion, targetVersionInput);\n const confirmedTagName = `v${newVersion}`;\n const confirmedTagExists = await checkIfTagExists(confirmedTagName);\n if (confirmedTagExists) {\n throw new Error(`Tag ${confirmedTagName} already exists. Please choose a different version or delete the existing tag.`);\n }\n } else {\n newVersion = proposedVersion;\n }\n\n logger.info(`Bumping version from ${currentVersion} to ${newVersion}`);\n packageJson.version = newVersion;\n await storage.writeFile('package.json', JSON.stringify(packageJson, null, 2) + '\\n', 'utf-8');\n logger.info(`Version updated in package.json: ${newVersion}`);\n }\n\n // STEP 4: Commit version bump as a separate commit\n logger.verbose('Staging version bump for commit');\n await runWithDryRunSupport('git add package.json package-lock.json', isDryRun);\n\n if (isDryRun) {\n logger.verbose('Would create version bump commit');\n } else {\n if (await Diff.hasStagedChanges()) {\n logger.verbose('Creating version bump commit...');\n await Commit.execute(runConfig);\n } else {\n logger.verbose('No version changes to commit.');\n }\n }\n\n logger.info('Generating release notes...');\n // Create a modified config for release notes generation that includes the publish --from, --interactive, and --from-main options\n const releaseConfig = { ...runConfig };\n if (runConfig.publish?.from || runConfig.publish?.interactive || runConfig.publish?.fromMain) {\n // Pass the publish options to the release config\n releaseConfig.release = {\n ...runConfig.release,\n ...(runConfig.publish.from && { from: runConfig.publish.from }),\n ...(runConfig.publish.interactive && { interactive: runConfig.publish.interactive }),\n ...(runConfig.publish.fromMain && { fromMain: runConfig.publish.fromMain })\n };\n if (runConfig.publish.from) {\n logger.verbose(`Using custom 'from' reference for release notes: ${runConfig.publish.from}`);\n }\n if (runConfig.publish.interactive) {\n logger.verbose('Interactive mode enabled for release notes generation');\n }\n if (runConfig.publish.fromMain) {\n logger.verbose('Forcing comparison against main branch for release notes');\n }\n }\n const releaseSummary = await Release.execute(releaseConfig);\n\n if (isDryRun) {\n logger.info('Would write release notes to RELEASE_NOTES.md and RELEASE_TITLE.md in output directory');\n } else {\n const outputDirectory = runConfig.outputDirectory || DEFAULT_OUTPUT_DIRECTORY;\n await storage.ensureDirectory(outputDirectory);\n\n const releaseNotesPath = getOutputPath(outputDirectory, 'RELEASE_NOTES.md');\n const releaseTitlePath = getOutputPath(outputDirectory, 'RELEASE_TITLE.md');\n\n await storage.writeFile(releaseNotesPath, releaseSummary.body, 'utf-8');\n await storage.writeFile(releaseTitlePath, releaseSummary.title, 'utf-8');\n logger.info(`Release notes and title generated and saved to ${releaseNotesPath} and ${releaseTitlePath}.`);\n }\n\n logger.info('Pushing to origin...');\n // Get current branch name and push explicitly to avoid pushing to wrong remote/branch\n const currentBranch = await GitHub.getCurrentBranchName();\n await runWithDryRunSupport(`git push origin ${currentBranch}`, isDryRun);\n\n logger.info('Creating pull request...');\n if (isDryRun) {\n logger.info('Would get commit title and create PR with GitHub API');\n pr = { number: 123, html_url: 'https://github.com/mock/repo/pull/123', labels: [] } as PullRequest;\n } else {\n const { stdout: commitTitle } = await run('git log -1 --pretty=%B');\n pr = await GitHub.createPullRequest(commitTitle, 'Automated release PR.', await GitHub.getCurrentBranchName());\n if (!pr) {\n throw new Error('Failed to create pull request.');\n }\n logger.info(`Pull request created: ${pr.html_url}`);\n }\n }\n\n logger.info(`Waiting for PR #${pr!.number} checks to complete...`);\n if (!isDryRun) {\n // Configure timeout and user confirmation behavior\n const timeout = runConfig.publish?.checksTimeout || KODRDRIV_DEFAULTS.publish.checksTimeout;\n const senditMode = runConfig.publish?.sendit || false;\n // sendit flag overrides skipUserConfirmation - if sendit is true, skip confirmation\n const skipUserConfirmation = senditMode || runConfig.publish?.skipUserConfirmation || false;\n\n\n await GitHub.waitForPullRequestChecks(pr!.number, {\n timeout,\n skipUserConfirmation\n });\n }\n\n const mergeMethod = runConfig.publish?.mergeMethod || 'squash';\n if (isDryRun) {\n logger.info(`Would merge PR #${pr!.number} using ${mergeMethod} method`);\n } else {\n try {\n await GitHub.mergePullRequest(pr!.number, mergeMethod, false); // Don't delete branch\n } catch (error: any) {\n // Check if this is a merge conflict error\n if (error.message && (\n error.message.includes('not mergeable') ||\n error.message.includes('Pull Request is not mergeable') ||\n error.message.includes('merge conflict')\n )) {\n logger.error(`❌ Pull Request #${pr!.number} has merge conflicts that need to be resolved.`);\n logger.error('');\n logger.error('📋 To resolve this issue:');\n logger.error(` 1. Visit the Pull Request: ${pr!.html_url}`);\n logger.error(' 2. Resolve the merge conflicts through GitHub\\'s web interface or locally');\n logger.error(' 3. Once conflicts are resolved, re-run the publish command');\n logger.error('');\n logger.error('💡 The command will automatically detect the existing PR and continue from where it left off.');\n throw new Error(`Merge conflicts detected in PR #${pr!.number}. Please resolve conflicts and re-run the command.`);\n } else {\n // Re-throw other merge errors\n throw error;\n }\n }\n }\n\n // Switch to target branch and pull latest changes\n logger.info(`Checking out target branch: ${targetBranch}...`);\n\n // Check for uncommitted changes and stash them if necessary\n let hasStashedChanges = false;\n if (!isDryRun) {\n const { stdout: statusOutput } = await runSecure('git', ['status', '--porcelain']);\n if (statusOutput.trim()) {\n logger.info('📦 Stashing uncommitted changes before checkout...');\n await runSecure('git', ['stash', 'push', '-m', 'kodrdriv: stash before checkout target branch']);\n hasStashedChanges = true;\n logger.info('✅ Successfully stashed uncommitted changes');\n }\n }\n\n try {\n await runWithDryRunSupport(`git checkout ${targetBranch}`, isDryRun);\n await runWithDryRunSupport(`git pull origin ${targetBranch}`, isDryRun);\n } catch (error: any) {\n // Check if this is a merge conflict or sync issue\n if (!isDryRun && (error.message.includes('conflict') ||\n error.message.includes('CONFLICT') ||\n error.message.includes('diverged') ||\n error.message.includes('non-fast-forward'))) {\n\n logger.error(`❌ Failed to sync target branch '${targetBranch}' with remote.`);\n logger.error('');\n logger.error('📋 Recovery options:');\n logger.error(` 1. Run 'kodrdriv publish --sync-target' to attempt automatic resolution`);\n logger.error(` 2. Manually resolve conflicts:`);\n logger.error(` - git checkout ${targetBranch}`);\n logger.error(` - git pull origin ${targetBranch}`);\n logger.error(` - Resolve any conflicts and commit`);\n logger.error(` - Re-run your original publish command`);\n logger.error('');\n logger.error('💡 The publish process has been stopped to prevent data loss.');\n\n throw new Error(`Target branch '${targetBranch}' sync failed. Use recovery options above to resolve.`);\n } else {\n // Re-throw other errors\n throw error;\n }\n }\n\n // Restore stashed changes if we stashed them\n if (hasStashedChanges) {\n logger.info('📦 Restoring previously stashed changes...');\n try {\n await runSecure('git', ['stash', 'pop']);\n logger.info('✅ Successfully restored stashed changes');\n } catch (stashError: any) {\n logger.warn(`⚠️ Warning: Could not restore stashed changes: ${stashError.message}`);\n logger.warn(' Your changes are still available in the git stash. Run \"git stash list\" to see them.');\n }\n }\n\n // Now create and push the tag on the target branch\n logger.info('Creating release tag...');\n let tagName: string;\n if (isDryRun) {\n logger.info('Would read package.json version and create git tag');\n tagName = 'v1.0.0'; // Mock version for dry run\n } else {\n const packageJsonContents = await storage.readFile('package.json', 'utf-8');\n const { version } = safeJsonParse(packageJsonContents, 'package.json');\n tagName = `v${version}`;\n\n // Check if tag already exists locally\n try {\n // Validate tag name to prevent injection\n if (!validateGitRef(tagName)) {\n throw new Error(`Invalid tag name: ${tagName}`);\n }\n const { stdout } = await runSecure('git', ['tag', '-l', tagName]);\n if (stdout.trim() === tagName) {\n logger.info(`Tag ${tagName} already exists locally, skipping tag creation`);\n } else {\n await runSecure('git', ['tag', tagName]);\n logger.info(`Created local tag: ${tagName}`);\n }\n } catch (error) {\n // If git tag -l fails, create the tag anyway\n await runSecure('git', ['tag', tagName]);\n logger.info(`Created local tag: ${tagName}`);\n }\n\n // Check if tag exists on remote before pushing\n let tagWasPushed = false;\n try {\n const { stdout } = await runSecure('git', ['ls-remote', 'origin', `refs/tags/${tagName}`]);\n if (stdout.trim()) {\n logger.info(`Tag ${tagName} already exists on remote, skipping push`);\n } else {\n await runSecure('git', ['push', 'origin', tagName]);\n logger.info(`Pushed tag to remote: ${tagName}`);\n tagWasPushed = true;\n }\n } catch (error) {\n // If ls-remote fails, try to push anyway (might be a new remote)\n try {\n await runSecure('git', ['push', 'origin', tagName]);\n logger.info(`Pushed tag to remote: ${tagName}`);\n tagWasPushed = true;\n } catch (pushError: any) {\n if (pushError.message && pushError.message.includes('already exists')) {\n logger.info(`Tag ${tagName} already exists on remote, continuing...`);\n } else {\n throw pushError;\n }\n }\n }\n\n // If we just pushed a new tag, wait for GitHub to process it\n if (tagWasPushed) {\n logger.verbose('Waiting for GitHub to process the pushed tag...');\n await new Promise(resolve => setTimeout(resolve, 5000)); // 5 second delay\n }\n }\n\n logger.info('Creating GitHub release...');\n if (isDryRun) {\n logger.info('Would read package.json version and create GitHub release with retry logic');\n const milestonesEnabled = !runConfig.publish?.noMilestones;\n if (milestonesEnabled) {\n logger.info('Would close milestone for released version');\n } else {\n logger.info('Would skip milestone closure (--no-milestones)');\n }\n } else {\n const outputDirectory = runConfig.outputDirectory || DEFAULT_OUTPUT_DIRECTORY;\n const releaseNotesPath = getOutputPath(outputDirectory, 'RELEASE_NOTES.md');\n const releaseTitlePath = getOutputPath(outputDirectory, 'RELEASE_TITLE.md');\n\n const releaseNotesContent = await storage.readFile(releaseNotesPath, 'utf-8');\n const releaseTitle = await storage.readFile(releaseTitlePath, 'utf-8');\n\n // Create release with retry logic to handle GitHub tag processing delays\n let retries = 3;\n while (retries > 0) {\n try {\n await GitHub.createRelease(tagName, releaseTitle, releaseNotesContent);\n logger.info(`GitHub release created successfully for tag: ${tagName}`);\n\n // Close milestone for this version if enabled\n const milestonesEnabled = !runConfig.publish?.noMilestones;\n if (milestonesEnabled) {\n logger.info('🏁 Closing milestone for released version...');\n const version = tagName.replace(/^v/, ''); // Remove 'v' prefix if present\n await GitHub.closeMilestoneForVersion(version);\n } else {\n logger.debug('Milestone integration disabled via --no-milestones');\n }\n\n break; // Success - exit retry loop\n } catch (error: any) {\n // Check if this is a tag-not-found error that we can retry\n const isTagNotFoundError = error.message && (\n error.message.includes('not found') ||\n error.message.includes('does not exist') ||\n error.message.includes('Reference does not exist')\n );\n\n if (isTagNotFoundError && retries > 1) {\n logger.verbose(`Tag ${tagName} not yet available on GitHub, retrying in 3 seconds... (${retries - 1} retries left)`);\n await new Promise(resolve => setTimeout(resolve, 3000));\n retries--;\n } else if (isTagNotFoundError) {\n // Tag not found error and we're out of retries\n throw new Error(`Tag ${tagName} was not found on GitHub after ${3 - retries + 1} attempts. This may indicate a problem with tag creation or GitHub synchronization.`);\n } else {\n // Not a tag-not-found error - re-throw the original error\n throw error;\n }\n }\n }\n }\n\n // Wait for release workflows to complete (if enabled)\n const waitForWorkflows = runConfig.publish?.waitForReleaseWorkflows !== false; // default to true\n if (waitForWorkflows) {\n logger.info('Waiting for release workflows...');\n if (isDryRun) {\n logger.info('Would monitor GitHub Actions workflows triggered by release');\n } else {\n const workflowTimeout = runConfig.publish?.releaseWorkflowsTimeout || KODRDRIV_DEFAULTS.publish.releaseWorkflowsTimeout;\n const senditMode = runConfig.publish?.sendit || false;\n const skipUserConfirmation = senditMode || runConfig.publish?.skipUserConfirmation || false;\n\n // Get workflow names - either from config or auto-detect\n let workflowNames = runConfig.publish?.releaseWorkflowNames;\n\n if (!workflowNames || workflowNames.length === 0) {\n logger.info('No specific workflow names configured, auto-detecting workflows triggered by release events...');\n try {\n workflowNames = await GitHub.getWorkflowsTriggeredByRelease();\n if (workflowNames.length === 0) {\n logger.info('No workflows found that are triggered by release events.');\n } else {\n logger.info(`Auto-detected release workflows: ${workflowNames.join(', ')}`);\n }\n } catch (error: any) {\n logger.warn(`Failed to auto-detect release workflows: ${error.message}`);\n workflowNames = undefined; // Fall back to monitoring all workflows\n }\n }\n\n await GitHub.waitForReleaseWorkflows(tagName, {\n timeout: workflowTimeout,\n workflowNames,\n skipUserConfirmation\n });\n }\n } else {\n logger.verbose('Skipping waiting for release workflows (disabled in config).');\n }\n\n // Switch to target branch\n logger.info(`Switching to target branch: ${targetBranch}`);\n await runWithDryRunSupport(`git checkout ${targetBranch}`, isDryRun);\n\n logger.info('Publish process complete.');\n};\n"],"names":["scanNpmrcForEnvVars","storage","logger","getLogger","npmrcPath","path","join","process","cwd","envVars","exists","npmrcContent","readFile","envVarMatches","match","varName","replace","includes","push","error","warn","message","verbose","debug","validateEnvironmentVariables","requiredEnvVars","isDryRun","getDryRunLogger","missingEnvVars","envVar","env","length","Error","runPrechecks","runConfig","dryRun","createStorage","log","info","run","originalMessage","toString","stdout","trim","targetBranch","publish","currentBranch","GitHub","targetBranchExists","localBranchExists","syncStatus","isBranchInSyncWithRemote","inSync","localSha","remoteSha","substring","packageJsonPath","packageJson","packageJsonContents","parsed","safeJsonParse","validatePackageJson","scripts","prepublishOnly","coreRequiredEnvVars","npmrcEnvVars","allRequiredEnvVars","Set","sortObjectKeys","value","Array","isArray","map","sorted","Object","keys","sort","forEach","key","isReleaseNecessaryComparedToTarget","namesStdout","runSecure","changedFiles","split","s","filter","Boolean","necessary","reason","nonVersionFiles","f","basePkgStdout","headPkgStdout","basePkg","headPkg","version","_baseVersion","baseWithoutVersion","_headVersion","headWithoutVersion","baseSorted","headSorted","equalExceptVersion","JSON","stringify","handleTargetBranchSyncRecovery","syncResult","safeSyncBranchWithRemote","success","conflictResolutionRequired","execute","syncTarget","necessity","pr","branchName","html_url","updatePatterns","dependencyUpdatePatterns","patternsArg","runWithDryRunSupport","Diff","Commit","newVersion","currentVersion","targetVersionInput","targetVersion","proposedVersion","calculateTargetVersion","targetTagName","tagExists","checkIfTagExists","interactive","confirmVersionInteractively","confirmedTagName","confirmedTagExists","writeFile","releaseConfig","from","fromMain","release","releaseSummary","Release","outputDirectory","DEFAULT_OUTPUT_DIRECTORY","ensureDirectory","releaseNotesPath","getOutputPath","releaseTitlePath","body","title","number","labels","commitTitle","timeout","checksTimeout","KODRDRIV_DEFAULTS","senditMode","sendit","skipUserConfirmation","mergeMethod","hasStashedChanges","statusOutput","stashError","tagName","validateGitRef","tagWasPushed","pushError","Promise","resolve","setTimeout","milestonesEnabled","noMilestones","releaseNotesContent","releaseTitle","retries","isTagNotFoundError","waitForWorkflows","waitForReleaseWorkflows","workflowTimeout","releaseWorkflowsTimeout","workflowNames","releaseWorkflowNames","undefined"],"mappings":"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"}
@@ -134,23 +134,23 @@ async function handleInteractiveReleaseFeedback(releaseSummary, runConfig, promp
134
134
  }
135
135
  }
136
136
  const execute = async (runConfig)=>{
137
- var _runConfig_release, _runConfig_release1, _runConfig_release2, _runConfig_release3, _runConfig_release4, _runConfig_release5, _runConfig_release6, _runConfig_release7;
137
+ var _runConfig_release, _runConfig_release1, _runConfig_release2, _runConfig_release3, _runConfig_release4, _runConfig_release5, _runConfig_release6, _runConfig_release7, _runConfig_release8;
138
138
  const isDryRun = runConfig.dryRun || false;
139
139
  const logger = getDryRunLogger(isDryRun);
140
140
  var _runConfig_release_from;
141
141
  // Resolve the from reference with fallback logic if not explicitly provided
142
- const fromRef = (_runConfig_release_from = (_runConfig_release = runConfig.release) === null || _runConfig_release === void 0 ? void 0 : _runConfig_release.from) !== null && _runConfig_release_from !== void 0 ? _runConfig_release_from : await getDefaultFromRef();
142
+ const fromRef = (_runConfig_release_from = (_runConfig_release = runConfig.release) === null || _runConfig_release === void 0 ? void 0 : _runConfig_release.from) !== null && _runConfig_release_from !== void 0 ? _runConfig_release_from : await getDefaultFromRef(((_runConfig_release1 = runConfig.release) === null || _runConfig_release1 === void 0 ? void 0 : _runConfig_release1.fromMain) || false);
143
143
  var _runConfig_release_to;
144
- const toRef = (_runConfig_release_to = (_runConfig_release1 = runConfig.release) === null || _runConfig_release1 === void 0 ? void 0 : _runConfig_release1.to) !== null && _runConfig_release_to !== void 0 ? _runConfig_release_to : DEFAULT_TO_COMMIT_ALIAS;
144
+ const toRef = (_runConfig_release_to = (_runConfig_release2 = runConfig.release) === null || _runConfig_release2 === void 0 ? void 0 : _runConfig_release2.to) !== null && _runConfig_release_to !== void 0 ? _runConfig_release_to : DEFAULT_TO_COMMIT_ALIAS;
145
145
  logger.debug(`Using git references: from=${fromRef}, to=${toRef}`);
146
146
  const log = await create({
147
147
  from: fromRef,
148
148
  to: toRef,
149
- limit: (_runConfig_release2 = runConfig.release) === null || _runConfig_release2 === void 0 ? void 0 : _runConfig_release2.messageLimit
149
+ limit: (_runConfig_release3 = runConfig.release) === null || _runConfig_release3 === void 0 ? void 0 : _runConfig_release3.messageLimit
150
150
  });
151
151
  let logContent = '';
152
152
  var _runConfig_release_maxDiffBytes;
153
- const maxDiffBytes = (_runConfig_release_maxDiffBytes = (_runConfig_release3 = runConfig.release) === null || _runConfig_release3 === void 0 ? void 0 : _runConfig_release3.maxDiffBytes) !== null && _runConfig_release_maxDiffBytes !== void 0 ? _runConfig_release_maxDiffBytes : DEFAULT_MAX_DIFF_BYTES;
153
+ const maxDiffBytes = (_runConfig_release_maxDiffBytes = (_runConfig_release4 = runConfig.release) === null || _runConfig_release4 === void 0 ? void 0 : _runConfig_release4.maxDiffBytes) !== null && _runConfig_release_maxDiffBytes !== void 0 ? _runConfig_release_maxDiffBytes : DEFAULT_MAX_DIFF_BYTES;
154
154
  var _runConfig_excludedPatterns;
155
155
  const diff = await create$1({
156
156
  from: fromRef,
@@ -204,7 +204,7 @@ const execute = async (runConfig)=>{
204
204
  };
205
205
  // Get milestone issues if enabled
206
206
  let milestoneIssuesContent = '';
207
- const milestonesEnabled = !((_runConfig_release4 = runConfig.release) === null || _runConfig_release4 === void 0 ? void 0 : _runConfig_release4.noMilestones);
207
+ const milestonesEnabled = !((_runConfig_release5 = runConfig.release) === null || _runConfig_release5 === void 0 ? void 0 : _runConfig_release5.noMilestones);
208
208
  if (milestonesEnabled) {
209
209
  logger.info('🔍 Checking for milestone issues to include in release notes...');
210
210
  const versions = await determineVersionsForMilestones();
@@ -224,11 +224,11 @@ const execute = async (runConfig)=>{
224
224
  const promptContent = {
225
225
  logContent,
226
226
  diffContent,
227
- releaseFocus: (_runConfig_release5 = runConfig.release) === null || _runConfig_release5 === void 0 ? void 0 : _runConfig_release5.focus,
227
+ releaseFocus: (_runConfig_release6 = runConfig.release) === null || _runConfig_release6 === void 0 ? void 0 : _runConfig_release6.focus,
228
228
  milestoneIssues: milestoneIssuesContent
229
229
  };
230
230
  const promptContext = {
231
- context: (_runConfig_release6 = runConfig.release) === null || _runConfig_release6 === void 0 ? void 0 : _runConfig_release6.context,
231
+ context: (_runConfig_release7 = runConfig.release) === null || _runConfig_release7 === void 0 ? void 0 : _runConfig_release7.context,
232
232
  directories: runConfig.contextDirectories
233
233
  };
234
234
  const promptResult = await createPrompt(promptConfig, promptContent, promptContext);
@@ -285,7 +285,7 @@ const execute = async (runConfig)=>{
285
285
  // Validate and safely cast the response
286
286
  let releaseSummary = validateReleaseSummary(summary);
287
287
  // Handle interactive mode
288
- if (((_runConfig_release7 = runConfig.release) === null || _runConfig_release7 === void 0 ? void 0 : _runConfig_release7.interactive) && !isDryRun) {
288
+ if (((_runConfig_release8 = runConfig.release) === null || _runConfig_release8 === void 0 ? void 0 : _runConfig_release8.interactive) && !isDryRun) {
289
289
  requireTTY('Interactive mode requires a terminal. Use --dry-run instead.');
290
290
  const interactiveResult = await handleInteractiveReleaseFeedback(releaseSummary, runConfig, promptConfig, promptContext, outputDirectory, storage, logContent, diffContent);
291
291
  if (interactiveResult.action === 'skip') {