@eldrforge/kodrdriv 1.2.123 → 1.2.124

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.
package/dist/constants.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import os__default from 'os';
2
2
  import path__default from 'path';
3
3
 
4
- const VERSION = '1.2.123 (HEAD/3c63d6b T:v1.2.123 2025-12-24 18:09:16 -0800) linux x64 v22.21.1';
4
+ const VERSION = '1.2.124 (HEAD/b29e979 T:v1.2.124 2025-12-24 18:48:20 -0800) linux x64 v22.21.1';
5
5
  const PROGRAM_NAME = 'kodrdriv';
6
6
  const DEFAULT_OVERRIDES = false;
7
7
  const DATE_FORMAT_YEAR_MONTH_DAY_HOURS_MINUTES_SECONDS_MILLISECONDS = 'YYYY-MM-DD-HHmmss.SSS';
@@ -1,120 +1,9 @@
1
1
  import path__default from 'path';
2
- import { createStorage } from '@eldrforge/shared';
2
+ import { incrementPatchVersion, validateVersionString, createStorage, convertToReleaseVersion, incrementPrereleaseVersion } from '@eldrforge/shared';
3
+ export { calculateTargetVersion, convertToReleaseVersion, deepMerge, incrementMajorVersion, incrementMinorVersion, incrementPatchVersion, incrementPrereleaseVersion, stringifyJSON, validateVersionString } from '@eldrforge/shared';
3
4
  import { getLogger } from '../logging.js';
4
5
  import * as fs from 'fs';
5
6
 
6
- const incrementPatchVersion = (version)=>{
7
- // Remove 'v' prefix if present
8
- const cleanVersion = version.startsWith('v') ? version.slice(1) : version;
9
- // Split into major.minor.patch and handle pre-release identifiers
10
- const parts = cleanVersion.split('.');
11
- if (parts.length < 3) {
12
- throw new Error(`Invalid version string: ${version}`);
13
- }
14
- // Handle pre-release versions like "4.6.24-dev.0"
15
- // Split the patch part on '-' to separate patch number from pre-release
16
- const patchPart = parts[2];
17
- let patchNumber;
18
- let originalPatchString;
19
- let hasPrerelease = false;
20
- if (patchPart.startsWith('-')) {
21
- // Handle negative patch numbers like "-1" or "-5" or "-1-dev.0"
22
- const negativeComponents = patchPart.split('-');
23
- // For "-1-dev.0", negativeComponents will be ['', '1', 'dev.0']
24
- if (negativeComponents.length > 2) {
25
- // This is a negative number with pre-release like "-1-dev.0"
26
- originalPatchString = `-${negativeComponents[1]}`;
27
- patchNumber = parseInt(`-${negativeComponents[1]}`, 10);
28
- hasPrerelease = true;
29
- } else {
30
- // This is just a negative number like "-1"
31
- patchNumber = parseInt(patchPart, 10);
32
- originalPatchString = patchPart;
33
- }
34
- } else {
35
- // Handle normal patch numbers with possible pre-release like "24-dev.0"
36
- const patchComponents = patchPart.split('-');
37
- originalPatchString = patchComponents[0];
38
- patchNumber = parseInt(patchComponents[0], 10);
39
- hasPrerelease = patchComponents.length > 1;
40
- }
41
- if (isNaN(patchNumber)) {
42
- throw new Error(`Invalid patch version: ${patchPart}`);
43
- }
44
- // For pre-release versions, graduate to the base version (drop pre-release identifier)
45
- // For stable versions, increment the patch number
46
- const newPatchNumber = hasPrerelease ? originalPatchString : (patchNumber + 1).toString();
47
- // Create clean release version
48
- const newVersion = `${parts[0]}.${parts[1]}.${newPatchNumber}`;
49
- return newVersion;
50
- };
51
- const validateVersionString = (version)=>{
52
- // Remove 'v' prefix if present
53
- const cleanVersion = version.startsWith('v') ? version.slice(1) : version;
54
- // Basic semver regex pattern
55
- const semverPattern = /^\d+\.\d+\.\d+$/;
56
- return semverPattern.test(cleanVersion);
57
- };
58
- /**
59
- * Increment prerelease version with a specific tag
60
- * Examples:
61
- * - incrementPrereleaseVersion("1.2.3-dev.0", "dev") => "1.2.3-dev.1"
62
- * - incrementPrereleaseVersion("1.2.3", "dev") => "1.2.3-dev.0"
63
- * - incrementPrereleaseVersion("1.2.3-dev.5", "test") => "1.2.3-test.0"
64
- */ const incrementPrereleaseVersion = (version, tag)=>{
65
- const cleanVersion = version.startsWith('v') ? version.slice(1) : version;
66
- // Split on dots but only use first 3 parts for major.minor.patch
67
- // This handles cases like "1.2.3-dev.5" correctly
68
- const dotParts = cleanVersion.split('.');
69
- if (dotParts.length < 3) {
70
- throw new Error(`Invalid version string: ${version}`);
71
- }
72
- const major = dotParts[0];
73
- const minor = dotParts[1];
74
- // Reconstruct the patch part - everything after the second dot
75
- const patchAndPrerelease = dotParts.slice(2).join('.');
76
- const patchComponents = patchAndPrerelease.split('-');
77
- const patchNumber = patchComponents[0];
78
- if (patchComponents.length > 1) {
79
- // Already has prerelease (e.g., "3-dev.0" or "3-test.2")
80
- const prereleaseString = patchComponents.slice(1).join('-'); // Handle multiple dashes
81
- const prereleaseComponents = prereleaseString.split('.');
82
- const existingTag = prereleaseComponents[0];
83
- const existingPrereleaseVersion = prereleaseComponents[1];
84
- if (existingTag === tag) {
85
- // Same tag, increment the prerelease version
86
- const prereleaseNumber = parseInt(existingPrereleaseVersion) || 0;
87
- return `${major}.${minor}.${patchNumber}-${tag}.${prereleaseNumber + 1}`;
88
- } else {
89
- // Different tag, start at 0
90
- return `${major}.${minor}.${patchNumber}-${tag}.0`;
91
- }
92
- } else {
93
- // No prerelease yet, add it
94
- return `${major}.${minor}.${patchNumber}-${tag}.0`;
95
- }
96
- };
97
- /**
98
- * Convert prerelease version to release version
99
- * Examples:
100
- * - convertToReleaseVersion("1.2.3-dev.5") => "1.2.3"
101
- * - convertToReleaseVersion("1.2.3-test.2") => "1.2.3"
102
- * - convertToReleaseVersion("1.2.3") => "1.2.3"
103
- */ const convertToReleaseVersion = (version)=>{
104
- const cleanVersion = version.startsWith('v') ? version.slice(1) : version;
105
- // Split on dots but only use first 3 parts for major.minor.patch
106
- const dotParts = cleanVersion.split('.');
107
- if (dotParts.length < 3) {
108
- throw new Error(`Invalid version string: ${version}`);
109
- }
110
- const major = dotParts[0];
111
- const minor = dotParts[1];
112
- // Reconstruct the patch part - everything after the second dot
113
- const patchAndPrerelease = dotParts.slice(2).join('.');
114
- const patchComponents = patchAndPrerelease.split('-');
115
- const patchNumber = patchComponents[0];
116
- return `${major}.${minor}.${patchNumber}`;
117
- };
118
7
  /**
119
8
  * Get version from a specific branch's package.json
120
9
  */ const getVersionFromBranch = async (branchName)=>{
@@ -535,5 +424,5 @@ const getTimestampedArchivedTranscriptFilename = ()=>{
535
424
  };
536
425
  };
537
426
 
538
- export { archiveAudio, calculateBranchDependentVersion, checkIfTagExists, confirmVersionInteractively, convertToReleaseVersion, findDevelopmentBranch, getExpectedVersionPattern, getNpmPublishedVersion, getOutputPath, getTagInfo, getTimestampedArchivedAudioFilename, getTimestampedArchivedTranscriptFilename, getTimestampedAudioFilename, getTimestampedCommitFilename, getTimestampedFilename, getTimestampedReleaseNotesFilename, getTimestampedRequestFilename, getTimestampedResponseFilename, getTimestampedReviewFilename, getTimestampedReviewNotesFilename, getVersionFromBranch, incrementPatchVersion, incrementPrereleaseVersion, isDevelopmentVersion, validateVersionForBranch, validateVersionString };
427
+ export { archiveAudio, calculateBranchDependentVersion, checkIfTagExists, confirmVersionInteractively, findDevelopmentBranch, getExpectedVersionPattern, getNpmPublishedVersion, getOutputPath, getTagInfo, getTimestampedArchivedAudioFilename, getTimestampedArchivedTranscriptFilename, getTimestampedAudioFilename, getTimestampedCommitFilename, getTimestampedFilename, getTimestampedReleaseNotesFilename, getTimestampedRequestFilename, getTimestampedResponseFilename, getTimestampedReviewFilename, getTimestampedReviewNotesFilename, getVersionFromBranch, isDevelopmentVersion, validateVersionForBranch };
539
428
  //# sourceMappingURL=general.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"general.js","sources":["../../src/util/general.ts"],"sourcesContent":["import path from 'path';\nimport { createStorage } from '@eldrforge/shared';\nimport { getLogger } from '../logging';\n// eslint-disable-next-line no-restricted-imports\nimport * as fs from 'fs';\n\n// Utility function for deep merging two objects.\nexport function deepMerge(target: any, source: any): any {\n for (const key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n if (key === \"__proto__\" || key === \"constructor\") {\n continue; // Skip prototype-polluting keys\n }\n if (source[key] && typeof source[key] === 'object' && !Array.isArray(source[key])) {\n if (!target[key]) {\n target[key] = {};\n }\n deepMerge(target[key], source[key]);\n } else {\n target[key] = source[key];\n }\n }\n }\n return target;\n}\n\n//Recursive implementation of jSON.stringify;\nexport const stringifyJSON = function (obj: any, options: { depth: number } = { depth: 0 }): string {\n\n if (options.depth > 10) {\n return '{\"error\": \"Maximum depth reached\"}';\n }\n\n const arrOfKeyVals: string[] = [];\n const arrVals: string[] = [];\n let objKeys: string[] = [];\n\n /*********CHECK FOR PRIMITIVE TYPES**********/\n if (typeof obj === 'number' || typeof obj === 'boolean' || obj === null)\n return '' + obj;\n else if (typeof obj === 'string')\n return '\"' + obj + '\"';\n\n /*********CHECK FOR ARRAY**********/\n else if (Array.isArray(obj)) {\n //check for empty array\n if (obj[0] === undefined)\n return '[]';\n else {\n obj.forEach(function (el) {\n arrVals.push(stringifyJSON(el, { depth: options.depth + 1 }));\n });\n return '[' + arrVals + ']';\n }\n }\n /*********CHECK FOR OBJECT**********/\n else if (obj instanceof Object) {\n //get object keys\n objKeys = Object.keys(obj);\n //set key output;\n objKeys.forEach(function (key) {\n const keyOut = '\"' + key + '\":';\n const keyValOut = obj[key];\n //skip functions and undefined properties\n if (keyValOut instanceof Function || keyValOut === undefined)\n arrOfKeyVals.push('');\n else if (typeof keyValOut === 'string')\n arrOfKeyVals.push(keyOut + '\"' + keyValOut + '\"');\n else if (typeof keyValOut === 'boolean' || typeof keyValOut === 'number' || keyValOut === null)\n arrOfKeyVals.push(keyOut + keyValOut);\n //check for nested objects, call recursively until no more objects\n else if (keyValOut instanceof Object) {\n arrOfKeyVals.push(keyOut + stringifyJSON(keyValOut, { depth: options.depth + 1 }));\n }\n });\n return '{' + arrOfKeyVals + '}';\n }\n return '';\n};\n\nexport const incrementPatchVersion = (version: string): string => {\n // Remove 'v' prefix if present\n const cleanVersion = version.startsWith('v') ? version.slice(1) : version;\n\n // Split into major.minor.patch and handle pre-release identifiers\n const parts = cleanVersion.split('.');\n if (parts.length < 3) {\n throw new Error(`Invalid version string: ${version}`);\n }\n\n // Handle pre-release versions like \"4.6.24-dev.0\"\n // Split the patch part on '-' to separate patch number from pre-release\n const patchPart = parts[2];\n let patchNumber: number;\n let originalPatchString: string;\n let hasPrerelease = false;\n\n if (patchPart.startsWith('-')) {\n // Handle negative patch numbers like \"-1\" or \"-5\" or \"-1-dev.0\"\n const negativeComponents = patchPart.split('-');\n // For \"-1-dev.0\", negativeComponents will be ['', '1', 'dev.0']\n if (negativeComponents.length > 2) {\n // This is a negative number with pre-release like \"-1-dev.0\"\n originalPatchString = `-${negativeComponents[1]}`;\n patchNumber = parseInt(`-${negativeComponents[1]}`, 10);\n hasPrerelease = true;\n } else {\n // This is just a negative number like \"-1\"\n patchNumber = parseInt(patchPart, 10);\n originalPatchString = patchPart;\n }\n } else {\n // Handle normal patch numbers with possible pre-release like \"24-dev.0\"\n const patchComponents = patchPart.split('-');\n originalPatchString = patchComponents[0];\n patchNumber = parseInt(patchComponents[0], 10);\n hasPrerelease = patchComponents.length > 1;\n }\n\n if (isNaN(patchNumber)) {\n throw new Error(`Invalid patch version: ${patchPart}`);\n }\n\n // For pre-release versions, graduate to the base version (drop pre-release identifier)\n // For stable versions, increment the patch number\n const newPatchNumber = hasPrerelease ? originalPatchString : (patchNumber + 1).toString();\n\n // Create clean release version\n const newVersion = `${parts[0]}.${parts[1]}.${newPatchNumber}`;\n\n return newVersion;\n};\n\nexport const incrementMinorVersion = (version: string): string => {\n // Remove 'v' prefix if present\n const cleanVersion = version.startsWith('v') ? version.slice(1) : version;\n\n // Split into major.minor.patch and handle pre-release identifiers\n const parts = cleanVersion.split('.');\n if (parts.length < 3) {\n throw new Error(`Invalid version string: ${version}`);\n }\n\n const majorNumber = parseInt(parts[0], 10);\n const minorPart = parts[1];\n\n // Handle pre-release versions on minor like \"23-dev.0\"\n const minorComponents = minorPart.split('-');\n const minorNumber = parseInt(minorComponents[0], 10);\n\n if (isNaN(majorNumber) || isNaN(minorNumber)) {\n throw new Error(`Invalid version numbers in: ${version}`);\n }\n\n // Increment the minor number and reset patch to 0\n const newMinorNumber = minorNumber + 1;\n const newVersion = `${majorNumber}.${newMinorNumber}.0`;\n\n return newVersion;\n};\n\nexport const incrementMajorVersion = (version: string): string => {\n // Remove 'v' prefix if present\n const cleanVersion = version.startsWith('v') ? version.slice(1) : version;\n\n // Split into major.minor.patch and handle pre-release identifiers\n const parts = cleanVersion.split('.');\n if (parts.length < 3) {\n throw new Error(`Invalid version string: ${version}`);\n }\n\n const majorPart = parts[0];\n\n // Handle pre-release versions on major like \"4-dev.0\"\n const majorComponents = majorPart.split('-');\n const majorNumber = parseInt(majorComponents[0], 10);\n\n if (isNaN(majorNumber)) {\n throw new Error(`Invalid major version number in: ${version}`);\n }\n\n // Increment the major number and reset minor and patch to 0\n const newMajorNumber = majorNumber + 1;\n const newVersion = `${newMajorNumber}.0.0`;\n\n return newVersion;\n};\n\nexport const validateVersionString = (version: string): boolean => {\n // Remove 'v' prefix if present\n const cleanVersion = version.startsWith('v') ? version.slice(1) : version;\n\n // Basic semver regex pattern\n const semverPattern = /^\\d+\\.\\d+\\.\\d+$/;\n return semverPattern.test(cleanVersion);\n};\n\nexport const calculateTargetVersion = (currentVersion: string, targetVersion: string): string => {\n switch (targetVersion.toLowerCase()) {\n case 'patch':\n return incrementPatchVersion(currentVersion);\n case 'minor':\n return incrementMinorVersion(currentVersion);\n case 'major':\n return incrementMajorVersion(currentVersion);\n default:\n // Explicit version provided\n if (!validateVersionString(targetVersion)) {\n throw new Error(`Invalid version format: ${targetVersion}. Expected format: \"x.y.z\" or one of: \"patch\", \"minor\", \"major\"`);\n }\n return targetVersion.startsWith('v') ? targetVersion.slice(1) : targetVersion;\n }\n};\n\n/**\n * Increment prerelease version with a specific tag\n * Examples:\n * - incrementPrereleaseVersion(\"1.2.3-dev.0\", \"dev\") => \"1.2.3-dev.1\"\n * - incrementPrereleaseVersion(\"1.2.3\", \"dev\") => \"1.2.3-dev.0\"\n * - incrementPrereleaseVersion(\"1.2.3-dev.5\", \"test\") => \"1.2.3-test.0\"\n */\nexport const incrementPrereleaseVersion = (version: string, tag: string): string => {\n const cleanVersion = version.startsWith('v') ? version.slice(1) : version;\n\n // Split on dots but only use first 3 parts for major.minor.patch\n // This handles cases like \"1.2.3-dev.5\" correctly\n const dotParts = cleanVersion.split('.');\n if (dotParts.length < 3) {\n throw new Error(`Invalid version string: ${version}`);\n }\n\n const major = dotParts[0];\n const minor = dotParts[1];\n\n // Reconstruct the patch part - everything after the second dot\n const patchAndPrerelease = dotParts.slice(2).join('.');\n const patchComponents = patchAndPrerelease.split('-');\n const patchNumber = patchComponents[0];\n\n if (patchComponents.length > 1) {\n // Already has prerelease (e.g., \"3-dev.0\" or \"3-test.2\")\n const prereleaseString = patchComponents.slice(1).join('-'); // Handle multiple dashes\n const prereleaseComponents = prereleaseString.split('.');\n const existingTag = prereleaseComponents[0];\n const existingPrereleaseVersion = prereleaseComponents[1];\n\n if (existingTag === tag) {\n // Same tag, increment the prerelease version\n const prereleaseNumber = parseInt(existingPrereleaseVersion) || 0;\n return `${major}.${minor}.${patchNumber}-${tag}.${prereleaseNumber + 1}`;\n } else {\n // Different tag, start at 0\n return `${major}.${minor}.${patchNumber}-${tag}.0`;\n }\n } else {\n // No prerelease yet, add it\n return `${major}.${minor}.${patchNumber}-${tag}.0`;\n }\n};\n\n/**\n * Convert prerelease version to release version\n * Examples:\n * - convertToReleaseVersion(\"1.2.3-dev.5\") => \"1.2.3\"\n * - convertToReleaseVersion(\"1.2.3-test.2\") => \"1.2.3\"\n * - convertToReleaseVersion(\"1.2.3\") => \"1.2.3\"\n */\nexport const convertToReleaseVersion = (version: string): string => {\n const cleanVersion = version.startsWith('v') ? version.slice(1) : version;\n\n // Split on dots but only use first 3 parts for major.minor.patch\n const dotParts = cleanVersion.split('.');\n if (dotParts.length < 3) {\n throw new Error(`Invalid version string: ${version}`);\n }\n\n const major = dotParts[0];\n const minor = dotParts[1];\n\n // Reconstruct the patch part - everything after the second dot\n const patchAndPrerelease = dotParts.slice(2).join('.');\n const patchComponents = patchAndPrerelease.split('-');\n const patchNumber = patchComponents[0];\n\n return `${major}.${minor}.${patchNumber}`;\n};\n\n/**\n * Get version from a specific branch's package.json\n */\nexport const getVersionFromBranch = async (branchName: string): Promise<string | null> => {\n const { runSecure, validateGitRef, safeJsonParse, validatePackageJson } = await import('@eldrforge/git-tools');\n\n try {\n // Validate branch name to prevent injection\n if (!validateGitRef(branchName)) {\n throw new Error(`Invalid branch name: ${branchName}`);\n }\n // Cast to any to avoid type mismatch with node_modules version\n const { stdout } = await (runSecure as any)('git', ['show', `${branchName}:package.json`], { suppressErrorLogging: true });\n const packageJson = safeJsonParse(stdout, 'package.json');\n const validated = validatePackageJson(packageJson, 'package.json');\n return validated.version;\n } catch {\n // Return null if we can't get the version (branch may not exist or no package.json)\n return null;\n }\n};\n\n/**\n * Calculate target version based on branch configuration\n * SEMANTICS: The version config specifies what version should be ON the target branch\n */\nexport const calculateBranchDependentVersion = async (\n currentVersion: string,\n currentBranch: string,\n branchesConfig: any,\n targetBranch?: string\n): Promise<{ version: string; targetBranch: string }> => {\n const { getLogger } = await import('../logging');\n const logger = getLogger();\n\n // Look up the source branch to find the target branch\n if (!branchesConfig || !branchesConfig[currentBranch]) {\n // Use default configuration from constants\n const { KODRDRIV_DEFAULTS } = await import('../constants');\n const defaultConfig = KODRDRIV_DEFAULTS.branches as any;\n\n if (defaultConfig && defaultConfig[currentBranch]) {\n const sourceConfig = defaultConfig[currentBranch];\n const finalTargetBranch = sourceConfig.targetBranch || targetBranch || 'main';\n\n // Look at target branch's version config to determine what version it should have\n const targetConfig = defaultConfig[finalTargetBranch];\n\n logger.info(`VERSION_BRANCH_DEFAULT: Using default branch configuration | Source Branch: ${currentBranch} | Target Branch: ${finalTargetBranch} | Source: default config`);\n\n if (!targetConfig?.version) {\n const defaultVersion = incrementPatchVersion(currentVersion);\n logger.debug(`No version config for target branch '${finalTargetBranch}', using default increment`);\n return { version: defaultVersion, targetBranch: finalTargetBranch };\n }\n\n return calculateVersionFromTargetConfig(currentVersion, finalTargetBranch, targetConfig.version, logger);\n }\n\n // No config at all, use traditional defaults\n const defaultTargetBranch = targetBranch || 'main';\n const defaultVersion = incrementPatchVersion(currentVersion);\n logger.debug(`No branch-specific config found for '${currentBranch}', using defaults`);\n return { version: defaultVersion, targetBranch: defaultTargetBranch };\n }\n\n const sourceConfig = branchesConfig[currentBranch];\n const finalTargetBranch = sourceConfig.targetBranch || targetBranch || 'main';\n\n // Look at target branch's version config to determine what version it should have\n const targetConfig = branchesConfig[finalTargetBranch];\n\n logger.info(`VERSION_BRANCH_DEPENDENT: Using branch-dependent targeting | Source Branch: ${currentBranch} | Target Branch: ${finalTargetBranch} | Source: branch config`);\n\n if (!targetConfig?.version) {\n // No version config for target, use default increment\n const defaultVersion = incrementPatchVersion(currentVersion);\n logger.debug(`No version config for target branch '${finalTargetBranch}', using default increment`);\n return { version: defaultVersion, targetBranch: finalTargetBranch };\n }\n\n return calculateVersionFromTargetConfig(currentVersion, finalTargetBranch, targetConfig.version, logger);\n};\n\n/**\n * Calculate version based on target branch configuration\n */\nconst calculateVersionFromTargetConfig = async (\n currentVersion: string,\n targetBranch: string,\n versionConfig: any,\n logger: any\n): Promise<{ version: string; targetBranch: string }> => {\n if (versionConfig.type === 'release') {\n // Convert to release version (remove prerelease tags)\n const releaseVersion = convertToReleaseVersion(currentVersion);\n logger.info(`VERSION_RELEASE_CONVERSION: Converting prerelease to release version | Current: ${currentVersion} | Release: ${releaseVersion} | Action: Remove prerelease tag`);\n return { version: releaseVersion, targetBranch };\n } else if (versionConfig.type === 'prerelease') {\n if (!versionConfig.tag) {\n throw new Error(`Prerelease version type requires a tag in branch configuration`);\n }\n\n const tag = versionConfig.tag;\n\n if (versionConfig.increment) {\n // Check if there's already a version with this tag in the target branch\n const targetBranchVersion = await getVersionFromBranch(targetBranch);\n\n if (targetBranchVersion) {\n // Use the target branch version as the base and increment\n const newVersion = incrementPrereleaseVersion(targetBranchVersion, tag);\n logger.info(`VERSION_PRERELEASE_INCREMENT: Incrementing prerelease version | Current: ${targetBranchVersion} | New: ${newVersion} | Action: Increment prerelease number`);\n return { version: newVersion, targetBranch };\n } else {\n // No version in target branch, use current version as base\n const newVersion = incrementPrereleaseVersion(currentVersion, tag);\n logger.info(`VERSION_PRERELEASE_CREATE: Creating new prerelease version | Current: ${currentVersion} | New: ${newVersion} | Action: Add prerelease tag`);\n return { version: newVersion, targetBranch };\n }\n } else {\n // Just add/change the prerelease tag without incrementing\n const baseVersion = convertToReleaseVersion(currentVersion);\n const newVersion = `${baseVersion}-${tag}.0`;\n logger.info(`VERSION_PRERELEASE_TAG: Setting prerelease tag | Current: ${currentVersion} | New: ${newVersion} | Tag: ${versionConfig.tag}`);\n return { version: newVersion, targetBranch };\n }\n }\n\n throw new Error(`Invalid version type: ${versionConfig.type}`);\n};\n\n\n/**\n * Find the development branch from branches configuration\n * Returns the branch marked with developmentBranch: true\n */\nexport const findDevelopmentBranch = (branchesConfig: any): string | null => {\n if (!branchesConfig || typeof branchesConfig !== 'object') {\n return null;\n }\n\n for (const [branchName, branchConfig] of Object.entries(branchesConfig)) {\n if (branchConfig && typeof branchConfig === 'object' && (branchConfig as any).developmentBranch === true) {\n return branchName;\n }\n }\n\n return null;\n};\n\n/**\n * Check if two prerelease versions have the same tag\n * Examples:\n * - haveSamePrereleaseTag(\"1.2.3-dev.0\", \"1.2.3-dev.5\") => true\n * - haveSamePrereleaseTag(\"1.2.3-dev.0\", \"1.2.3-test.0\") => false\n * - haveSamePrereleaseTag(\"1.2.3\", \"1.2.3-dev.0\") => false\n */\nexport const haveSamePrereleaseTag = (version1: string, version2: string): boolean => {\n const extractTag = (version: string): string | null => {\n const cleanVersion = version.startsWith('v') ? version.slice(1) : version;\n const parts = cleanVersion.split('.');\n if (parts.length < 3) return null;\n\n const patchAndPrerelease = parts.slice(2).join('.');\n const patchComponents = patchAndPrerelease.split('-');\n\n if (patchComponents.length > 1) {\n const prereleaseString = patchComponents.slice(1).join('-');\n const prereleaseComponents = prereleaseString.split('.');\n return prereleaseComponents[0] || null;\n }\n\n return null;\n };\n\n const tag1 = extractTag(version1);\n const tag2 = extractTag(version2);\n\n return tag1 !== null && tag2 !== null && tag1 === tag2;\n};\n\nexport const checkIfTagExists = async (tagName: string): Promise<boolean> => {\n const { runSecure, validateGitRef } = await import('@eldrforge/git-tools');\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 return stdout.trim() === tagName;\n } catch {\n // If git command fails, assume tag doesn't exist\n return false;\n }\n};\n\nexport const confirmVersionInteractively = async (currentVersion: string, proposedVersion: string, targetVersionInput?: string): Promise<string> => {\n const { getUserChoice, getUserTextInput, requireTTY } = await import('./interactive');\n const { getLogger } = await import('../logging');\n\n requireTTY('Interactive version confirmation requires a terminal.');\n\n const logger = getLogger();\n logger.info(`\\nVERSION_CONFIRMATION: Version confirmation required | Current: ${currentVersion} | Proposed: ${proposedVersion}`);\n logger.info(`VERSION_CURRENT: Current package version | Version: ${currentVersion}`);\n logger.info(`VERSION_PROPOSED: Proposed new version | Version: ${proposedVersion}`);\n if (targetVersionInput) {\n logger.info(`VERSION_TARGET_INPUT: Target version provided | Input: ${targetVersionInput}`);\n }\n\n const choices = [\n { key: 'c', label: `Confirm ${proposedVersion}` },\n { key: 'e', label: 'Enter custom version' },\n { key: 'a', label: 'Abort publish' }\n ];\n\n const choice = await getUserChoice('\\nšŸ¤” Confirm the version for this release:', choices);\n\n switch (choice) {\n case 'c':\n return proposedVersion;\n case 'e': {\n const customVersion = await getUserTextInput('\\nšŸ“ Enter the version number (e.g., \"4.30.0\"):');\n if (!validateVersionString(customVersion)) {\n throw new Error(`Invalid version format: ${customVersion}. Expected format: \"x.y.z\"`);\n }\n const cleanCustomVersion = customVersion.startsWith('v') ? customVersion.slice(1) : customVersion;\n logger.info(`VERSION_CUSTOM_SELECTED: Using custom version from user input | Version: ${cleanCustomVersion} | Source: interactive input`);\n return cleanCustomVersion;\n }\n case 'a':\n throw new Error('Release aborted by user');\n default:\n throw new Error(`Unexpected choice: ${choice}`);\n }\n};\n\nexport const getOutputPath = (outputDirectory: string, filename: string): string => {\n return path.join(outputDirectory, filename);\n};\n\nexport const getTimestampedFilename = (baseName: string, extension: string = '.json'): string => {\n const now = new Date();\n\n // Format as YYMMdd-HHmm (e.g., 250701-1030)\n const yy = now.getFullYear().toString().slice(-2);\n const mm = (now.getMonth() + 1).toString().padStart(2, '0');\n const dd = now.getDate().toString().padStart(2, '0');\n const hh = now.getHours().toString().padStart(2, '0');\n const min = now.getMinutes().toString().padStart(2, '0');\n\n const timestamp = `${yy}${mm}${dd}-${hh}${min}`;\n\n return `${timestamp}-${baseName}${extension}`;\n};\n\nexport const getTimestampedRequestFilename = (baseName: string): string => {\n return getTimestampedFilename(baseName, '.request.json');\n};\n\nexport const getTimestampedResponseFilename = (baseName: string): string => {\n return getTimestampedFilename(baseName, '.response.json');\n};\n\nexport const getTimestampedCommitFilename = (): string => {\n return getTimestampedFilename('commit-message', '.md');\n};\n\nexport const getTimestampedReleaseNotesFilename = (): string => {\n return getTimestampedFilename('release-notes', '.md');\n};\n\nexport const getTimestampedAudioFilename = (): string => {\n return getTimestampedFilename('audio-recording', '.wav');\n};\n\nexport const getTimestampedTranscriptFilename = (): string => {\n return getTimestampedFilename('audio-transcript', '.md');\n};\n\nexport const getTimestampedReviewFilename = (): string => {\n return getTimestampedFilename('review-analysis', '.md');\n};\n\nexport const getTimestampedReviewNotesFilename = (): string => {\n return getTimestampedFilename('review-notes', '.md');\n};\n\nexport const getTimestampedArchivedAudioFilename = (originalExtension: string = '.wav'): string => {\n return getTimestampedFilename('review-audio', originalExtension);\n};\n\nexport const getTimestampedArchivedTranscriptFilename = (): string => {\n return getTimestampedFilename('review-transcript', '.md');\n};\n\n/**\n * Archives an audio file and its transcription to the output/kodrdriv directory\n * @param originalAudioPath - Path to the original audio file\n * @param transcriptionText - The raw transcription text\n * @param outputDirectory - Base output directory (default: 'output')\n * @returns Object containing the paths where files were archived\n */\nexport const archiveAudio = async (\n originalAudioPath: string,\n transcriptionText: string,\n outputDirectory: string = 'output'\n): Promise<{ audioPath: string; transcriptPath: string }> => {\n const logger = getLogger();\n const storage = createStorage();\n\n try {\n // Ensure the output directory exists (should already be output/kodrdriv)\n await storage.ensureDirectory(outputDirectory);\n\n // Get file extension from original audio file\n const originalExtension = path.extname(originalAudioPath);\n\n // Generate timestamped filenames\n const archivedAudioFilename = getTimestampedArchivedAudioFilename(originalExtension);\n const archivedTranscriptFilename = getTimestampedArchivedTranscriptFilename();\n\n // Full paths for archived files - directly in the output directory\n const archivedAudioPath = path.join(outputDirectory, archivedAudioFilename);\n const archivedTranscriptPath = path.join(outputDirectory, archivedTranscriptFilename);\n\n // Copy audio file if it exists\n if (await storage.isFileReadable(originalAudioPath)) {\n // Read original audio file as buffer using fs directly for binary files\n const audioBuffer = await fs.promises.readFile(originalAudioPath);\n await storage.writeFile(archivedAudioPath, audioBuffer, 'binary');\n logger.debug('Archived audio file to: %s', archivedAudioPath);\n } else {\n logger.warn('AUDIO_FILE_NOT_FOUND: Original audio file not accessible | Path: %s | Impact: Cannot archive original', originalAudioPath);\n }\n\n // Save transcription text\n const transcriptContent = `# Audio Transcription Archive\\n\\n**Original Audio File:** ${originalAudioPath}\\n**Archived:** ${new Date().toISOString()}\\n\\n## Transcription\\n\\n${transcriptionText}`;\n await storage.writeFile(archivedTranscriptPath, transcriptContent, 'utf8');\n logger.debug('Archived transcription to: %s', archivedTranscriptPath);\n\n logger.info('AUDIO_ARCHIVED: Audio and transcript archived successfully | Audio: %s | Transcript: %s | Status: archived', archivedAudioFilename, archivedTranscriptFilename);\n\n return {\n audioPath: archivedAudioPath,\n transcriptPath: archivedTranscriptPath\n };\n\n } catch (error: any) {\n logger.error('AUDIO_ARCHIVE_FAILED: Failed to archive audio files | Error: %s | Impact: Audio not preserved', error.message);\n throw new Error(`Audio archiving failed: ${error.message}`);\n }\n};\n\n/**\n * Query npm registry for published version of a package\n * Returns null if package is not published or on error\n */\nexport const getNpmPublishedVersion = async (packageName: string): Promise<string | null> => {\n const logger = getLogger();\n try {\n const { runSecure } = await import('@eldrforge/git-tools');\n\n // Use npm view to get the latest published version\n // --json flag ensures parseable output\n const { stdout } = await runSecure('npm', ['view', packageName, 'version', '--json']);\n\n if (!stdout || stdout.trim() === '') {\n logger.verbose(`Package ${packageName} not found on npm registry`);\n return null;\n }\n\n // npm view returns just the version string for a single version\n const version = stdout.trim().replace(/^[\"']|[\"']$/g, ''); // Remove quotes if present\n logger.verbose(`Found ${packageName}@${version} on npm registry`);\n return version;\n } catch (error: any) {\n // Package not found or network error\n logger.verbose(`Could not query npm for ${packageName}: ${error.message}`);\n return null;\n }\n};\n\n/**\n * Check if a package version already exists on npm registry\n */\nexport const isVersionPublishedOnNpm = async (packageName: string, version: string): Promise<boolean> => {\n const logger = getLogger();\n try {\n const { runSecure } = await import('@eldrforge/git-tools');\n\n // Use npm view to check for specific version\n const { stdout } = await runSecure('npm', ['view', `${packageName}@${version}`, 'version', '--json']);\n\n if (!stdout || stdout.trim() === '') {\n logger.verbose(`Version ${packageName}@${version} not found on npm registry`);\n return false;\n }\n\n logger.verbose(`Version ${packageName}@${version} exists on npm registry`);\n return true;\n } catch (error: any) {\n // Version not found\n logger.verbose(`Version ${packageName}@${version} not published: ${error.message}`);\n return false;\n }\n};\n\n/**\n * Get detailed info about a tag including the version it points to\n */\nexport const getTagInfo = async (tagName: string): Promise<{ exists: boolean; commit?: string; version?: string } | null> => {\n try {\n const { runSecure, validateGitRef } = await import('@eldrforge/git-tools');\n\n if (!validateGitRef(tagName)) {\n throw new Error(`Invalid tag name: ${tagName}`);\n }\n\n // Check if tag exists\n const { stdout: tagList } = await runSecure('git', ['tag', '-l', tagName]);\n if (tagList.trim() !== tagName) {\n return { exists: false };\n }\n\n // Get the commit the tag points to\n const { stdout: commit } = await runSecure('git', ['rev-list', '-n', '1', tagName]);\n\n // Extract version from tag name (assumes format like v1.2.3 or working/v1.2.3)\n const versionMatch = tagName.match(/v?(\\d+\\.\\d+\\.\\d+(?:-[a-zA-Z0-9.-]+)?)/);\n const version = versionMatch ? versionMatch[1] : undefined;\n\n return {\n exists: true,\n commit: commit.trim(),\n version\n };\n } catch {\n return null;\n }\n};\n\n/**\n * Check if a version is a development/prerelease version (has prerelease tag)\n */\nexport const isDevelopmentVersion = (version: string): boolean => {\n // Development versions have prerelease tags: 1.2.3-dev.0, 1.2.3-alpha.1, etc.\n return version.includes('-');\n};\n\n/**\n * Check if a version is a release version (no prerelease tag)\n */\nexport const isReleaseVersion = (version: string): boolean => {\n // Release versions are X.Y.Z without any suffix\n return /^\\d+\\.\\d+\\.\\d+$/.test(version);\n};\n\n/**\n * Get expected version pattern for a branch\n */\nexport const getExpectedVersionPattern = (branchName: string): { pattern: RegExp; description: string; isDevelopment: boolean } => {\n // Development/working branches should have prerelease versions\n const devBranchPatterns = /^(working|development|dev|feature\\/|wip\\/)/i;\n\n if (devBranchPatterns.test(branchName)) {\n return {\n pattern: /^\\d+\\.\\d+\\.\\d+-[a-zA-Z0-9.-]+$/,\n description: 'X.Y.Z-<tag> (e.g., 1.2.3-dev.0)',\n isDevelopment: true\n };\n }\n\n // Main/master/production branches should have release versions\n const releaseBranchPatterns = /^(main|master|production|release\\/)/i;\n\n if (releaseBranchPatterns.test(branchName)) {\n return {\n pattern: /^\\d+\\.\\d+\\.\\d+$/,\n description: 'X.Y.Z (e.g., 1.2.3)',\n isDevelopment: false\n };\n }\n\n // For other branches, allow both but prefer release versions\n return {\n pattern: /^\\d+\\.\\d+\\.\\d+(-[a-zA-Z0-9.-]+)?$/,\n description: 'X.Y.Z or X.Y.Z-<tag>',\n isDevelopment: false\n };\n};\n\n/**\n * Validate version against branch expectations\n */\nexport const validateVersionForBranch = (version: string, branchName: string): {\n valid: boolean;\n issue?: string;\n fix?: string;\n} => {\n const expected = getExpectedVersionPattern(branchName);\n\n if (!expected.pattern.test(version)) {\n return {\n valid: false,\n issue: `Invalid version format for branch '${branchName}'`,\n fix: `Version should match ${expected.description}`\n };\n }\n\n const isDevVersion = isDevelopmentVersion(version);\n\n // Development branches should have development versions\n if (expected.isDevelopment && !isDevVersion) {\n return {\n valid: false,\n issue: `Release version on development branch '${branchName}'`,\n fix: 'Run kodrdriv development to update to development version'\n };\n }\n\n // Release branches should NOT have development versions\n if (!expected.isDevelopment && branchName.match(/^(main|master|production|release\\/)/) && isDevVersion) {\n return {\n valid: false,\n issue: `Development version on release branch '${branchName}'`,\n fix: 'Do not commit development versions to release branches'\n };\n }\n\n return { valid: true };\n};\n"],"names":["incrementPatchVersion","version","cleanVersion","startsWith","slice","parts","split","length","Error","patchPart","patchNumber","originalPatchString","hasPrerelease","negativeComponents","parseInt","patchComponents","isNaN","newPatchNumber","toString","newVersion","validateVersionString","semverPattern","test","incrementPrereleaseVersion","tag","dotParts","major","minor","patchAndPrerelease","join","prereleaseString","prereleaseComponents","existingTag","existingPrereleaseVersion","prereleaseNumber","convertToReleaseVersion","getVersionFromBranch","branchName","runSecure","validateGitRef","safeJsonParse","validatePackageJson","stdout","suppressErrorLogging","packageJson","validated","calculateBranchDependentVersion","currentVersion","currentBranch","branchesConfig","targetBranch","getLogger","logger","KODRDRIV_DEFAULTS","defaultConfig","branches","sourceConfig","finalTargetBranch","targetConfig","info","defaultVersion","debug","calculateVersionFromTargetConfig","defaultTargetBranch","versionConfig","type","releaseVersion","increment","targetBranchVersion","baseVersion","findDevelopmentBranch","branchConfig","Object","entries","developmentBranch","checkIfTagExists","tagName","trim","confirmVersionInteractively","proposedVersion","targetVersionInput","getUserChoice","getUserTextInput","requireTTY","choices","key","label","choice","customVersion","cleanCustomVersion","getOutputPath","outputDirectory","filename","path","getTimestampedFilename","baseName","extension","now","Date","yy","getFullYear","mm","getMonth","padStart","dd","getDate","hh","getHours","min","getMinutes","timestamp","getTimestampedRequestFilename","getTimestampedResponseFilename","getTimestampedCommitFilename","getTimestampedReleaseNotesFilename","getTimestampedAudioFilename","getTimestampedReviewFilename","getTimestampedReviewNotesFilename","getTimestampedArchivedAudioFilename","originalExtension","getTimestampedArchivedTranscriptFilename","archiveAudio","originalAudioPath","transcriptionText","storage","createStorage","ensureDirectory","extname","archivedAudioFilename","archivedTranscriptFilename","archivedAudioPath","archivedTranscriptPath","isFileReadable","audioBuffer","fs","promises","readFile","writeFile","warn","transcriptContent","toISOString","audioPath","transcriptPath","error","message","getNpmPublishedVersion","packageName","verbose","replace","getTagInfo","tagList","exists","commit","versionMatch","match","undefined","isDevelopmentVersion","includes","getExpectedVersionPattern","devBranchPatterns","pattern","description","isDevelopment","releaseBranchPatterns","validateVersionForBranch","expected","valid","issue","fix","isDevVersion"],"mappings":"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"}
1
+ {"version":3,"file":"general.js","sources":["../../src/util/general.ts"],"sourcesContent":["import path from 'path';\nimport { createStorage, deepMerge, stringifyJSON, incrementPatchVersion, incrementMinorVersion, incrementMajorVersion, validateVersionString, calculateTargetVersion, incrementPrereleaseVersion, convertToReleaseVersion } from '@eldrforge/shared';\nimport { getLogger } from '../logging';\n// eslint-disable-next-line no-restricted-imports\nimport * as fs from 'fs';\n\n/**\n * Get version from a specific branch's package.json\n */\nexport const getVersionFromBranch = async (branchName: string): Promise<string | null> => {\n const { runSecure, validateGitRef, safeJsonParse, validatePackageJson } = await import('@eldrforge/git-tools');\n\n try {\n // Validate branch name to prevent injection\n if (!validateGitRef(branchName)) {\n throw new Error(`Invalid branch name: ${branchName}`);\n }\n // Cast to any to avoid type mismatch with node_modules version\n const { stdout } = await (runSecure as any)('git', ['show', `${branchName}:package.json`], { suppressErrorLogging: true });\n const packageJson = safeJsonParse(stdout, 'package.json');\n const validated = validatePackageJson(packageJson, 'package.json');\n return validated.version;\n } catch {\n // Return null if we can't get the version (branch may not exist or no package.json)\n return null;\n }\n};\n\n/**\n * Calculate target version based on branch configuration\n * SEMANTICS: The version config specifies what version should be ON the target branch\n */\nexport const calculateBranchDependentVersion = async (\n currentVersion: string,\n currentBranch: string,\n branchesConfig: any,\n targetBranch?: string\n): Promise<{ version: string; targetBranch: string }> => {\n const { getLogger } = await import('../logging');\n const logger = getLogger();\n\n // Look up the source branch to find the target branch\n if (!branchesConfig || !branchesConfig[currentBranch]) {\n // Use default configuration from constants\n const { KODRDRIV_DEFAULTS } = await import('../constants');\n const defaultConfig = KODRDRIV_DEFAULTS.branches as any;\n\n if (defaultConfig && defaultConfig[currentBranch]) {\n const sourceConfig = defaultConfig[currentBranch];\n const finalTargetBranch = sourceConfig.targetBranch || targetBranch || 'main';\n\n // Look at target branch's version config to determine what version it should have\n const targetConfig = defaultConfig[finalTargetBranch];\n\n logger.info(`VERSION_BRANCH_DEFAULT: Using default branch configuration | Source Branch: ${currentBranch} | Target Branch: ${finalTargetBranch} | Source: default config`);\n\n if (!targetConfig?.version) {\n const defaultVersion = incrementPatchVersion(currentVersion);\n logger.debug(`No version config for target branch '${finalTargetBranch}', using default increment`);\n return { version: defaultVersion, targetBranch: finalTargetBranch };\n }\n\n return calculateVersionFromTargetConfig(currentVersion, finalTargetBranch, targetConfig.version, logger);\n }\n\n // No config at all, use traditional defaults\n const defaultTargetBranch = targetBranch || 'main';\n const defaultVersion = incrementPatchVersion(currentVersion);\n logger.debug(`No branch-specific config found for '${currentBranch}', using defaults`);\n return { version: defaultVersion, targetBranch: defaultTargetBranch };\n }\n\n const sourceConfig = branchesConfig[currentBranch];\n const finalTargetBranch = sourceConfig.targetBranch || targetBranch || 'main';\n\n // Look at target branch's version config to determine what version it should have\n const targetConfig = branchesConfig[finalTargetBranch];\n\n logger.info(`VERSION_BRANCH_DEPENDENT: Using branch-dependent targeting | Source Branch: ${currentBranch} | Target Branch: ${finalTargetBranch} | Source: branch config`);\n\n if (!targetConfig?.version) {\n // No version config for target, use default increment\n const defaultVersion = incrementPatchVersion(currentVersion);\n logger.debug(`No version config for target branch '${finalTargetBranch}', using default increment`);\n return { version: defaultVersion, targetBranch: finalTargetBranch };\n }\n\n return calculateVersionFromTargetConfig(currentVersion, finalTargetBranch, targetConfig.version, logger);\n};\n\n/**\n * Calculate version based on target branch configuration\n */\nconst calculateVersionFromTargetConfig = async (\n currentVersion: string,\n targetBranch: string,\n versionConfig: any,\n logger: any\n): Promise<{ version: string; targetBranch: string }> => {\n if (versionConfig.type === 'release') {\n // Convert to release version (remove prerelease tags)\n const releaseVersion = convertToReleaseVersion(currentVersion);\n logger.info(`VERSION_RELEASE_CONVERSION: Converting prerelease to release version | Current: ${currentVersion} | Release: ${releaseVersion} | Action: Remove prerelease tag`);\n return { version: releaseVersion, targetBranch };\n } else if (versionConfig.type === 'prerelease') {\n if (!versionConfig.tag) {\n throw new Error(`Prerelease version type requires a tag in branch configuration`);\n }\n\n const tag = versionConfig.tag;\n\n if (versionConfig.increment) {\n // Check if there's already a version with this tag in the target branch\n const targetBranchVersion = await getVersionFromBranch(targetBranch);\n\n if (targetBranchVersion) {\n // Use the target branch version as the base and increment\n const newVersion = incrementPrereleaseVersion(targetBranchVersion, tag);\n logger.info(`VERSION_PRERELEASE_INCREMENT: Incrementing prerelease version | Current: ${targetBranchVersion} | New: ${newVersion} | Action: Increment prerelease number`);\n return { version: newVersion, targetBranch };\n } else {\n // No version in target branch, use current version as base\n const newVersion = incrementPrereleaseVersion(currentVersion, tag);\n logger.info(`VERSION_PRERELEASE_CREATE: Creating new prerelease version | Current: ${currentVersion} | New: ${newVersion} | Action: Add prerelease tag`);\n return { version: newVersion, targetBranch };\n }\n } else {\n // Just add/change the prerelease tag without incrementing\n const baseVersion = convertToReleaseVersion(currentVersion);\n const newVersion = `${baseVersion}-${tag}.0`;\n logger.info(`VERSION_PRERELEASE_TAG: Setting prerelease tag | Current: ${currentVersion} | New: ${newVersion} | Tag: ${versionConfig.tag}`);\n return { version: newVersion, targetBranch };\n }\n }\n\n throw new Error(`Invalid version type: ${versionConfig.type}`);\n};\n\n\n/**\n * Find the development branch from branches configuration\n * Returns the branch marked with developmentBranch: true\n */\nexport const findDevelopmentBranch = (branchesConfig: any): string | null => {\n if (!branchesConfig || typeof branchesConfig !== 'object') {\n return null;\n }\n\n for (const [branchName, branchConfig] of Object.entries(branchesConfig)) {\n if (branchConfig && typeof branchConfig === 'object' && (branchConfig as any).developmentBranch === true) {\n return branchName;\n }\n }\n\n return null;\n};\n\n/**\n * Check if two prerelease versions have the same tag\n * Examples:\n * - haveSamePrereleaseTag(\"1.2.3-dev.0\", \"1.2.3-dev.5\") => true\n * - haveSamePrereleaseTag(\"1.2.3-dev.0\", \"1.2.3-test.0\") => false\n * - haveSamePrereleaseTag(\"1.2.3\", \"1.2.3-dev.0\") => false\n */\nexport const haveSamePrereleaseTag = (version1: string, version2: string): boolean => {\n const extractTag = (version: string): string | null => {\n const cleanVersion = version.startsWith('v') ? version.slice(1) : version;\n const parts = cleanVersion.split('.');\n if (parts.length < 3) return null;\n\n const patchAndPrerelease = parts.slice(2).join('.');\n const patchComponents = patchAndPrerelease.split('-');\n\n if (patchComponents.length > 1) {\n const prereleaseString = patchComponents.slice(1).join('-');\n const prereleaseComponents = prereleaseString.split('.');\n return prereleaseComponents[0] || null;\n }\n\n return null;\n };\n\n const tag1 = extractTag(version1);\n const tag2 = extractTag(version2);\n\n return tag1 !== null && tag2 !== null && tag1 === tag2;\n};\n\nexport const checkIfTagExists = async (tagName: string): Promise<boolean> => {\n const { runSecure, validateGitRef } = await import('@eldrforge/git-tools');\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 return stdout.trim() === tagName;\n } catch {\n // If git command fails, assume tag doesn't exist\n return false;\n }\n};\n\nexport const confirmVersionInteractively = async (currentVersion: string, proposedVersion: string, targetVersionInput?: string): Promise<string> => {\n const { getUserChoice, getUserTextInput, requireTTY } = await import('./interactive');\n const { getLogger } = await import('../logging');\n\n requireTTY('Interactive version confirmation requires a terminal.');\n\n const logger = getLogger();\n logger.info(`\\nVERSION_CONFIRMATION: Version confirmation required | Current: ${currentVersion} | Proposed: ${proposedVersion}`);\n logger.info(`VERSION_CURRENT: Current package version | Version: ${currentVersion}`);\n logger.info(`VERSION_PROPOSED: Proposed new version | Version: ${proposedVersion}`);\n if (targetVersionInput) {\n logger.info(`VERSION_TARGET_INPUT: Target version provided | Input: ${targetVersionInput}`);\n }\n\n const choices = [\n { key: 'c', label: `Confirm ${proposedVersion}` },\n { key: 'e', label: 'Enter custom version' },\n { key: 'a', label: 'Abort publish' }\n ];\n\n const choice = await getUserChoice('\\nšŸ¤” Confirm the version for this release:', choices);\n\n switch (choice) {\n case 'c':\n return proposedVersion;\n case 'e': {\n const customVersion = await getUserTextInput('\\nšŸ“ Enter the version number (e.g., \"4.30.0\"):');\n if (!validateVersionString(customVersion)) {\n throw new Error(`Invalid version format: ${customVersion}. Expected format: \"x.y.z\"`);\n }\n const cleanCustomVersion = customVersion.startsWith('v') ? customVersion.slice(1) : customVersion;\n logger.info(`VERSION_CUSTOM_SELECTED: Using custom version from user input | Version: ${cleanCustomVersion} | Source: interactive input`);\n return cleanCustomVersion;\n }\n case 'a':\n throw new Error('Release aborted by user');\n default:\n throw new Error(`Unexpected choice: ${choice}`);\n }\n};\n\nexport const getOutputPath = (outputDirectory: string, filename: string): string => {\n return path.join(outputDirectory, filename);\n};\n\nexport const getTimestampedFilename = (baseName: string, extension: string = '.json'): string => {\n const now = new Date();\n\n // Format as YYMMdd-HHmm (e.g., 250701-1030)\n const yy = now.getFullYear().toString().slice(-2);\n const mm = (now.getMonth() + 1).toString().padStart(2, '0');\n const dd = now.getDate().toString().padStart(2, '0');\n const hh = now.getHours().toString().padStart(2, '0');\n const min = now.getMinutes().toString().padStart(2, '0');\n\n const timestamp = `${yy}${mm}${dd}-${hh}${min}`;\n\n return `${timestamp}-${baseName}${extension}`;\n};\n\nexport const getTimestampedRequestFilename = (baseName: string): string => {\n return getTimestampedFilename(baseName, '.request.json');\n};\n\nexport const getTimestampedResponseFilename = (baseName: string): string => {\n return getTimestampedFilename(baseName, '.response.json');\n};\n\nexport const getTimestampedCommitFilename = (): string => {\n return getTimestampedFilename('commit-message', '.md');\n};\n\nexport const getTimestampedReleaseNotesFilename = (): string => {\n return getTimestampedFilename('release-notes', '.md');\n};\n\nexport const getTimestampedAudioFilename = (): string => {\n return getTimestampedFilename('audio-recording', '.wav');\n};\n\nexport const getTimestampedTranscriptFilename = (): string => {\n return getTimestampedFilename('audio-transcript', '.md');\n};\n\nexport const getTimestampedReviewFilename = (): string => {\n return getTimestampedFilename('review-analysis', '.md');\n};\n\nexport const getTimestampedReviewNotesFilename = (): string => {\n return getTimestampedFilename('review-notes', '.md');\n};\n\nexport const getTimestampedArchivedAudioFilename = (originalExtension: string = '.wav'): string => {\n return getTimestampedFilename('review-audio', originalExtension);\n};\n\nexport const getTimestampedArchivedTranscriptFilename = (): string => {\n return getTimestampedFilename('review-transcript', '.md');\n};\n\n/**\n * Archives an audio file and its transcription to the output/kodrdriv directory\n * @param originalAudioPath - Path to the original audio file\n * @param transcriptionText - The raw transcription text\n * @param outputDirectory - Base output directory (default: 'output')\n * @returns Object containing the paths where files were archived\n */\nexport const archiveAudio = async (\n originalAudioPath: string,\n transcriptionText: string,\n outputDirectory: string = 'output'\n): Promise<{ audioPath: string; transcriptPath: string }> => {\n const logger = getLogger();\n const storage = createStorage();\n\n try {\n // Ensure the output directory exists (should already be output/kodrdriv)\n await storage.ensureDirectory(outputDirectory);\n\n // Get file extension from original audio file\n const originalExtension = path.extname(originalAudioPath);\n\n // Generate timestamped filenames\n const archivedAudioFilename = getTimestampedArchivedAudioFilename(originalExtension);\n const archivedTranscriptFilename = getTimestampedArchivedTranscriptFilename();\n\n // Full paths for archived files - directly in the output directory\n const archivedAudioPath = path.join(outputDirectory, archivedAudioFilename);\n const archivedTranscriptPath = path.join(outputDirectory, archivedTranscriptFilename);\n\n // Copy audio file if it exists\n if (await storage.isFileReadable(originalAudioPath)) {\n // Read original audio file as buffer using fs directly for binary files\n const audioBuffer = await fs.promises.readFile(originalAudioPath);\n await storage.writeFile(archivedAudioPath, audioBuffer, 'binary');\n logger.debug('Archived audio file to: %s', archivedAudioPath);\n } else {\n logger.warn('AUDIO_FILE_NOT_FOUND: Original audio file not accessible | Path: %s | Impact: Cannot archive original', originalAudioPath);\n }\n\n // Save transcription text\n const transcriptContent = `# Audio Transcription Archive\\n\\n**Original Audio File:** ${originalAudioPath}\\n**Archived:** ${new Date().toISOString()}\\n\\n## Transcription\\n\\n${transcriptionText}`;\n await storage.writeFile(archivedTranscriptPath, transcriptContent, 'utf8');\n logger.debug('Archived transcription to: %s', archivedTranscriptPath);\n\n logger.info('AUDIO_ARCHIVED: Audio and transcript archived successfully | Audio: %s | Transcript: %s | Status: archived', archivedAudioFilename, archivedTranscriptFilename);\n\n return {\n audioPath: archivedAudioPath,\n transcriptPath: archivedTranscriptPath\n };\n\n } catch (error: any) {\n logger.error('AUDIO_ARCHIVE_FAILED: Failed to archive audio files | Error: %s | Impact: Audio not preserved', error.message);\n throw new Error(`Audio archiving failed: ${error.message}`);\n }\n};\n\n/**\n * Query npm registry for published version of a package\n * Returns null if package is not published or on error\n */\nexport const getNpmPublishedVersion = async (packageName: string): Promise<string | null> => {\n const logger = getLogger();\n try {\n const { runSecure } = await import('@eldrforge/git-tools');\n\n // Use npm view to get the latest published version\n // --json flag ensures parseable output\n const { stdout } = await runSecure('npm', ['view', packageName, 'version', '--json']);\n\n if (!stdout || stdout.trim() === '') {\n logger.verbose(`Package ${packageName} not found on npm registry`);\n return null;\n }\n\n // npm view returns just the version string for a single version\n const version = stdout.trim().replace(/^[\"']|[\"']$/g, ''); // Remove quotes if present\n logger.verbose(`Found ${packageName}@${version} on npm registry`);\n return version;\n } catch (error: any) {\n // Package not found or network error\n logger.verbose(`Could not query npm for ${packageName}: ${error.message}`);\n return null;\n }\n};\n\n/**\n * Check if a package version already exists on npm registry\n */\nexport const isVersionPublishedOnNpm = async (packageName: string, version: string): Promise<boolean> => {\n const logger = getLogger();\n try {\n const { runSecure } = await import('@eldrforge/git-tools');\n\n // Use npm view to check for specific version\n const { stdout } = await runSecure('npm', ['view', `${packageName}@${version}`, 'version', '--json']);\n\n if (!stdout || stdout.trim() === '') {\n logger.verbose(`Version ${packageName}@${version} not found on npm registry`);\n return false;\n }\n\n logger.verbose(`Version ${packageName}@${version} exists on npm registry`);\n return true;\n } catch (error: any) {\n // Version not found\n logger.verbose(`Version ${packageName}@${version} not published: ${error.message}`);\n return false;\n }\n};\n\n/**\n * Get detailed info about a tag including the version it points to\n */\nexport const getTagInfo = async (tagName: string): Promise<{ exists: boolean; commit?: string; version?: string } | null> => {\n try {\n const { runSecure, validateGitRef } = await import('@eldrforge/git-tools');\n\n if (!validateGitRef(tagName)) {\n throw new Error(`Invalid tag name: ${tagName}`);\n }\n\n // Check if tag exists\n const { stdout: tagList } = await runSecure('git', ['tag', '-l', tagName]);\n if (tagList.trim() !== tagName) {\n return { exists: false };\n }\n\n // Get the commit the tag points to\n const { stdout: commit } = await runSecure('git', ['rev-list', '-n', '1', tagName]);\n\n // Extract version from tag name (assumes format like v1.2.3 or working/v1.2.3)\n const versionMatch = tagName.match(/v?(\\d+\\.\\d+\\.\\d+(?:-[a-zA-Z0-9.-]+)?)/);\n const version = versionMatch ? versionMatch[1] : undefined;\n\n return {\n exists: true,\n commit: commit.trim(),\n version\n };\n } catch {\n return null;\n }\n};\n\n/**\n * Check if a version is a development/prerelease version (has prerelease tag)\n */\nexport const isDevelopmentVersion = (version: string): boolean => {\n // Development versions have prerelease tags: 1.2.3-dev.0, 1.2.3-alpha.1, etc.\n return version.includes('-');\n};\n\n/**\n * Check if a version is a release version (no prerelease tag)\n */\nexport const isReleaseVersion = (version: string): boolean => {\n // Release versions are X.Y.Z without any suffix\n return /^\\d+\\.\\d+\\.\\d+$/.test(version);\n};\n\n/**\n * Get expected version pattern for a branch\n */\nexport const getExpectedVersionPattern = (branchName: string): { pattern: RegExp; description: string; isDevelopment: boolean } => {\n // Development/working branches should have prerelease versions\n const devBranchPatterns = /^(working|development|dev|feature\\/|wip\\/)/i;\n\n if (devBranchPatterns.test(branchName)) {\n return {\n pattern: /^\\d+\\.\\d+\\.\\d+-[a-zA-Z0-9.-]+$/,\n description: 'X.Y.Z-<tag> (e.g., 1.2.3-dev.0)',\n isDevelopment: true\n };\n }\n\n // Main/master/production branches should have release versions\n const releaseBranchPatterns = /^(main|master|production|release\\/)/i;\n\n if (releaseBranchPatterns.test(branchName)) {\n return {\n pattern: /^\\d+\\.\\d+\\.\\d+$/,\n description: 'X.Y.Z (e.g., 1.2.3)',\n isDevelopment: false\n };\n }\n\n // For other branches, allow both but prefer release versions\n return {\n pattern: /^\\d+\\.\\d+\\.\\d+(-[a-zA-Z0-9.-]+)?$/,\n description: 'X.Y.Z or X.Y.Z-<tag>',\n isDevelopment: false\n };\n};\n\n/**\n * Validate version against branch expectations\n */\nexport const validateVersionForBranch = (version: string, branchName: string): {\n valid: boolean;\n issue?: string;\n fix?: string;\n} => {\n const expected = getExpectedVersionPattern(branchName);\n\n if (!expected.pattern.test(version)) {\n return {\n valid: false,\n issue: `Invalid version format for branch '${branchName}'`,\n fix: `Version should match ${expected.description}`\n };\n }\n\n const isDevVersion = isDevelopmentVersion(version);\n\n // Development branches should have development versions\n if (expected.isDevelopment && !isDevVersion) {\n return {\n valid: false,\n issue: `Release version on development branch '${branchName}'`,\n fix: 'Run kodrdriv development to update to development version'\n };\n }\n\n // Release branches should NOT have development versions\n if (!expected.isDevelopment && branchName.match(/^(main|master|production|release\\/)/) && isDevVersion) {\n return {\n valid: false,\n issue: `Development version on release branch '${branchName}'`,\n fix: 'Do not commit development versions to release branches'\n };\n }\n\n return { valid: true };\n};\n\n// Re-export shared utilities for backwards compatibility\nexport { deepMerge, stringifyJSON, incrementPatchVersion, incrementMinorVersion, incrementMajorVersion, validateVersionString, calculateTargetVersion, incrementPrereleaseVersion, convertToReleaseVersion };\n"],"names":["getVersionFromBranch","branchName","runSecure","validateGitRef","safeJsonParse","validatePackageJson","Error","stdout","suppressErrorLogging","packageJson","validated","version","calculateBranchDependentVersion","currentVersion","currentBranch","branchesConfig","targetBranch","getLogger","logger","KODRDRIV_DEFAULTS","defaultConfig","branches","sourceConfig","finalTargetBranch","targetConfig","info","defaultVersion","incrementPatchVersion","debug","calculateVersionFromTargetConfig","defaultTargetBranch","versionConfig","type","releaseVersion","convertToReleaseVersion","tag","increment","targetBranchVersion","newVersion","incrementPrereleaseVersion","baseVersion","findDevelopmentBranch","branchConfig","Object","entries","developmentBranch","checkIfTagExists","tagName","trim","confirmVersionInteractively","proposedVersion","targetVersionInput","getUserChoice","getUserTextInput","requireTTY","choices","key","label","choice","customVersion","validateVersionString","cleanCustomVersion","startsWith","slice","getOutputPath","outputDirectory","filename","path","join","getTimestampedFilename","baseName","extension","now","Date","yy","getFullYear","toString","mm","getMonth","padStart","dd","getDate","hh","getHours","min","getMinutes","timestamp","getTimestampedRequestFilename","getTimestampedResponseFilename","getTimestampedCommitFilename","getTimestampedReleaseNotesFilename","getTimestampedAudioFilename","getTimestampedReviewFilename","getTimestampedReviewNotesFilename","getTimestampedArchivedAudioFilename","originalExtension","getTimestampedArchivedTranscriptFilename","archiveAudio","originalAudioPath","transcriptionText","storage","createStorage","ensureDirectory","extname","archivedAudioFilename","archivedTranscriptFilename","archivedAudioPath","archivedTranscriptPath","isFileReadable","audioBuffer","fs","promises","readFile","writeFile","warn","transcriptContent","toISOString","audioPath","transcriptPath","error","message","getNpmPublishedVersion","packageName","verbose","replace","getTagInfo","tagList","exists","commit","versionMatch","match","undefined","isDevelopmentVersion","includes","getExpectedVersionPattern","devBranchPatterns","test","pattern","description","isDevelopment","releaseBranchPatterns","validateVersionForBranch","expected","valid","issue","fix","isDevVersion"],"mappings":"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"}
@@ -1,8 +1,8 @@
1
1
  /**
2
- * Runtime validation utilities for safe type handling
2
+ * Kodrdriv-specific validation utilities
3
3
  *
4
- * Note: Generic validation functions (safeJsonParse, validateString, etc.)
5
- * have been moved to @eldrforge/git-tools
4
+ * Note: Generic validation functions (validateString, validateNumber, etc.)
5
+ * are in @eldrforge/shared
6
6
  */ /**
7
7
  * Validates and safely casts data to ReleaseSummary type
8
8
  */ const validateReleaseSummary = (data)=>{
@@ -1 +1 @@
1
- {"version":3,"file":"validation.js","sources":["../../src/util/validation.ts"],"sourcesContent":["/**\n * Runtime validation utilities for safe type handling\n *\n * Note: Generic validation functions (safeJsonParse, validateString, etc.)\n * have been moved to @eldrforge/git-tools\n */\n\nexport interface ReleaseSummary {\n title: string;\n body: string;\n}\n\nexport interface TranscriptionResult {\n text: string;\n [key: string]: any;\n}\n\n/**\n * Validates and safely casts data to ReleaseSummary type\n */\nexport const validateReleaseSummary = (data: any): ReleaseSummary => {\n if (!data || typeof data !== 'object') {\n throw new Error('Invalid release summary: not an object');\n }\n if (typeof data.title !== 'string') {\n throw new Error('Invalid release summary: title must be a string');\n }\n if (typeof data.body !== 'string') {\n throw new Error('Invalid release summary: body must be a string');\n }\n return data as ReleaseSummary;\n};\n\n/**\n * Validates transcription result has required text property\n */\nexport const validateTranscriptionResult = (data: any): TranscriptionResult => {\n if (!data || typeof data !== 'object') {\n throw new Error('Invalid transcription result: not an object');\n }\n if (typeof data.text !== 'string') {\n throw new Error('Invalid transcription result: text property must be a string');\n }\n return data as TranscriptionResult;\n};\n\n/**\n * Sanitizes and truncates direction parameter for safe use in prompts\n * @param direction The direction string to sanitize\n * @param maxLength Maximum length before truncation (default: 2000)\n * @returns Sanitized and truncated direction string\n */\nexport const sanitizeDirection = (direction: string | undefined, maxLength: number = 2000): string | undefined => {\n if (!direction) {\n return undefined;\n }\n\n // Remove newlines and excessive whitespace to prevent template breakage\n const sanitized = direction\n .replace(/\\r?\\n/g, ' ') // Replace newlines with spaces\n .replace(/\\s+/g, ' ') // Replace multiple whitespace with single space\n .trim();\n\n // Truncate if too long\n if (sanitized.length > maxLength) {\n const truncated = sanitized.substring(0, maxLength - 3) + '...';\n // Log truncation for debugging\n // eslint-disable-next-line no-console\n console.warn(`Direction truncated from ${sanitized.length} to ${truncated.length} characters`);\n return truncated;\n }\n\n return sanitized;\n};\n"],"names":["validateReleaseSummary","data","Error","title","body","sanitizeDirection","direction","maxLength","undefined","sanitized","replace","trim","length","truncated","substring","console","warn"],"mappings":"AAAA;;;;;;;IAoBO,MAAMA,sBAAAA,GAAyB,CAACC,IAAAA,GAAAA;AACnC,IAAA,IAAI,CAACA,IAAAA,IAAQ,OAAOA,IAAAA,KAAS,QAAA,EAAU;AACnC,QAAA,MAAM,IAAIC,KAAAA,CAAM,wCAAA,CAAA;AACpB,IAAA;AACA,IAAA,IAAI,OAAOD,IAAAA,CAAKE,KAAK,KAAK,QAAA,EAAU;AAChC,QAAA,MAAM,IAAID,KAAAA,CAAM,iDAAA,CAAA;AACpB,IAAA;AACA,IAAA,IAAI,OAAOD,IAAAA,CAAKG,IAAI,KAAK,QAAA,EAAU;AAC/B,QAAA,MAAM,IAAIF,KAAAA,CAAM,gDAAA,CAAA;AACpB,IAAA;IACA,OAAOD,IAAAA;AACX;AAeA;;;;;AAKC,IACM,MAAMI,iBAAAA,GAAoB,CAACC,SAAAA,EAA+BC,YAAoB,IAAI,GAAA;AACrF,IAAA,IAAI,CAACD,SAAAA,EAAW;QACZ,OAAOE,SAAAA;AACX,IAAA;;AAGA,IAAA,MAAMC,YAAYH,SAAAA,CACbI,OAAO,CAAC,QAAA,EAAU;KAClBA,OAAO,CAAC,MAAA,EAAQ,GAAA,CAAA;KAChBC,IAAI,EAAA;;IAGT,IAAIF,SAAAA,CAAUG,MAAM,GAAGL,SAAAA,EAAW;AAC9B,QAAA,MAAMM,YAAYJ,SAAAA,CAAUK,SAAS,CAAC,CAAA,EAAGP,YAAY,CAAA,CAAA,GAAK,KAAA;;;AAG1DQ,QAAAA,OAAAA,CAAQC,IAAI,CAAC,CAAC,yBAAyB,EAAEP,SAAAA,CAAUG,MAAM,CAAC,IAAI,EAAEC,SAAAA,CAAUD,MAAM,CAAC,WAAW,CAAC,CAAA;QAC7F,OAAOC,SAAAA;AACX,IAAA;IAEA,OAAOJ,SAAAA;AACX;;;;"}
1
+ {"version":3,"file":"validation.js","sources":["../../src/util/validation.ts"],"sourcesContent":["/**\n * Kodrdriv-specific validation utilities\n *\n * Note: Generic validation functions (validateString, validateNumber, etc.)\n * are in @eldrforge/shared\n */\n\nexport interface ReleaseSummary {\n title: string;\n body: string;\n}\n\nexport interface TranscriptionResult {\n text: string;\n [key: string]: any;\n}\n\n/**\n * Validates and safely casts data to ReleaseSummary type\n */\nexport const validateReleaseSummary = (data: any): ReleaseSummary => {\n if (!data || typeof data !== 'object') {\n throw new Error('Invalid release summary: not an object');\n }\n if (typeof data.title !== 'string') {\n throw new Error('Invalid release summary: title must be a string');\n }\n if (typeof data.body !== 'string') {\n throw new Error('Invalid release summary: body must be a string');\n }\n return data as ReleaseSummary;\n};\n\n/**\n * Validates transcription result has required text property\n */\nexport const validateTranscriptionResult = (data: any): TranscriptionResult => {\n if (!data || typeof data !== 'object') {\n throw new Error('Invalid transcription result: not an object');\n }\n if (typeof data.text !== 'string') {\n throw new Error('Invalid transcription result: text property must be a string');\n }\n return data as TranscriptionResult;\n};\n\n/**\n * Sanitizes and truncates direction parameter for safe use in prompts\n * @param direction The direction string to sanitize\n * @param maxLength Maximum length before truncation (default: 2000)\n * @returns Sanitized and truncated direction string\n */\nexport const sanitizeDirection = (direction: string | undefined, maxLength: number = 2000): string | undefined => {\n if (!direction) {\n return undefined;\n }\n\n // Remove newlines and excessive whitespace to prevent template breakage\n const sanitized = direction\n .replace(/\\r?\\n/g, ' ') // Replace newlines with spaces\n .replace(/\\s+/g, ' ') // Replace multiple whitespace with single space\n .trim();\n\n // Truncate if too long\n if (sanitized.length > maxLength) {\n const truncated = sanitized.substring(0, maxLength - 3) + '...';\n // Log truncation for debugging\n // eslint-disable-next-line no-console\n console.warn(`Direction truncated from ${sanitized.length} to ${truncated.length} characters`);\n return truncated;\n }\n\n return sanitized;\n};\n\n"],"names":["validateReleaseSummary","data","Error","title","body","sanitizeDirection","direction","maxLength","undefined","sanitized","replace","trim","length","truncated","substring","console","warn"],"mappings":"AAAA;;;;;;;IAoBO,MAAMA,sBAAAA,GAAyB,CAACC,IAAAA,GAAAA;AACnC,IAAA,IAAI,CAACA,IAAAA,IAAQ,OAAOA,IAAAA,KAAS,QAAA,EAAU;AACnC,QAAA,MAAM,IAAIC,KAAAA,CAAM,wCAAA,CAAA;AACpB,IAAA;AACA,IAAA,IAAI,OAAOD,IAAAA,CAAKE,KAAK,KAAK,QAAA,EAAU;AAChC,QAAA,MAAM,IAAID,KAAAA,CAAM,iDAAA,CAAA;AACpB,IAAA;AACA,IAAA,IAAI,OAAOD,IAAAA,CAAKG,IAAI,KAAK,QAAA,EAAU;AAC/B,QAAA,MAAM,IAAIF,KAAAA,CAAM,gDAAA,CAAA;AACpB,IAAA;IACA,OAAOD,IAAAA;AACX;AAeA;;;;;AAKC,IACM,MAAMI,iBAAAA,GAAoB,CAACC,SAAAA,EAA+BC,YAAoB,IAAI,GAAA;AACrF,IAAA,IAAI,CAACD,SAAAA,EAAW;QACZ,OAAOE,SAAAA;AACX,IAAA;;AAGA,IAAA,MAAMC,YAAYH,SAAAA,CACbI,OAAO,CAAC,QAAA,EAAU;KAClBA,OAAO,CAAC,MAAA,EAAQ,GAAA,CAAA;KAChBC,IAAI,EAAA;;IAGT,IAAIF,SAAAA,CAAUG,MAAM,GAAGL,SAAAA,EAAW;AAC9B,QAAA,MAAMM,YAAYJ,SAAAA,CAAUK,SAAS,CAAC,CAAA,EAAGP,YAAY,CAAA,CAAA,GAAK,KAAA;;;AAG1DQ,QAAAA,OAAAA,CAAQC,IAAI,CAAC,CAAC,yBAAyB,EAAEP,SAAAA,CAAUG,MAAM,CAAC,IAAI,EAAEC,SAAAA,CAAUD,MAAM,CAAC,WAAW,CAAC,CAAA;QAC7F,OAAOC,SAAAA;AACX,IAAA;IAEA,OAAOJ,SAAAA;AACX;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@eldrforge/kodrdriv",
3
- "version": "1.2.123",
3
+ "version": "1.2.124",
4
4
  "description": "Create Intelligent Release Notes or Change Logs from Git",
5
5
  "main": "dist/main.js",
6
6
  "type": "module",
@@ -38,7 +38,7 @@
38
38
  "author": "Calen Varek <calenvarek@gmail.com>",
39
39
  "license": "Apache-2.0",
40
40
  "dependencies": {
41
- "@eldrforge/ai-service": "^0.1.8",
41
+ "@eldrforge/ai-service": "^0.1.9",
42
42
  "@eldrforge/git-tools": "^0.1.11",
43
43
  "@eldrforge/github-tools": "^0.1.14",
44
44
  "@eldrforge/shared": "^0.1.1",