@redaksjon/protokoll-engine 0.1.14 → 0.1.15-dev.20260304211459.adfddc8

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/index58.js CHANGED
@@ -1,78 +1,45 @@
1
- import dayjs from 'dayjs';
2
- import timezone from './index60.js';
3
- import utc from './index61.js';
4
- import 'moment-timezone';
5
-
6
- dayjs.extend(utc);
7
- dayjs.extend(timezone);
8
- const create = (parameters) => {
9
- const { timezone: timezone2 } = parameters;
10
- const now = () => {
11
- return date(void 0);
12
- };
13
- const date = (date2) => {
14
- let value;
15
- try {
16
- if (date2) {
17
- value = dayjs.tz(date2, timezone2);
18
- } else {
19
- value = dayjs().tz(timezone2);
1
+ const create = (ctx) => ({
2
+ name: "route_note",
3
+ description: "Determine the destination for this note based on content analysis.",
4
+ parameters: {
5
+ type: "object",
6
+ properties: {
7
+ projectHint: {
8
+ type: "string",
9
+ description: "The detected project name or hint"
10
+ },
11
+ contentSummary: {
12
+ type: "string",
13
+ description: "Brief summary of what the note is about"
20
14
  }
21
- } catch (error) {
22
- throw new Error(`Invalid date: ${date2}, error: ${error.message}`);
23
- }
24
- return value.toDate();
25
- };
26
- const parse = (date2, format2) => {
27
- let value;
28
- try {
29
- value = dayjs.tz(date2, format2, timezone2);
30
- } catch (error) {
31
- throw new Error(`Invalid date: ${date2}, expected format: ${format2}, error: ${error.message}`);
32
15
  }
33
- return value.toDate();
34
- };
35
- const addDays = (date2, days) => {
36
- return dayjs.tz(date2, timezone2).add(days, "day").toDate();
37
- };
38
- const addMonths = (date2, months) => {
39
- return dayjs.tz(date2, timezone2).add(months, "month").toDate();
40
- };
41
- const addYears = (date2, years) => {
42
- return dayjs.tz(date2, timezone2).add(years, "year").toDate();
43
- };
44
- const format = (date2, format2) => {
45
- return dayjs.tz(date2, timezone2).format(format2);
46
- };
47
- const subDays = (date2, days) => {
48
- return dayjs.tz(date2, timezone2).subtract(days, "day").toDate();
49
- };
50
- const subMonths = (date2, months) => {
51
- return dayjs.tz(date2, timezone2).subtract(months, "month").toDate();
52
- };
53
- const subYears = (date2, years) => {
54
- return dayjs.tz(date2, timezone2).subtract(years, "year").toDate();
55
- };
56
- const startOfMonth = (date2) => {
57
- return dayjs.tz(date2, timezone2).startOf("month").toDate();
58
- };
59
- const endOfMonth = (date2) => {
60
- return dayjs.tz(date2, timezone2).endOf("month").toDate();
61
- };
62
- const startOfYear = (date2) => {
63
- return dayjs.tz(date2, timezone2).startOf("year").toDate();
64
- };
65
- const endOfYear = (date2) => {
66
- return dayjs.tz(date2, timezone2).endOf("year").toDate();
67
- };
68
- const isBefore = (date2, other) => {
69
- return dayjs.tz(date2, timezone2).isBefore(dayjs.tz(other, timezone2));
70
- };
71
- const isAfter = (date2, other) => {
72
- return dayjs.tz(date2, timezone2).isAfter(dayjs.tz(other, timezone2));
73
- };
74
- return { now, date, parse, addDays, addMonths, addYears, format, subDays, subMonths, subYears, startOfMonth, endOfMonth, startOfYear, endOfYear, isBefore, isAfter };
75
- };
16
+ },
17
+ execute: async (args) => {
18
+ const routing = ctx.routingInstance;
19
+ const routingContext = {
20
+ transcriptText: ctx.transcriptText,
21
+ audioDate: ctx.audioDate,
22
+ sourceFile: ctx.sourceFile
23
+ };
24
+ const decision = routing.route(routingContext);
25
+ const outputPath = routing.buildOutputPath(decision, routingContext);
26
+ return {
27
+ success: true,
28
+ data: {
29
+ projectId: decision.projectId,
30
+ // Return the routing decision (base path + structure), NOT the built output path
31
+ // The orchestrator will call buildOutputPath() later
32
+ routingDecision: decision,
33
+ // Also include the built path for informational purposes
34
+ outputPath,
35
+ confidence: decision.confidence,
36
+ reasoning: decision.reasoning,
37
+ projectHint: args.projectHint,
38
+ contentSummary: args.contentSummary
39
+ }
40
+ };
41
+ }
42
+ });
76
43
 
77
44
  export { create };
78
45
  //# sourceMappingURL=index58.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index58.js","sources":["../src/util/dates.ts"],"sourcesContent":["// eslint-disable-next-line no-restricted-imports\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\n// eslint-disable-next-line no-restricted-imports\nimport moment from 'moment-timezone';\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\n\n/**\n * Yes, wrapping dayjs is a bit annoying and might seem overly paranoid. However, I feel strongly\n * about not letting Dayjs instances leak into the rest of the codebase. Having Dayjs objects\n * floating around the application leads to inconsistent timezone handling, makes testing more\n * difficult, and creates subtle bugs that are hard to track down.\n * \n * By wrapping dayjs completely and only exposing plain JavaScript Date objects, we get several\n * key benefits:\n * 1. Consistent timezone handling through a single configuration point\n * 2. Simpler testing since we only need to mock this one library\n * 3. Type safety - the rest of the codebase only deals with standard Date objects\n * 4. No risk of dayjs method chains creating unexpected timezone shifts\n * \n * The Library interface gives us full control over all date operations while keeping the messy\n * details of timezone manipulation contained in one place. Yes it's more code, but the peace of\n * mind is worth it.\n */\nexport interface Utility {\n now: () => Date;\n date: (date: string | number | Date | null | undefined) => Date;\n parse: (date: string | number | Date | null | undefined, format: string) => Date;\n addDays: (date: Date, days: number) => Date;\n addMonths: (date: Date, months: number) => Date;\n addYears: (date: Date, years: number) => Date;\n format: (date: Date, format: string) => string;\n subDays: (date: Date, days: number) => Date;\n subMonths: (date: Date, months: number) => Date;\n subYears: (date: Date, years: number) => Date;\n startOfMonth: (date: Date) => Date;\n endOfMonth: (date: Date) => Date;\n startOfYear: (date: Date) => Date;\n endOfYear: (date: Date) => Date;\n isBefore: (date: Date, other: Date) => boolean;\n isAfter: (date: Date, other: Date) => boolean;\n}\n\nexport const create = (parameters: { timezone: string }) => {\n const { timezone } = parameters;\n const now = () => {\n return date(undefined);\n }\n\n const date = (date: string | number | Date | null | undefined) => {\n let value: dayjs.Dayjs;\n try {\n if (date) {\n value = dayjs.tz(date, timezone);\n } else {\n value = dayjs().tz(timezone);\n }\n } catch (error: any) {\n throw new Error(`Invalid date: ${date}, error: ${error.message}`);\n }\n\n return value.toDate();\n }\n\n const parse = (date: string | number | Date | null | undefined, format: string) => {\n let value: dayjs.Dayjs;\n try {\n value = dayjs.tz(date, format, timezone);\n } catch (error: any) {\n throw new Error(`Invalid date: ${date}, expected format: ${format}, error: ${error.message}`);\n }\n\n return value.toDate();\n }\n\n const addDays = (date: Date, days: number) => {\n return dayjs.tz(date, timezone).add(days, 'day').toDate();\n }\n\n const addMonths = (date: Date, months: number) => {\n return dayjs.tz(date, timezone).add(months, 'month').toDate();\n }\n\n const addYears = (date: Date, years: number) => {\n return dayjs.tz(date, timezone).add(years, 'year').toDate();\n }\n\n const format = (date: Date, format: string) => {\n return dayjs.tz(date, timezone).format(format);\n }\n\n const subDays = (date: Date, days: number) => {\n return dayjs.tz(date, timezone).subtract(days, 'day').toDate();\n }\n\n const subMonths = (date: Date, months: number) => {\n return dayjs.tz(date, timezone).subtract(months, 'month').toDate();\n }\n\n const subYears = (date: Date, years: number) => {\n return dayjs.tz(date, timezone).subtract(years, 'year').toDate();\n }\n\n const startOfMonth = (date: Date) => {\n return dayjs.tz(date, timezone).startOf('month').toDate();\n }\n\n const endOfMonth = (date: Date) => {\n return dayjs.tz(date, timezone).endOf('month').toDate();\n }\n\n const startOfYear = (date: Date) => {\n return dayjs.tz(date, timezone).startOf('year').toDate();\n }\n\n const endOfYear = (date: Date) => {\n return dayjs.tz(date, timezone).endOf('year').toDate();\n }\n\n const isBefore = (date: Date, other: Date) => {\n return dayjs.tz(date, timezone).isBefore(dayjs.tz(other, timezone));\n }\n\n const isAfter = (date: Date, other: Date) => {\n return dayjs.tz(date, timezone).isAfter(dayjs.tz(other, timezone));\n }\n\n return { now, date, parse, addDays, addMonths, addYears, format, subDays, subMonths, subYears, startOfMonth, endOfMonth, startOfYear, endOfYear, isBefore, isAfter };\n}\n\nexport const validTimezones = () => {\n return moment.tz.names();\n}\n"],"names":["timezone","date","format"],"mappings":"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"}
1
+ {"version":3,"file":"index58.js","sources":["../src/agentic/tools/route-note.ts"],"sourcesContent":["/**\n * Route Note Tool\n * \n * Determines the destination for a note based on content analysis.\n */\n\nimport { TranscriptionTool, ToolContext, ToolResult } from '../types';\n\nexport const create = (ctx: ToolContext): TranscriptionTool => ({\n name: 'route_note',\n description: 'Determine the destination for this note based on content analysis.',\n parameters: {\n type: 'object',\n properties: {\n projectHint: {\n type: 'string',\n description: 'The detected project name or hint',\n },\n contentSummary: {\n type: 'string',\n description: 'Brief summary of what the note is about',\n },\n },\n },\n execute: async (args: { projectHint?: string; contentSummary?: string }): Promise<ToolResult> => {\n const routing = ctx.routingInstance;\n \n const routingContext = {\n transcriptText: ctx.transcriptText,\n audioDate: ctx.audioDate,\n sourceFile: ctx.sourceFile,\n };\n \n const decision = routing.route(routingContext);\n const outputPath = routing.buildOutputPath(decision, routingContext);\n \n return {\n success: true,\n data: {\n projectId: decision.projectId,\n // Return the routing decision (base path + structure), NOT the built output path\n // The orchestrator will call buildOutputPath() later\n routingDecision: decision,\n // Also include the built path for informational purposes\n outputPath: outputPath,\n confidence: decision.confidence,\n reasoning: decision.reasoning,\n projectHint: args.projectHint,\n contentSummary: args.contentSummary,\n },\n };\n },\n});\n\n"],"names":[],"mappings":"AAQO,MAAM,MAAA,GAAS,CAAC,GAAA,MAAyC;AAAA,EAC5D,IAAA,EAAM,YAAA;AAAA,EACN,WAAA,EAAa,oEAAA;AAAA,EACb,UAAA,EAAY;AAAA,IACR,IAAA,EAAM,QAAA;AAAA,IACN,UAAA,EAAY;AAAA,MACR,WAAA,EAAa;AAAA,QACT,IAAA,EAAM,QAAA;AAAA,QACN,WAAA,EAAa;AAAA,OACjB;AAAA,MACA,cAAA,EAAgB;AAAA,QACZ,IAAA,EAAM,QAAA;AAAA,QACN,WAAA,EAAa;AAAA;AACjB;AACJ,GACJ;AAAA,EACA,OAAA,EAAS,OAAO,IAAA,KAAiF;AAC7F,IAAA,MAAM,UAAU,GAAA,CAAI,eAAA;AAEpB,IAAA,MAAM,cAAA,GAAiB;AAAA,MACnB,gBAAgB,GAAA,CAAI,cAAA;AAAA,MACpB,WAAW,GAAA,CAAI,SAAA;AAAA,MACf,YAAY,GAAA,CAAI;AAAA,KACpB;AAEA,IAAA,MAAM,QAAA,GAAW,OAAA,CAAQ,KAAA,CAAM,cAAc,CAAA;AAC7C,IAAA,MAAM,UAAA,GAAa,OAAA,CAAQ,eAAA,CAAgB,QAAA,EAAU,cAAc,CAAA;AAEnE,IAAA,OAAO;AAAA,MACH,OAAA,EAAS,IAAA;AAAA,MACT,IAAA,EAAM;AAAA,QACF,WAAW,QAAA,CAAS,SAAA;AAAA;AAAA;AAAA,QAGpB,eAAA,EAAiB,QAAA;AAAA;AAAA,QAEjB,UAAA;AAAA,QACA,YAAY,QAAA,CAAS,UAAA;AAAA,QACrB,WAAW,QAAA,CAAS,SAAA;AAAA,QACpB,aAAa,IAAA,CAAK,WAAA;AAAA,QAClB,gBAAgB,IAAA,CAAK;AAAA;AACzB,KACJ;AAAA,EACJ;AACJ,CAAA;;;;"}
package/dist/index59.js CHANGED
@@ -1,8 +1,37 @@
1
- import { create as create$1 } from './index62.js';
2
-
3
- const create = (config) => {
4
- return create$1(config);
5
- };
1
+ const create = (_ctx) => ({
2
+ name: "store_context",
3
+ description: "Store new context information for future use. Use when you learn something new that should be remembered.",
4
+ parameters: {
5
+ type: "object",
6
+ properties: {
7
+ entityType: {
8
+ type: "string",
9
+ enum: ["person", "project", "company", "term"],
10
+ description: "Type of entity to store"
11
+ },
12
+ name: {
13
+ type: "string",
14
+ description: "Name of the entity"
15
+ },
16
+ details: {
17
+ type: "object",
18
+ description: "Additional details about the entity"
19
+ }
20
+ },
21
+ required: ["entityType", "name"]
22
+ },
23
+ execute: async (args) => {
24
+ return {
25
+ success: true,
26
+ data: {
27
+ stored: false,
28
+ message: "Context storage requires --self-update flag. Information noted but not persisted.",
29
+ entityType: args.entityType,
30
+ name: args.name
31
+ }
32
+ };
33
+ }
34
+ });
6
35
 
7
36
  export { create };
8
37
  //# sourceMappingURL=index59.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index59.js","sources":["../src/out/index.ts"],"sourcesContent":["/**\n * Output Management System\n *\n * Main entry point for the output management system. Handles intermediate\n * files and final output destinations.\n */\n\nimport { OutputConfig, OutputPaths, IntermediateFiles, RawTranscriptData } from './types';\nimport * as Manager from './manager';\nimport * as Metadata from '../util/metadata';\n\nexport interface OutputInstance {\n createOutputPaths(\n audioFile: string,\n routedDestination: string,\n hash: string,\n date: Date\n ): OutputPaths;\n ensureDirectories(paths: OutputPaths): Promise<void>;\n writeIntermediate(\n paths: OutputPaths,\n type: keyof IntermediateFiles,\n content: unknown\n ): Promise<string>;\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 writeTranscript(paths: OutputPaths, content: string, metadata?: Metadata.TranscriptMetadata): Promise<string>;\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 cleanIntermediates(paths: OutputPaths): Promise<void>;\n}\n\nexport const create = (config: OutputConfig): OutputInstance => {\n return Manager.create(config);\n};\n\nexport const DEFAULT_OUTPUT_CONFIG: OutputConfig = {\n intermediateDir: './output/protokoll',\n keepIntermediates: true,\n timestampFormat: 'YYMMDD-HHmm',\n};\n\n// Re-export types\nexport * from './types';\n"],"names":["Manager.create"],"mappings":";;AAsCO,MAAM,MAAA,GAAS,CAAC,MAAA,KAAyC;AAC5D,EAAA,OAAOA,SAAe,MAAM,CAAA;AAChC;;;;"}
1
+ {"version":3,"file":"index59.js","sources":["../src/agentic/tools/store-context.ts"],"sourcesContent":["/**\n * Store Context Tool\n * \n * Stores new context information for future use.\n */\n\nimport { TranscriptionTool, ToolContext, ToolResult } from '../types';\n\nexport const create = (_ctx: ToolContext): TranscriptionTool => ({\n name: 'store_context',\n description: 'Store new context information for future use. Use when you learn something new that should be remembered.',\n parameters: {\n type: 'object',\n properties: {\n entityType: {\n type: 'string',\n enum: ['person', 'project', 'company', 'term'],\n description: 'Type of entity to store',\n },\n name: {\n type: 'string',\n description: 'Name of the entity',\n },\n details: {\n type: 'object',\n description: 'Additional details about the entity',\n },\n },\n required: ['entityType', 'name'],\n },\n \n execute: async (args: { entityType: string; name: string; details?: any }): Promise<ToolResult> => {\n // This tool requires --self-update flag to actually persist\n // Otherwise it just acknowledges without saving\n \n return {\n success: true,\n data: {\n stored: false,\n message: 'Context storage requires --self-update flag. Information noted but not persisted.',\n entityType: args.entityType,\n name: args.name,\n },\n };\n },\n});\n\n"],"names":[],"mappings":"AAQO,MAAM,MAAA,GAAS,CAAC,IAAA,MAA0C;AAAA,EAC7D,IAAA,EAAM,eAAA;AAAA,EACN,WAAA,EAAa,2GAAA;AAAA,EACb,UAAA,EAAY;AAAA,IACR,IAAA,EAAM,QAAA;AAAA,IACN,UAAA,EAAY;AAAA,MACR,UAAA,EAAY;AAAA,QACR,IAAA,EAAM,QAAA;AAAA,QACN,IAAA,EAAM,CAAC,QAAA,EAAU,SAAA,EAAW,WAAW,MAAM,CAAA;AAAA,QAC7C,WAAA,EAAa;AAAA,OACjB;AAAA,MACA,IAAA,EAAM;AAAA,QACF,IAAA,EAAM,QAAA;AAAA,QACN,WAAA,EAAa;AAAA,OACjB;AAAA,MACA,OAAA,EAAS;AAAA,QACL,IAAA,EAAM,QAAA;AAAA,QACN,WAAA,EAAa;AAAA;AACjB,KACJ;AAAA,IACA,QAAA,EAAU,CAAC,YAAA,EAAc,MAAM;AAAA,GACnC;AAAA,EAEA,OAAA,EAAS,OAAO,IAAA,KAAmF;AAI/F,IAAA,OAAO;AAAA,MACH,OAAA,EAAS,IAAA;AAAA,MACT,IAAA,EAAM;AAAA,QACF,MAAA,EAAQ,KAAA;AAAA,QACR,OAAA,EAAS,mFAAA;AAAA,QACT,YAAY,IAAA,CAAK,UAAA;AAAA,QACjB,MAAM,IAAA,CAAK;AAAA;AACf,KACJ;AAAA,EACJ;AACJ,CAAA;;;;"}
package/dist/index60.js CHANGED
@@ -1,8 +1,151 @@
1
- import { getDefaultExportFromCjs } from './index67.js';
2
- import { __require as requireTimezone } from './index63.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 timezoneExports = requireTimezone();
5
- const timezone = /*@__PURE__*/getDefaultExportFromCjs(timezoneExports);
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 { timezone as default };
150
+ export { create };
8
151
  //# sourceMappingURL=index60.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index60.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
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 // Compatibility cast: engine metadata can include newer statuses than\n // the currently installed protokoll-format type declarations.\n const transcript = PklTranscript.create(paths.final, pklMetadata as any);\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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"}
package/dist/index61.js CHANGED
@@ -1,8 +1,8 @@
1
1
  import { getDefaultExportFromCjs } from './index67.js';
2
- import { __require as requireUtc } from './index65.js';
2
+ import { __require as requireTimezone } from './index63.js';
3
3
 
4
- var utcExports = requireUtc();
5
- const utc = /*@__PURE__*/getDefaultExportFromCjs(utcExports);
4
+ var timezoneExports = requireTimezone();
5
+ const timezone = /*@__PURE__*/getDefaultExportFromCjs(timezoneExports);
6
6
 
7
- export { utc as default };
7
+ export { timezone as default };
8
8
  //# sourceMappingURL=index61.js.map
package/dist/index62.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 requireUtc } from './index65.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 utcExports = requireUtc();
5
+ const utc = /*@__PURE__*/getDefaultExportFromCjs(utcExports);
149
6
 
150
- export { create };
7
+ export { utc as default };
151
8
  //# sourceMappingURL=index62.js.map
@@ -1 +1 @@
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 // Compatibility cast: engine metadata can include newer statuses than\n // the currently installed protokoll-format type declarations.\n const transcript = PklTranscript.create(paths.final, pklMetadata as any);\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":"index62.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
@@ -17,6 +17,7 @@ type PklMetadata = {
17
17
  duration?: string;
18
18
  status?: string;
19
19
  tasks?: unknown[];
20
+ comments?: unknown[];
20
21
  entities?: unknown;
21
22
  history?: unknown;
22
23
  title?: string;