@redaksjon/protokoll-engine 0.1.7 → 0.1.8-dev.20260221045945.bbdc773

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/index60.js CHANGED
@@ -1,151 +1,8 @@
1
- import * as path from 'node:path';
2
- import * as fs from 'node:fs/promises';
3
- import { randomUUID } from 'node:crypto';
4
- import { getLogger } from './index47.js';
5
- import { PklTranscript } from '@redaksjon/protokoll-format';
1
+ import { getDefaultExportFromCjs } from './index67.js';
2
+ import { __require as requireTimezone } from './index63.js';
6
3
 
7
- const create = (config) => {
8
- const logger = getLogger();
9
- const formatTimestamp = (date) => {
10
- const pad = (n) => n.toString().padStart(2, "0");
11
- const year = date.getFullYear().toString();
12
- const month = pad(date.getMonth() + 1);
13
- const day = pad(date.getDate());
14
- const hours = pad(date.getHours());
15
- const minutes = pad(date.getMinutes());
16
- return `${year}-${month}-${day}-${hours}${minutes}`;
17
- };
18
- const createOutputPaths = (_audioFile, routedDestination, hash, date) => {
19
- const timestamp = formatTimestamp(date);
20
- const shortHash = hash.slice(0, 6);
21
- const buildFilename = (type, ext) => `${timestamp}-${type}-${shortHash}${ext}`;
22
- const intermediateDir = config.intermediateDir;
23
- let finalPath = routedDestination;
24
- if (finalPath.endsWith(".md")) {
25
- finalPath = finalPath.replace(/\.md$/, ".pkl");
26
- } else if (!finalPath.endsWith(".pkl")) {
27
- finalPath = finalPath + ".pkl";
28
- }
29
- const finalDir = path.dirname(finalPath);
30
- const finalBasename = path.basename(finalPath, ".pkl");
31
- const rawTranscriptPath = path.join(finalDir, ".transcript", `${finalBasename}.json`);
32
- return {
33
- final: finalPath,
34
- rawTranscript: rawTranscriptPath,
35
- intermediate: {
36
- transcript: path.join(intermediateDir, buildFilename("transcript", ".json")),
37
- context: path.join(intermediateDir, buildFilename("context", ".json")),
38
- request: path.join(intermediateDir, buildFilename("request", ".json")),
39
- response: path.join(intermediateDir, buildFilename("response", ".json")),
40
- reflection: path.join(intermediateDir, buildFilename("reflection", ".md")),
41
- session: path.join(intermediateDir, buildFilename("session", ".json"))
42
- }
43
- };
44
- };
45
- const ensureDirectories = async (paths) => {
46
- await fs.mkdir(path.dirname(paths.intermediate.transcript), { recursive: true });
47
- await fs.mkdir(path.dirname(paths.final), { recursive: true });
48
- await fs.mkdir(path.dirname(paths.rawTranscript), { recursive: true });
49
- logger.debug("Ensured output directories", {
50
- intermediate: path.dirname(paths.intermediate.transcript),
51
- final: path.dirname(paths.final),
52
- rawTranscript: path.dirname(paths.rawTranscript)
53
- });
54
- };
55
- const writeIntermediate = async (paths, type, content) => {
56
- const filePath = paths.intermediate[type];
57
- if (!filePath) {
58
- throw new Error(`Invalid intermediate type: ${type}`);
59
- }
60
- const contentStr = typeof content === "string" ? content : JSON.stringify(content, null, 2);
61
- await fs.writeFile(filePath, contentStr, "utf-8");
62
- logger.debug("Wrote intermediate file", { type, path: filePath });
63
- return filePath;
64
- };
65
- const writeTranscript = async (paths, content, metadata) => {
66
- const pklRouting = metadata?.routing ? {
67
- destination: metadata.routing.destination,
68
- confidence: metadata.routing.confidence,
69
- signals: metadata.routing.signals?.map(
70
- (s) => typeof s === "string" ? s : `${s.type}: ${s.value} (weight: ${s.weight})`
71
- ),
72
- reasoning: metadata.routing.reasoning
73
- } : void 0;
74
- const pklMetadata = metadata ? {
75
- id: metadata.id || randomUUID(),
76
- // Use provided UUID or generate new one
77
- title: metadata.title,
78
- date: metadata.date,
79
- recordingTime: metadata.recordingTime,
80
- project: metadata.project,
81
- projectId: metadata.projectId,
82
- tags: metadata.tags || [],
83
- duration: metadata.duration,
84
- status: metadata.status || "initial",
85
- entities: metadata.entities,
86
- routing: pklRouting
87
- } : {
88
- id: randomUUID(),
89
- title: "Untitled",
90
- tags: [],
91
- status: "initial"
92
- };
93
- const transcript = PklTranscript.create(paths.final, pklMetadata);
94
- try {
95
- transcript.updateContent(content);
96
- logger.info("Wrote final transcript", { path: paths.final });
97
- } finally {
98
- transcript.close();
99
- }
100
- return paths.final;
101
- };
102
- const cleanIntermediates = async (paths) => {
103
- if (config.keepIntermediates) {
104
- logger.debug("Keeping intermediate files");
105
- return;
106
- }
107
- for (const [type, filePath] of Object.entries(paths.intermediate)) {
108
- if (filePath) {
109
- try {
110
- await fs.unlink(filePath);
111
- logger.debug("Removed intermediate file", { type, path: filePath });
112
- } catch {
113
- }
114
- }
115
- }
116
- };
117
- const writeRawTranscript = async (paths, data) => {
118
- const filePath = paths.rawTranscript;
119
- await fs.writeFile(filePath, JSON.stringify(data, null, 2), "utf-8");
120
- logger.debug("Wrote raw transcript to .transcript/", { path: filePath });
121
- return filePath;
122
- };
123
- const readRawTranscript = async (finalOutputPath) => {
124
- const finalDir = path.dirname(finalOutputPath);
125
- const ext = path.extname(finalOutputPath);
126
- const finalBasename = path.basename(finalOutputPath, ext);
127
- const rawTranscriptPath = path.join(finalDir, ".transcript", `${finalBasename}.json`);
128
- try {
129
- const content = await fs.readFile(rawTranscriptPath, "utf-8");
130
- return JSON.parse(content);
131
- } catch (error) {
132
- if (error && typeof error === "object" && "code" in error && error.code === "ENOENT") {
133
- logger.debug("No raw transcript found", { path: rawTranscriptPath });
134
- return null;
135
- }
136
- throw error;
137
- }
138
- };
139
- return {
140
- createOutputPaths,
141
- ensureDirectories,
142
- writeIntermediate,
143
- writeRawTranscript,
144
- writeTranscript,
145
- readRawTranscript,
146
- cleanIntermediates
147
- };
148
- };
4
+ var timezoneExports = requireTimezone();
5
+ const timezone = /*@__PURE__*/getDefaultExportFromCjs(timezoneExports);
149
6
 
150
- export { create };
7
+ export { timezone as default };
151
8
  //# sourceMappingURL=index60.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index60.js","sources":["../src/out/manager.ts"],"sourcesContent":["/**\n * Output Manager\n *\n * Manages intermediate files and final output destinations.\n * Follows the kodrdriv pattern for debugging and intermediate file management.\n * \n * PKL-only implementation - all transcripts are stored in PKL format.\n */\n\nimport * as path from 'node:path';\nimport * as fs from 'node:fs/promises';\nimport { randomUUID } from 'node:crypto';\nimport { OutputConfig, IntermediateFiles, OutputPaths, RawTranscriptData } from './types';\nimport * as Logging from '../logging';\nimport * as Metadata from '../util/metadata';\nimport { PklTranscript } from '@redaksjon/protokoll-format';\n\nexport interface ManagerInstance {\n createOutputPaths(\n audioFile: string,\n routedDestination: string,\n hash: string,\n date: Date\n ): OutputPaths;\n \n ensureDirectories(paths: OutputPaths): Promise<void>;\n \n writeIntermediate(\n paths: OutputPaths,\n type: keyof IntermediateFiles,\n content: unknown\n ): Promise<string>;\n \n /**\n * Write the raw Whisper transcript to the .transcript/ directory alongside final output.\n * This enables compare and reanalyze workflows.\n */\n writeRawTranscript(paths: OutputPaths, data: RawTranscriptData): Promise<string>;\n \n writeTranscript(paths: OutputPaths, content: string, metadata?: Metadata.TranscriptMetadata): Promise<string>;\n \n cleanIntermediates(paths: OutputPaths): Promise<void>;\n \n /**\n * Read a previously stored raw transcript from the .transcript/ directory.\n * Returns null if no raw transcript exists.\n */\n readRawTranscript(finalOutputPath: string): Promise<RawTranscriptData | null>;\n}\n\nexport const create = (config: OutputConfig): ManagerInstance => {\n const logger = Logging.getLogger();\n \n const formatTimestamp = (date: Date): string => {\n // Format: YYYY-MM-DD-HHmm (full year, dashes for separation)\n const pad = (n: number) => n.toString().padStart(2, '0');\n const year = date.getFullYear().toString();\n const month = pad(date.getMonth() + 1);\n const day = pad(date.getDate());\n const hours = pad(date.getHours());\n const minutes = pad(date.getMinutes());\n return `${year}-${month}-${day}-${hours}${minutes}`;\n };\n \n const createOutputPaths = (\n _audioFile: string,\n routedDestination: string,\n hash: string,\n date: Date\n ): OutputPaths => {\n const timestamp = formatTimestamp(date);\n const shortHash = hash.slice(0, 6);\n // Hash at the end for easier filename correlation\n const buildFilename = (type: string, ext: string) => `${timestamp}-${type}-${shortHash}${ext}`;\n \n const intermediateDir = config.intermediateDir;\n \n // Ensure final path uses .pkl extension\n let finalPath = routedDestination;\n if (finalPath.endsWith('.md')) {\n finalPath = finalPath.replace(/\\.md$/, '.pkl');\n } else if (!finalPath.endsWith('.pkl')) {\n finalPath = finalPath + '.pkl';\n }\n\n // Generate raw transcript path in .transcript/ directory alongside final output\n // e.g., /notes/2026/1/14-meeting.pkl -> /notes/2026/1/.transcript/14-meeting.json\n const finalDir = path.dirname(finalPath);\n const finalBasename = path.basename(finalPath, '.pkl');\n const rawTranscriptPath = path.join(finalDir, '.transcript', `${finalBasename}.json`);\n\n return {\n final: finalPath,\n rawTranscript: rawTranscriptPath,\n intermediate: {\n transcript: path.join(intermediateDir, buildFilename('transcript', '.json')),\n context: path.join(intermediateDir, buildFilename('context', '.json')),\n request: path.join(intermediateDir, buildFilename('request', '.json')),\n response: path.join(intermediateDir, buildFilename('response', '.json')),\n reflection: path.join(intermediateDir, buildFilename('reflection', '.md')),\n session: path.join(intermediateDir, buildFilename('session', '.json')),\n },\n };\n };\n \n const ensureDirectories = async (paths: OutputPaths): Promise<void> => {\n // Ensure intermediate directory\n await fs.mkdir(path.dirname(paths.intermediate.transcript), { recursive: true });\n \n // Ensure final directory\n await fs.mkdir(path.dirname(paths.final), { recursive: true });\n \n // Ensure .transcript directory alongside final output\n await fs.mkdir(path.dirname(paths.rawTranscript), { recursive: true });\n \n logger.debug('Ensured output directories', {\n intermediate: path.dirname(paths.intermediate.transcript),\n final: path.dirname(paths.final),\n rawTranscript: path.dirname(paths.rawTranscript),\n });\n };\n \n const writeIntermediate = async (\n paths: OutputPaths,\n type: keyof IntermediateFiles,\n content: unknown\n ): Promise<string> => {\n const filePath = paths.intermediate[type];\n if (!filePath) {\n throw new Error(`Invalid intermediate type: ${type}`);\n }\n \n const contentStr = typeof content === 'string' \n ? content \n : JSON.stringify(content, null, 2);\n \n await fs.writeFile(filePath, contentStr, 'utf-8');\n logger.debug('Wrote intermediate file', { type, path: filePath });\n \n return filePath;\n };\n \n const writeTranscript = async (\n paths: OutputPaths,\n content: string,\n metadata?: Metadata.TranscriptMetadata\n ): Promise<string> => {\n // Create PKL transcript\n // Convert routing metadata to PKL format (signals are strings in PKL)\n const pklRouting = metadata?.routing ? {\n destination: metadata.routing.destination,\n confidence: metadata.routing.confidence,\n signals: metadata.routing.signals?.map(s => \n typeof s === 'string' ? s : `${s.type}: ${s.value} (weight: ${s.weight})`\n ),\n reasoning: metadata.routing.reasoning,\n } : undefined;\n \n const pklMetadata = metadata ? {\n id: metadata.id || randomUUID(), // Use provided UUID or generate new one\n title: metadata.title,\n date: metadata.date,\n recordingTime: metadata.recordingTime,\n project: metadata.project,\n projectId: metadata.projectId,\n tags: metadata.tags || [],\n duration: metadata.duration,\n status: metadata.status || 'initial' as const,\n entities: metadata.entities,\n routing: pklRouting,\n } : {\n id: randomUUID(),\n title: 'Untitled',\n tags: [],\n status: 'initial' as const,\n };\n \n const transcript = PklTranscript.create(paths.final, pklMetadata);\n try {\n transcript.updateContent(content);\n logger.info('Wrote final transcript', { path: paths.final });\n } finally {\n transcript.close();\n }\n \n return paths.final;\n };\n \n const cleanIntermediates = async (paths: OutputPaths): Promise<void> => {\n if (config.keepIntermediates) {\n logger.debug('Keeping intermediate files');\n return;\n }\n \n for (const [type, filePath] of Object.entries(paths.intermediate)) {\n if (filePath) {\n try {\n await fs.unlink(filePath);\n logger.debug('Removed intermediate file', { type, path: filePath });\n } catch {\n // File might not exist, that's OK\n }\n }\n }\n };\n \n /**\n * Write the raw Whisper transcript to the .transcript/ directory.\n * This preserves the original transcription for compare/reanalyze workflows.\n */\n const writeRawTranscript = async (\n paths: OutputPaths,\n data: RawTranscriptData\n ): Promise<string> => {\n const filePath = paths.rawTranscript;\n \n await fs.writeFile(filePath, JSON.stringify(data, null, 2), 'utf-8');\n logger.debug('Wrote raw transcript to .transcript/', { path: filePath });\n \n return filePath;\n };\n \n /**\n * Read a previously stored raw transcript from the .transcript/ directory.\n * Calculates the path based on the final output path.\n * Returns null if no raw transcript exists.\n */\n const readRawTranscript = async (finalOutputPath: string): Promise<RawTranscriptData | null> => {\n const finalDir = path.dirname(finalOutputPath);\n const ext = path.extname(finalOutputPath);\n const finalBasename = path.basename(finalOutputPath, ext);\n const rawTranscriptPath = path.join(finalDir, '.transcript', `${finalBasename}.json`);\n \n try {\n const content = await fs.readFile(rawTranscriptPath, 'utf-8');\n return JSON.parse(content) as RawTranscriptData;\n } catch (error: unknown) {\n if (error && typeof error === 'object' && 'code' in error && error.code === 'ENOENT') {\n logger.debug('No raw transcript found', { path: rawTranscriptPath });\n return null;\n }\n throw error;\n }\n };\n \n return {\n createOutputPaths,\n ensureDirectories,\n writeIntermediate,\n writeRawTranscript,\n writeTranscript,\n readRawTranscript,\n cleanIntermediates,\n };\n};\n"],"names":["Logging.getLogger"],"mappings":"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"}
1
+ {"version":3,"file":"index60.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
package/dist/index61.js CHANGED
@@ -1,8 +1,8 @@
1
1
  import { getDefaultExportFromCjs } from './index67.js';
2
- import { __require as requireTimezone } from './index63.js';
2
+ import { __require as requireUtc } from './index65.js';
3
3
 
4
- var timezoneExports = requireTimezone();
5
- const timezone = /*@__PURE__*/getDefaultExportFromCjs(timezoneExports);
4
+ var utcExports = requireUtc();
5
+ const utc = /*@__PURE__*/getDefaultExportFromCjs(utcExports);
6
6
 
7
- export { timezone as default };
7
+ export { utc as default };
8
8
  //# sourceMappingURL=index61.js.map
package/dist/index62.js CHANGED
@@ -1,8 +1,151 @@
1
- import { getDefaultExportFromCjs } from './index67.js';
2
- import { __require as requireUtc } from './index65.js';
1
+ import * as path from 'node:path';
2
+ import * as fs from 'node:fs/promises';
3
+ import { randomUUID } from 'node:crypto';
4
+ import { getLogger } from './index47.js';
5
+ import { PklTranscript } from '@redaksjon/protokoll-format';
3
6
 
4
- var utcExports = requireUtc();
5
- const utc = /*@__PURE__*/getDefaultExportFromCjs(utcExports);
7
+ const create = (config) => {
8
+ const logger = getLogger();
9
+ const formatTimestamp = (date) => {
10
+ const pad = (n) => n.toString().padStart(2, "0");
11
+ const year = date.getFullYear().toString();
12
+ const month = pad(date.getMonth() + 1);
13
+ const day = pad(date.getDate());
14
+ const hours = pad(date.getHours());
15
+ const minutes = pad(date.getMinutes());
16
+ return `${year}-${month}-${day}-${hours}${minutes}`;
17
+ };
18
+ const createOutputPaths = (_audioFile, routedDestination, hash, date) => {
19
+ const timestamp = formatTimestamp(date);
20
+ const shortHash = hash.slice(0, 6);
21
+ const buildFilename = (type, ext) => `${timestamp}-${type}-${shortHash}${ext}`;
22
+ const intermediateDir = config.intermediateDir;
23
+ let finalPath = routedDestination;
24
+ if (finalPath.endsWith(".md")) {
25
+ finalPath = finalPath.replace(/\.md$/, ".pkl");
26
+ } else if (!finalPath.endsWith(".pkl")) {
27
+ finalPath = finalPath + ".pkl";
28
+ }
29
+ const finalDir = path.dirname(finalPath);
30
+ const finalBasename = path.basename(finalPath, ".pkl");
31
+ const rawTranscriptPath = path.join(finalDir, ".transcript", `${finalBasename}.json`);
32
+ return {
33
+ final: finalPath,
34
+ rawTranscript: rawTranscriptPath,
35
+ intermediate: {
36
+ transcript: path.join(intermediateDir, buildFilename("transcript", ".json")),
37
+ context: path.join(intermediateDir, buildFilename("context", ".json")),
38
+ request: path.join(intermediateDir, buildFilename("request", ".json")),
39
+ response: path.join(intermediateDir, buildFilename("response", ".json")),
40
+ reflection: path.join(intermediateDir, buildFilename("reflection", ".md")),
41
+ session: path.join(intermediateDir, buildFilename("session", ".json"))
42
+ }
43
+ };
44
+ };
45
+ const ensureDirectories = async (paths) => {
46
+ await fs.mkdir(path.dirname(paths.intermediate.transcript), { recursive: true });
47
+ await fs.mkdir(path.dirname(paths.final), { recursive: true });
48
+ await fs.mkdir(path.dirname(paths.rawTranscript), { recursive: true });
49
+ logger.debug("Ensured output directories", {
50
+ intermediate: path.dirname(paths.intermediate.transcript),
51
+ final: path.dirname(paths.final),
52
+ rawTranscript: path.dirname(paths.rawTranscript)
53
+ });
54
+ };
55
+ const writeIntermediate = async (paths, type, content) => {
56
+ const filePath = paths.intermediate[type];
57
+ if (!filePath) {
58
+ throw new Error(`Invalid intermediate type: ${type}`);
59
+ }
60
+ const contentStr = typeof content === "string" ? content : JSON.stringify(content, null, 2);
61
+ await fs.writeFile(filePath, contentStr, "utf-8");
62
+ logger.debug("Wrote intermediate file", { type, path: filePath });
63
+ return filePath;
64
+ };
65
+ const writeTranscript = async (paths, content, metadata) => {
66
+ const pklRouting = metadata?.routing ? {
67
+ destination: metadata.routing.destination,
68
+ confidence: metadata.routing.confidence,
69
+ signals: metadata.routing.signals?.map(
70
+ (s) => typeof s === "string" ? s : `${s.type}: ${s.value} (weight: ${s.weight})`
71
+ ),
72
+ reasoning: metadata.routing.reasoning
73
+ } : void 0;
74
+ const pklMetadata = metadata ? {
75
+ id: metadata.id || randomUUID(),
76
+ // Use provided UUID or generate new one
77
+ title: metadata.title,
78
+ date: metadata.date,
79
+ recordingTime: metadata.recordingTime,
80
+ project: metadata.project,
81
+ projectId: metadata.projectId,
82
+ tags: metadata.tags || [],
83
+ duration: metadata.duration,
84
+ status: metadata.status || "initial",
85
+ entities: metadata.entities,
86
+ routing: pklRouting
87
+ } : {
88
+ id: randomUUID(),
89
+ title: "Untitled",
90
+ tags: [],
91
+ status: "initial"
92
+ };
93
+ const transcript = PklTranscript.create(paths.final, pklMetadata);
94
+ try {
95
+ transcript.updateContent(content);
96
+ logger.info("Wrote final transcript", { path: paths.final });
97
+ } finally {
98
+ transcript.close();
99
+ }
100
+ return paths.final;
101
+ };
102
+ const cleanIntermediates = async (paths) => {
103
+ if (config.keepIntermediates) {
104
+ logger.debug("Keeping intermediate files");
105
+ return;
106
+ }
107
+ for (const [type, filePath] of Object.entries(paths.intermediate)) {
108
+ if (filePath) {
109
+ try {
110
+ await fs.unlink(filePath);
111
+ logger.debug("Removed intermediate file", { type, path: filePath });
112
+ } catch {
113
+ }
114
+ }
115
+ }
116
+ };
117
+ const writeRawTranscript = async (paths, data) => {
118
+ const filePath = paths.rawTranscript;
119
+ await fs.writeFile(filePath, JSON.stringify(data, null, 2), "utf-8");
120
+ logger.debug("Wrote raw transcript to .transcript/", { path: filePath });
121
+ return filePath;
122
+ };
123
+ const readRawTranscript = async (finalOutputPath) => {
124
+ const finalDir = path.dirname(finalOutputPath);
125
+ const ext = path.extname(finalOutputPath);
126
+ const finalBasename = path.basename(finalOutputPath, ext);
127
+ const rawTranscriptPath = path.join(finalDir, ".transcript", `${finalBasename}.json`);
128
+ try {
129
+ const content = await fs.readFile(rawTranscriptPath, "utf-8");
130
+ return JSON.parse(content);
131
+ } catch (error) {
132
+ if (error && typeof error === "object" && "code" in error && error.code === "ENOENT") {
133
+ logger.debug("No raw transcript found", { path: rawTranscriptPath });
134
+ return null;
135
+ }
136
+ throw error;
137
+ }
138
+ };
139
+ return {
140
+ createOutputPaths,
141
+ ensureDirectories,
142
+ writeIntermediate,
143
+ writeRawTranscript,
144
+ writeTranscript,
145
+ readRawTranscript,
146
+ cleanIntermediates
147
+ };
148
+ };
6
149
 
7
- export { utc as default };
150
+ export { create };
8
151
  //# sourceMappingURL=index62.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index62.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
1
+ {"version":3,"file":"index62.js","sources":["../src/out/manager.ts"],"sourcesContent":["/**\n * Output Manager\n *\n * Manages intermediate files and final output destinations.\n * Follows the kodrdriv pattern for debugging and intermediate file management.\n * \n * PKL-only implementation - all transcripts are stored in PKL format.\n */\n\nimport * as path from 'node:path';\nimport * as fs from 'node:fs/promises';\nimport { randomUUID } from 'node:crypto';\nimport { OutputConfig, IntermediateFiles, OutputPaths, RawTranscriptData } from './types';\nimport * as Logging from '../logging';\nimport * as Metadata from '../util/metadata';\nimport { PklTranscript } from '@redaksjon/protokoll-format';\n\nexport interface ManagerInstance {\n createOutputPaths(\n audioFile: string,\n routedDestination: string,\n hash: string,\n date: Date\n ): OutputPaths;\n \n ensureDirectories(paths: OutputPaths): Promise<void>;\n \n writeIntermediate(\n paths: OutputPaths,\n type: keyof IntermediateFiles,\n content: unknown\n ): Promise<string>;\n \n /**\n * Write the raw Whisper transcript to the .transcript/ directory alongside final output.\n * This enables compare and reanalyze workflows.\n */\n writeRawTranscript(paths: OutputPaths, data: RawTranscriptData): Promise<string>;\n \n writeTranscript(paths: OutputPaths, content: string, metadata?: Metadata.TranscriptMetadata): Promise<string>;\n \n cleanIntermediates(paths: OutputPaths): Promise<void>;\n \n /**\n * Read a previously stored raw transcript from the .transcript/ directory.\n * Returns null if no raw transcript exists.\n */\n readRawTranscript(finalOutputPath: string): Promise<RawTranscriptData | null>;\n}\n\nexport const create = (config: OutputConfig): ManagerInstance => {\n const logger = Logging.getLogger();\n \n const formatTimestamp = (date: Date): string => {\n // Format: YYYY-MM-DD-HHmm (full year, dashes for separation)\n const pad = (n: number) => n.toString().padStart(2, '0');\n const year = date.getFullYear().toString();\n const month = pad(date.getMonth() + 1);\n const day = pad(date.getDate());\n const hours = pad(date.getHours());\n const minutes = pad(date.getMinutes());\n return `${year}-${month}-${day}-${hours}${minutes}`;\n };\n \n const createOutputPaths = (\n _audioFile: string,\n routedDestination: string,\n hash: string,\n date: Date\n ): OutputPaths => {\n const timestamp = formatTimestamp(date);\n const shortHash = hash.slice(0, 6);\n // Hash at the end for easier filename correlation\n const buildFilename = (type: string, ext: string) => `${timestamp}-${type}-${shortHash}${ext}`;\n \n const intermediateDir = config.intermediateDir;\n \n // Ensure final path uses .pkl extension\n let finalPath = routedDestination;\n if (finalPath.endsWith('.md')) {\n finalPath = finalPath.replace(/\\.md$/, '.pkl');\n } else if (!finalPath.endsWith('.pkl')) {\n finalPath = finalPath + '.pkl';\n }\n\n // Generate raw transcript path in .transcript/ directory alongside final output\n // e.g., /notes/2026/1/14-meeting.pkl -> /notes/2026/1/.transcript/14-meeting.json\n const finalDir = path.dirname(finalPath);\n const finalBasename = path.basename(finalPath, '.pkl');\n const rawTranscriptPath = path.join(finalDir, '.transcript', `${finalBasename}.json`);\n\n return {\n final: finalPath,\n rawTranscript: rawTranscriptPath,\n intermediate: {\n transcript: path.join(intermediateDir, buildFilename('transcript', '.json')),\n context: path.join(intermediateDir, buildFilename('context', '.json')),\n request: path.join(intermediateDir, buildFilename('request', '.json')),\n response: path.join(intermediateDir, buildFilename('response', '.json')),\n reflection: path.join(intermediateDir, buildFilename('reflection', '.md')),\n session: path.join(intermediateDir, buildFilename('session', '.json')),\n },\n };\n };\n \n const ensureDirectories = async (paths: OutputPaths): Promise<void> => {\n // Ensure intermediate directory\n await fs.mkdir(path.dirname(paths.intermediate.transcript), { recursive: true });\n \n // Ensure final directory\n await fs.mkdir(path.dirname(paths.final), { recursive: true });\n \n // Ensure .transcript directory alongside final output\n await fs.mkdir(path.dirname(paths.rawTranscript), { recursive: true });\n \n logger.debug('Ensured output directories', {\n intermediate: path.dirname(paths.intermediate.transcript),\n final: path.dirname(paths.final),\n rawTranscript: path.dirname(paths.rawTranscript),\n });\n };\n \n const writeIntermediate = async (\n paths: OutputPaths,\n type: keyof IntermediateFiles,\n content: unknown\n ): Promise<string> => {\n const filePath = paths.intermediate[type];\n if (!filePath) {\n throw new Error(`Invalid intermediate type: ${type}`);\n }\n \n const contentStr = typeof content === 'string' \n ? content \n : JSON.stringify(content, null, 2);\n \n await fs.writeFile(filePath, contentStr, 'utf-8');\n logger.debug('Wrote intermediate file', { type, path: filePath });\n \n return filePath;\n };\n \n const writeTranscript = async (\n paths: OutputPaths,\n content: string,\n metadata?: Metadata.TranscriptMetadata\n ): Promise<string> => {\n // Create PKL transcript\n // Convert routing metadata to PKL format (signals are strings in PKL)\n const pklRouting = metadata?.routing ? {\n destination: metadata.routing.destination,\n confidence: metadata.routing.confidence,\n signals: metadata.routing.signals?.map(s => \n typeof s === 'string' ? s : `${s.type}: ${s.value} (weight: ${s.weight})`\n ),\n reasoning: metadata.routing.reasoning,\n } : undefined;\n \n const pklMetadata = metadata ? {\n id: metadata.id || randomUUID(), // Use provided UUID or generate new one\n title: metadata.title,\n date: metadata.date,\n recordingTime: metadata.recordingTime,\n project: metadata.project,\n projectId: metadata.projectId,\n tags: metadata.tags || [],\n duration: metadata.duration,\n status: metadata.status || 'initial' as const,\n entities: metadata.entities,\n routing: pklRouting,\n } : {\n id: randomUUID(),\n title: 'Untitled',\n tags: [],\n status: 'initial' as const,\n };\n \n const transcript = PklTranscript.create(paths.final, pklMetadata);\n try {\n transcript.updateContent(content);\n logger.info('Wrote final transcript', { path: paths.final });\n } finally {\n transcript.close();\n }\n \n return paths.final;\n };\n \n const cleanIntermediates = async (paths: OutputPaths): Promise<void> => {\n if (config.keepIntermediates) {\n logger.debug('Keeping intermediate files');\n return;\n }\n \n for (const [type, filePath] of Object.entries(paths.intermediate)) {\n if (filePath) {\n try {\n await fs.unlink(filePath);\n logger.debug('Removed intermediate file', { type, path: filePath });\n } catch {\n // File might not exist, that's OK\n }\n }\n }\n };\n \n /**\n * Write the raw Whisper transcript to the .transcript/ directory.\n * This preserves the original transcription for compare/reanalyze workflows.\n */\n const writeRawTranscript = async (\n paths: OutputPaths,\n data: RawTranscriptData\n ): Promise<string> => {\n const filePath = paths.rawTranscript;\n \n await fs.writeFile(filePath, JSON.stringify(data, null, 2), 'utf-8');\n logger.debug('Wrote raw transcript to .transcript/', { path: filePath });\n \n return filePath;\n };\n \n /**\n * Read a previously stored raw transcript from the .transcript/ directory.\n * Calculates the path based on the final output path.\n * Returns null if no raw transcript exists.\n */\n const readRawTranscript = async (finalOutputPath: string): Promise<RawTranscriptData | null> => {\n const finalDir = path.dirname(finalOutputPath);\n const ext = path.extname(finalOutputPath);\n const finalBasename = path.basename(finalOutputPath, ext);\n const rawTranscriptPath = path.join(finalDir, '.transcript', `${finalBasename}.json`);\n \n try {\n const content = await fs.readFile(rawTranscriptPath, 'utf-8');\n return JSON.parse(content) as RawTranscriptData;\n } catch (error: unknown) {\n if (error && typeof error === 'object' && 'code' in error && error.code === 'ENOENT') {\n logger.debug('No raw transcript found', { path: rawTranscriptPath });\n return null;\n }\n throw error;\n }\n };\n \n return {\n createOutputPaths,\n ensureDirectories,\n writeIntermediate,\n writeRawTranscript,\n writeTranscript,\n readRawTranscript,\n cleanIntermediates,\n };\n};\n"],"names":["Logging.getLogger"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"operations.d.ts","sourceRoot":"","sources":["../../src/transcript/operations.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"operations.d.ts","sourceRoot":"","sources":["../../src/transcript/operations.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@redaksjon/protokoll-engine",
3
- "version": "0.1.7",
3
+ "version": "0.1.8-dev.20260221045945.bbdc773",
4
4
  "description": "Processing engine for Protokoll - transcription pipeline, agentic execution, routing, and LLM integration",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",