@eldrforge/kodrdriv 0.0.14 → 0.0.17
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/README.md +1 -9
- package/dist/arguments.js +306 -55
- package/dist/arguments.js.map +1 -1
- package/dist/audio/devices.js +284 -0
- package/dist/audio/devices.js.map +1 -0
- package/dist/audio/index.js +31 -0
- package/dist/audio/index.js.map +1 -0
- package/dist/audio/processor.js +766 -0
- package/dist/audio/processor.js.map +1 -0
- package/dist/audio/types.js +16 -0
- package/dist/audio/types.js.map +1 -0
- package/dist/audio/validation.js +35 -0
- package/dist/audio/validation.js.map +1 -0
- package/dist/commands/audio-commit.js +64 -248
- package/dist/commands/audio-commit.js.map +1 -1
- package/dist/commands/audio-review.js +90 -701
- package/dist/commands/audio-review.js.map +1 -1
- package/dist/commands/commit.js +18 -18
- package/dist/commands/commit.js.map +1 -1
- package/dist/commands/release.js +14 -15
- package/dist/commands/release.js.map +1 -1
- package/dist/commands/review.js +152 -0
- package/dist/commands/review.js.map +1 -0
- package/dist/commands/select-audio.js +265 -0
- package/dist/commands/select-audio.js.map +1 -0
- package/dist/constants.js +86 -68
- package/dist/constants.js.map +1 -1
- package/dist/content/diff.js +155 -1
- package/dist/content/diff.js.map +1 -1
- package/dist/content/issues.js +256 -0
- package/dist/content/issues.js.map +1 -0
- package/dist/content/releaseNotes.js +90 -0
- package/dist/content/releaseNotes.js.map +1 -0
- package/dist/main.js +9 -2
- package/dist/main.js.map +1 -1
- package/dist/prompt/instructions/commit.md +18 -15
- package/dist/prompt/instructions/release.md +6 -5
- package/dist/prompt/instructions/{audio-review.md → review.md} +24 -18
- package/dist/prompt/prompts.js +87 -19
- package/dist/prompt/prompts.js.map +1 -1
- package/dist/types.js +27 -3
- package/dist/types.js.map +1 -1
- package/dist/util/general.js +7 -1
- package/dist/util/general.js.map +1 -1
- package/dist/util/openai.js +34 -3
- package/dist/util/openai.js.map +1 -1
- package/dist/util/stdin.js +61 -0
- package/dist/util/stdin.js.map +1 -0
- package/package.json +6 -6
- package/.kodrdriv/config.yaml +0 -20
- package/.kodrdriv/context/content.md +0 -7
- package/RELEASE_NOTES.md +0 -14
- package/docs/index.html +0 -17
- package/docs/package.json +0 -36
- package/docs/pnpm-lock.yaml +0 -3441
- package/docs/public/README.md +0 -132
- package/docs/public/advanced-usage.md +0 -188
- package/docs/public/code-icon.svg +0 -4
- package/docs/public/commands.md +0 -116
- package/docs/public/configuration.md +0 -274
- package/docs/public/examples.md +0 -352
- package/docs/public/kodrdriv-logo.svg +0 -62
- package/docs/src/App.css +0 -387
- package/docs/src/App.tsx +0 -60
- package/docs/src/components/DocumentPage.tsx +0 -56
- package/docs/src/components/ErrorMessage.tsx +0 -15
- package/docs/src/components/LoadingSpinner.tsx +0 -14
- package/docs/src/components/MarkdownRenderer.tsx +0 -56
- package/docs/src/components/Navigation.css +0 -73
- package/docs/src/components/Navigation.tsx +0 -36
- package/docs/src/index.css +0 -61
- package/docs/src/main.tsx +0 -10
- package/docs/src/test/setup.ts +0 -1
- package/docs/src/vite-env.d.ts +0 -10
- package/docs/tsconfig.node.json +0 -13
- package/docs/vite.config.ts +0 -15
- package/docs/vitest.config.ts +0 -15
- package/eslint.config.mjs +0 -83
- package/nodemon.json +0 -14
- package/output/kodrdriv/250701-1442-release-notes.md +0 -3
- package/pnpm-workspace.yaml +0 -5
- package/tsconfig.tsbuildinfo +0 -1
- package/vite.config.ts +0 -90
- package/vitest.config.ts +0 -24
package/dist/prompt/prompts.js
CHANGED
|
@@ -8,7 +8,7 @@ const __filename = fileURLToPath(import.meta.url);
|
|
|
8
8
|
const __dirname = path.dirname(__filename);
|
|
9
9
|
const create = (model, runConfig)=>{
|
|
10
10
|
const logger = getLogger();
|
|
11
|
-
const createCommitPrompt = async (
|
|
11
|
+
const createCommitPrompt = async ({ diffContent }, { logContext, userDirection, context })=>{
|
|
12
12
|
let builder = Builder.create({
|
|
13
13
|
logger,
|
|
14
14
|
basePath: __dirname,
|
|
@@ -17,18 +17,37 @@ const create = (model, runConfig)=>{
|
|
|
17
17
|
});
|
|
18
18
|
builder = await builder.addPersonaPath(DEFAULT_PERSONA_COMMITTER_FILE);
|
|
19
19
|
builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_COMMIT_FILE);
|
|
20
|
-
if (
|
|
21
|
-
builder = await builder.addContent(
|
|
20
|
+
if (userDirection) {
|
|
21
|
+
builder = await builder.addContent(userDirection, {
|
|
22
|
+
title: 'User Direction',
|
|
23
|
+
weight: 1.0
|
|
24
|
+
});
|
|
22
25
|
}
|
|
23
|
-
builder = await builder.addContent(
|
|
24
|
-
|
|
26
|
+
builder = await builder.addContent(diffContent, {
|
|
27
|
+
title: 'Diff',
|
|
28
|
+
weight: 0.5
|
|
29
|
+
});
|
|
25
30
|
if (runConfig.contextDirectories) {
|
|
26
|
-
builder = await builder.loadContext(runConfig.contextDirectories
|
|
31
|
+
builder = await builder.loadContext(runConfig.contextDirectories, {
|
|
32
|
+
weight: 0.5
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
if (context) {
|
|
36
|
+
builder = await builder.addContext(context, {
|
|
37
|
+
title: 'User Context',
|
|
38
|
+
weight: 1.0
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
if (logContext) {
|
|
42
|
+
builder = await builder.addContext(logContext, {
|
|
43
|
+
title: 'Log Context',
|
|
44
|
+
weight: 0.5
|
|
45
|
+
});
|
|
27
46
|
}
|
|
28
47
|
const prompt = await builder.build();
|
|
29
48
|
return prompt;
|
|
30
49
|
};
|
|
31
|
-
const createReleasePrompt = async (
|
|
50
|
+
const createReleasePrompt = async ({ logContent, diffContent }, { releaseFocus, context })=>{
|
|
32
51
|
let builder = Builder.create({
|
|
33
52
|
logger,
|
|
34
53
|
basePath: __dirname,
|
|
@@ -37,18 +56,35 @@ const create = (model, runConfig)=>{
|
|
|
37
56
|
});
|
|
38
57
|
builder = await builder.addPersonaPath(DEFAULT_PERSONA_RELEASER_FILE);
|
|
39
58
|
builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_RELEASE_FILE);
|
|
40
|
-
if (
|
|
41
|
-
builder = await builder.addContent(
|
|
59
|
+
if (releaseFocus) {
|
|
60
|
+
builder = await builder.addContent(releaseFocus, {
|
|
61
|
+
title: 'Release Focus',
|
|
62
|
+
weight: 1.0
|
|
63
|
+
});
|
|
42
64
|
}
|
|
43
|
-
builder = await builder.addContent(
|
|
44
|
-
|
|
65
|
+
builder = await builder.addContent(logContent, {
|
|
66
|
+
title: 'Log',
|
|
67
|
+
weight: 0.5
|
|
68
|
+
});
|
|
69
|
+
builder = await builder.addContent(diffContent, {
|
|
70
|
+
title: 'Diff',
|
|
71
|
+
weight: 0.5
|
|
72
|
+
});
|
|
45
73
|
if (runConfig.contextDirectories) {
|
|
46
|
-
builder = await builder.loadContext(runConfig.contextDirectories
|
|
74
|
+
builder = await builder.loadContext(runConfig.contextDirectories, {
|
|
75
|
+
weight: 0.5
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
if (context) {
|
|
79
|
+
builder = await builder.addContext(context, {
|
|
80
|
+
title: 'User Context',
|
|
81
|
+
weight: 1.0
|
|
82
|
+
});
|
|
47
83
|
}
|
|
48
84
|
const prompt = await builder.build();
|
|
49
85
|
return prompt;
|
|
50
86
|
};
|
|
51
|
-
const
|
|
87
|
+
const createReviewPrompt = async ({ notes }, { logContext, diffContext, releaseNotesContext, issuesContext, context })=>{
|
|
52
88
|
let builder = Builder.create({
|
|
53
89
|
logger,
|
|
54
90
|
basePath: __dirname,
|
|
@@ -57,12 +93,44 @@ const create = (model, runConfig)=>{
|
|
|
57
93
|
});
|
|
58
94
|
builder = await builder.addPersonaPath(DEFAULT_PERSONA_REVIEWER_FILE);
|
|
59
95
|
builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_AUDIO_REVIEW_FILE);
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
96
|
+
builder = await builder.addContent(notes, {
|
|
97
|
+
title: 'Review Notes',
|
|
98
|
+
weight: 1.0
|
|
99
|
+
});
|
|
64
100
|
if (runConfig.contextDirectories) {
|
|
65
|
-
builder = await builder.loadContext(runConfig.contextDirectories
|
|
101
|
+
builder = await builder.loadContext(runConfig.contextDirectories, {
|
|
102
|
+
weight: 0.5
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
if (logContext) {
|
|
106
|
+
builder = await builder.addContext(logContext, {
|
|
107
|
+
title: 'Log Context',
|
|
108
|
+
weight: 0.5
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
if (diffContext) {
|
|
112
|
+
builder = await builder.addContext(diffContext, {
|
|
113
|
+
title: 'Diff Context',
|
|
114
|
+
weight: 0.5
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
if (releaseNotesContext) {
|
|
118
|
+
builder = await builder.addContext(releaseNotesContext, {
|
|
119
|
+
title: 'Release Notes Context',
|
|
120
|
+
weight: 0.5
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
if (issuesContext) {
|
|
124
|
+
builder = await builder.addContext(issuesContext, {
|
|
125
|
+
title: 'Issues Context',
|
|
126
|
+
weight: 0.5
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
if (context) {
|
|
130
|
+
builder = await builder.addContext(context, {
|
|
131
|
+
title: 'User Context',
|
|
132
|
+
weight: 1.0
|
|
133
|
+
});
|
|
66
134
|
}
|
|
67
135
|
const prompt = await builder.build();
|
|
68
136
|
return prompt;
|
|
@@ -83,7 +151,7 @@ const create = (model, runConfig)=>{
|
|
|
83
151
|
return {
|
|
84
152
|
createCommitPrompt,
|
|
85
153
|
createReleasePrompt,
|
|
86
|
-
|
|
154
|
+
createReviewPrompt,
|
|
87
155
|
format
|
|
88
156
|
};
|
|
89
157
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"prompts.js","sources":["../../src/prompt/prompts.ts"],"sourcesContent":["import { Builder, Formatter, Model, Prompt, Request } from '@riotprompt/riotprompt';\nimport path from 'path';\nimport { fileURLToPath } from 'url';\nimport { DEFAULT_INSTRUCTIONS_COMMIT_FILE, DEFAULT_INSTRUCTIONS_RELEASE_FILE, DEFAULT_INSTRUCTIONS_AUDIO_REVIEW_FILE, DEFAULT_PERSONA_COMMITTER_FILE, DEFAULT_PERSONA_RELEASER_FILE, DEFAULT_PERSONA_REVIEWER_FILE } from '../constants';\nimport { getLogger } from '../logging';\nimport { Config as RunConfig } from '../types';\n\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = path.dirname(__filename);\n\nexport interface Factory {\n createCommitPrompt: (content: string, logContent: string, context?: string) => Promise<Prompt>;\n createReleasePrompt: (content: string, diffContent: string, context?: string) => Promise<Prompt>;\n createAudioReviewPrompt: (transcription: string, context?: string) => Promise<Prompt>;\n format: (prompt: Prompt) => Request;\n}\n\nexport const create = (model: Model, runConfig: RunConfig): Factory => {\n\n const logger = getLogger();\n\n const createCommitPrompt = async (content: string, logContent: string, context?: string): Promise<Prompt> => {\n let builder: Builder.Instance = Builder.create({ logger, basePath: __dirname, overridePath: runConfig?.configDirectory, overrides: runConfig?.overrides || false });\n builder = await builder.addPersonaPath(DEFAULT_PERSONA_COMMITTER_FILE);\n builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_COMMIT_FILE);\n if (context) {\n builder = await builder.addContent(`\\n\\n[User Context]\\n${context}`);\n }\n builder = await builder.addContent(`\\n\\n[Diff]\\n${content}`);\n builder = await builder.addContent(`\\n\\n[Log]\\n${logContent}`);\n\n if (runConfig.contextDirectories) {\n builder = await builder.loadContext(runConfig.contextDirectories);\n }\n\n const prompt = await builder.build();\n return prompt;\n };\n\n const createReleasePrompt = async (content: string, diffContent: string, context?: string): Promise<Prompt> => {\n let builder: Builder.Instance = Builder.create({ logger, basePath: __dirname, overridePath: runConfig?.configDirectory, overrides: runConfig?.overrides || false });\n builder = await builder.addPersonaPath(DEFAULT_PERSONA_RELEASER_FILE);\n builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_RELEASE_FILE);\n if (context) {\n builder = await builder.addContent(`\\n\\n[User Context]\\n${context}`);\n }\n builder = await builder.addContent(`\\n\\n[Log]\\n${content}`);\n builder = await builder.addContent(`\\n\\n[Diff]\\n${diffContent}`);\n if (runConfig.contextDirectories) {\n builder = await builder.loadContext(runConfig.contextDirectories);\n }\n\n const prompt = await builder.build();\n return prompt;\n }\n\n const createAudioReviewPrompt = async (transcription: string, context?: string): Promise<Prompt> => {\n let builder: Builder.Instance = Builder.create({ logger, basePath: __dirname, overridePath: runConfig?.configDirectory, overrides: runConfig?.overrides || false });\n builder = await builder.addPersonaPath(DEFAULT_PERSONA_REVIEWER_FILE);\n builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_AUDIO_REVIEW_FILE);\n if (context) {\n builder = await builder.addContent(`\\n\\n[Additional Context]\\n${context}`);\n }\n builder = await builder.addContent(`\\n\\n[Audio Transcription]\\n${transcription}`);\n\n if (runConfig.contextDirectories) {\n builder = await builder.loadContext(runConfig.contextDirectories);\n }\n\n const prompt = await builder.build();\n return prompt;\n };\n\n const format = (prompt: Prompt): Request => {\n const formatter = Formatter.create();\n const request = formatter.formatPrompt(model, prompt);\n\n // Debug log the final formatted prompt\n if (runConfig.debug) {\n logger.debug('Final formatted prompt for AI:');\n logger.debug('Messages count: %d', request.messages.length);\n request.messages.forEach((message, index) => {\n logger.debug('Message %d (%s): %s',\n index + 1,\n (message as any).role || 'unknown',\n typeof (message as any).content === 'string'\n ? (message as any).content.substring(0, 500) + (((message as any).content.length > 500) ? '...' : '')\n : JSON.stringify((message as any).content).substring(0, 500)\n );\n });\n }\n\n return request;\n };\n\n return {\n createCommitPrompt,\n createReleasePrompt,\n createAudioReviewPrompt,\n format,\n };\n}\n\n"],"names":["__filename","fileURLToPath","url","__dirname","path","dirname","create","model","runConfig","logger","getLogger","createCommitPrompt","content","logContent","context","builder","Builder","basePath","overridePath","configDirectory","overrides","addPersonaPath","DEFAULT_PERSONA_COMMITTER_FILE","addInstructionPath","DEFAULT_INSTRUCTIONS_COMMIT_FILE","addContent","contextDirectories","loadContext","prompt","build","createReleasePrompt","diffContent","DEFAULT_PERSONA_RELEASER_FILE","DEFAULT_INSTRUCTIONS_RELEASE_FILE","createAudioReviewPrompt","transcription","DEFAULT_PERSONA_REVIEWER_FILE","DEFAULT_INSTRUCTIONS_AUDIO_REVIEW_FILE","format","formatter","Formatter","request","formatPrompt","debug","messages","length","forEach","message","index","role","substring","JSON","stringify"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"prompts.js","sources":["../../src/prompt/prompts.ts"],"sourcesContent":["import { Builder, Formatter, Model, Prompt, Request } from '@riotprompt/riotprompt';\nimport path from 'path';\nimport { fileURLToPath } from 'url';\nimport { DEFAULT_INSTRUCTIONS_COMMIT_FILE, DEFAULT_INSTRUCTIONS_RELEASE_FILE, DEFAULT_INSTRUCTIONS_AUDIO_REVIEW_FILE, DEFAULT_PERSONA_COMMITTER_FILE, DEFAULT_PERSONA_RELEASER_FILE, DEFAULT_PERSONA_REVIEWER_FILE } from '../constants';\nimport { getLogger } from '../logging';\nimport { Config as RunConfig } from '../types';\n\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = path.dirname(__filename);\n\nexport interface Factory {\n createCommitPrompt: ({ diffContent }: { diffContent: string }, { logContext, userDirection, context }: { logContext?: string, userDirection?: string, context?: string }) => Promise<Prompt>;\n createReleasePrompt: ({ logContent, diffContent }: { logContent: string, diffContent: string }, { releaseFocus, context }: { releaseFocus?: string, context?: string }) => Promise<Prompt>;\n createReviewPrompt: ({ notes }: { notes: string }, { logContext, diffContext, releaseNotesContext, issuesContext, context }: { logContext?: string, diffContext?: string, releaseNotesContext?: string, issuesContext?: string, context?: string }) => Promise<Prompt>;\n format: (prompt: Prompt) => Request;\n}\n\nexport const create = (model: Model, runConfig: RunConfig): Factory => {\n\n const logger = getLogger();\n\n const createCommitPrompt = async ({ diffContent }: { diffContent: string }, { logContext, userDirection, context }: { logContext?: string, userDirection?: string, context?: string }): Promise<Prompt> => {\n let builder: Builder.Instance = Builder.create({ logger, basePath: __dirname, overridePath: runConfig?.configDirectory, overrides: runConfig?.overrides || false });\n builder = await builder.addPersonaPath(DEFAULT_PERSONA_COMMITTER_FILE);\n builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_COMMIT_FILE);\n if (userDirection) {\n builder = await builder.addContent(userDirection, { title: 'User Direction', weight: 1.0 });\n }\n builder = await builder.addContent(diffContent, { title: 'Diff', weight: 0.5 });\n\n if (runConfig.contextDirectories) {\n builder = await builder.loadContext(runConfig.contextDirectories, { weight: 0.5 });\n }\n if (context) {\n builder = await builder.addContext(context, { title: 'User Context', weight: 1.0 });\n }\n if (logContext) {\n builder = await builder.addContext(logContext, { title: 'Log Context', weight: 0.5 });\n }\n\n const prompt = await builder.build();\n return prompt;\n };\n\n const createReleasePrompt = async ({ logContent, diffContent }: { logContent: string, diffContent: string }, { releaseFocus, context }: { releaseFocus?: string, context?: string }): Promise<Prompt> => {\n let builder: Builder.Instance = Builder.create({ logger, basePath: __dirname, overridePath: runConfig?.configDirectory, overrides: runConfig?.overrides || false });\n builder = await builder.addPersonaPath(DEFAULT_PERSONA_RELEASER_FILE);\n builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_RELEASE_FILE);\n if (releaseFocus) {\n builder = await builder.addContent(releaseFocus, { title: 'Release Focus', weight: 1.0 });\n }\n builder = await builder.addContent(logContent, { title: 'Log', weight: 0.5 });\n builder = await builder.addContent(diffContent, { title: 'Diff', weight: 0.5 });\n if (runConfig.contextDirectories) {\n builder = await builder.loadContext(runConfig.contextDirectories, { weight: 0.5 });\n }\n if (context) {\n builder = await builder.addContext(context, { title: 'User Context', weight: 1.0 });\n }\n\n const prompt = await builder.build();\n return prompt;\n }\n\n const createReviewPrompt = async ({ notes }: { notes: string }, { logContext, diffContext, releaseNotesContext, issuesContext, context }: { logContext?: string, diffContext?: string, releaseNotesContext?: string, issuesContext?: string, context?: string }): Promise<Prompt> => {\n let builder: Builder.Instance = Builder.create({ logger, basePath: __dirname, overridePath: runConfig?.configDirectory, overrides: runConfig?.overrides || false });\n builder = await builder.addPersonaPath(DEFAULT_PERSONA_REVIEWER_FILE);\n builder = await builder.addInstructionPath(DEFAULT_INSTRUCTIONS_AUDIO_REVIEW_FILE);\n\n builder = await builder.addContent(notes, { title: 'Review Notes', weight: 1.0 });\n\n if (runConfig.contextDirectories) {\n builder = await builder.loadContext(runConfig.contextDirectories, { weight: 0.5 });\n }\n if (logContext) {\n builder = await builder.addContext(logContext, { title: 'Log Context', weight: 0.5 });\n }\n if (diffContext) {\n builder = await builder.addContext(diffContext, { title: 'Diff Context', weight: 0.5 });\n }\n if (releaseNotesContext) {\n builder = await builder.addContext(releaseNotesContext, { title: 'Release Notes Context', weight: 0.5 });\n }\n if (issuesContext) {\n builder = await builder.addContext(issuesContext, { title: 'Issues Context', weight: 0.5 });\n }\n if (context) {\n builder = await builder.addContext(context, { title: 'User Context', weight: 1.0 });\n }\n\n const prompt = await builder.build();\n return prompt;\n };\n\n const format = (prompt: Prompt): Request => {\n const formatter = Formatter.create();\n const request = formatter.formatPrompt(model, prompt);\n\n // Debug log the final formatted prompt\n if (runConfig.debug) {\n logger.debug('Final formatted prompt for AI:');\n logger.debug('Messages count: %d', request.messages.length);\n request.messages.forEach((message, index) => {\n logger.debug('Message %d (%s): %s',\n index + 1,\n (message as any).role || 'unknown',\n typeof (message as any).content === 'string'\n ? (message as any).content.substring(0, 500) + (((message as any).content.length > 500) ? '...' : '')\n : JSON.stringify((message as any).content).substring(0, 500)\n );\n });\n }\n\n return request;\n };\n\n return {\n createCommitPrompt,\n createReleasePrompt,\n createReviewPrompt,\n format,\n };\n}\n\n"],"names":["__filename","fileURLToPath","url","__dirname","path","dirname","create","model","runConfig","logger","getLogger","createCommitPrompt","diffContent","logContext","userDirection","context","builder","Builder","basePath","overridePath","configDirectory","overrides","addPersonaPath","DEFAULT_PERSONA_COMMITTER_FILE","addInstructionPath","DEFAULT_INSTRUCTIONS_COMMIT_FILE","addContent","title","weight","contextDirectories","loadContext","addContext","prompt","build","createReleasePrompt","logContent","releaseFocus","DEFAULT_PERSONA_RELEASER_FILE","DEFAULT_INSTRUCTIONS_RELEASE_FILE","createReviewPrompt","notes","diffContext","releaseNotesContext","issuesContext","DEFAULT_PERSONA_REVIEWER_FILE","DEFAULT_INSTRUCTIONS_AUDIO_REVIEW_FILE","format","formatter","Formatter","request","formatPrompt","debug","messages","length","forEach","message","index","role","content","substring","JSON","stringify"],"mappings":"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"}
|
package/dist/types.js
CHANGED
|
@@ -5,16 +5,23 @@ const ConfigSchema = z.object({
|
|
|
5
5
|
verbose: z.boolean().optional(),
|
|
6
6
|
debug: z.boolean().optional(),
|
|
7
7
|
overrides: z.boolean().optional(),
|
|
8
|
-
instructions: z.string().optional(),
|
|
9
8
|
model: z.string().optional(),
|
|
10
9
|
contextDirectories: z.array(z.string()).optional(),
|
|
11
10
|
outputDirectory: z.string().optional(),
|
|
11
|
+
preferencesDirectory: z.string().optional(),
|
|
12
12
|
commit: z.object({
|
|
13
13
|
add: z.boolean().optional(),
|
|
14
14
|
cached: z.boolean().optional(),
|
|
15
15
|
sendit: z.boolean().optional(),
|
|
16
16
|
messageLimit: z.number().optional(),
|
|
17
|
-
context: z.string().optional()
|
|
17
|
+
context: z.string().optional(),
|
|
18
|
+
direction: z.string().optional()
|
|
19
|
+
}).optional(),
|
|
20
|
+
audioCommit: z.object({
|
|
21
|
+
maxRecordingTime: z.number().optional(),
|
|
22
|
+
audioDevice: z.string().optional(),
|
|
23
|
+
file: z.string().optional(),
|
|
24
|
+
keepTemp: z.boolean().optional()
|
|
18
25
|
}).optional(),
|
|
19
26
|
release: z.object({
|
|
20
27
|
from: z.string().optional(),
|
|
@@ -22,6 +29,19 @@ const ConfigSchema = z.object({
|
|
|
22
29
|
messageLimit: z.number().optional(),
|
|
23
30
|
context: z.string().optional()
|
|
24
31
|
}).optional(),
|
|
32
|
+
review: z.object({
|
|
33
|
+
includeCommitHistory: z.boolean().optional(),
|
|
34
|
+
includeRecentDiffs: z.boolean().optional(),
|
|
35
|
+
includeReleaseNotes: z.boolean().optional(),
|
|
36
|
+
includeGithubIssues: z.boolean().optional(),
|
|
37
|
+
commitHistoryLimit: z.number().optional(),
|
|
38
|
+
diffHistoryLimit: z.number().optional(),
|
|
39
|
+
releaseNotesLimit: z.number().optional(),
|
|
40
|
+
githubIssuesLimit: z.number().optional(),
|
|
41
|
+
context: z.string().optional(),
|
|
42
|
+
sendit: z.boolean().optional(),
|
|
43
|
+
note: z.string().optional()
|
|
44
|
+
}).optional(),
|
|
25
45
|
audioReview: z.object({
|
|
26
46
|
includeCommitHistory: z.boolean().optional(),
|
|
27
47
|
includeRecentDiffs: z.boolean().optional(),
|
|
@@ -32,7 +52,11 @@ const ConfigSchema = z.object({
|
|
|
32
52
|
releaseNotesLimit: z.number().optional(),
|
|
33
53
|
githubIssuesLimit: z.number().optional(),
|
|
34
54
|
context: z.string().optional(),
|
|
35
|
-
sendit: z.boolean().optional()
|
|
55
|
+
sendit: z.boolean().optional(),
|
|
56
|
+
maxRecordingTime: z.number().optional(),
|
|
57
|
+
audioDevice: z.string().optional(),
|
|
58
|
+
file: z.string().optional(),
|
|
59
|
+
keepTemp: z.boolean().optional()
|
|
36
60
|
}).optional(),
|
|
37
61
|
publish: z.object({
|
|
38
62
|
mergeMethod: z.enum([
|
package/dist/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sources":["../src/types.ts"],"sourcesContent":["import * as Cardigantime from '@theunwalked/cardigantime';\nimport { z } from \"zod\";\n\nexport const ConfigSchema = z.object({\n dryRun: z.boolean().optional(),\n verbose: z.boolean().optional(),\n debug: z.boolean().optional(),\n overrides: z.boolean().optional(),\n instructions: z.string().optional(),\n model: z.string().optional(),\n contextDirectories: z.array(z.string()).optional(),\n outputDirectory: z.string().optional(),\n commit: z.object({\n add: z.boolean().optional(),\n cached: z.boolean().optional(),\n sendit: z.boolean().optional(),\n messageLimit: z.number().optional(),\n context: z.string().optional(),\n }).optional(),\n release: z.object({\n from: z.string().optional(),\n to: z.string().optional(),\n messageLimit: z.number().optional(),\n context: z.string().optional(),\n }).optional(),\n audioReview: z.object({\n includeCommitHistory: z.boolean().optional(),\n includeRecentDiffs: z.boolean().optional(),\n includeReleaseNotes: z.boolean().optional(),\n includeGithubIssues: z.boolean().optional(),\n commitHistoryLimit: z.number().optional(),\n diffHistoryLimit: z.number().optional(),\n releaseNotesLimit: z.number().optional(),\n githubIssuesLimit: z.number().optional(),\n context: z.string().optional(),\n sendit: z.boolean().optional(),\n }).optional(),\n publish: z.object({\n mergeMethod: z.enum(['merge', 'squash', 'rebase']).optional(),\n dependencyUpdatePatterns: z.array(z.string()).optional(),\n requiredEnvVars: z.array(z.string()).optional(),\n linkWorkspacePackages: z.boolean().optional(),\n unlinkWorkspacePackages: z.boolean().optional(),\n }).optional(),\n link: z.object({\n scopeRoots: z.record(z.string(), z.string()).optional(),\n workspaceFile: z.string().optional(),\n dryRun: z.boolean().optional(),\n }).optional(),\n excludedPatterns: z.array(z.string()).optional(),\n});\n\nexport const SecureConfigSchema = z.object({\n openaiApiKey: z.string().optional(),\n});\n\nexport const CommandConfigSchema = z.object({\n commandName: z.string().optional(),\n});\n\nexport type Config = z.infer<typeof ConfigSchema> & Cardigantime.Config;\nexport type SecureConfig = z.infer<typeof SecureConfigSchema>;\nexport type CommandConfig = z.infer<typeof CommandConfigSchema>;\n\nexport type MergeMethod = 'merge' | 'squash' | 'rebase';\n\nexport interface PullRequest {\n html_url: string;\n number: number;\n labels: {\n name: string;\n }[];\n}\n\nexport type ReleaseSummary = {\n title: string;\n body: string;\n}\n\nexport type ReleaseConfig = {\n from?: string;\n to?: string;\n context?: string;\n}\n\nexport type AudioReviewConfig = {\n includeCommitHistory?: boolean;\n includeRecentDiffs?: boolean;\n includeReleaseNotes?: boolean;\n includeGithubIssues?: boolean;\n commitHistoryLimit?: number;\n diffHistoryLimit?: number;\n releaseNotesLimit?: number;\n githubIssuesLimit?: number;\n context?: string;\n sendit?: boolean;\n}\n\nexport type PublishConfig = {\n from?: string;\n to?: string;\n}\n"],"names":["ConfigSchema","z","object","dryRun","boolean","optional","verbose","debug","overrides","instructions","string","model","contextDirectories","array","outputDirectory","commit","add","cached","sendit","messageLimit","number","context","release","from","to","audioReview","includeCommitHistory","includeRecentDiffs","includeReleaseNotes","includeGithubIssues","commitHistoryLimit","diffHistoryLimit","releaseNotesLimit","githubIssuesLimit","publish","mergeMethod","enum","dependencyUpdatePatterns","requiredEnvVars","linkWorkspacePackages","unlinkWorkspacePackages","link","scopeRoots","record","workspaceFile","excludedPatterns","openaiApiKey","commandName"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"types.js","sources":["../src/types.ts"],"sourcesContent":["import * as Cardigantime from '@theunwalked/cardigantime';\nimport { z } from \"zod\";\n\nexport const ConfigSchema = z.object({\n dryRun: z.boolean().optional(),\n verbose: z.boolean().optional(),\n debug: z.boolean().optional(),\n overrides: z.boolean().optional(),\n model: z.string().optional(),\n contextDirectories: z.array(z.string()).optional(),\n outputDirectory: z.string().optional(),\n preferencesDirectory: z.string().optional(),\n commit: z.object({\n add: z.boolean().optional(),\n cached: z.boolean().optional(),\n sendit: z.boolean().optional(),\n messageLimit: z.number().optional(),\n context: z.string().optional(),\n direction: z.string().optional(),\n }).optional(),\n audioCommit: z.object({\n maxRecordingTime: z.number().optional(),\n audioDevice: z.string().optional(),\n file: z.string().optional(),\n keepTemp: z.boolean().optional(),\n }).optional(),\n release: z.object({\n from: z.string().optional(),\n to: z.string().optional(),\n messageLimit: z.number().optional(),\n context: z.string().optional(),\n }).optional(),\n review: z.object({\n includeCommitHistory: z.boolean().optional(),\n includeRecentDiffs: z.boolean().optional(),\n includeReleaseNotes: z.boolean().optional(),\n includeGithubIssues: z.boolean().optional(),\n commitHistoryLimit: z.number().optional(),\n diffHistoryLimit: z.number().optional(),\n releaseNotesLimit: z.number().optional(),\n githubIssuesLimit: z.number().optional(),\n context: z.string().optional(),\n sendit: z.boolean().optional(),\n note: z.string().optional(),\n }).optional(),\n audioReview: z.object({\n includeCommitHistory: z.boolean().optional(),\n includeRecentDiffs: z.boolean().optional(),\n includeReleaseNotes: z.boolean().optional(),\n includeGithubIssues: z.boolean().optional(),\n commitHistoryLimit: z.number().optional(),\n diffHistoryLimit: z.number().optional(),\n releaseNotesLimit: z.number().optional(),\n githubIssuesLimit: z.number().optional(),\n context: z.string().optional(),\n sendit: z.boolean().optional(),\n maxRecordingTime: z.number().optional(),\n audioDevice: z.string().optional(),\n file: z.string().optional(),\n keepTemp: z.boolean().optional(),\n }).optional(),\n publish: z.object({\n mergeMethod: z.enum(['merge', 'squash', 'rebase']).optional(),\n dependencyUpdatePatterns: z.array(z.string()).optional(),\n requiredEnvVars: z.array(z.string()).optional(),\n linkWorkspacePackages: z.boolean().optional(),\n unlinkWorkspacePackages: z.boolean().optional(),\n }).optional(),\n link: z.object({\n scopeRoots: z.record(z.string(), z.string()).optional(),\n workspaceFile: z.string().optional(),\n dryRun: z.boolean().optional(),\n }).optional(),\n excludedPatterns: z.array(z.string()).optional(),\n});\n\nexport const SecureConfigSchema = z.object({\n openaiApiKey: z.string().optional(),\n});\n\nexport const CommandConfigSchema = z.object({\n commandName: z.string().optional(),\n});\n\nexport type Config = z.infer<typeof ConfigSchema> & Cardigantime.Config;\nexport type SecureConfig = z.infer<typeof SecureConfigSchema>;\nexport type CommandConfig = z.infer<typeof CommandConfigSchema>;\n\nexport type MergeMethod = 'merge' | 'squash' | 'rebase';\n\nexport interface PullRequest {\n html_url: string;\n number: number;\n labels: {\n name: string;\n }[];\n}\n\nexport type ReleaseSummary = {\n title: string;\n body: string;\n}\n\nexport type ReleaseConfig = {\n from?: string;\n to?: string;\n context?: string;\n}\n\nexport type ReviewConfig = {\n includeCommitHistory?: boolean;\n includeRecentDiffs?: boolean;\n includeReleaseNotes?: boolean;\n includeGithubIssues?: boolean;\n commitHistoryLimit?: number;\n diffHistoryLimit?: number;\n releaseNotesLimit?: number;\n githubIssuesLimit?: number;\n context?: string;\n sendit?: boolean;\n note?: string;\n}\n\nexport type AudioReviewConfig = {\n includeCommitHistory?: boolean;\n includeRecentDiffs?: boolean;\n includeReleaseNotes?: boolean;\n includeGithubIssues?: boolean;\n commitHistoryLimit?: number;\n diffHistoryLimit?: number;\n releaseNotesLimit?: number;\n githubIssuesLimit?: number;\n context?: string;\n sendit?: boolean;\n maxRecordingTime?: number;\n audioDevice?: string;\n file?: string;\n keepTemp?: boolean;\n}\n\nexport type AudioCommitConfig = {\n maxRecordingTime?: number;\n audioDevice?: string;\n file?: string;\n keepTemp?: boolean;\n}\n\nexport type PublishConfig = {\n from?: string;\n to?: string;\n}\n"],"names":["ConfigSchema","z","object","dryRun","boolean","optional","verbose","debug","overrides","model","string","contextDirectories","array","outputDirectory","preferencesDirectory","commit","add","cached","sendit","messageLimit","number","context","direction","audioCommit","maxRecordingTime","audioDevice","file","keepTemp","release","from","to","review","includeCommitHistory","includeRecentDiffs","includeReleaseNotes","includeGithubIssues","commitHistoryLimit","diffHistoryLimit","releaseNotesLimit","githubIssuesLimit","note","audioReview","publish","mergeMethod","enum","dependencyUpdatePatterns","requiredEnvVars","linkWorkspacePackages","unlinkWorkspacePackages","link","scopeRoots","record","workspaceFile","excludedPatterns","openaiApiKey","commandName"],"mappings":"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"}
|
package/dist/util/general.js
CHANGED
|
@@ -82,6 +82,12 @@ const getTimestampedCommitFilename = ()=>{
|
|
|
82
82
|
const getTimestampedReleaseNotesFilename = ()=>{
|
|
83
83
|
return getTimestampedFilename('release-notes', '.md');
|
|
84
84
|
};
|
|
85
|
+
const getTimestampedAudioFilename = ()=>{
|
|
86
|
+
return getTimestampedFilename('audio-recording', '.wav');
|
|
87
|
+
};
|
|
88
|
+
const getTimestampedTranscriptFilename = ()=>{
|
|
89
|
+
return getTimestampedFilename('audio-transcript', '.md');
|
|
90
|
+
};
|
|
85
91
|
|
|
86
|
-
export { getOutputPath, getTimestampedCommitFilename, getTimestampedFilename, getTimestampedReleaseNotesFilename, getTimestampedRequestFilename, getTimestampedResponseFilename, incrementPatchVersion, stringifyJSON };
|
|
92
|
+
export { getOutputPath, getTimestampedAudioFilename, getTimestampedCommitFilename, getTimestampedFilename, getTimestampedReleaseNotesFilename, getTimestampedRequestFilename, getTimestampedResponseFilename, getTimestampedTranscriptFilename, incrementPatchVersion, stringifyJSON };
|
|
87
93
|
//# sourceMappingURL=general.js.map
|
package/dist/util/general.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"general.js","sources":["../../src/util/general.ts"],"sourcesContent":["import path from 'path';\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 const parts = version.split('.');\n if (parts.length !== 3) {\n throw new Error(`Invalid version string: ${version}`);\n }\n const patch = parseInt(parts[2], 10);\n if (isNaN(patch)) {\n throw new Error(`Invalid patch version: ${parts[2]}`);\n }\n parts[2] = (patch + 1).toString();\n return parts.join('.');\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};"],"names":["stringifyJSON","obj","options","depth","arrOfKeyVals","arrVals","objKeys","Array","isArray","undefined","forEach","el","push","Object","keys","key","keyOut","keyValOut","Function","incrementPatchVersion","version","parts","split","length","Error","patch","parseInt","isNaN","toString","join","getOutputPath","outputDirectory","filename","path","getTimestampedFilename","baseName","extension","now","Date","yy","getFullYear","slice","mm","getMonth","padStart","dd","getDate","hh","getHours","min","getMinutes","timestamp","getTimestampedRequestFilename","getTimestampedResponseFilename","getTimestampedCommitFilename","getTimestampedReleaseNotesFilename"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"general.js","sources":["../../src/util/general.ts"],"sourcesContent":["import path from 'path';\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 const parts = version.split('.');\n if (parts.length !== 3) {\n throw new Error(`Invalid version string: ${version}`);\n }\n const patch = parseInt(parts[2], 10);\n if (isNaN(patch)) {\n throw new Error(`Invalid patch version: ${parts[2]}`);\n }\n parts[2] = (patch + 1).toString();\n return parts.join('.');\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};"],"names":["stringifyJSON","obj","options","depth","arrOfKeyVals","arrVals","objKeys","Array","isArray","undefined","forEach","el","push","Object","keys","key","keyOut","keyValOut","Function","incrementPatchVersion","version","parts","split","length","Error","patch","parseInt","isNaN","toString","join","getOutputPath","outputDirectory","filename","path","getTimestampedFilename","baseName","extension","now","Date","yy","getFullYear","slice","mm","getMonth","padStart","dd","getDate","hh","getHours","min","getMinutes","timestamp","getTimestampedRequestFilename","getTimestampedResponseFilename","getTimestampedCommitFilename","getTimestampedReleaseNotesFilename","getTimestampedAudioFilename","getTimestampedTranscriptFilename"],"mappings":";;AAsBA;AACO,MAAMA,aAAAA,GAAgB,SAAUC,GAAQ,EAAEC,OAAAA,GAA6B;IAAEC,KAAAA,EAAO;AAAE,CAAC,EAAA;IAEtF,IAAID,OAAAA,CAAQC,KAAK,GAAG,EAAA,EAAI;QACpB,OAAO,oCAAA;AACX;AAEA,IAAA,MAAMC,eAAyB,EAAE;AACjC,IAAA,MAAMC,UAAoB,EAAE;AAC5B,IAAA,IAAIC,UAAoB,EAAE;mDAG1B,IAAI,OAAOL,GAAAA,KAAQ,QAAA,IAAY,OAAOA,GAAAA,KAAQ,SAAA,IAAaA,GAAAA,KAAQ,IAAA,EAC/D,OAAO,EAAA,GAAKA,GAAAA;AACX,SAAA,IAAI,OAAOA,GAAAA,KAAQ,QAAA,EACpB,OAAO,MAAMA,GAAAA,GAAM,GAAA;SAGlB,IAAIM,KAAAA,CAAMC,OAAO,CAACP,GAAAA,CAAAA,EAAM;;AAEzB,QAAA,IAAIA,GAAG,CAAC,CAAA,CAAE,KAAKQ,WACX,OAAO,IAAA;AACN,aAAA;YACDR,GAAAA,CAAIS,OAAO,CAAC,SAAUC,EAAE,EAAA;gBACpBN,OAAAA,CAAQO,IAAI,CAACZ,aAAAA,CAAcW,EAAAA,EAAI;oBAAER,KAAAA,EAAOD,OAAAA,CAAQC,KAAK,GAAG;AAAE,iBAAA,CAAA,CAAA;AAC9D,aAAA,CAAA;AACA,YAAA,OAAO,MAAME,OAAAA,GAAU,GAAA;AAC3B;KACJ,MAEK,IAAIJ,eAAeY,MAAAA,EAAQ;;QAE5BP,OAAAA,GAAUO,MAAAA,CAAOC,IAAI,CAACb,GAAAA,CAAAA;;QAEtBK,OAAAA,CAAQI,OAAO,CAAC,SAAUK,GAAG,EAAA;YACzB,MAAMC,MAAAA,GAAS,MAAMD,GAAAA,GAAM,IAAA;YAC3B,MAAME,SAAAA,GAAYhB,GAAG,CAACc,GAAAA,CAAI;;AAE1B,YAAA,IAAIE,qBAAqBC,QAAAA,IAAYD,SAAAA,KAAcR,SAAAA,EAC/CL,YAAAA,CAAaQ,IAAI,CAAC,EAAA,CAAA;iBACjB,IAAI,OAAOK,cAAc,QAAA,EAC1Bb,YAAAA,CAAaQ,IAAI,CAACI,MAAAA,GAAS,MAAMC,SAAAA,GAAY,GAAA,CAAA;iBAC5C,IAAI,OAAOA,SAAAA,KAAc,SAAA,IAAa,OAAOA,SAAAA,KAAc,QAAA,IAAYA,SAAAA,KAAc,IAAA,EACtFb,YAAAA,CAAaQ,IAAI,CAACI,MAAAA,GAASC,SAAAA,CAAAA;AAE1B,iBAAA,IAAIA,qBAAqBJ,MAAAA,EAAQ;AAClCT,gBAAAA,YAAAA,CAAaQ,IAAI,CAACI,MAAAA,GAAShB,aAAAA,CAAciB,SAAAA,EAAW;oBAAEd,KAAAA,EAAOD,OAAAA,CAAQC,KAAK,GAAG;AAAE,iBAAA,CAAA,CAAA;AACnF;AACJ,SAAA,CAAA;AACA,QAAA,OAAO,MAAMC,YAAAA,GAAe,GAAA;AAChC;IACA,OAAO,EAAA;AACX;AAEO,MAAMe,wBAAwB,CAACC,OAAAA,GAAAA;IAClC,MAAMC,KAAAA,GAAQD,OAAAA,CAAQE,KAAK,CAAC,GAAA,CAAA;IAC5B,IAAID,KAAAA,CAAME,MAAM,KAAK,CAAA,EAAG;AACpB,QAAA,MAAM,IAAIC,KAAAA,CAAM,CAAC,wBAAwB,EAAEJ,OAAAA,CAAAA,CAAS,CAAA;AACxD;AACA,IAAA,MAAMK,KAAAA,GAAQC,QAAAA,CAASL,KAAK,CAAC,EAAE,EAAE,EAAA,CAAA;AACjC,IAAA,IAAIM,MAAMF,KAAAA,CAAAA,EAAQ;QACd,MAAM,IAAID,MAAM,CAAC,uBAAuB,EAAEH,KAAK,CAAC,EAAE,CAAA,CAAE,CAAA;AACxD;IACAA,KAAK,CAAC,EAAE,GAAII,CAAAA,KAAAA,GAAQ,CAAA,EAAGG,QAAQ,EAAA;IAC/B,OAAOP,KAAAA,CAAMQ,IAAI,CAAC,GAAA,CAAA;AACtB;AAEO,MAAMC,aAAAA,GAAgB,CAACC,eAAAA,EAAyBC,QAAAA,GAAAA;IACnD,OAAOC,IAAAA,CAAKJ,IAAI,CAACE,eAAAA,EAAiBC,QAAAA,CAAAA;AACtC;AAEO,MAAME,sBAAAA,GAAyB,CAACC,QAAAA,EAAkBC,YAAoB,OAAO,GAAA;AAChF,IAAA,MAAMC,MAAM,IAAIC,IAAAA,EAAAA;;IAGhB,MAAMC,EAAAA,GAAKF,IAAIG,WAAW,EAAA,CAAGZ,QAAQ,EAAA,CAAGa,KAAK,CAAC,EAAC,CAAA;AAC/C,IAAA,MAAMC,EAAAA,GAAML,CAAAA,GAAAA,CAAIM,QAAQ,EAAA,GAAK,CAAA,EAAGf,QAAQ,EAAA,CAAGgB,QAAQ,CAAC,CAAA,EAAG,GAAA,CAAA;IACvD,MAAMC,EAAAA,GAAKR,IAAIS,OAAO,EAAA,CAAGlB,QAAQ,EAAA,CAAGgB,QAAQ,CAAC,CAAA,EAAG,GAAA,CAAA;IAChD,MAAMG,EAAAA,GAAKV,IAAIW,QAAQ,EAAA,CAAGpB,QAAQ,EAAA,CAAGgB,QAAQ,CAAC,CAAA,EAAG,GAAA,CAAA;IACjD,MAAMK,GAAAA,GAAMZ,IAAIa,UAAU,EAAA,CAAGtB,QAAQ,EAAA,CAAGgB,QAAQ,CAAC,CAAA,EAAG,GAAA,CAAA;IAEpD,MAAMO,SAAAA,GAAY,GAAGZ,EAAAA,CAAAA,EAAKG,EAAAA,CAAAA,EAAKG,GAAG,CAAC,EAAEE,KAAKE,GAAAA,CAAAA,CAAK;AAE/C,IAAA,OAAO,CAAA,EAAGE,SAAAA,CAAU,CAAC,EAAEhB,WAAWC,SAAAA,CAAAA,CAAW;AACjD;AAEO,MAAMgB,gCAAgC,CAACjB,QAAAA,GAAAA;AAC1C,IAAA,OAAOD,uBAAuBC,QAAAA,EAAU,eAAA,CAAA;AAC5C;AAEO,MAAMkB,iCAAiC,CAAClB,QAAAA,GAAAA;AAC3C,IAAA,OAAOD,uBAAuBC,QAAAA,EAAU,gBAAA,CAAA;AAC5C;MAEamB,4BAAAA,GAA+B,IAAA;AACxC,IAAA,OAAOpB,uBAAuB,gBAAA,EAAkB,KAAA,CAAA;AACpD;MAEaqB,kCAAAA,GAAqC,IAAA;AAC9C,IAAA,OAAOrB,uBAAuB,eAAA,EAAiB,KAAA,CAAA;AACnD;MAEasB,2BAAAA,GAA8B,IAAA;AACvC,IAAA,OAAOtB,uBAAuB,iBAAA,EAAmB,MAAA,CAAA;AACrD;MAEauB,gCAAAA,GAAmC,IAAA;AAC5C,IAAA,OAAOvB,uBAAuB,kBAAA,EAAoB,KAAA,CAAA;AACtD;;;;"}
|
package/dist/util/openai.js
CHANGED
|
@@ -15,13 +15,15 @@ async function createCompletion(messages, options = {
|
|
|
15
15
|
const storage = create({
|
|
16
16
|
log: logger.debug
|
|
17
17
|
});
|
|
18
|
+
let openai = null;
|
|
18
19
|
try {
|
|
19
20
|
var _completion_choices__message_content, _completion_choices__message, _completion_choices_;
|
|
20
21
|
const apiKey = process.env.OPENAI_API_KEY;
|
|
21
22
|
if (!apiKey) {
|
|
22
23
|
throw new OpenAIError('OPENAI_API_KEY environment variable is not set');
|
|
23
24
|
}
|
|
24
|
-
|
|
25
|
+
// Create the client which we'll close in the finally block.
|
|
26
|
+
openai = new OpenAI({
|
|
25
27
|
apiKey: apiKey
|
|
26
28
|
});
|
|
27
29
|
logger.debug('Sending prompt to OpenAI: %j', messages);
|
|
@@ -62,6 +64,17 @@ async function createCompletion(messages, options = {
|
|
|
62
64
|
} catch (error) {
|
|
63
65
|
logger.error('Error calling OpenAI API: %s %s', error.message, error.stack);
|
|
64
66
|
throw new OpenAIError(`Failed to create completion: ${error.message}`);
|
|
67
|
+
} finally{
|
|
68
|
+
// Ensure we close the OpenAI client to release underlying keep-alive sockets
|
|
69
|
+
try {
|
|
70
|
+
// openai.close() returns a promise; awaiting ensures proper cleanup
|
|
71
|
+
// but if it throws we silently ignore as it's best-effort.
|
|
72
|
+
if (openai && typeof openai.close === 'function') {
|
|
73
|
+
await openai.close();
|
|
74
|
+
}
|
|
75
|
+
} catch (closeErr) {
|
|
76
|
+
logger.debug('Failed to close OpenAI client: %s', closeErr.message);
|
|
77
|
+
}
|
|
65
78
|
}
|
|
66
79
|
}
|
|
67
80
|
async function transcribeAudio(filePath, options = {
|
|
@@ -71,12 +84,14 @@ async function transcribeAudio(filePath, options = {
|
|
|
71
84
|
const storage = create({
|
|
72
85
|
log: logger.debug
|
|
73
86
|
});
|
|
87
|
+
let openai = null;
|
|
88
|
+
let audioStream = null;
|
|
74
89
|
try {
|
|
75
90
|
const apiKey = process.env.OPENAI_API_KEY;
|
|
76
91
|
if (!apiKey) {
|
|
77
92
|
throw new OpenAIError('OPENAI_API_KEY environment variable is not set');
|
|
78
93
|
}
|
|
79
|
-
|
|
94
|
+
openai = new OpenAI({
|
|
80
95
|
apiKey: apiKey
|
|
81
96
|
});
|
|
82
97
|
logger.debug('Transcribing audio file: %s', filePath);
|
|
@@ -91,7 +106,7 @@ async function transcribeAudio(filePath, options = {
|
|
|
91
106
|
await storage.writeFile(debugFile, JSON.stringify(requestData, null, 2), 'utf8');
|
|
92
107
|
logger.debug('Wrote request debug file to %s', debugFile);
|
|
93
108
|
}
|
|
94
|
-
|
|
109
|
+
audioStream = await storage.readStream(filePath);
|
|
95
110
|
const transcription = await openai.audio.transcriptions.create({
|
|
96
111
|
model: options.model || "whisper-1",
|
|
97
112
|
file: audioStream,
|
|
@@ -112,6 +127,22 @@ async function transcribeAudio(filePath, options = {
|
|
|
112
127
|
} catch (error) {
|
|
113
128
|
logger.error('Error transcribing audio file: %s %s', error.message, error.stack);
|
|
114
129
|
throw new OpenAIError(`Failed to transcribe audio: ${error.message}`);
|
|
130
|
+
} finally{
|
|
131
|
+
// Ensure the audio stream is properly closed to release file handles
|
|
132
|
+
try {
|
|
133
|
+
if (audioStream) {
|
|
134
|
+
audioStream.close();
|
|
135
|
+
}
|
|
136
|
+
} catch (streamErr) {
|
|
137
|
+
logger.debug('Failed to close audio read stream: %s', streamErr.message);
|
|
138
|
+
}
|
|
139
|
+
try {
|
|
140
|
+
if (openai && typeof openai.close === 'function') {
|
|
141
|
+
await openai.close();
|
|
142
|
+
}
|
|
143
|
+
} catch (closeErr) {
|
|
144
|
+
logger.debug('Failed to close OpenAI client: %s', closeErr.message);
|
|
145
|
+
}
|
|
115
146
|
}
|
|
116
147
|
}
|
|
117
148
|
|
package/dist/util/openai.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"openai.js","sources":["../../src/util/openai.ts"],"sourcesContent":["import { OpenAI } from 'openai';\nimport { ChatCompletionMessageParam } from 'openai/resources';\nimport * as Storage from './storage';\nimport { getLogger } from '../logging';\nexport interface Transcription {\n text: string;\n}\n\nexport class OpenAIError extends Error {\n constructor(message: string) {\n super(message);\n this.name = 'OpenAIError';\n }\n}\n\nexport async function createCompletion(messages: ChatCompletionMessageParam[], options: { responseFormat?: any, model?: string, debug?: boolean, debugFile?: string, debugRequestFile?: string, debugResponseFile?: string } = { model: \"gpt-4o-mini\" }): Promise<string | any> {\n const logger = getLogger();\n const storage = Storage.create({ log: logger.debug });\n try {\n const apiKey = process.env.OPENAI_API_KEY;\n if (!apiKey) {\n throw new OpenAIError('OPENAI_API_KEY environment variable is not set');\n }\n\n const openai = new OpenAI({\n apiKey: apiKey,\n });\n\n logger.debug('Sending prompt to OpenAI: %j', messages);\n\n // Save request debug file if enabled\n if (options.debug && (options.debugRequestFile || options.debugFile)) {\n const requestData = {\n model: options.model || \"gpt-4o-mini\",\n messages,\n max_completion_tokens: 10000,\n response_format: options.responseFormat,\n };\n const debugFile = options.debugRequestFile || options.debugFile;\n await storage.writeFile(debugFile!, JSON.stringify(requestData, null, 2), 'utf8');\n logger.debug('Wrote request debug file to %s', debugFile);\n }\n\n const completion = await openai.chat.completions.create({\n model: options.model || \"gpt-4o-mini\",\n messages,\n max_completion_tokens: 10000,\n response_format: options.responseFormat,\n });\n\n // Save response debug file if enabled\n if (options.debug && (options.debugResponseFile || options.debugFile)) {\n const debugFile = options.debugResponseFile || options.debugFile;\n await storage.writeFile(debugFile!, JSON.stringify(completion, null, 2), 'utf8');\n logger.debug('Wrote response debug file to %s', debugFile);\n }\n\n const response = completion.choices[0]?.message?.content?.trim();\n if (!response) {\n throw new OpenAIError('No response received from OpenAI');\n }\n\n logger.debug('Received response from OpenAI: %s...', response.substring(0, 30));\n if (options.responseFormat) {\n return JSON.parse(response);\n } else {\n return response;\n }\n\n } catch (error: any) {\n logger.error('Error calling OpenAI API: %s %s', error.message, error.stack);\n throw new OpenAIError(`Failed to create completion: ${error.message}`);\n }\n}\n\nexport async function transcribeAudio(filePath: string, options: { model?: string, debug?: boolean, debugFile?: string, debugRequestFile?: string, debugResponseFile?: string } = { model: \"whisper-1\" }): Promise<Transcription> {\n const logger = getLogger();\n const storage = Storage.create({ log: logger.debug });\n try {\n const apiKey = process.env.OPENAI_API_KEY;\n if (!apiKey) {\n throw new OpenAIError('OPENAI_API_KEY environment variable is not set');\n }\n\n const openai = new OpenAI({\n apiKey: apiKey,\n });\n\n logger.debug('Transcribing audio file: %s', filePath);\n\n // Save request debug file if enabled\n if (options.debug && (options.debugRequestFile || options.debugFile)) {\n const requestData = {\n model: options.model || \"whisper-1\",\n file: filePath, // Can't serialize the stream, so just save the file path\n response_format: \"json\",\n };\n const debugFile = options.debugRequestFile || options.debugFile;\n await storage.writeFile(debugFile!, JSON.stringify(requestData, null, 2), 'utf8');\n logger.debug('Wrote request debug file to %s', debugFile);\n }\n\n const audioStream = await storage.readStream(filePath);\n const transcription = await openai.audio.transcriptions.create({\n model: options.model || \"whisper-1\",\n file: audioStream,\n response_format: \"json\",\n });\n\n // Save response debug file if enabled\n if (options.debug && (options.debugResponseFile || options.debugFile)) {\n const debugFile = options.debugResponseFile || options.debugFile;\n await storage.writeFile(debugFile!, JSON.stringify(transcription, null, 2), 'utf8');\n logger.debug('Wrote response debug file to %s', debugFile);\n }\n\n const response = transcription;\n if (!response) {\n throw new OpenAIError('No transcription received from OpenAI');\n }\n\n logger.debug('Received transcription from OpenAI: %s', response);\n return response;\n\n } catch (error: any) {\n logger.error('Error transcribing audio file: %s %s', error.message, error.stack);\n throw new OpenAIError(`Failed to transcribe audio: ${error.message}`);\n }\n}\n"],"names":["OpenAIError","Error","message","name","createCompletion","messages","options","model","logger","getLogger","storage","Storage","log","debug","completion","apiKey","process","env","OPENAI_API_KEY","openai","OpenAI","debugRequestFile","debugFile","requestData","max_completion_tokens","response_format","responseFormat","writeFile","JSON","stringify","chat","completions","create","debugResponseFile","response","choices","content","trim","substring","parse","error","stack","transcribeAudio","filePath","file","audioStream","readStream","transcription","audio","transcriptions"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"openai.js","sources":["../../src/util/openai.ts"],"sourcesContent":["import { OpenAI } from 'openai';\nimport { ChatCompletionMessageParam } from 'openai/resources';\nimport * as Storage from './storage';\nimport { getLogger } from '../logging';\n// eslint-disable-next-line no-restricted-imports\nimport fs from 'fs';\n\nexport interface Transcription {\n text: string;\n}\n\nexport class OpenAIError extends Error {\n constructor(message: string) {\n super(message);\n this.name = 'OpenAIError';\n }\n}\n\nexport async function createCompletion(messages: ChatCompletionMessageParam[], options: { responseFormat?: any, model?: string, debug?: boolean, debugFile?: string, debugRequestFile?: string, debugResponseFile?: string } = { model: \"gpt-4o-mini\" }): Promise<string | any> {\n const logger = getLogger();\n const storage = Storage.create({ log: logger.debug });\n let openai: OpenAI | null = null;\n try {\n const apiKey = process.env.OPENAI_API_KEY;\n if (!apiKey) {\n throw new OpenAIError('OPENAI_API_KEY environment variable is not set');\n }\n\n // Create the client which we'll close in the finally block.\n openai = new OpenAI({\n apiKey: apiKey,\n });\n\n logger.debug('Sending prompt to OpenAI: %j', messages);\n\n // Save request debug file if enabled\n if (options.debug && (options.debugRequestFile || options.debugFile)) {\n const requestData = {\n model: options.model || \"gpt-4o-mini\",\n messages,\n max_completion_tokens: 10000,\n response_format: options.responseFormat,\n };\n const debugFile = options.debugRequestFile || options.debugFile;\n await storage.writeFile(debugFile!, JSON.stringify(requestData, null, 2), 'utf8');\n logger.debug('Wrote request debug file to %s', debugFile);\n }\n\n const completion = await openai.chat.completions.create({\n model: options.model || \"gpt-4o-mini\",\n messages,\n max_completion_tokens: 10000,\n response_format: options.responseFormat,\n });\n\n // Save response debug file if enabled\n if (options.debug && (options.debugResponseFile || options.debugFile)) {\n const debugFile = options.debugResponseFile || options.debugFile;\n await storage.writeFile(debugFile!, JSON.stringify(completion, null, 2), 'utf8');\n logger.debug('Wrote response debug file to %s', debugFile);\n }\n\n const response = completion.choices[0]?.message?.content?.trim();\n if (!response) {\n throw new OpenAIError('No response received from OpenAI');\n }\n\n logger.debug('Received response from OpenAI: %s...', response.substring(0, 30));\n if (options.responseFormat) {\n return JSON.parse(response);\n } else {\n return response;\n }\n\n } catch (error: any) {\n logger.error('Error calling OpenAI API: %s %s', error.message, error.stack);\n throw new OpenAIError(`Failed to create completion: ${error.message}`);\n } finally {\n // Ensure we close the OpenAI client to release underlying keep-alive sockets\n try {\n // openai.close() returns a promise; awaiting ensures proper cleanup\n // but if it throws we silently ignore as it's best-effort.\n\n if (openai && typeof (openai as any).close === 'function') {\n await (openai as any).close();\n }\n } catch (closeErr) {\n logger.debug('Failed to close OpenAI client: %s', (closeErr as Error).message);\n }\n }\n}\n\nexport async function transcribeAudio(filePath: string, options: { model?: string, debug?: boolean, debugFile?: string, debugRequestFile?: string, debugResponseFile?: string } = { model: \"whisper-1\" }): Promise<Transcription> {\n const logger = getLogger();\n const storage = Storage.create({ log: logger.debug });\n let openai: OpenAI | null = null;\n let audioStream: fs.ReadStream | null = null;\n try {\n const apiKey = process.env.OPENAI_API_KEY;\n if (!apiKey) {\n throw new OpenAIError('OPENAI_API_KEY environment variable is not set');\n }\n\n openai = new OpenAI({\n apiKey: apiKey,\n });\n\n logger.debug('Transcribing audio file: %s', filePath);\n\n // Save request debug file if enabled\n if (options.debug && (options.debugRequestFile || options.debugFile)) {\n const requestData = {\n model: options.model || \"whisper-1\",\n file: filePath, // Can't serialize the stream, so just save the file path\n response_format: \"json\",\n };\n const debugFile = options.debugRequestFile || options.debugFile;\n await storage.writeFile(debugFile!, JSON.stringify(requestData, null, 2), 'utf8');\n logger.debug('Wrote request debug file to %s', debugFile);\n }\n\n audioStream = await storage.readStream(filePath);\n const transcription = await openai.audio.transcriptions.create({\n model: options.model || \"whisper-1\",\n file: audioStream,\n response_format: \"json\",\n });\n\n // Save response debug file if enabled\n if (options.debug && (options.debugResponseFile || options.debugFile)) {\n const debugFile = options.debugResponseFile || options.debugFile;\n await storage.writeFile(debugFile!, JSON.stringify(transcription, null, 2), 'utf8');\n logger.debug('Wrote response debug file to %s', debugFile);\n }\n\n const response = transcription;\n if (!response) {\n throw new OpenAIError('No transcription received from OpenAI');\n }\n\n logger.debug('Received transcription from OpenAI: %s', response);\n return response;\n\n } catch (error: any) {\n logger.error('Error transcribing audio file: %s %s', error.message, error.stack);\n throw new OpenAIError(`Failed to transcribe audio: ${error.message}`);\n } finally {\n // Ensure the audio stream is properly closed to release file handles\n try {\n if (audioStream) {\n audioStream.close();\n }\n } catch (streamErr) {\n logger.debug('Failed to close audio read stream: %s', (streamErr as Error).message);\n }\n try {\n if (openai && typeof (openai as any).close === 'function') {\n await (openai as any).close();\n }\n } catch (closeErr) {\n logger.debug('Failed to close OpenAI client: %s', (closeErr as Error).message);\n }\n }\n}\n"],"names":["OpenAIError","Error","message","name","createCompletion","messages","options","model","logger","getLogger","storage","Storage","log","debug","openai","completion","apiKey","process","env","OPENAI_API_KEY","OpenAI","debugRequestFile","debugFile","requestData","max_completion_tokens","response_format","responseFormat","writeFile","JSON","stringify","chat","completions","create","debugResponseFile","response","choices","content","trim","substring","parse","error","stack","close","closeErr","transcribeAudio","filePath","audioStream","file","readStream","transcription","audio","transcriptions","streamErr"],"mappings":"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"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
// Function to read from STDIN if available
|
|
2
|
+
async function readStdin() {
|
|
3
|
+
// In test environment, allow mocking to work by skipping TTY check
|
|
4
|
+
if (process.env.NODE_ENV === 'test' || process.env.VITEST === 'true') {
|
|
5
|
+
return new Promise((resolve)=>{
|
|
6
|
+
let input = '';
|
|
7
|
+
let hasData = false;
|
|
8
|
+
const timeout = setTimeout(()=>{
|
|
9
|
+
if (!hasData) {
|
|
10
|
+
resolve(null);
|
|
11
|
+
}
|
|
12
|
+
}, 10); // Very short timeout for tests
|
|
13
|
+
process.stdin.setEncoding('utf8');
|
|
14
|
+
process.stdin.on('data', (chunk)=>{
|
|
15
|
+
hasData = true;
|
|
16
|
+
clearTimeout(timeout);
|
|
17
|
+
input += chunk;
|
|
18
|
+
});
|
|
19
|
+
process.stdin.on('end', ()=>{
|
|
20
|
+
resolve(input.trim() || null);
|
|
21
|
+
});
|
|
22
|
+
process.stdin.on('error', ()=>{
|
|
23
|
+
clearTimeout(timeout);
|
|
24
|
+
resolve(null);
|
|
25
|
+
});
|
|
26
|
+
process.stdin.resume();
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
return new Promise((resolve)=>{
|
|
30
|
+
// Check if stdin is TTY (interactive terminal)
|
|
31
|
+
if (process.stdin.isTTY) {
|
|
32
|
+
resolve(null);
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
let input = '';
|
|
36
|
+
let hasData = false;
|
|
37
|
+
const timeout = setTimeout(()=>{
|
|
38
|
+
if (!hasData) {
|
|
39
|
+
resolve(null);
|
|
40
|
+
}
|
|
41
|
+
}, 100); // Short timeout to detect if data is available
|
|
42
|
+
process.stdin.setEncoding('utf8');
|
|
43
|
+
process.stdin.on('data', (chunk)=>{
|
|
44
|
+
hasData = true;
|
|
45
|
+
clearTimeout(timeout);
|
|
46
|
+
input += chunk;
|
|
47
|
+
});
|
|
48
|
+
process.stdin.on('end', ()=>{
|
|
49
|
+
resolve(input.trim() || null);
|
|
50
|
+
});
|
|
51
|
+
process.stdin.on('error', ()=>{
|
|
52
|
+
clearTimeout(timeout);
|
|
53
|
+
resolve(null);
|
|
54
|
+
});
|
|
55
|
+
// If no data comes in quickly, assume no stdin
|
|
56
|
+
process.stdin.resume();
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
export { readStdin };
|
|
61
|
+
//# sourceMappingURL=stdin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stdin.js","sources":["../../src/util/stdin.ts"],"sourcesContent":["// Function to read from STDIN if available\nexport async function readStdin(): Promise<string | null> {\n // In test environment, allow mocking to work by skipping TTY check\n if (process.env.NODE_ENV === 'test' || process.env.VITEST === 'true') {\n return new Promise((resolve) => {\n let input = '';\n let hasData = false;\n\n const timeout = setTimeout(() => {\n if (!hasData) {\n resolve(null);\n }\n }, 10); // Very short timeout for tests\n\n process.stdin.setEncoding('utf8');\n\n process.stdin.on('data', (chunk) => {\n hasData = true;\n clearTimeout(timeout);\n input += chunk;\n });\n\n process.stdin.on('end', () => {\n resolve(input.trim() || null);\n });\n\n process.stdin.on('error', () => {\n clearTimeout(timeout);\n resolve(null);\n });\n\n process.stdin.resume();\n });\n }\n\n return new Promise((resolve) => {\n // Check if stdin is TTY (interactive terminal)\n if (process.stdin.isTTY) {\n resolve(null);\n return;\n }\n\n let input = '';\n let hasData = false;\n\n const timeout = setTimeout(() => {\n if (!hasData) {\n resolve(null);\n }\n }, 100); // Short timeout to detect if data is available\n\n process.stdin.setEncoding('utf8');\n\n process.stdin.on('data', (chunk) => {\n hasData = true;\n clearTimeout(timeout);\n input += chunk;\n });\n\n process.stdin.on('end', () => {\n resolve(input.trim() || null);\n });\n\n process.stdin.on('error', () => {\n clearTimeout(timeout);\n resolve(null);\n });\n\n // If no data comes in quickly, assume no stdin\n process.stdin.resume();\n });\n} "],"names":["readStdin","process","env","NODE_ENV","VITEST","Promise","resolve","input","hasData","timeout","setTimeout","stdin","setEncoding","on","chunk","clearTimeout","trim","resume","isTTY"],"mappings":"AAAA;AACO,eAAeA,SAAAA,GAAAA;;IAElB,IAAIC,OAAAA,CAAQC,GAAG,CAACC,QAAQ,KAAK,MAAA,IAAUF,OAAAA,CAAQC,GAAG,CAACE,MAAM,KAAK,MAAA,EAAQ;QAClE,OAAO,IAAIC,QAAQ,CAACC,OAAAA,GAAAA;AAChB,YAAA,IAAIC,KAAAA,GAAQ,EAAA;AACZ,YAAA,IAAIC,OAAAA,GAAU,KAAA;AAEd,YAAA,MAAMC,UAAUC,UAAAA,CAAW,IAAA;AACvB,gBAAA,IAAI,CAACF,OAAAA,EAAS;oBACVF,OAAAA,CAAQ,IAAA,CAAA;AACZ;AACJ,aAAA,EAAG;YAEHL,OAAAA,CAAQU,KAAK,CAACC,WAAW,CAAC,MAAA,CAAA;AAE1BX,YAAAA,OAAAA,CAAQU,KAAK,CAACE,EAAE,CAAC,QAAQ,CAACC,KAAAA,GAAAA;gBACtBN,OAAAA,GAAU,IAAA;gBACVO,YAAAA,CAAaN,OAAAA,CAAAA;gBACbF,KAAAA,IAASO,KAAAA;AACb,aAAA,CAAA;AAEAb,YAAAA,OAAAA,CAAQU,KAAK,CAACE,EAAE,CAAC,KAAA,EAAO,IAAA;gBACpBP,OAAAA,CAAQC,KAAAA,CAAMS,IAAI,EAAA,IAAM,IAAA,CAAA;AAC5B,aAAA,CAAA;AAEAf,YAAAA,OAAAA,CAAQU,KAAK,CAACE,EAAE,CAAC,OAAA,EAAS,IAAA;gBACtBE,YAAAA,CAAaN,OAAAA,CAAAA;gBACbH,OAAAA,CAAQ,IAAA,CAAA;AACZ,aAAA,CAAA;YAEAL,OAAAA,CAAQU,KAAK,CAACM,MAAM,EAAA;AACxB,SAAA,CAAA;AACJ;IAEA,OAAO,IAAIZ,QAAQ,CAACC,OAAAA,GAAAA;;AAEhB,QAAA,IAAIL,OAAAA,CAAQU,KAAK,CAACO,KAAK,EAAE;YACrBZ,OAAAA,CAAQ,IAAA,CAAA;AACR,YAAA;AACJ;AAEA,QAAA,IAAIC,KAAAA,GAAQ,EAAA;AACZ,QAAA,IAAIC,OAAAA,GAAU,KAAA;AAEd,QAAA,MAAMC,UAAUC,UAAAA,CAAW,IAAA;AACvB,YAAA,IAAI,CAACF,OAAAA,EAAS;gBACVF,OAAAA,CAAQ,IAAA,CAAA;AACZ;AACJ,SAAA,EAAG;QAEHL,OAAAA,CAAQU,KAAK,CAACC,WAAW,CAAC,MAAA,CAAA;AAE1BX,QAAAA,OAAAA,CAAQU,KAAK,CAACE,EAAE,CAAC,QAAQ,CAACC,KAAAA,GAAAA;YACtBN,OAAAA,GAAU,IAAA;YACVO,YAAAA,CAAaN,OAAAA,CAAAA;YACbF,KAAAA,IAASO,KAAAA;AACb,SAAA,CAAA;AAEAb,QAAAA,OAAAA,CAAQU,KAAK,CAACE,EAAE,CAAC,KAAA,EAAO,IAAA;YACpBP,OAAAA,CAAQC,KAAAA,CAAMS,IAAI,EAAA,IAAM,IAAA,CAAA;AAC5B,SAAA,CAAA;AAEAf,QAAAA,OAAAA,CAAQU,KAAK,CAACE,EAAE,CAAC,OAAA,EAAS,IAAA;YACtBE,YAAAA,CAAaN,OAAAA,CAAAA;YACbH,OAAAA,CAAQ,IAAA,CAAA;AACZ,SAAA,CAAA;;QAGAL,OAAAA,CAAQU,KAAK,CAACM,MAAM,EAAA;AACxB,KAAA,CAAA;AACJ;;;;"}
|