@narrative-os/engine 0.1.0

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.
Files changed (71) hide show
  1. package/dist/agents/canonValidator.d.ts +9 -0
  2. package/dist/agents/canonValidator.js +51 -0
  3. package/dist/agents/chapterPlanner.d.ts +50 -0
  4. package/dist/agents/chapterPlanner.js +250 -0
  5. package/dist/agents/completeness.d.ts +7 -0
  6. package/dist/agents/completeness.js +51 -0
  7. package/dist/agents/memoryExtractor.d.ts +12 -0
  8. package/dist/agents/memoryExtractor.js +82 -0
  9. package/dist/agents/stateUpdater.d.ts +30 -0
  10. package/dist/agents/stateUpdater.js +150 -0
  11. package/dist/agents/storyDirector.d.ts +40 -0
  12. package/dist/agents/storyDirector.js +213 -0
  13. package/dist/agents/summarizer.d.ts +8 -0
  14. package/dist/agents/summarizer.js +56 -0
  15. package/dist/agents/tensionController.d.ts +68 -0
  16. package/dist/agents/tensionController.js +197 -0
  17. package/dist/agents/writer.d.ts +12 -0
  18. package/dist/agents/writer.js +148 -0
  19. package/dist/constraints/constraintGraph.d.ts +117 -0
  20. package/dist/constraints/constraintGraph.js +381 -0
  21. package/dist/constraints/validator.d.ts +58 -0
  22. package/dist/constraints/validator.js +236 -0
  23. package/dist/index.d.ts +25 -0
  24. package/dist/index.js +115 -0
  25. package/dist/llm/client.d.ts +14 -0
  26. package/dist/llm/client.js +108 -0
  27. package/dist/memory/canonStore.d.ts +20 -0
  28. package/dist/memory/canonStore.js +110 -0
  29. package/dist/memory/memoryRetriever.d.ts +28 -0
  30. package/dist/memory/memoryRetriever.js +126 -0
  31. package/dist/memory/stateUpdater.d.ts +49 -0
  32. package/dist/memory/stateUpdater.js +315 -0
  33. package/dist/memory/vectorStore.d.ts +41 -0
  34. package/dist/memory/vectorStore.js +166 -0
  35. package/dist/pipeline/generateChapter.d.ts +17 -0
  36. package/dist/pipeline/generateChapter.js +75 -0
  37. package/dist/story/bible.d.ts +4 -0
  38. package/dist/story/bible.js +53 -0
  39. package/dist/story/state.d.ts +3 -0
  40. package/dist/story/state.js +27 -0
  41. package/dist/story/structuredState.d.ts +39 -0
  42. package/dist/story/structuredState.js +159 -0
  43. package/dist/test/canon.test.d.ts +1 -0
  44. package/dist/test/canon.test.js +104 -0
  45. package/dist/test/chapter-planner.test.d.ts +1 -0
  46. package/dist/test/chapter-planner.test.js +171 -0
  47. package/dist/test/constraints.test.d.ts +1 -0
  48. package/dist/test/constraints.test.js +210 -0
  49. package/dist/test/simple.test.d.ts +1 -0
  50. package/dist/test/simple.test.js +51 -0
  51. package/dist/test/state-updater.test.d.ts +1 -0
  52. package/dist/test/state-updater.test.js +200 -0
  53. package/dist/test/story-director.test.d.ts +1 -0
  54. package/dist/test/story-director.test.js +142 -0
  55. package/dist/test/structured-state.test.d.ts +1 -0
  56. package/dist/test/structured-state.test.js +144 -0
  57. package/dist/test/tension-controller.test.d.ts +1 -0
  58. package/dist/test/tension-controller.test.js +116 -0
  59. package/dist/test/vector-memory.test.d.ts +1 -0
  60. package/dist/test/vector-memory.test.js +153 -0
  61. package/dist/test/world-simulation.test.d.ts +1 -0
  62. package/dist/test/world-simulation.test.js +152 -0
  63. package/dist/types/index.d.ts +79 -0
  64. package/dist/types/index.js +3 -0
  65. package/dist/world/characterAgent.d.ts +73 -0
  66. package/dist/world/characterAgent.js +232 -0
  67. package/dist/world/eventResolver.d.ts +52 -0
  68. package/dist/world/eventResolver.js +205 -0
  69. package/dist/world/worldState.d.ts +93 -0
  70. package/dist/world/worldState.js +258 -0
  71. package/package.json +43 -0
@@ -0,0 +1,236 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.validator = exports.Validator = void 0;
4
+ const client_js_1 = require("../llm/client.js");
5
+ const constraintGraph_js_1 = require("./constraintGraph.js");
6
+ const VALIDATOR_PROMPT = `You are a narrative validator. Check this chapter for consistency issues.
7
+
8
+ ## Story Bible
9
+
10
+ **Title:** {{title}}
11
+ **Setting:** {{setting}}
12
+
13
+ ## Canon Facts (must never be violated)
14
+ {{canon}}
15
+
16
+ ## Current Story State
17
+
18
+ **Chapter:** {{chapterNumber}}
19
+
20
+ ### Character States
21
+ {{characters}}
22
+
23
+ ### Plot Threads
24
+ {{plotThreads}}
25
+
26
+ ## Chapter to Validate
27
+
28
+ **Title:** {{chapterTitle}}
29
+
30
+ {{chapterContent}}
31
+
32
+ ## Your Task
33
+
34
+ Check for these types of errors:
35
+
36
+ 1. **Canon Violations**: Does the chapter contradict any established facts?
37
+ 2. **Character Consistency**: Do characters act according to their established personality?
38
+ 3. **Location Errors**: Are characters in places they couldn't be? Is travel time realistic?
39
+ 4. **Knowledge Leaks**: Do characters know things they shouldn't know yet?
40
+ 5. **Timeline Errors**: Are events in the right order?
41
+ 6. **Logic Errors**: Any impossible or contradictory situations?
42
+
43
+ Output JSON:
44
+ {
45
+ "valid": true/false,
46
+ "violations": [
47
+ {
48
+ "type": "canon|character|location|knowledge|timeline|logic",
49
+ "severity": "error|warning",
50
+ "description": "Detailed description of the issue",
51
+ "suggestedFix": "How to fix this issue"
52
+ }
53
+ ],
54
+ "summary": "Overall assessment of chapter consistency"
55
+ }`;
56
+ class Validator {
57
+ constraintGraph;
58
+ constructor(constraintGraph) {
59
+ this.constraintGraph = constraintGraph || new constraintGraph_js_1.ConstraintGraph();
60
+ }
61
+ /**
62
+ * Validate a chapter using both graph-based and LLM-based checks
63
+ */
64
+ async validateChapter(context) {
65
+ const { chapter, bible, structuredState, canon, constraintGraph } = context;
66
+ // Graph-based validation
67
+ const graphViolations = constraintGraph.checkConstraints(chapter.number);
68
+ // LLM-based validation
69
+ let llmViolations = [];
70
+ try {
71
+ llmViolations = await this.llmValidate(context);
72
+ }
73
+ catch (error) {
74
+ // If LLM fails, rely on graph validation only
75
+ console.log('LLM validation failed, using graph validation only');
76
+ }
77
+ // Combine violations
78
+ const allViolations = [...graphViolations, ...llmViolations];
79
+ // Remove duplicates (same description)
80
+ const uniqueViolations = allViolations.filter((v, i, a) => a.findIndex(t => t.description === v.description) === i);
81
+ // Generate summary
82
+ const errorCount = uniqueViolations.filter(v => v.severity === 'error').length;
83
+ const warningCount = uniqueViolations.filter(v => v.severity === 'warning').length;
84
+ let summary;
85
+ if (errorCount === 0 && warningCount === 0) {
86
+ summary = 'Chapter is consistent with story canon and state.';
87
+ }
88
+ else if (errorCount === 0) {
89
+ summary = `Chapter has ${warningCount} warning(s) but no critical errors.`;
90
+ }
91
+ else {
92
+ summary = `Chapter has ${errorCount} error(s) and ${warningCount} warning(s) that need attention.`;
93
+ }
94
+ return {
95
+ valid: errorCount === 0,
96
+ violations: uniqueViolations,
97
+ summary,
98
+ };
99
+ }
100
+ /**
101
+ * LLM-based validation
102
+ */
103
+ async llmValidate(context) {
104
+ const { chapter, bible, structuredState, canon } = context;
105
+ const prompt = VALIDATOR_PROMPT
106
+ .replace('{{title}}', bible.title)
107
+ .replace('{{setting}}', bible.setting)
108
+ .replace('{{canon}}', this.formatCanon(canon))
109
+ .replace('{{chapterNumber}}', chapter.number.toString())
110
+ .replace('{{characters}}', this.formatCharacters(structuredState))
111
+ .replace('{{plotThreads}}', this.formatPlotThreads(structuredState))
112
+ .replace('{{chapterTitle}}', chapter.title)
113
+ .replace('{{chapterContent}}', chapter.content.substring(0, 4000));
114
+ const result = await (0, client_js_1.getLLM)().completeJSON(prompt, {
115
+ temperature: 0.3,
116
+ maxTokens: 1500,
117
+ });
118
+ return result.violations;
119
+ }
120
+ /**
121
+ * Quick validation without LLM (for testing/fallback)
122
+ */
123
+ quickValidate(context) {
124
+ const { chapter, canon, constraintGraph } = context;
125
+ // Graph-based validation only
126
+ const violations = constraintGraph.checkConstraints(chapter.number);
127
+ // Basic canon check
128
+ const canonViolations = this.checkCanonBasic(chapter, canon);
129
+ const allViolations = [...violations, ...canonViolations];
130
+ const errorCount = allViolations.filter(v => v.severity === 'error').length;
131
+ return {
132
+ valid: errorCount === 0,
133
+ violations: allViolations,
134
+ summary: errorCount === 0
135
+ ? 'Chapter passes basic validation.'
136
+ : `Found ${errorCount} error(s) in basic validation.`,
137
+ };
138
+ }
139
+ /**
140
+ * Basic canon check (keyword matching)
141
+ */
142
+ checkCanonBasic(chapter, canon) {
143
+ const violations = [];
144
+ const content = chapter.content.toLowerCase();
145
+ for (const fact of canon.facts) {
146
+ // Check for contradictions (simplified)
147
+ // If fact says "X is Y", check for "X is not Y" or "X was never Y"
148
+ const subject = fact.subject.toLowerCase();
149
+ const value = fact.value.toLowerCase();
150
+ // Look for negations
151
+ const negationPatterns = [
152
+ `${subject}.*不是.*${value}`,
153
+ `${subject}.*从未.*${value}`,
154
+ `${subject}.*不再.*${value}`,
155
+ ];
156
+ for (const pattern of negationPatterns) {
157
+ const regex = new RegExp(pattern);
158
+ if (regex.test(content)) {
159
+ violations.push({
160
+ type: 'canon',
161
+ severity: 'error',
162
+ description: `Canon violation: "${fact.subject} ${fact.attribute} = ${fact.value}" is contradicted`,
163
+ nodes: [],
164
+ suggestedFix: `Ensure ${fact.subject} remains ${fact.value} as established in chapter ${fact.chapterEstablished}`,
165
+ });
166
+ }
167
+ }
168
+ }
169
+ return violations;
170
+ }
171
+ /**
172
+ * Format canon for prompt
173
+ */
174
+ formatCanon(canon) {
175
+ if (canon.facts.length === 0)
176
+ return 'No canon facts established.';
177
+ return canon.facts
178
+ .map(f => `- ${f.subject} ${f.attribute} = ${f.value} (est. Ch ${f.chapterEstablished})`)
179
+ .join('\n');
180
+ }
181
+ /**
182
+ * Format characters for prompt
183
+ */
184
+ formatCharacters(state) {
185
+ return Object.values(state.characters)
186
+ .map(c => `- ${c.name}: ${c.emotionalState}, at ${c.location}`)
187
+ .join('\n') || 'No characters.';
188
+ }
189
+ /**
190
+ * Format plot threads for prompt
191
+ */
192
+ formatPlotThreads(state) {
193
+ return Object.values(state.plotThreads)
194
+ .filter(t => t.status !== 'resolved')
195
+ .map(t => `- ${t.name} (${t.status}, ${Math.round(t.tension * 100)}% tension)`)
196
+ .join('\n') || 'No active plot threads.';
197
+ }
198
+ /**
199
+ * Format validation result for display
200
+ */
201
+ formatResult(result) {
202
+ const lines = [];
203
+ lines.push(`**Validation Result:** ${result.valid ? '✅ VALID' : '❌ INVALID'}`);
204
+ lines.push(`**Summary:** ${result.summary}`);
205
+ if (result.violations.length > 0) {
206
+ lines.push('\n**Violations:**');
207
+ const errors = result.violations.filter(v => v.severity === 'error');
208
+ const warnings = result.violations.filter(v => v.severity === 'warning');
209
+ if (errors.length > 0) {
210
+ lines.push('\n*Errors:*');
211
+ for (const v of errors) {
212
+ lines.push(`❌ [${v.type.toUpperCase()}] ${v.description}`);
213
+ if (v.suggestedFix) {
214
+ lines.push(` 💡 Fix: ${v.suggestedFix}`);
215
+ }
216
+ }
217
+ }
218
+ if (warnings.length > 0) {
219
+ lines.push('\n*Warnings:*');
220
+ for (const v of warnings) {
221
+ lines.push(`⚠️ [${v.type.toUpperCase()}] ${v.description}`);
222
+ }
223
+ }
224
+ }
225
+ return lines.join('\n');
226
+ }
227
+ /**
228
+ * Get the constraint graph
229
+ */
230
+ getConstraintGraph() {
231
+ return this.constraintGraph;
232
+ }
233
+ }
234
+ exports.Validator = Validator;
235
+ exports.validator = new Validator();
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validator.js","sourceRoot":"","sources":["../../src/constraints/validator.ts"],"names":[],"mappings":"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","sourcesContent":["import { getLLM } from '../llm/client.js';\r\nimport type { Chapter, StoryBible } from '../types/index.js';\r\nimport type { StoryStructuredState } from '../story/structuredState.js';\r\nimport type { CanonStore, CanonFact } from '../memory/canonStore.js';\r\nimport { ConstraintGraph, type ConstraintViolation } from './constraintGraph.js';\r\n\r\nexport interface ValidationResult {\r\n  valid: boolean;\r\n  violations: ConstraintViolation[];\r\n  summary: string;\r\n}\r\n\r\nexport interface ChapterValidationContext {\r\n  chapter: Chapter;\r\n  bible: StoryBible;\r\n  structuredState: StoryStructuredState;\r\n  canon: CanonStore;\r\n  previousChapters: Chapter[];\r\n  constraintGraph: ConstraintGraph;\r\n}\r\n\r\nconst VALIDATOR_PROMPT = `You are a narrative validator. Check this chapter for consistency issues.\r\n\r\n## Story Bible\r\n\r\n**Title:** {{title}}\r\n**Setting:** {{setting}}\r\n\r\n## Canon Facts (must never be violated)\r\n{{canon}}\r\n\r\n## Current Story State\r\n\r\n**Chapter:** {{chapterNumber}}\r\n\r\n### Character States\r\n{{characters}}\r\n\r\n### Plot Threads\r\n{{plotThreads}}\r\n\r\n## Chapter to Validate\r\n\r\n**Title:** {{chapterTitle}}\r\n\r\n{{chapterContent}}\r\n\r\n## Your Task\r\n\r\nCheck for these types of errors:\r\n\r\n1. **Canon Violations**: Does the chapter contradict any established facts?\r\n2. **Character Consistency**: Do characters act according to their established personality?\r\n3. **Location Errors**: Are characters in places they couldn't be? Is travel time realistic?\r\n4. **Knowledge Leaks**: Do characters know things they shouldn't know yet?\r\n5. **Timeline Errors**: Are events in the right order?\r\n6. **Logic Errors**: Any impossible or contradictory situations?\r\n\r\nOutput JSON:\r\n{\r\n  \"valid\": true/false,\r\n  \"violations\": [\r\n    {\r\n      \"type\": \"canon|character|location|knowledge|timeline|logic\",\r\n      \"severity\": \"error|warning\",\r\n      \"description\": \"Detailed description of the issue\",\r\n      \"suggestedFix\": \"How to fix this issue\"\r\n    }\r\n  ],\r\n  \"summary\": \"Overall assessment of chapter consistency\"\r\n}`;\r\n\r\nexport class Validator {\r\n  private constraintGraph: ConstraintGraph;\r\n  \r\n  constructor(constraintGraph?: ConstraintGraph) {\r\n    this.constraintGraph = constraintGraph || new ConstraintGraph();\r\n  }\r\n  \r\n  /**\r\n   * Validate a chapter using both graph-based and LLM-based checks\r\n   */\r\n  async validateChapter(context: ChapterValidationContext): Promise<ValidationResult> {\r\n    const { chapter, bible, structuredState, canon, constraintGraph } = context;\r\n    \r\n    // Graph-based validation\r\n    const graphViolations = constraintGraph.checkConstraints(chapter.number);\r\n    \r\n    // LLM-based validation\r\n    let llmViolations: ConstraintViolation[] = [];\r\n    try {\r\n      llmViolations = await this.llmValidate(context);\r\n    } catch (error) {\r\n      // If LLM fails, rely on graph validation only\r\n      console.log('LLM validation failed, using graph validation only');\r\n    }\r\n    \r\n    // Combine violations\r\n    const allViolations = [...graphViolations, ...llmViolations];\r\n    \r\n    // Remove duplicates (same description)\r\n    const uniqueViolations = allViolations.filter((v, i, a) => \r\n      a.findIndex(t => t.description === v.description) === i\r\n    );\r\n    \r\n    // Generate summary\r\n    const errorCount = uniqueViolations.filter(v => v.severity === 'error').length;\r\n    const warningCount = uniqueViolations.filter(v => v.severity === 'warning').length;\r\n    \r\n    let summary: string;\r\n    if (errorCount === 0 && warningCount === 0) {\r\n      summary = 'Chapter is consistent with story canon and state.';\r\n    } else if (errorCount === 0) {\r\n      summary = `Chapter has ${warningCount} warning(s) but no critical errors.`;\r\n    } else {\r\n      summary = `Chapter has ${errorCount} error(s) and ${warningCount} warning(s) that need attention.`;\r\n    }\r\n    \r\n    return {\r\n      valid: errorCount === 0,\r\n      violations: uniqueViolations,\r\n      summary,\r\n    };\r\n  }\r\n  \r\n  /**\r\n   * LLM-based validation\r\n   */\r\n  private async llmValidate(context: ChapterValidationContext): Promise<ConstraintViolation[]> {\r\n    const { chapter, bible, structuredState, canon } = context;\r\n    \r\n    const prompt = VALIDATOR_PROMPT\r\n      .replace('{{title}}', bible.title)\r\n      .replace('{{setting}}', bible.setting)\r\n      .replace('{{canon}}', this.formatCanon(canon))\r\n      .replace('{{chapterNumber}}', chapter.number.toString())\r\n      .replace('{{characters}}', this.formatCharacters(structuredState))\r\n      .replace('{{plotThreads}}', this.formatPlotThreads(structuredState))\r\n      .replace('{{chapterTitle}}', chapter.title)\r\n      .replace('{{chapterContent}}', chapter.content.substring(0, 4000));\r\n    \r\n    const result = await getLLM().completeJSON<ValidationResult>(prompt, {\r\n      temperature: 0.3,\r\n      maxTokens: 1500,\r\n    });\r\n    \r\n    return result.violations;\r\n  }\r\n  \r\n  /**\r\n   * Quick validation without LLM (for testing/fallback)\r\n   */\r\n  quickValidate(context: ChapterValidationContext): ValidationResult {\r\n    const { chapter, canon, constraintGraph } = context;\r\n    \r\n    // Graph-based validation only\r\n    const violations = constraintGraph.checkConstraints(chapter.number);\r\n    \r\n    // Basic canon check\r\n    const canonViolations = this.checkCanonBasic(chapter, canon);\r\n    \r\n    const allViolations = [...violations, ...canonViolations];\r\n    const errorCount = allViolations.filter(v => v.severity === 'error').length;\r\n    \r\n    return {\r\n      valid: errorCount === 0,\r\n      violations: allViolations,\r\n      summary: errorCount === 0 \r\n        ? 'Chapter passes basic validation.' \r\n        : `Found ${errorCount} error(s) in basic validation.`,\r\n    };\r\n  }\r\n  \r\n  /**\r\n   * Basic canon check (keyword matching)\r\n   */\r\n  private checkCanonBasic(chapter: Chapter, canon: CanonStore): ConstraintViolation[] {\r\n    const violations: ConstraintViolation[] = [];\r\n    const content = chapter.content.toLowerCase();\r\n    \r\n    for (const fact of canon.facts) {\r\n      // Check for contradictions (simplified)\r\n      // If fact says \"X is Y\", check for \"X is not Y\" or \"X was never Y\"\r\n      const subject = fact.subject.toLowerCase();\r\n      const value = fact.value.toLowerCase();\r\n      \r\n      // Look for negations\r\n      const negationPatterns = [\r\n        `${subject}.*不是.*${value}`,\r\n        `${subject}.*从未.*${value}`,\r\n        `${subject}.*不再.*${value}`,\r\n      ];\r\n      \r\n      for (const pattern of negationPatterns) {\r\n        const regex = new RegExp(pattern);\r\n        if (regex.test(content)) {\r\n          violations.push({\r\n            type: 'canon',\r\n            severity: 'error',\r\n            description: `Canon violation: \"${fact.subject} ${fact.attribute} = ${fact.value}\" is contradicted`,\r\n            nodes: [],\r\n            suggestedFix: `Ensure ${fact.subject} remains ${fact.value} as established in chapter ${fact.chapterEstablished}`,\r\n          });\r\n        }\r\n      }\r\n    }\r\n    \r\n    return violations;\r\n  }\r\n  \r\n  /**\r\n   * Format canon for prompt\r\n   */\r\n  private formatCanon(canon: CanonStore): string {\r\n    if (canon.facts.length === 0) return 'No canon facts established.';\r\n    \r\n    return canon.facts\r\n      .map(f => `- ${f.subject} ${f.attribute} = ${f.value} (est. Ch ${f.chapterEstablished})`)\r\n      .join('\\n');\r\n  }\r\n  \r\n  /**\r\n   * Format characters for prompt\r\n   */\r\n  private formatCharacters(state: StoryStructuredState): string {\r\n    return Object.values(state.characters)\r\n      .map(c => `- ${c.name}: ${c.emotionalState}, at ${c.location}`)\r\n      .join('\\n') || 'No characters.';\r\n  }\r\n  \r\n  /**\r\n   * Format plot threads for prompt\r\n   */\r\n  private formatPlotThreads(state: StoryStructuredState): string {\r\n    return Object.values(state.plotThreads)\r\n      .filter(t => t.status !== 'resolved')\r\n      .map(t => `- ${t.name} (${t.status}, ${Math.round(t.tension * 100)}% tension)`)\r\n      .join('\\n') || 'No active plot threads.';\r\n  }\r\n  \r\n  /**\r\n   * Format validation result for display\r\n   */\r\n  formatResult(result: ValidationResult): string {\r\n    const lines: string[] = [];\r\n    \r\n    lines.push(`**Validation Result:** ${result.valid ? '✅ VALID' : '❌ INVALID'}`);\r\n    lines.push(`**Summary:** ${result.summary}`);\r\n    \r\n    if (result.violations.length > 0) {\r\n      lines.push('\\n**Violations:**');\r\n      \r\n      const errors = result.violations.filter(v => v.severity === 'error');\r\n      const warnings = result.violations.filter(v => v.severity === 'warning');\r\n      \r\n      if (errors.length > 0) {\r\n        lines.push('\\n*Errors:*');\r\n        for (const v of errors) {\r\n          lines.push(`❌ [${v.type.toUpperCase()}] ${v.description}`);\r\n          if (v.suggestedFix) {\r\n            lines.push(`   💡 Fix: ${v.suggestedFix}`);\r\n          }\r\n        }\r\n      }\r\n      \r\n      if (warnings.length > 0) {\r\n        lines.push('\\n*Warnings:*');\r\n        for (const v of warnings) {\r\n          lines.push(`⚠️ [${v.type.toUpperCase()}] ${v.description}`);\r\n        }\r\n      }\r\n    }\r\n    \r\n    return lines.join('\\n');\r\n  }\r\n  \r\n  /**\r\n   * Get the constraint graph\r\n   */\r\n  getConstraintGraph(): ConstraintGraph {\r\n    return this.constraintGraph;\r\n  }\r\n}\r\n\r\nexport const validator = new Validator();\r\n"]}
@@ -0,0 +1,25 @@
1
+ export * from './types/index.js';
2
+ export type { LLMProviderConfig } from './types/index.js';
3
+ export { LLMClient, getLLM } from './llm/client.js';
4
+ export { ChapterWriter, writer } from './agents/writer.js';
5
+ export { CompletenessChecker, completenessChecker } from './agents/completeness.js';
6
+ export { ChapterSummarizer, summarizer } from './agents/summarizer.js';
7
+ export { CanonValidator, canonValidator } from './agents/canonValidator.js';
8
+ export { MemoryExtractor, memoryExtractor } from './agents/memoryExtractor.js';
9
+ export { StateUpdater, stateUpdater } from './agents/stateUpdater.js';
10
+ export { TensionController, tensionController, calculateTargetTension, calculateNextChapterTension, analyzeTension, generateTensionGuidance, formatTensionForPrompt, estimateTensionFromChapter, type TensionAnalysis, type TensionGuidance, } from './agents/tensionController.js';
11
+ export { StoryDirector, storyDirector, type ChapterObjective, type DirectorOutput, type DirectorContext, } from './agents/storyDirector.js';
12
+ export { ChapterPlanner, chapterPlanner, type Scene, type ChapterOutline, type PlannerContext, } from './agents/chapterPlanner.js';
13
+ export { CharacterAgentSystem, characterAgentSystem, type CharacterAgent, type AgendaItem, type CharacterDecision, type CharacterAgentContext, } from './world/characterAgent.js';
14
+ export { EventResolver, eventResolver, type WorldEvent, type EventResolution, type ConflictResolution, } from './world/eventResolver.js';
15
+ export { WorldStateManager, createWorldStateManager, type Location, type WorldState, } from './world/worldState.js';
16
+ export { ConstraintGraph, createConstraintGraph, type ConstraintNode, type ConstraintEdge, type ConstraintViolation, type NodeType, } from './constraints/constraintGraph.js';
17
+ export { Validator, validator, type ValidationResult, type ChapterValidationContext, } from './constraints/validator.js';
18
+ export { StateUpdaterPipeline, stateUpdaterPipeline, type StateUpdateResult, type StateChange, type UpdateContext, } from './memory/stateUpdater.js';
19
+ export { generateChapter, type GenerateChapterResult, type GenerateChapterOptions } from './pipeline/generateChapter.js';
20
+ export { createStoryBible, addCharacter, addPlotThread } from './story/bible.js';
21
+ export { createStoryState, updateStoryState } from './story/state.js';
22
+ export { createStructuredState, initializeCharactersFromBible, initializePlotThreadsFromBible, updateCharacterState, updatePlotThread, addUnresolvedQuestion, resolveQuestion, addRecentEvent, updateStoryTension, formatStructuredStateForPrompt, type StoryStructuredState, type CharacterState, type PlotThreadState, } from './story/structuredState.js';
23
+ export { createCanonStore, extractCanonFromBible, addFact, formatCanonForPrompt, type CanonStore, type CanonFact } from './memory/canonStore.js';
24
+ export { VectorStore, getVectorStore, clearVectorStore, type NarrativeMemory, type MemorySearchResult } from './memory/vectorStore.js';
25
+ export { MemoryRetriever, createMemoryRetriever, type RetrievalContext, type RetrievedMemory } from './memory/memoryRetriever.js';
package/dist/index.js ADDED
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.addUnresolvedQuestion = exports.updatePlotThread = exports.updateCharacterState = exports.initializePlotThreadsFromBible = exports.initializeCharactersFromBible = exports.createStructuredState = exports.updateStoryState = exports.createStoryState = exports.addPlotThread = exports.addCharacter = exports.createStoryBible = exports.generateChapter = exports.stateUpdaterPipeline = exports.StateUpdaterPipeline = exports.validator = exports.Validator = exports.createConstraintGraph = exports.ConstraintGraph = exports.createWorldStateManager = exports.WorldStateManager = exports.eventResolver = exports.EventResolver = exports.characterAgentSystem = exports.CharacterAgentSystem = exports.chapterPlanner = exports.ChapterPlanner = exports.storyDirector = exports.StoryDirector = exports.estimateTensionFromChapter = exports.formatTensionForPrompt = exports.generateTensionGuidance = exports.analyzeTension = exports.calculateNextChapterTension = exports.calculateTargetTension = exports.tensionController = exports.TensionController = exports.stateUpdater = exports.StateUpdater = exports.memoryExtractor = exports.MemoryExtractor = exports.canonValidator = exports.CanonValidator = exports.summarizer = exports.ChapterSummarizer = exports.completenessChecker = exports.CompletenessChecker = exports.writer = exports.ChapterWriter = exports.getLLM = exports.LLMClient = void 0;
18
+ exports.createMemoryRetriever = exports.MemoryRetriever = exports.clearVectorStore = exports.getVectorStore = exports.VectorStore = exports.formatCanonForPrompt = exports.addFact = exports.extractCanonFromBible = exports.createCanonStore = exports.formatStructuredStateForPrompt = exports.updateStoryTension = exports.addRecentEvent = exports.resolveQuestion = void 0;
19
+ // Types
20
+ __exportStar(require("./types/index.js"), exports);
21
+ // LLM
22
+ var client_js_1 = require("./llm/client.js");
23
+ Object.defineProperty(exports, "LLMClient", { enumerable: true, get: function () { return client_js_1.LLMClient; } });
24
+ Object.defineProperty(exports, "getLLM", { enumerable: true, get: function () { return client_js_1.getLLM; } });
25
+ // Agents
26
+ var writer_js_1 = require("./agents/writer.js");
27
+ Object.defineProperty(exports, "ChapterWriter", { enumerable: true, get: function () { return writer_js_1.ChapterWriter; } });
28
+ Object.defineProperty(exports, "writer", { enumerable: true, get: function () { return writer_js_1.writer; } });
29
+ var completeness_js_1 = require("./agents/completeness.js");
30
+ Object.defineProperty(exports, "CompletenessChecker", { enumerable: true, get: function () { return completeness_js_1.CompletenessChecker; } });
31
+ Object.defineProperty(exports, "completenessChecker", { enumerable: true, get: function () { return completeness_js_1.completenessChecker; } });
32
+ var summarizer_js_1 = require("./agents/summarizer.js");
33
+ Object.defineProperty(exports, "ChapterSummarizer", { enumerable: true, get: function () { return summarizer_js_1.ChapterSummarizer; } });
34
+ Object.defineProperty(exports, "summarizer", { enumerable: true, get: function () { return summarizer_js_1.summarizer; } });
35
+ var canonValidator_js_1 = require("./agents/canonValidator.js");
36
+ Object.defineProperty(exports, "CanonValidator", { enumerable: true, get: function () { return canonValidator_js_1.CanonValidator; } });
37
+ Object.defineProperty(exports, "canonValidator", { enumerable: true, get: function () { return canonValidator_js_1.canonValidator; } });
38
+ var memoryExtractor_js_1 = require("./agents/memoryExtractor.js");
39
+ Object.defineProperty(exports, "MemoryExtractor", { enumerable: true, get: function () { return memoryExtractor_js_1.MemoryExtractor; } });
40
+ Object.defineProperty(exports, "memoryExtractor", { enumerable: true, get: function () { return memoryExtractor_js_1.memoryExtractor; } });
41
+ var stateUpdater_js_1 = require("./agents/stateUpdater.js");
42
+ Object.defineProperty(exports, "StateUpdater", { enumerable: true, get: function () { return stateUpdater_js_1.StateUpdater; } });
43
+ Object.defineProperty(exports, "stateUpdater", { enumerable: true, get: function () { return stateUpdater_js_1.stateUpdater; } });
44
+ var tensionController_js_1 = require("./agents/tensionController.js");
45
+ Object.defineProperty(exports, "TensionController", { enumerable: true, get: function () { return tensionController_js_1.TensionController; } });
46
+ Object.defineProperty(exports, "tensionController", { enumerable: true, get: function () { return tensionController_js_1.tensionController; } });
47
+ Object.defineProperty(exports, "calculateTargetTension", { enumerable: true, get: function () { return tensionController_js_1.calculateTargetTension; } });
48
+ Object.defineProperty(exports, "calculateNextChapterTension", { enumerable: true, get: function () { return tensionController_js_1.calculateNextChapterTension; } });
49
+ Object.defineProperty(exports, "analyzeTension", { enumerable: true, get: function () { return tensionController_js_1.analyzeTension; } });
50
+ Object.defineProperty(exports, "generateTensionGuidance", { enumerable: true, get: function () { return tensionController_js_1.generateTensionGuidance; } });
51
+ Object.defineProperty(exports, "formatTensionForPrompt", { enumerable: true, get: function () { return tensionController_js_1.formatTensionForPrompt; } });
52
+ Object.defineProperty(exports, "estimateTensionFromChapter", { enumerable: true, get: function () { return tensionController_js_1.estimateTensionFromChapter; } });
53
+ var storyDirector_js_1 = require("./agents/storyDirector.js");
54
+ Object.defineProperty(exports, "StoryDirector", { enumerable: true, get: function () { return storyDirector_js_1.StoryDirector; } });
55
+ Object.defineProperty(exports, "storyDirector", { enumerable: true, get: function () { return storyDirector_js_1.storyDirector; } });
56
+ var chapterPlanner_js_1 = require("./agents/chapterPlanner.js");
57
+ Object.defineProperty(exports, "ChapterPlanner", { enumerable: true, get: function () { return chapterPlanner_js_1.ChapterPlanner; } });
58
+ Object.defineProperty(exports, "chapterPlanner", { enumerable: true, get: function () { return chapterPlanner_js_1.chapterPlanner; } });
59
+ // World Simulation
60
+ var characterAgent_js_1 = require("./world/characterAgent.js");
61
+ Object.defineProperty(exports, "CharacterAgentSystem", { enumerable: true, get: function () { return characterAgent_js_1.CharacterAgentSystem; } });
62
+ Object.defineProperty(exports, "characterAgentSystem", { enumerable: true, get: function () { return characterAgent_js_1.characterAgentSystem; } });
63
+ var eventResolver_js_1 = require("./world/eventResolver.js");
64
+ Object.defineProperty(exports, "EventResolver", { enumerable: true, get: function () { return eventResolver_js_1.EventResolver; } });
65
+ Object.defineProperty(exports, "eventResolver", { enumerable: true, get: function () { return eventResolver_js_1.eventResolver; } });
66
+ var worldState_js_1 = require("./world/worldState.js");
67
+ Object.defineProperty(exports, "WorldStateManager", { enumerable: true, get: function () { return worldState_js_1.WorldStateManager; } });
68
+ Object.defineProperty(exports, "createWorldStateManager", { enumerable: true, get: function () { return worldState_js_1.createWorldStateManager; } });
69
+ // Constraints
70
+ var constraintGraph_js_1 = require("./constraints/constraintGraph.js");
71
+ Object.defineProperty(exports, "ConstraintGraph", { enumerable: true, get: function () { return constraintGraph_js_1.ConstraintGraph; } });
72
+ Object.defineProperty(exports, "createConstraintGraph", { enumerable: true, get: function () { return constraintGraph_js_1.createConstraintGraph; } });
73
+ var validator_js_1 = require("./constraints/validator.js");
74
+ Object.defineProperty(exports, "Validator", { enumerable: true, get: function () { return validator_js_1.Validator; } });
75
+ Object.defineProperty(exports, "validator", { enumerable: true, get: function () { return validator_js_1.validator; } });
76
+ // State Update Pipeline
77
+ var stateUpdater_js_2 = require("./memory/stateUpdater.js");
78
+ Object.defineProperty(exports, "StateUpdaterPipeline", { enumerable: true, get: function () { return stateUpdater_js_2.StateUpdaterPipeline; } });
79
+ Object.defineProperty(exports, "stateUpdaterPipeline", { enumerable: true, get: function () { return stateUpdater_js_2.stateUpdaterPipeline; } });
80
+ // Pipeline
81
+ var generateChapter_js_1 = require("./pipeline/generateChapter.js");
82
+ Object.defineProperty(exports, "generateChapter", { enumerable: true, get: function () { return generateChapter_js_1.generateChapter; } });
83
+ // Story
84
+ var bible_js_1 = require("./story/bible.js");
85
+ Object.defineProperty(exports, "createStoryBible", { enumerable: true, get: function () { return bible_js_1.createStoryBible; } });
86
+ Object.defineProperty(exports, "addCharacter", { enumerable: true, get: function () { return bible_js_1.addCharacter; } });
87
+ Object.defineProperty(exports, "addPlotThread", { enumerable: true, get: function () { return bible_js_1.addPlotThread; } });
88
+ var state_js_1 = require("./story/state.js");
89
+ Object.defineProperty(exports, "createStoryState", { enumerable: true, get: function () { return state_js_1.createStoryState; } });
90
+ Object.defineProperty(exports, "updateStoryState", { enumerable: true, get: function () { return state_js_1.updateStoryState; } });
91
+ var structuredState_js_1 = require("./story/structuredState.js");
92
+ Object.defineProperty(exports, "createStructuredState", { enumerable: true, get: function () { return structuredState_js_1.createStructuredState; } });
93
+ Object.defineProperty(exports, "initializeCharactersFromBible", { enumerable: true, get: function () { return structuredState_js_1.initializeCharactersFromBible; } });
94
+ Object.defineProperty(exports, "initializePlotThreadsFromBible", { enumerable: true, get: function () { return structuredState_js_1.initializePlotThreadsFromBible; } });
95
+ Object.defineProperty(exports, "updateCharacterState", { enumerable: true, get: function () { return structuredState_js_1.updateCharacterState; } });
96
+ Object.defineProperty(exports, "updatePlotThread", { enumerable: true, get: function () { return structuredState_js_1.updatePlotThread; } });
97
+ Object.defineProperty(exports, "addUnresolvedQuestion", { enumerable: true, get: function () { return structuredState_js_1.addUnresolvedQuestion; } });
98
+ Object.defineProperty(exports, "resolveQuestion", { enumerable: true, get: function () { return structuredState_js_1.resolveQuestion; } });
99
+ Object.defineProperty(exports, "addRecentEvent", { enumerable: true, get: function () { return structuredState_js_1.addRecentEvent; } });
100
+ Object.defineProperty(exports, "updateStoryTension", { enumerable: true, get: function () { return structuredState_js_1.updateStoryTension; } });
101
+ Object.defineProperty(exports, "formatStructuredStateForPrompt", { enumerable: true, get: function () { return structuredState_js_1.formatStructuredStateForPrompt; } });
102
+ // Memory
103
+ var canonStore_js_1 = require("./memory/canonStore.js");
104
+ Object.defineProperty(exports, "createCanonStore", { enumerable: true, get: function () { return canonStore_js_1.createCanonStore; } });
105
+ Object.defineProperty(exports, "extractCanonFromBible", { enumerable: true, get: function () { return canonStore_js_1.extractCanonFromBible; } });
106
+ Object.defineProperty(exports, "addFact", { enumerable: true, get: function () { return canonStore_js_1.addFact; } });
107
+ Object.defineProperty(exports, "formatCanonForPrompt", { enumerable: true, get: function () { return canonStore_js_1.formatCanonForPrompt; } });
108
+ var vectorStore_js_1 = require("./memory/vectorStore.js");
109
+ Object.defineProperty(exports, "VectorStore", { enumerable: true, get: function () { return vectorStore_js_1.VectorStore; } });
110
+ Object.defineProperty(exports, "getVectorStore", { enumerable: true, get: function () { return vectorStore_js_1.getVectorStore; } });
111
+ Object.defineProperty(exports, "clearVectorStore", { enumerable: true, get: function () { return vectorStore_js_1.clearVectorStore; } });
112
+ var memoryRetriever_js_1 = require("./memory/memoryRetriever.js");
113
+ Object.defineProperty(exports, "MemoryRetriever", { enumerable: true, get: function () { return memoryRetriever_js_1.MemoryRetriever; } });
114
+ Object.defineProperty(exports, "createMemoryRetriever", { enumerable: true, get: function () { return memoryRetriever_js_1.createMemoryRetriever; } });
115
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsUUFBUTtBQUNSLG1EQUFpQztBQUdqQyxNQUFNO0FBQ04sNkNBQW9EO0FBQTNDLHNHQUFBLFNBQVMsT0FBQTtBQUFFLG1HQUFBLE1BQU0sT0FBQTtBQUUxQixTQUFTO0FBQ1QsZ0RBQTJEO0FBQWxELDBHQUFBLGFBQWEsT0FBQTtBQUFFLG1HQUFBLE1BQU0sT0FBQTtBQUM5Qiw0REFBb0Y7QUFBM0Usc0hBQUEsbUJBQW1CLE9BQUE7QUFBRSxzSEFBQSxtQkFBbUIsT0FBQTtBQUNqRCx3REFBdUU7QUFBOUQsa0hBQUEsaUJBQWlCLE9BQUE7QUFBRSwyR0FBQSxVQUFVLE9BQUE7QUFDdEMsZ0VBQTRFO0FBQW5FLG1IQUFBLGNBQWMsT0FBQTtBQUFFLG1IQUFBLGNBQWMsT0FBQTtBQUN2QyxrRUFBK0U7QUFBdEUscUhBQUEsZUFBZSxPQUFBO0FBQUUscUhBQUEsZUFBZSxPQUFBO0FBQ3pDLDREQUFzRTtBQUE3RCwrR0FBQSxZQUFZLE9BQUE7QUFBRSwrR0FBQSxZQUFZLE9BQUE7QUFDbkMsc0VBV3VDO0FBVnJDLHlIQUFBLGlCQUFpQixPQUFBO0FBQ2pCLHlIQUFBLGlCQUFpQixPQUFBO0FBQ2pCLDhIQUFBLHNCQUFzQixPQUFBO0FBQ3RCLG1JQUFBLDJCQUEyQixPQUFBO0FBQzNCLHNIQUFBLGNBQWMsT0FBQTtBQUNkLCtIQUFBLHVCQUF1QixPQUFBO0FBQ3ZCLDhIQUFBLHNCQUFzQixPQUFBO0FBQ3RCLGtJQUFBLDBCQUEwQixPQUFBO0FBSTVCLDhEQU1tQztBQUxqQyxpSEFBQSxhQUFhLE9BQUE7QUFDYixpSEFBQSxhQUFhLE9BQUE7QUFLZixnRUFNb0M7QUFMbEMsbUhBQUEsY0FBYyxPQUFBO0FBQ2QsbUhBQUEsY0FBYyxPQUFBO0FBTWhCLG1CQUFtQjtBQUNuQiwrREFPbUM7QUFOakMseUhBQUEsb0JBQW9CLE9BQUE7QUFDcEIseUhBQUEsb0JBQW9CLE9BQUE7QUFNdEIsNkRBTWtDO0FBTGhDLGlIQUFBLGFBQWEsT0FBQTtBQUNiLGlIQUFBLGFBQWEsT0FBQTtBQUtmLHVEQUsrQjtBQUo3QixrSEFBQSxpQkFBaUIsT0FBQTtBQUNqQix3SEFBQSx1QkFBdUIsT0FBQTtBQUt6QixjQUFjO0FBQ2QsdUVBTzBDO0FBTnhDLHFIQUFBLGVBQWUsT0FBQTtBQUNmLDJIQUFBLHFCQUFxQixPQUFBO0FBTXZCLDJEQUtvQztBQUpsQyx5R0FBQSxTQUFTLE9BQUE7QUFDVCx5R0FBQSxTQUFTLE9BQUE7QUFLWCx3QkFBd0I7QUFDeEIsNERBTWtDO0FBTGhDLHVIQUFBLG9CQUFvQixPQUFBO0FBQ3BCLHVIQUFBLG9CQUFvQixPQUFBO0FBTXRCLFdBQVc7QUFDWCxvRUFBeUg7QUFBaEgscUhBQUEsZUFBZSxPQUFBO0FBRXhCLFFBQVE7QUFDUiw2Q0FBaUY7QUFBeEUsNEdBQUEsZ0JBQWdCLE9BQUE7QUFBRSx3R0FBQSxZQUFZLE9BQUE7QUFBRSx5R0FBQSxhQUFhLE9BQUE7QUFDdEQsNkNBQXNFO0FBQTdELDRHQUFBLGdCQUFnQixPQUFBO0FBQUUsNEdBQUEsZ0JBQWdCLE9BQUE7QUFDM0MsaUVBY29DO0FBYmxDLDJIQUFBLHFCQUFxQixPQUFBO0FBQ3JCLG1JQUFBLDZCQUE2QixPQUFBO0FBQzdCLG9JQUFBLDhCQUE4QixPQUFBO0FBQzlCLDBIQUFBLG9CQUFvQixPQUFBO0FBQ3BCLHNIQUFBLGdCQUFnQixPQUFBO0FBQ2hCLDJIQUFBLHFCQUFxQixPQUFBO0FBQ3JCLHFIQUFBLGVBQWUsT0FBQTtBQUNmLG9IQUFBLGNBQWMsT0FBQTtBQUNkLHdIQUFBLGtCQUFrQixPQUFBO0FBQ2xCLG9JQUFBLDhCQUE4QixPQUFBO0FBTWhDLFNBQVM7QUFDVCx3REFBaUo7QUFBeEksaUhBQUEsZ0JBQWdCLE9BQUE7QUFBRSxzSEFBQSxxQkFBcUIsT0FBQTtBQUFFLHdHQUFBLE9BQU8sT0FBQTtBQUFFLHFIQUFBLG9CQUFvQixPQUFBO0FBQy9FLDBEQUF1STtBQUE5SCw2R0FBQSxXQUFXLE9BQUE7QUFBRSxnSEFBQSxjQUFjLE9BQUE7QUFBRSxrSEFBQSxnQkFBZ0IsT0FBQTtBQUN0RCxrRUFBa0k7QUFBekgscUhBQUEsZUFBZSxPQUFBO0FBQUUsMkhBQUEscUJBQXFCLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUeXBlc1xyXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzL2luZGV4LmpzJztcclxuZXhwb3J0IHR5cGUgeyBMTE1Qcm92aWRlckNvbmZpZyB9IGZyb20gJy4vdHlwZXMvaW5kZXguanMnO1xyXG5cclxuLy8gTExNXHJcbmV4cG9ydCB7IExMTUNsaWVudCwgZ2V0TExNIH0gZnJvbSAnLi9sbG0vY2xpZW50LmpzJztcclxuXHJcbi8vIEFnZW50c1xyXG5leHBvcnQgeyBDaGFwdGVyV3JpdGVyLCB3cml0ZXIgfSBmcm9tICcuL2FnZW50cy93cml0ZXIuanMnO1xyXG5leHBvcnQgeyBDb21wbGV0ZW5lc3NDaGVja2VyLCBjb21wbGV0ZW5lc3NDaGVja2VyIH0gZnJvbSAnLi9hZ2VudHMvY29tcGxldGVuZXNzLmpzJztcclxuZXhwb3J0IHsgQ2hhcHRlclN1bW1hcml6ZXIsIHN1bW1hcml6ZXIgfSBmcm9tICcuL2FnZW50cy9zdW1tYXJpemVyLmpzJztcclxuZXhwb3J0IHsgQ2Fub25WYWxpZGF0b3IsIGNhbm9uVmFsaWRhdG9yIH0gZnJvbSAnLi9hZ2VudHMvY2Fub25WYWxpZGF0b3IuanMnO1xyXG5leHBvcnQgeyBNZW1vcnlFeHRyYWN0b3IsIG1lbW9yeUV4dHJhY3RvciB9IGZyb20gJy4vYWdlbnRzL21lbW9yeUV4dHJhY3Rvci5qcyc7XHJcbmV4cG9ydCB7IFN0YXRlVXBkYXRlciwgc3RhdGVVcGRhdGVyIH0gZnJvbSAnLi9hZ2VudHMvc3RhdGVVcGRhdGVyLmpzJztcclxuZXhwb3J0IHtcclxuICBUZW5zaW9uQ29udHJvbGxlcixcclxuICB0ZW5zaW9uQ29udHJvbGxlcixcclxuICBjYWxjdWxhdGVUYXJnZXRUZW5zaW9uLFxyXG4gIGNhbGN1bGF0ZU5leHRDaGFwdGVyVGVuc2lvbixcclxuICBhbmFseXplVGVuc2lvbixcclxuICBnZW5lcmF0ZVRlbnNpb25HdWlkYW5jZSxcclxuICBmb3JtYXRUZW5zaW9uRm9yUHJvbXB0LFxyXG4gIGVzdGltYXRlVGVuc2lvbkZyb21DaGFwdGVyLFxyXG4gIHR5cGUgVGVuc2lvbkFuYWx5c2lzLFxyXG4gIHR5cGUgVGVuc2lvbkd1aWRhbmNlLFxyXG59IGZyb20gJy4vYWdlbnRzL3RlbnNpb25Db250cm9sbGVyLmpzJztcclxuZXhwb3J0IHtcclxuICBTdG9yeURpcmVjdG9yLFxyXG4gIHN0b3J5RGlyZWN0b3IsXHJcbiAgdHlwZSBDaGFwdGVyT2JqZWN0aXZlLFxyXG4gIHR5cGUgRGlyZWN0b3JPdXRwdXQsXHJcbiAgdHlwZSBEaXJlY3RvckNvbnRleHQsXHJcbn0gZnJvbSAnLi9hZ2VudHMvc3RvcnlEaXJlY3Rvci5qcyc7XHJcbmV4cG9ydCB7XHJcbiAgQ2hhcHRlclBsYW5uZXIsXHJcbiAgY2hhcHRlclBsYW5uZXIsXHJcbiAgdHlwZSBTY2VuZSxcclxuICB0eXBlIENoYXB0ZXJPdXRsaW5lLFxyXG4gIHR5cGUgUGxhbm5lckNvbnRleHQsXHJcbn0gZnJvbSAnLi9hZ2VudHMvY2hhcHRlclBsYW5uZXIuanMnO1xyXG5cclxuLy8gV29ybGQgU2ltdWxhdGlvblxyXG5leHBvcnQge1xyXG4gIENoYXJhY3RlckFnZW50U3lzdGVtLFxyXG4gIGNoYXJhY3RlckFnZW50U3lzdGVtLFxyXG4gIHR5cGUgQ2hhcmFjdGVyQWdlbnQsXHJcbiAgdHlwZSBBZ2VuZGFJdGVtLFxyXG4gIHR5cGUgQ2hhcmFjdGVyRGVjaXNpb24sXHJcbiAgdHlwZSBDaGFyYWN0ZXJBZ2VudENvbnRleHQsXHJcbn0gZnJvbSAnLi93b3JsZC9jaGFyYWN0ZXJBZ2VudC5qcyc7XHJcbmV4cG9ydCB7XHJcbiAgRXZlbnRSZXNvbHZlcixcclxuICBldmVudFJlc29sdmVyLFxyXG4gIHR5cGUgV29ybGRFdmVudCxcclxuICB0eXBlIEV2ZW50UmVzb2x1dGlvbixcclxuICB0eXBlIENvbmZsaWN0UmVzb2x1dGlvbixcclxufSBmcm9tICcuL3dvcmxkL2V2ZW50UmVzb2x2ZXIuanMnO1xyXG5leHBvcnQge1xyXG4gIFdvcmxkU3RhdGVNYW5hZ2VyLFxyXG4gIGNyZWF0ZVdvcmxkU3RhdGVNYW5hZ2VyLFxyXG4gIHR5cGUgTG9jYXRpb24sXHJcbiAgdHlwZSBXb3JsZFN0YXRlLFxyXG59IGZyb20gJy4vd29ybGQvd29ybGRTdGF0ZS5qcyc7XHJcblxyXG4vLyBDb25zdHJhaW50c1xyXG5leHBvcnQge1xyXG4gIENvbnN0cmFpbnRHcmFwaCxcclxuICBjcmVhdGVDb25zdHJhaW50R3JhcGgsXHJcbiAgdHlwZSBDb25zdHJhaW50Tm9kZSxcclxuICB0eXBlIENvbnN0cmFpbnRFZGdlLFxyXG4gIHR5cGUgQ29uc3RyYWludFZpb2xhdGlvbixcclxuICB0eXBlIE5vZGVUeXBlLFxyXG59IGZyb20gJy4vY29uc3RyYWludHMvY29uc3RyYWludEdyYXBoLmpzJztcclxuZXhwb3J0IHtcclxuICBWYWxpZGF0b3IsXHJcbiAgdmFsaWRhdG9yLFxyXG4gIHR5cGUgVmFsaWRhdGlvblJlc3VsdCxcclxuICB0eXBlIENoYXB0ZXJWYWxpZGF0aW9uQ29udGV4dCxcclxufSBmcm9tICcuL2NvbnN0cmFpbnRzL3ZhbGlkYXRvci5qcyc7XHJcblxyXG4vLyBTdGF0ZSBVcGRhdGUgUGlwZWxpbmVcclxuZXhwb3J0IHtcclxuICBTdGF0ZVVwZGF0ZXJQaXBlbGluZSxcclxuICBzdGF0ZVVwZGF0ZXJQaXBlbGluZSxcclxuICB0eXBlIFN0YXRlVXBkYXRlUmVzdWx0LFxyXG4gIHR5cGUgU3RhdGVDaGFuZ2UsXHJcbiAgdHlwZSBVcGRhdGVDb250ZXh0LFxyXG59IGZyb20gJy4vbWVtb3J5L3N0YXRlVXBkYXRlci5qcyc7XHJcblxyXG4vLyBQaXBlbGluZVxyXG5leHBvcnQgeyBnZW5lcmF0ZUNoYXB0ZXIsIHR5cGUgR2VuZXJhdGVDaGFwdGVyUmVzdWx0LCB0eXBlIEdlbmVyYXRlQ2hhcHRlck9wdGlvbnMgfSBmcm9tICcuL3BpcGVsaW5lL2dlbmVyYXRlQ2hhcHRlci5qcyc7XHJcblxyXG4vLyBTdG9yeVxyXG5leHBvcnQgeyBjcmVhdGVTdG9yeUJpYmxlLCBhZGRDaGFyYWN0ZXIsIGFkZFBsb3RUaHJlYWQgfSBmcm9tICcuL3N0b3J5L2JpYmxlLmpzJztcclxuZXhwb3J0IHsgY3JlYXRlU3RvcnlTdGF0ZSwgdXBkYXRlU3RvcnlTdGF0ZSB9IGZyb20gJy4vc3Rvcnkvc3RhdGUuanMnO1xyXG5leHBvcnQge1xyXG4gIGNyZWF0ZVN0cnVjdHVyZWRTdGF0ZSxcclxuICBpbml0aWFsaXplQ2hhcmFjdGVyc0Zyb21CaWJsZSxcclxuICBpbml0aWFsaXplUGxvdFRocmVhZHNGcm9tQmlibGUsXHJcbiAgdXBkYXRlQ2hhcmFjdGVyU3RhdGUsXHJcbiAgdXBkYXRlUGxvdFRocmVhZCxcclxuICBhZGRVbnJlc29sdmVkUXVlc3Rpb24sXHJcbiAgcmVzb2x2ZVF1ZXN0aW9uLFxyXG4gIGFkZFJlY2VudEV2ZW50LFxyXG4gIHVwZGF0ZVN0b3J5VGVuc2lvbixcclxuICBmb3JtYXRTdHJ1Y3R1cmVkU3RhdGVGb3JQcm9tcHQsXHJcbiAgdHlwZSBTdG9yeVN0cnVjdHVyZWRTdGF0ZSxcclxuICB0eXBlIENoYXJhY3RlclN0YXRlLFxyXG4gIHR5cGUgUGxvdFRocmVhZFN0YXRlLFxyXG59IGZyb20gJy4vc3Rvcnkvc3RydWN0dXJlZFN0YXRlLmpzJztcclxuXHJcbi8vIE1lbW9yeVxyXG5leHBvcnQgeyBjcmVhdGVDYW5vblN0b3JlLCBleHRyYWN0Q2Fub25Gcm9tQmlibGUsIGFkZEZhY3QsIGZvcm1hdENhbm9uRm9yUHJvbXB0LCB0eXBlIENhbm9uU3RvcmUsIHR5cGUgQ2Fub25GYWN0IH0gZnJvbSAnLi9tZW1vcnkvY2Fub25TdG9yZS5qcyc7XHJcbmV4cG9ydCB7IFZlY3RvclN0b3JlLCBnZXRWZWN0b3JTdG9yZSwgY2xlYXJWZWN0b3JTdG9yZSwgdHlwZSBOYXJyYXRpdmVNZW1vcnksIHR5cGUgTWVtb3J5U2VhcmNoUmVzdWx0IH0gZnJvbSAnLi9tZW1vcnkvdmVjdG9yU3RvcmUuanMnO1xyXG5leHBvcnQgeyBNZW1vcnlSZXRyaWV2ZXIsIGNyZWF0ZU1lbW9yeVJldHJpZXZlciwgdHlwZSBSZXRyaWV2YWxDb250ZXh0LCB0eXBlIFJldHJpZXZlZE1lbW9yeSB9IGZyb20gJy4vbWVtb3J5L21lbW9yeVJldHJpZXZlci5qcyc7XHJcbiJdfQ==
@@ -0,0 +1,14 @@
1
+ import type { LLMConfig, LLMProviderConfig } from '../types/index.js';
2
+ export interface LLMProvider {
3
+ complete(prompt: string, config?: Partial<LLMConfig>): Promise<string>;
4
+ }
5
+ export declare class LLMClient {
6
+ private provider;
7
+ private defaultConfig;
8
+ constructor(providerConfig?: LLMProviderConfig);
9
+ private loadConfig;
10
+ private createProvider;
11
+ complete(prompt: string, config?: Partial<LLMConfig>): Promise<string>;
12
+ completeJSON<T>(prompt: string, config?: Partial<LLMConfig>): Promise<T>;
13
+ }
14
+ export declare function getLLM(): LLMClient;
@@ -0,0 +1,108 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.LLMClient = void 0;
7
+ exports.getLLM = getLLM;
8
+ const openai_1 = __importDefault(require("openai"));
9
+ class OpenAIProvider {
10
+ client;
11
+ constructor(config) {
12
+ this.client = new openai_1.default({
13
+ apiKey: config.apiKey,
14
+ baseURL: config.baseURL,
15
+ });
16
+ }
17
+ async complete(prompt, config) {
18
+ const model = config?.model || 'gpt-4o-mini';
19
+ console.log(`[LLM] Using model: ${model}`);
20
+ const response = await this.client.chat.completions.create({
21
+ model,
22
+ messages: [{ role: 'user', content: prompt }],
23
+ temperature: config?.temperature ?? 0.7,
24
+ max_tokens: config?.maxTokens ?? 4000,
25
+ });
26
+ // Handle DeepSeek reasoning models which may have reasoning_content
27
+ const message = response.choices[0]?.message;
28
+ if (!message)
29
+ return '';
30
+ // For DeepSeek reasoning models, content may be in reasoning_content field
31
+ const content = message.reasoning_content || message.content || '';
32
+ return content;
33
+ }
34
+ }
35
+ class LLMClient {
36
+ provider;
37
+ defaultConfig;
38
+ constructor(providerConfig) {
39
+ const config = providerConfig || this.loadConfig();
40
+ this.provider = this.createProvider(config);
41
+ this.defaultConfig = {
42
+ model: config.model || 'gpt-4o-mini',
43
+ temperature: 0.7,
44
+ maxTokens: 4000,
45
+ };
46
+ }
47
+ loadConfig() {
48
+ const provider = process.env.LLM_PROVIDER || 'openai';
49
+ switch (provider) {
50
+ case 'openai':
51
+ return {
52
+ provider: 'openai',
53
+ apiKey: process.env.OPENAI_API_KEY || '',
54
+ model: process.env.LLM_MODEL || 'gpt-4o-mini',
55
+ };
56
+ case 'deepseek':
57
+ return {
58
+ provider: 'deepseek',
59
+ apiKey: process.env.DEEPSEEK_API_KEY || '',
60
+ baseURL: 'https://api.deepseek.com',
61
+ model: process.env.LLM_MODEL || 'deepseek-chat',
62
+ };
63
+ default:
64
+ throw new Error(`Unknown provider: ${provider}`);
65
+ }
66
+ }
67
+ createProvider(config) {
68
+ switch (config.provider) {
69
+ case 'openai':
70
+ case 'deepseek':
71
+ return new OpenAIProvider(config);
72
+ default:
73
+ throw new Error(`Unknown provider: ${config.provider}`);
74
+ }
75
+ }
76
+ async complete(prompt, config) {
77
+ const finalConfig = { ...this.defaultConfig, ...config };
78
+ return this.provider.complete(prompt, finalConfig);
79
+ }
80
+ async completeJSON(prompt, config) {
81
+ const jsonPrompt = `${prompt}\n\nYou must respond with valid JSON only. No markdown, no explanations. Wrap your JSON response in triple backticks if needed.`;
82
+ const response = await this.complete(jsonPrompt, {
83
+ ...config,
84
+ temperature: config?.temperature ?? 0.3,
85
+ });
86
+ // Try to extract JSON from markdown code blocks if present
87
+ let jsonText = response.trim();
88
+ const codeBlockMatch = jsonText.match(/```(?:json)?\s*([\s\S]*?)```/);
89
+ if (codeBlockMatch) {
90
+ jsonText = codeBlockMatch[1].trim();
91
+ }
92
+ try {
93
+ return JSON.parse(jsonText);
94
+ }
95
+ catch (error) {
96
+ throw new Error(`Failed to parse JSON response: ${jsonText.substring(0, 200)}`);
97
+ }
98
+ }
99
+ }
100
+ exports.LLMClient = LLMClient;
101
+ let _llm = null;
102
+ function getLLM() {
103
+ if (!_llm) {
104
+ _llm = new LLMClient();
105
+ }
106
+ return _llm;
107
+ }
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"client.js","sourceRoot":"","sources":["../../src/llm/client.ts"],"names":[],"mappings":"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","sourcesContent":["import OpenAI from 'openai';\r\nimport type { LLMConfig, LLMProviderConfig } from '../types/index.js';\r\n\r\nexport interface LLMProvider {\r\n  complete(prompt: string, config?: Partial<LLMConfig>): Promise<string>;\r\n}\r\n\r\nclass OpenAIProvider implements LLMProvider {\r\n  private client: OpenAI;\r\n\r\n  constructor(config: LLMProviderConfig) {\r\n    this.client = new OpenAI({\r\n      apiKey: config.apiKey,\r\n      baseURL: config.baseURL,\r\n    });\r\n  }\r\n\r\n  async complete(prompt: string, config?: Partial<LLMConfig>): Promise<string> {\r\n    const model = config?.model || 'gpt-4o-mini';\r\n    console.log(`[LLM] Using model: ${model}`);\r\n    const response = await this.client.chat.completions.create({\r\n      model,\r\n      messages: [{ role: 'user', content: prompt }],\r\n      temperature: config?.temperature ?? 0.7,\r\n      max_tokens: config?.maxTokens ?? 4000,\r\n    });\r\n    \r\n    // Handle DeepSeek reasoning models which may have reasoning_content\r\n    const message = response.choices[0]?.message;\r\n    if (!message) return '';\r\n    \r\n    // For DeepSeek reasoning models, content may be in reasoning_content field\r\n    const content = (message as any).reasoning_content || message.content || '';\r\n    return content;\r\n  }\r\n}\r\n\r\nexport class LLMClient {\r\n  private provider: LLMProvider;\r\n  private defaultConfig: LLMConfig;\r\n\r\n  constructor(providerConfig?: LLMProviderConfig) {\r\n    const config = providerConfig || this.loadConfig();\r\n    this.provider = this.createProvider(config);\r\n    \r\n    this.defaultConfig = {\r\n      model: config.model || 'gpt-4o-mini',\r\n      temperature: 0.7,\r\n      maxTokens: 4000,\r\n    };\r\n  }\r\n\r\n  private loadConfig(): LLMProviderConfig {\r\n    const provider = process.env.LLM_PROVIDER || 'openai';\r\n    \r\n    switch (provider) {\r\n      case 'openai':\r\n        return {\r\n          provider: 'openai',\r\n          apiKey: process.env.OPENAI_API_KEY || '',\r\n          model: process.env.LLM_MODEL || 'gpt-4o-mini',\r\n        };\r\n      case 'deepseek':\r\n        return {\r\n          provider: 'deepseek',\r\n          apiKey: process.env.DEEPSEEK_API_KEY || '',\r\n          baseURL: 'https://api.deepseek.com',\r\n          model: process.env.LLM_MODEL || 'deepseek-chat',\r\n        };\r\n      default:\r\n        throw new Error(`Unknown provider: ${provider}`);\r\n    }\r\n  }\r\n\r\n  private createProvider(config: LLMProviderConfig): LLMProvider {\r\n    switch (config.provider) {\r\n      case 'openai':\r\n      case 'deepseek':\r\n        return new OpenAIProvider(config);\r\n      default:\r\n        throw new Error(`Unknown provider: ${config.provider}`);\r\n    }\r\n  }\r\n\r\n  async complete(prompt: string, config?: Partial<LLMConfig>): Promise<string> {\r\n    const finalConfig = { ...this.defaultConfig, ...config };\r\n    return this.provider.complete(prompt, finalConfig);\r\n  }\r\n\r\n  async completeJSON<T>(prompt: string, config?: Partial<LLMConfig>): Promise<T> {\r\n    const jsonPrompt = `${prompt}\\n\\nYou must respond with valid JSON only. No markdown, no explanations. Wrap your JSON response in triple backticks if needed.`;\r\n    const response = await this.complete(jsonPrompt, {\r\n      ...config,\r\n      temperature: config?.temperature ?? 0.3,\r\n    });\r\n    \r\n    // Try to extract JSON from markdown code blocks if present\r\n    let jsonText = response.trim();\r\n    const codeBlockMatch = jsonText.match(/```(?:json)?\\s*([\\s\\S]*?)```/);\r\n    if (codeBlockMatch) {\r\n      jsonText = codeBlockMatch[1].trim();\r\n    }\r\n    \r\n    try {\r\n      return JSON.parse(jsonText) as T;\r\n    } catch (error) {\r\n      throw new Error(`Failed to parse JSON response: ${jsonText.substring(0, 200)}`);\r\n    }\r\n  }\r\n}\r\n\r\nlet _llm: LLMClient | null = null;\r\n\r\nexport function getLLM(): LLMClient {\r\n  if (!_llm) {\r\n    _llm = new LLMClient();\r\n  }\r\n  return _llm;\r\n}\r\n"]}
@@ -0,0 +1,20 @@
1
+ import type { StoryBible } from '../types/index.js';
2
+ export interface CanonFact {
3
+ id: string;
4
+ category: 'character' | 'world' | 'plot' | 'timeline';
5
+ subject: string;
6
+ attribute: string;
7
+ value: string;
8
+ chapterEstablished: number;
9
+ }
10
+ export interface CanonStore {
11
+ storyId: string;
12
+ facts: CanonFact[];
13
+ }
14
+ export declare function createCanonStore(storyId: string): CanonStore;
15
+ export declare function extractCanonFromBible(bible: StoryBible): CanonStore;
16
+ export declare function addFact(store: CanonStore, fact: Omit<CanonFact, 'id'>): CanonStore;
17
+ export declare function getFactsByCategory(store: CanonStore, category: CanonFact['category']): CanonFact[];
18
+ export declare function getFact(store: CanonStore, subject: string, attribute: string): CanonFact | undefined;
19
+ export declare function updateFact(store: CanonStore, subject: string, attribute: string, value: string, chapter: number): CanonStore;
20
+ export declare function formatCanonForPrompt(store: CanonStore): string;