@alan512/experienceengine 0.2.0 → 0.3.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 (182) hide show
  1. package/.claude-plugin/plugin.json +1 -1
  2. package/.mcp.json +5 -6
  3. package/README.md +65 -54
  4. package/README.zh-CN.md +64 -53
  5. package/dist/adapters/codex/action-registry.d.ts +23 -1
  6. package/dist/adapters/codex/action-registry.js +73 -0
  7. package/dist/adapters/codex/action-registry.js.map +1 -1
  8. package/dist/adapters/codex/behavior-loop.d.ts +80 -0
  9. package/dist/adapters/codex/behavior-loop.js +189 -0
  10. package/dist/adapters/codex/behavior-loop.js.map +1 -0
  11. package/dist/adapters/codex/mcp-server.d.ts +27 -72
  12. package/dist/adapters/codex/mcp-server.js +36 -160
  13. package/dist/adapters/codex/mcp-server.js.map +1 -1
  14. package/dist/cli/commands/claude-hook.d.ts +4 -0
  15. package/dist/cli/commands/claude-hook.js +105 -21
  16. package/dist/cli/commands/claude-hook.js.map +1 -1
  17. package/dist/cli/commands/codex-hook.d.ts +22 -0
  18. package/dist/cli/commands/codex-hook.js +298 -0
  19. package/dist/cli/commands/codex-hook.js.map +1 -0
  20. package/dist/cli/commands/config.js +9 -1
  21. package/dist/cli/commands/config.js.map +1 -1
  22. package/dist/cli/commands/doctor.js +77 -2
  23. package/dist/cli/commands/doctor.js.map +1 -1
  24. package/dist/cli/commands/inspect.d.ts +1 -1
  25. package/dist/cli/commands/inspect.js +329 -4
  26. package/dist/cli/commands/inspect.js.map +1 -1
  27. package/dist/cli/commands/install.js +2 -0
  28. package/dist/cli/commands/install.js.map +1 -1
  29. package/dist/cli/commands/maintenance.js +4 -0
  30. package/dist/cli/commands/maintenance.js.map +1 -1
  31. package/dist/cli/commands/repair.js +33 -3
  32. package/dist/cli/commands/repair.js.map +1 -1
  33. package/dist/cli/commands/status.js +33 -0
  34. package/dist/cli/commands/status.js.map +1 -1
  35. package/dist/cli/dispatch.js +8 -3
  36. package/dist/cli/dispatch.js.map +1 -1
  37. package/dist/cli/index.js +0 -0
  38. package/dist/config/config-schema.d.ts +8 -0
  39. package/dist/config/config-schema.js +6 -0
  40. package/dist/config/config-schema.js.map +1 -1
  41. package/dist/config/default-config.js +1 -0
  42. package/dist/config/default-config.js.map +1 -1
  43. package/dist/config/load-config.js +3 -0
  44. package/dist/config/load-config.js.map +1 -1
  45. package/dist/controller/candidate-retriever.d.ts +5 -1
  46. package/dist/controller/candidate-retriever.js +237 -13
  47. package/dist/controller/candidate-retriever.js.map +1 -1
  48. package/dist/controller/injection-renderer.d.ts +2 -2
  49. package/dist/controller/injection-renderer.js +22 -3
  50. package/dist/controller/injection-renderer.js.map +1 -1
  51. package/dist/controller/injection-scorecard.js +3 -0
  52. package/dist/controller/injection-scorecard.js.map +1 -1
  53. package/dist/controller/intervention-controller.d.ts +2 -2
  54. package/dist/controller/intervention-controller.js +185 -25
  55. package/dist/controller/intervention-controller.js.map +1 -1
  56. package/dist/controller/model-reranker-mode.d.ts +4 -0
  57. package/dist/controller/model-reranker-mode.js +14 -0
  58. package/dist/controller/model-reranker-mode.js.map +1 -0
  59. package/dist/controller/model-reranker.d.ts +0 -1
  60. package/dist/controller/model-reranker.js +1 -13
  61. package/dist/controller/model-reranker.js.map +1 -1
  62. package/dist/controller/policy-enricher.d.ts +2 -1
  63. package/dist/controller/policy-enricher.js +71 -11
  64. package/dist/controller/policy-enricher.js.map +1 -1
  65. package/dist/controller/trigger-evaluator.d.ts +2 -1
  66. package/dist/controller/trigger-evaluator.js +24 -0
  67. package/dist/controller/trigger-evaluator.js.map +1 -1
  68. package/dist/evaluation/openclaw-scenarios.js +12 -5
  69. package/dist/evaluation/openclaw-scenarios.js.map +1 -1
  70. package/dist/experience-management/repo-policy.d.ts +53 -0
  71. package/dist/experience-management/repo-policy.js +175 -0
  72. package/dist/experience-management/repo-policy.js.map +1 -0
  73. package/dist/hybrid/capsule-builder.js +2 -0
  74. package/dist/hybrid/capsule-builder.js.map +1 -1
  75. package/dist/input/scope-resolver.js +16 -4
  76. package/dist/input/scope-resolver.js.map +1 -1
  77. package/dist/install/claude-cli.js +38 -21
  78. package/dist/install/claude-cli.js.map +1 -1
  79. package/dist/install/claude-code-doctor.js +8 -3
  80. package/dist/install/claude-code-doctor.js.map +1 -1
  81. package/dist/install/claude-code-installer.js +5 -2
  82. package/dist/install/claude-code-installer.js.map +1 -1
  83. package/dist/install/claude-runtime-target.d.ts +5 -0
  84. package/dist/install/claude-runtime-target.js +32 -2
  85. package/dist/install/claude-runtime-target.js.map +1 -1
  86. package/dist/install/codex-cli.d.ts +7 -0
  87. package/dist/install/codex-cli.js +43 -20
  88. package/dist/install/codex-cli.js.map +1 -1
  89. package/dist/install/codex-hooks.d.ts +42 -0
  90. package/dist/install/codex-hooks.js +258 -0
  91. package/dist/install/codex-hooks.js.map +1 -0
  92. package/dist/install/codex-installer.d.ts +28 -3
  93. package/dist/install/codex-installer.js +120 -9
  94. package/dist/install/codex-installer.js.map +1 -1
  95. package/dist/install/codex-runtime-target.d.ts +20 -0
  96. package/dist/install/codex-runtime-target.js +85 -17
  97. package/dist/install/codex-runtime-target.js.map +1 -1
  98. package/dist/install/openclaw-cli.d.ts +1 -0
  99. package/dist/install/openclaw-cli.js +52 -3
  100. package/dist/install/openclaw-cli.js.map +1 -1
  101. package/dist/install/openclaw-installer.d.ts +5 -0
  102. package/dist/install/openclaw-installer.js +24 -5
  103. package/dist/install/openclaw-installer.js.map +1 -1
  104. package/dist/interaction/repo-summary.d.ts +17 -0
  105. package/dist/interaction/repo-summary.js +33 -15
  106. package/dist/interaction/repo-summary.js.map +1 -1
  107. package/dist/interaction/retrieval-policy-inspection.d.ts +19 -0
  108. package/dist/interaction/retrieval-policy-inspection.js +33 -0
  109. package/dist/interaction/retrieval-policy-inspection.js.map +1 -0
  110. package/dist/interaction/service.d.ts +24 -1
  111. package/dist/interaction/service.js +186 -23
  112. package/dist/interaction/service.js.map +1 -1
  113. package/dist/maintenance/claude-validate-print.d.ts +8 -1
  114. package/dist/maintenance/claude-validate-print.js +52 -2
  115. package/dist/maintenance/claude-validate-print.js.map +1 -1
  116. package/dist/maintenance/experience-export-drafts.d.ts +56 -0
  117. package/dist/maintenance/experience-export-drafts.js +217 -0
  118. package/dist/maintenance/experience-export-drafts.js.map +1 -0
  119. package/dist/maintenance/experience-hygiene.d.ts +38 -0
  120. package/dist/maintenance/experience-hygiene.js +266 -0
  121. package/dist/maintenance/experience-hygiene.js.map +1 -0
  122. package/dist/maintenance/operator-review-flow.d.ts +81 -0
  123. package/dist/maintenance/operator-review-flow.js +172 -0
  124. package/dist/maintenance/operator-review-flow.js.map +1 -0
  125. package/dist/plugin/openclaw-plugin.d.ts +5 -0
  126. package/dist/plugin/runtime-helpers.js +43 -1
  127. package/dist/plugin/runtime-helpers.js.map +1 -1
  128. package/dist/runtime/prompt-service.d.ts +51 -0
  129. package/dist/runtime/prompt-service.js +209 -0
  130. package/dist/runtime/prompt-service.js.map +1 -0
  131. package/dist/runtime/service.d.ts +8 -2
  132. package/dist/runtime/service.js +234 -44
  133. package/dist/runtime/service.js.map +1 -1
  134. package/dist/store/sqlite/db.js +15 -0
  135. package/dist/store/sqlite/db.js.map +1 -1
  136. package/dist/store/sqlite/repositories/attribution-record-repo.d.ts +15 -0
  137. package/dist/store/sqlite/repositories/attribution-record-repo.js +111 -0
  138. package/dist/store/sqlite/repositories/attribution-record-repo.js.map +1 -0
  139. package/dist/store/sqlite/repositories/episode-repo.d.ts +14 -0
  140. package/dist/store/sqlite/repositories/episode-repo.js +84 -0
  141. package/dist/store/sqlite/repositories/episode-repo.js.map +1 -0
  142. package/dist/store/sqlite/repositories/injection-repo.d.ts +2 -0
  143. package/dist/store/sqlite/repositories/injection-repo.js +32 -5
  144. package/dist/store/sqlite/repositories/injection-repo.js.map +1 -1
  145. package/dist/store/sqlite/repositories/input-record-repo.d.ts +1 -0
  146. package/dist/store/sqlite/repositories/input-record-repo.js +23 -10
  147. package/dist/store/sqlite/repositories/input-record-repo.js.map +1 -1
  148. package/dist/store/sqlite/repositories/node-repo.d.ts +2 -0
  149. package/dist/store/sqlite/repositories/node-repo.js +19 -0
  150. package/dist/store/sqlite/repositories/node-repo.js.map +1 -1
  151. package/dist/store/sqlite/repositories/outcome-record-repo.d.ts +1 -0
  152. package/dist/store/sqlite/repositories/outcome-record-repo.js +11 -2
  153. package/dist/store/sqlite/repositories/outcome-record-repo.js.map +1 -1
  154. package/dist/store/sqlite/repositories/repo-policy-repo.d.ts +11 -0
  155. package/dist/store/sqlite/repositories/repo-policy-repo.js +87 -0
  156. package/dist/store/sqlite/repositories/repo-policy-repo.js.map +1 -0
  157. package/dist/store/sqlite/repositories/review-event-repo.d.ts +1 -0
  158. package/dist/store/sqlite/repositories/review-event-repo.js +11 -2
  159. package/dist/store/sqlite/repositories/review-event-repo.js.map +1 -1
  160. package/dist/store/sqlite/repositories/task-run-repo.d.ts +1 -0
  161. package/dist/store/sqlite/repositories/task-run-repo.js +11 -2
  162. package/dist/store/sqlite/repositories/task-run-repo.js.map +1 -1
  163. package/dist/store/sqlite/schema.sql +43 -0
  164. package/dist/store/vector/api-embedding-provider.js +14 -3
  165. package/dist/store/vector/api-embedding-provider.js.map +1 -1
  166. package/dist/store/vector/embeddings.js +7 -1
  167. package/dist/store/vector/embeddings.js.map +1 -1
  168. package/dist/types/domain.d.ts +105 -3
  169. package/dist/utils/text.js +5 -1
  170. package/dist/utils/text.js.map +1 -1
  171. package/docs/assets/readme/inspect-last-example.svg +37 -0
  172. package/docs/releases/v0.2.1.md +30 -0
  173. package/docs/releases/v0.3.0.md +17 -0
  174. package/docs/user-guide.md +91 -5
  175. package/openclaw.plugin.json +1 -1
  176. package/package.json +16 -14
  177. package/plugins/claude-code-experienceengine/.claude-plugin/plugin.json +1 -1
  178. package/plugins/claude-code-experienceengine/.mcp.json +3 -9
  179. package/plugins/claude-code-experienceengine/scripts/install-deps.sh +1 -1
  180. package/plugins/claude-code-experienceengine/scripts/mcp-server.sh +43 -0
  181. package/scripts/claude-plugin/claude-hook.sh +6 -1
  182. package/scripts/claude-plugin/mcp-server.sh +45 -0
@@ -34,6 +34,9 @@ const ensureColumn = (db, table, column, definition) => {
34
34
  }
35
35
  return false;
36
36
  };
37
+ const ensureIndex = (db, indexName, table, column) => {
38
+ db.exec(`CREATE INDEX IF NOT EXISTS ${indexName} ON ${table}(${column})`);
39
+ };
37
40
  const backfillExperienceNodeDeliveryState = (db, forceAllRows = false) => {
38
41
  db.exec(`UPDATE experience_nodes
39
42
  SET delivery_state = CASE state
@@ -119,6 +122,18 @@ export const bootstrapDatabase = (db) => {
119
122
  ensureColumn(db, "injection_events", "delivered", "INTEGER NOT NULL DEFAULT 1");
120
123
  ensureColumn(db, "injection_events", "scorecard_json", "TEXT");
121
124
  ensureColumn(db, "injection_events", "attribution_reason", "TEXT");
125
+ ensureColumn(db, "experience_input_records", "episode_id", "TEXT");
126
+ ensureColumn(db, "task_runs", "episode_id", "TEXT");
127
+ ensureColumn(db, "outcome_records", "episode_id", "TEXT");
128
+ ensureColumn(db, "injection_events", "episode_id", "TEXT");
129
+ ensureColumn(db, "attribution_records", "episode_id", "TEXT");
130
+ ensureColumn(db, "review_events", "episode_id", "TEXT");
131
+ ensureIndex(db, "idx_experience_input_records_episode_id", "experience_input_records", "episode_id");
132
+ ensureIndex(db, "idx_task_runs_episode_id", "task_runs", "episode_id");
133
+ ensureIndex(db, "idx_outcome_records_episode_id", "outcome_records", "episode_id");
134
+ ensureIndex(db, "idx_injection_events_episode_id", "injection_events", "episode_id");
135
+ ensureIndex(db, "idx_attribution_records_episode_id", "attribution_records", "episode_id");
136
+ ensureIndex(db, "idx_review_events_episode_id", "review_events", "episode_id");
122
137
  ensureColumn(db, "task_runs", "learning_status", "TEXT");
123
138
  ensureColumn(db, "task_runs", "learning_reason", "TEXT");
124
139
  ensureColumn(db, "hybrid_review_artifacts", "schema_version", "TEXT NOT NULL DEFAULT 'hybrid-capsule-v1'");
@@ -1 +1 @@
1
- {"version":3,"file":"db.js","sourceRoot":"","sources":["../../../src/store/sqlite/db.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"db.js","sourceRoot":"","sources":["../../../src/store/sqlite/db.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC9D,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAGzC,MAAM,SAAS,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;AAC1D,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,UAAkB,SAAS,EAAU,EAAE;IAC7E,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IAChD,MAAM,UAAU,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC;IAExG,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;QACnC,IAAI,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;YAC1B,OAAO,SAAS,CAAC;QACnB,CAAC;IACH,CAAC;IAED,MAAM,IAAI,KAAK,CACb,6DAA6D,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CACrF,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,MAA8B,EAAgB,EAAE;IAC3E,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAC1C,MAAM,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAE9B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;QACvB,SAAS,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACxC,CAAC;IAED,MAAM,EAAE,GAAG,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC;IACpC,EAAE,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;IACtC,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,EAAgB,EAAE,KAAa,EAAE,MAAc,EAAW,EAAE;IAChF,MAAM,IAAI,GAAG,EAAE,CAAC,OAAO,CAAC,qBAAqB,KAAK,GAAG,CAAC,CAAC,GAAG,EAA6B,CAAC;IACxF,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;AACjD,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,EAAgB,EAAE,KAAa,EAAE,MAAc,EAAE,UAAkB,EAAW,EAAE;IACpG,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,EAAE,CAAC;QACrC,EAAE,CAAC,IAAI,CAAC,eAAe,KAAK,eAAe,MAAM,IAAI,UAAU,EAAE,CAAC,CAAC;QACnE,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,CAAC,EAAgB,EAAE,SAAiB,EAAE,KAAa,EAAE,MAAc,EAAQ,EAAE;IAC/F,EAAE,CAAC,IAAI,CAAC,8BAA8B,SAAS,OAAO,KAAK,IAAI,MAAM,GAAG,CAAC,CAAC;AAC5E,CAAC,CAAC;AAEF,MAAM,mCAAmC,GAAG,CAAC,EAAgB,EAAE,YAAY,GAAG,KAAK,EAAQ,EAAE;IAC3F,EAAE,CAAC,IAAI,CACL;;;;;;;;;aASS,YAAY;QAClB,CAAC,CAAC,OAAO;QACT,CAAC,CAAC,wIAAwI,EAAE,CAChJ,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAgB,EAAQ,EAAE;IAC1D,MAAM,UAAU,GAAG,uBAAuB,CAAC,SAAS,CAAC,CAAC;IACtD,MAAM,MAAM,GAAG,YAAY,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;IAChD,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAEhB,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;IAC/D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;IAC/D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,CAAC,CAAC;IACnE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;IAChE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;IAClE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,SAAS,CAAC,CAAC;IACxE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,MAAM,CAAC,CAAC;IACvE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,CAAC,CAAC;IACpE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACjE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACjE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACjE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;IAC/D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;IAC7D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,4BAA4B,EAAE,4BAA4B,CAAC,CAAC;IACjG,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,4BAA4B,CAAC,CAAC;IAC7F,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,4BAA4B,CAAC,CAAC;IAC7F,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,4BAA4B,CAAC,CAAC;IAC7F,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;IAChE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;IAClE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACjE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACjE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,CAAC,CAAC;IACpE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;IAClE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,MAAM,CAAC,CAAC;IACrE,MAAM,kBAAkB,GAAG,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,qCAAqC,CAAC,CAAC;IACzH,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,0BAA0B,EAAE,4BAA4B,CAAC,CAAC;IAC/F,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,uBAAuB,EAAE,MAAM,CAAC,CAAC;IACtE,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;IAC/D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;IAClE,mCAAmC,CAAC,EAAE,EAAE,kBAAkB,CAAC,CAAC;IAC5D,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,wBAAwB,EAAE,MAAM,CAAC,CAAC;IAC5E,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,iCAAiC,CAAC,CAAC;IACtG,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;IACjE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;IACpE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;IACjE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;IACvE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,oBAAoB,EAAE,4BAA4B,CAAC,CAAC;IAC9F,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,iCAAiC,CAAC,CAAC;IAChG,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,aAAa,EAAE,4BAA4B,CAAC,CAAC;IACvF,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;IACvE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAChE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;IAClE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;IAClE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;IACpE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACtE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACtE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;IACrE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;IACvE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACtE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,kBAAkB,EAAE,MAAM,CAAC,CAAC;IACtE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,MAAM,CAAC,CAAC;IACzE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,mBAAmB,EAAE,MAAM,CAAC,CAAC;IACvE,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,CAAC,CAAC;IAC1E,YAAY,CAAC,EAAE,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,kCAAkC,CAAC,CAAC;IAC/F,YAAY,CAAC,EAAE,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,MAAM,CAAC,CAAC;IACrE,YAAY,CAAC,EAAE,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;IAChE,YAAY,CAAC,EAAE,EAAE,mBAAmB,EAAE,aAAa,EAAE,4BAA4B,CAAC,CAAC;IACnF,YAAY,CAAC,EAAE,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAC5D,YAAY,CAAC,EAAE,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAC5D,YAAY,CAAC,EAAE,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;IAC7D,YAAY,CAAC,EAAE,EAAE,mBAAmB,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;IAC9D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAC3D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;IAC7D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,eAAe,EAAE,8BAA8B,CAAC,CAAC;IACtF,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,WAAW,EAAE,4BAA4B,CAAC,CAAC;IAChF,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,CAAC,CAAC;IAC/D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,CAAC,CAAC;IACnE,YAAY,CAAC,EAAE,EAAE,0BAA0B,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IACnE,YAAY,CAAC,EAAE,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IACpD,YAAY,CAAC,EAAE,EAAE,iBAAiB,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAC1D,YAAY,CAAC,EAAE,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAC3D,YAAY,CAAC,EAAE,EAAE,qBAAqB,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IAC9D,YAAY,CAAC,EAAE,EAAE,eAAe,EAAE,YAAY,EAAE,MAAM,CAAC,CAAC;IACxD,WAAW,CAAC,EAAE,EAAE,yCAAyC,EAAE,0BAA0B,EAAE,YAAY,CAAC,CAAC;IACrG,WAAW,CAAC,EAAE,EAAE,0BAA0B,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;IACvE,WAAW,CAAC,EAAE,EAAE,gCAAgC,EAAE,iBAAiB,EAAE,YAAY,CAAC,CAAC;IACnF,WAAW,CAAC,EAAE,EAAE,iCAAiC,EAAE,kBAAkB,EAAE,YAAY,CAAC,CAAC;IACrF,WAAW,CAAC,EAAE,EAAE,oCAAoC,EAAE,qBAAqB,EAAE,YAAY,CAAC,CAAC;IAC3F,WAAW,CAAC,EAAE,EAAE,8BAA8B,EAAE,eAAe,EAAE,YAAY,CAAC,CAAC;IAC/E,YAAY,CAAC,EAAE,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;IACzD,YAAY,CAAC,EAAE,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;IACzD,YAAY,CAAC,EAAE,EAAE,yBAAyB,EAAE,gBAAgB,EAAE,2CAA2C,CAAC,CAAC;IAC3G,YAAY,CAAC,EAAE,EAAE,yBAAyB,EAAE,sBAAsB,EAAE,0CAA0C,CAAC,CAAC;IAChH,YAAY,CAAC,EAAE,EAAE,yBAAyB,EAAE,wBAAwB,EAAE,8CAA8C,CAAC,CAAC;IACtH,YAAY,CAAC,EAAE,EAAE,0BAA0B,EAAE,wBAAwB,EAAE,MAAM,CAAC,CAAC;IAC/E,YAAY,CAAC,EAAE,EAAE,0BAA0B,EAAE,wBAAwB,EAAE,MAAM,CAAC,CAAC;IAC/E,YAAY,CAAC,EAAE,EAAE,0BAA0B,EAAE,iBAAiB,EAAE,MAAM,CAAC,CAAC;AAC1E,CAAC,CAAC;AAEF,MAAM,eAAe,GAAG,CAAC,KAAc,EAAW,EAAE;IAClD,IAAI,CAAC,CAAC,KAAK,YAAY,KAAK,CAAC,EAAE,CAAC;QAC9B,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,WAAW,GAAG,KAAmD,CAAC;IACxE,MAAM,OAAO,GAAG,GAAG,KAAK,CAAC,OAAO,IAAI,WAAW,CAAC,MAAM,IAAI,EAAE,EAAE,CAAC,WAAW,EAAE,CAAC;IAE7E,OAAO,WAAW,CAAC,IAAI,KAAK,kBAAkB,IAAI,CAChD,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAC;QACtC,OAAO,CAAC,QAAQ,CAAC,0BAA0B,CAAC;QAC5C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CACzB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAI,EAAgB,EAAE,SAAkB,EAAK,EAAE;IAC5E,IAAI,KAAK,GAAG,KAAK,CAAC;IAElB,KAAK,IAAI,OAAO,GAAG,CAAC,EAAE,OAAO,GAAG,CAAC,EAAE,OAAO,IAAI,CAAC,EAAE,CAAC;QAChD,IAAI,CAAC;YACH,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;YAC3B,KAAK,GAAG,IAAI,CAAC;YACb,MAAM;QACR,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,OAAO,KAAK,CAAC,EAAE,CAAC;gBAC7C,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;QAC3B,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClB,OAAO,MAAM,CAAC;IAChB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,KAAK,EAAE,CAAC;YACV,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACtB,CAAC;QACD,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC,CAAC"}
@@ -0,0 +1,15 @@
1
+ import type { DatabaseSync } from "node:sqlite";
2
+ import type { AttributionRecord, AttributionVerdict } from "../../../types/domain.js";
3
+ export declare class AttributionRecordRepository {
4
+ private readonly db;
5
+ constructor(db: DatabaseSync);
6
+ private mapRow;
7
+ insert(record: AttributionRecord): AttributionRecord;
8
+ getById(id: string): AttributionRecord | undefined;
9
+ listByInjectionId(injectionId: string): AttributionRecord[];
10
+ listByNodeId(nodeId: string): AttributionRecord[];
11
+ listByEpisodeId(episodeId: string): AttributionRecord[];
12
+ listRecentEligibleByScope(scopeId: string, limit?: number): AttributionRecord[];
13
+ listRecentByScope(scopeId: string, limit?: number): AttributionRecord[];
14
+ countByVerdict(verdict: AttributionVerdict): number;
15
+ }
@@ -0,0 +1,111 @@
1
+ export class AttributionRecordRepository {
2
+ db;
3
+ constructor(db) {
4
+ this.db = db;
5
+ }
6
+ mapRow(row) {
7
+ return {
8
+ id: row.id,
9
+ injection_id: row.injection_id ?? undefined,
10
+ node_id: row.node_id,
11
+ episode_id: row.episode_id ?? undefined,
12
+ intervention_strength: row.intervention_strength ?? undefined,
13
+ injection_mode: row.injection_mode ?? undefined,
14
+ delivery_mode: row.delivery_mode ?? undefined,
15
+ delivered: Boolean(row.delivered),
16
+ outcome: row.outcome,
17
+ attribution_verdict: row.attribution_verdict,
18
+ confidence: row.confidence,
19
+ evidence_refs: JSON.parse(row.evidence_refs_json),
20
+ user_override: row.user_override ?? undefined,
21
+ source: row.source,
22
+ attribution_reason: row.attribution_reason ?? undefined,
23
+ created_at: row.created_at,
24
+ resolved_at: row.resolved_at ?? undefined
25
+ };
26
+ }
27
+ insert(record) {
28
+ this.db
29
+ .prepare(`INSERT INTO attribution_records
30
+ (id, injection_id, node_id, episode_id, intervention_strength, injection_mode, delivery_mode, delivered,
31
+ outcome, attribution_verdict, confidence, evidence_refs_json, user_override, source, attribution_reason,
32
+ created_at, resolved_at)
33
+ VALUES
34
+ (@id, @injection_id, @node_id, @episode_id, @intervention_strength, @injection_mode, @delivery_mode, @delivered,
35
+ @outcome, @attribution_verdict, @confidence, @evidence_refs_json, @user_override, @source, @attribution_reason,
36
+ @created_at, @resolved_at)
37
+ ON CONFLICT(id) DO NOTHING`)
38
+ .run({
39
+ id: record.id,
40
+ injection_id: record.injection_id ?? null,
41
+ node_id: record.node_id,
42
+ episode_id: record.episode_id ?? null,
43
+ intervention_strength: record.intervention_strength ?? null,
44
+ injection_mode: record.injection_mode ?? null,
45
+ delivery_mode: record.delivery_mode ?? null,
46
+ delivered: Number(record.delivered),
47
+ outcome: record.outcome,
48
+ attribution_verdict: record.attribution_verdict,
49
+ confidence: record.confidence,
50
+ evidence_refs_json: JSON.stringify(record.evidence_refs),
51
+ user_override: record.user_override ?? null,
52
+ source: record.source,
53
+ attribution_reason: record.attribution_reason ?? null,
54
+ created_at: record.created_at,
55
+ resolved_at: record.resolved_at ?? null
56
+ });
57
+ return record;
58
+ }
59
+ getById(id) {
60
+ const row = this.db.prepare("SELECT * FROM attribution_records WHERE id = ? LIMIT 1").get(id);
61
+ return row ? this.mapRow(row) : undefined;
62
+ }
63
+ listByInjectionId(injectionId) {
64
+ return this.db
65
+ .prepare("SELECT * FROM attribution_records WHERE injection_id = ? ORDER BY created_at DESC, id DESC")
66
+ .all(injectionId)
67
+ .map((row) => this.mapRow(row));
68
+ }
69
+ listByNodeId(nodeId) {
70
+ return this.db
71
+ .prepare("SELECT * FROM attribution_records WHERE node_id = ? ORDER BY created_at DESC, id DESC")
72
+ .all(nodeId)
73
+ .map((row) => this.mapRow(row));
74
+ }
75
+ listByEpisodeId(episodeId) {
76
+ return this.db
77
+ .prepare("SELECT * FROM attribution_records WHERE episode_id = ? ORDER BY created_at DESC, id DESC")
78
+ .all(episodeId)
79
+ .map((row) => this.mapRow(row));
80
+ }
81
+ listRecentEligibleByScope(scopeId, limit = 20) {
82
+ return this.db
83
+ .prepare(`SELECT ar.*
84
+ FROM attribution_records ar
85
+ LEFT JOIN injection_events ie ON ie.injection_id = ar.injection_id
86
+ LEFT JOIN experience_nodes en ON en.id = ar.node_id
87
+ WHERE (ie.scope_id = ? OR (ie.injection_id IS NULL AND en.scope_id = ?))
88
+ AND (ar.delivered = 1 OR ar.intervention_strength = 'diagnostic_hint')
89
+ ORDER BY ar.created_at DESC, ar.id DESC
90
+ LIMIT ?`)
91
+ .all(scopeId, scopeId, limit)
92
+ .map((row) => this.mapRow(row));
93
+ }
94
+ listRecentByScope(scopeId, limit = 50) {
95
+ return this.db
96
+ .prepare(`SELECT ar.*
97
+ FROM attribution_records ar
98
+ INNER JOIN experience_nodes en ON en.id = ar.node_id
99
+ WHERE en.scope_id = ?
100
+ ORDER BY ar.created_at DESC, ar.id DESC
101
+ LIMIT ?`)
102
+ .all(scopeId, limit)
103
+ .map((row) => this.mapRow(row));
104
+ }
105
+ countByVerdict(verdict) {
106
+ return this.db
107
+ .prepare("SELECT COUNT(*) AS count FROM attribution_records WHERE attribution_verdict = ?")
108
+ .get(verdict).count;
109
+ }
110
+ }
111
+ //# sourceMappingURL=attribution-record-repo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"attribution-record-repo.js","sourceRoot":"","sources":["../../../../src/store/sqlite/repositories/attribution-record-repo.ts"],"names":[],"mappings":"AAuBA,MAAM,OAAO,2BAA2B;IACT;IAA7B,YAA6B,EAAgB;QAAhB,OAAE,GAAF,EAAE,CAAc;IAAG,CAAC;IAEzC,MAAM,CAAC,GAAyB;QACtC,OAAO;YACL,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,YAAY,EAAE,GAAG,CAAC,YAAY,IAAI,SAAS;YAC3C,OAAO,EAAE,GAAG,CAAC,OAAO;YACpB,UAAU,EAAE,GAAG,CAAC,UAAU,IAAI,SAAS;YACvC,qBAAqB,EAAE,GAAG,CAAC,qBAAqB,IAAI,SAAS;YAC7D,cAAc,EAAE,GAAG,CAAC,cAAc,IAAI,SAAS;YAC/C,aAAa,EAAE,GAAG,CAAC,aAAa,IAAI,SAAS;YAC7C,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC;YACjC,OAAO,EAAE,GAAG,CAAC,OAAO;YACpB,mBAAmB,EAAE,GAAG,CAAC,mBAAmB;YAC5C,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,aAAa,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,kBAAkB,CAAa;YAC7D,aAAa,EAAE,GAAG,CAAC,aAAa,IAAI,SAAS;YAC7C,MAAM,EAAE,GAAG,CAAC,MAAM;YAClB,kBAAkB,EAAE,GAAG,CAAC,kBAAkB,IAAI,SAAS;YACvD,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,WAAW,EAAE,GAAG,CAAC,WAAW,IAAI,SAAS;SAC1C,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,MAAyB;QAC9B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;oCAQ4B,CAC7B;aACA,GAAG,CAAC;YACH,EAAE,EAAE,MAAM,CAAC,EAAE;YACb,YAAY,EAAE,MAAM,CAAC,YAAY,IAAI,IAAI;YACzC,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,UAAU,EAAE,MAAM,CAAC,UAAU,IAAI,IAAI;YACrC,qBAAqB,EAAE,MAAM,CAAC,qBAAqB,IAAI,IAAI;YAC3D,cAAc,EAAE,MAAM,CAAC,cAAc,IAAI,IAAI;YAC7C,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,IAAI;YAC3C,SAAS,EAAE,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC;YACnC,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,mBAAmB,EAAE,MAAM,CAAC,mBAAmB;YAC/C,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,aAAa,CAAC;YACxD,aAAa,EAAE,MAAM,CAAC,aAAa,IAAI,IAAI;YAC3C,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,kBAAkB,EAAE,MAAM,CAAC,kBAAkB,IAAI,IAAI;YACrD,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,WAAW,EAAE,MAAM,CAAC,WAAW,IAAI,IAAI;SACxC,CAAC,CAAC;QAEL,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,OAAO,CAAC,EAAU;QAChB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,wDAAwD,CAAC,CAAC,GAAG,CAAC,EAAE,CAE/E,CAAC;QACd,OAAO,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC5C,CAAC;IAED,iBAAiB,CAAC,WAAmB;QACnC,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CAAC,4FAA4F,CAAC;aACrG,GAAG,CAAC,WAAW,CAAC;aAChB,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAA2B,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,YAAY,CAAC,MAAc;QACzB,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CAAC,uFAAuF,CAAC;aAChG,GAAG,CAAC,MAAM,CAAC;aACX,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAA2B,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,eAAe,CAAC,SAAiB;QAC/B,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CAAC,0FAA0F,CAAC;aACnG,GAAG,CAAC,SAAS,CAAC;aACd,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAA2B,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,yBAAyB,CAAC,OAAe,EAAE,KAAK,GAAG,EAAE;QACnD,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;iBAOS,CACV;aACA,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC;aAC5B,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAA2B,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,iBAAiB,CAAC,OAAe,EAAE,KAAK,GAAG,EAAE;QAC3C,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;iBAKS,CACV;aACA,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC;aACnB,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAA2B,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,cAAc,CAAC,OAA2B;QACxC,OACE,IAAI,CAAC,EAAE;aACJ,OAAO,CAAC,iFAAiF,CAAC;aAC1F,GAAG,CAAC,OAAO,CACf,CAAC,KAAK,CAAC;IACV,CAAC;CACF"}
@@ -0,0 +1,14 @@
1
+ import type { DatabaseSync } from "node:sqlite";
2
+ import type { EpisodeProjection, EpisodeSummary } from "../../../types/domain.js";
3
+ export declare class EpisodeRepository {
4
+ private readonly db;
5
+ private readonly inputRepo;
6
+ private readonly taskRunRepo;
7
+ private readonly outcomeRepo;
8
+ private readonly injectionRepo;
9
+ private readonly attributionRepo;
10
+ private readonly reviewRepo;
11
+ constructor(db: DatabaseSync);
12
+ getByEpisodeId(episodeId: string): EpisodeProjection | undefined;
13
+ listRecentByScope(scopeId: string, limit?: number): EpisodeSummary[];
14
+ }
@@ -0,0 +1,84 @@
1
+ import { AttributionRecordRepository } from "./attribution-record-repo.js";
2
+ import { InjectionRepository } from "./injection-repo.js";
3
+ import { InputRecordRepository } from "./input-record-repo.js";
4
+ import { OutcomeRecordRepository } from "./outcome-record-repo.js";
5
+ import { ReviewEventRepository } from "./review-event-repo.js";
6
+ import { TaskRunRepository } from "./task-run-repo.js";
7
+ export class EpisodeRepository {
8
+ db;
9
+ inputRepo;
10
+ taskRunRepo;
11
+ outcomeRepo;
12
+ injectionRepo;
13
+ attributionRepo;
14
+ reviewRepo;
15
+ constructor(db) {
16
+ this.db = db;
17
+ this.inputRepo = new InputRecordRepository(db);
18
+ this.taskRunRepo = new TaskRunRepository(db);
19
+ this.outcomeRepo = new OutcomeRecordRepository(db);
20
+ this.injectionRepo = new InjectionRepository(db);
21
+ this.attributionRepo = new AttributionRecordRepository(db);
22
+ this.reviewRepo = new ReviewEventRepository(db);
23
+ }
24
+ getByEpisodeId(episodeId) {
25
+ const taskRun = this.taskRunRepo.getLatestByEpisodeId(episodeId);
26
+ const inputRecords = this.inputRepo.listByEpisodeId(episodeId);
27
+ const outcomeRecords = this.outcomeRepo.listByEpisodeId(episodeId);
28
+ const injectionEvents = this.injectionRepo.listByEpisodeId(episodeId);
29
+ const attributionRecords = this.attributionRepo.listByEpisodeId(episodeId);
30
+ const reviewEvents = this.reviewRepo.listByEpisodeId(episodeId);
31
+ if (!taskRun &&
32
+ inputRecords.length === 0 &&
33
+ outcomeRecords.length === 0 &&
34
+ injectionEvents.length === 0 &&
35
+ attributionRecords.length === 0 &&
36
+ reviewEvents.length === 0) {
37
+ return undefined;
38
+ }
39
+ return {
40
+ episode_id: episodeId,
41
+ scope_id: taskRun?.scope_id ?? inputRecords[0]?.scope_id ?? injectionEvents[0]?.scope_id,
42
+ session_id: taskRun?.session_id ?? inputRecords[0]?.session_id ?? injectionEvents[0]?.session_id,
43
+ task_run: taskRun,
44
+ input_records: inputRecords,
45
+ outcome_records: outcomeRecords,
46
+ injection_events: injectionEvents,
47
+ attribution_records: attributionRecords,
48
+ review_events: reviewEvents
49
+ };
50
+ }
51
+ listRecentByScope(scopeId, limit = 10) {
52
+ return this.db
53
+ .prepare(`SELECT
54
+ episode_id,
55
+ scope_id,
56
+ MAX(session_id) AS session_id,
57
+ MAX(task_type) AS task_type,
58
+ MAX(task_summary) AS task_summary,
59
+ MAX(outcome_signal) AS outcome,
60
+ MIN(created_at) AS created_at,
61
+ MAX(created_at) AS updated_at
62
+ FROM experience_input_records
63
+ WHERE scope_id = ?
64
+ AND episode_id IS NOT NULL
65
+ GROUP BY episode_id, scope_id
66
+ ORDER BY updated_at DESC
67
+ LIMIT ?`)
68
+ .all(scopeId, limit)
69
+ .map((row) => {
70
+ const value = row;
71
+ return {
72
+ episode_id: value.episode_id,
73
+ scope_id: value.scope_id,
74
+ session_id: value.session_id ?? undefined,
75
+ task_type: value.task_type ?? undefined,
76
+ task_summary: value.task_summary ?? undefined,
77
+ outcome: value.outcome ?? undefined,
78
+ created_at: value.created_at,
79
+ updated_at: value.updated_at
80
+ };
81
+ });
82
+ }
83
+ }
84
+ //# sourceMappingURL=episode-repo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"episode-repo.js","sourceRoot":"","sources":["../../../../src/store/sqlite/repositories/episode-repo.ts"],"names":[],"mappings":"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"}
@@ -9,6 +9,8 @@ export declare class InjectionRepository {
9
9
  getLatestByScope(scopeId: string): InjectionEvent | undefined;
10
10
  getLatestBySessionId(sessionId: string): InjectionEvent | undefined;
11
11
  count(): number;
12
+ listByEpisodeId(episodeId: string): InjectionEvent[];
13
+ listRecentResolvedByScope(scopeId: string, limit?: number): InjectionEvent[];
12
14
  countByScope(scopeId: string): number;
13
15
  countByDeliveryMode(deliveryMode: InjectionEvent["delivery_mode"]): number;
14
16
  countByScopeAndDeliveryMode(scopeId: string, deliveryMode: InjectionEvent["delivery_mode"]): number;
@@ -6,6 +6,7 @@ export class InjectionRepository {
6
6
  mapEvent(row) {
7
7
  return {
8
8
  injection_id: row.injection_id,
9
+ episode_id: row.episode_id ?? undefined,
9
10
  session_id: row.session_id ?? undefined,
10
11
  scope_id: row.scope_id,
11
12
  task_type: row.task_type,
@@ -26,6 +27,7 @@ export class InjectionRepository {
26
27
  upsert(event) {
27
28
  const payload = {
28
29
  injection_id: event.injection_id,
30
+ episode_id: event.episode_id ?? null,
29
31
  session_id: event.session_id ?? null,
30
32
  scope_id: event.scope_id,
31
33
  task_type: event.task_type,
@@ -44,10 +46,11 @@ export class InjectionRepository {
44
46
  };
45
47
  this.db
46
48
  .prepare(`INSERT INTO injection_events
47
- (injection_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json, injection_count, scorecard_json, was_successful, harm_observed, attribution_reason, created_at, resolved_at)
49
+ (injection_id, episode_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json, injection_count, scorecard_json, was_successful, harm_observed, attribution_reason, created_at, resolved_at)
48
50
  VALUES
49
- (@injection_id, @session_id, @scope_id, @task_type, @task_summary, @mode, @delivery_mode, @delivered, @injected_node_ids_json, @injection_count, @scorecard_json, @was_successful, @harm_observed, @attribution_reason, @created_at, @resolved_at)
51
+ (@injection_id, @episode_id, @session_id, @scope_id, @task_type, @task_summary, @mode, @delivery_mode, @delivered, @injected_node_ids_json, @injection_count, @scorecard_json, @was_successful, @harm_observed, @attribution_reason, @created_at, @resolved_at)
50
52
  ON CONFLICT(injection_id) DO UPDATE SET
53
+ episode_id = excluded.episode_id,
51
54
  session_id = excluded.session_id,
52
55
  task_summary = excluded.task_summary,
53
56
  delivery_mode = excluded.delivery_mode,
@@ -62,7 +65,7 @@ export class InjectionRepository {
62
65
  }
63
66
  getLatest() {
64
67
  const row = this.db
65
- .prepare(`SELECT injection_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json,
68
+ .prepare(`SELECT injection_id, episode_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json,
66
69
  injection_count, scorecard_json, was_successful, harm_observed, attribution_reason, created_at, resolved_at
67
70
  FROM injection_events
68
71
  ORDER BY created_at DESC
@@ -72,7 +75,7 @@ export class InjectionRepository {
72
75
  }
73
76
  getLatestByScope(scopeId) {
74
77
  const row = this.db
75
- .prepare(`SELECT injection_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json,
78
+ .prepare(`SELECT injection_id, episode_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json,
76
79
  injection_count, scorecard_json, was_successful, harm_observed, attribution_reason, created_at, resolved_at
77
80
  FROM injection_events
78
81
  WHERE scope_id = ?
@@ -83,7 +86,7 @@ export class InjectionRepository {
83
86
  }
84
87
  getLatestBySessionId(sessionId) {
85
88
  const row = this.db
86
- .prepare(`SELECT injection_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json,
89
+ .prepare(`SELECT injection_id, episode_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json,
87
90
  injection_count, scorecard_json, was_successful, harm_observed, attribution_reason, created_at, resolved_at
88
91
  FROM injection_events
89
92
  WHERE session_id = ?
@@ -95,6 +98,30 @@ export class InjectionRepository {
95
98
  count() {
96
99
  return this.db.prepare("SELECT COUNT(*) AS count FROM injection_events").get().count;
97
100
  }
101
+ listByEpisodeId(episodeId) {
102
+ return this.db
103
+ .prepare(`SELECT injection_id, episode_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json,
104
+ injection_count, scorecard_json, was_successful, harm_observed, attribution_reason, created_at, resolved_at
105
+ FROM injection_events
106
+ WHERE episode_id = ?
107
+ ORDER BY created_at DESC`)
108
+ .all(episodeId)
109
+ .map((row) => this.mapEvent(row));
110
+ }
111
+ listRecentResolvedByScope(scopeId, limit = 20) {
112
+ return this.db
113
+ .prepare(`SELECT injection_id, episode_id, session_id, scope_id, task_type, task_summary, mode, delivery_mode, delivered, injected_node_ids_json,
114
+ injection_count, scorecard_json, was_successful, harm_observed, attribution_reason, created_at, resolved_at
115
+ FROM injection_events
116
+ WHERE scope_id = ?
117
+ AND resolved_at IS NOT NULL
118
+ AND (delivered = 1 OR mode = 'inject_conservative')
119
+ AND (was_successful IS NOT NULL OR harm_observed IS NOT NULL OR attribution_reason IS NOT NULL)
120
+ ORDER BY created_at DESC, injection_id DESC
121
+ LIMIT ?`)
122
+ .all(scopeId, limit)
123
+ .map((row) => this.mapEvent(row));
124
+ }
98
125
  countByScope(scopeId) {
99
126
  return this.db
100
127
  .prepare("SELECT COUNT(*) AS count FROM injection_events WHERE scope_id = ?")
@@ -1 +1 @@
1
- {"version":3,"file":"injection-repo.js","sourceRoot":"","sources":["../../../../src/store/sqlite/repositories/injection-repo.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"injection-repo.js","sourceRoot":"","sources":["../../../../src/store/sqlite/repositories/injection-repo.ts"],"names":[],"mappings":"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"}
@@ -11,6 +11,7 @@ export declare class InputRecordRepository {
11
11
  getLatestBySessionId(sessionId: string): ExperienceInputRecord | undefined;
12
12
  getLatestByScope(scopeId: string): ExperienceInputRecord | undefined;
13
13
  listByIds(recordIds: string[]): ExperienceInputRecord[];
14
+ listByEpisodeId(episodeId: string): ExperienceInputRecord[];
14
15
  listRecent(options?: {
15
16
  limit?: number;
16
17
  injectedOnly?: boolean;
@@ -6,6 +6,7 @@ export class InputRecordRepository {
6
6
  mapRecord(row) {
7
7
  return {
8
8
  record_id: row.record_id,
9
+ episode_id: row.episode_id ?? undefined,
9
10
  scope_id: row.scope_id,
10
11
  session_id: row.session_id ?? undefined,
11
12
  task_type: row.task_type,
@@ -20,6 +21,7 @@ export class InputRecordRepository {
20
21
  upsert(record) {
21
22
  const payload = {
22
23
  record_id: record.record_id,
24
+ episode_id: record.episode_id ?? null,
23
25
  scope_id: record.scope_id,
24
26
  session_id: record.session_id ?? null,
25
27
  task_type: record.task_type,
@@ -32,10 +34,11 @@ export class InputRecordRepository {
32
34
  };
33
35
  this.db
34
36
  .prepare(`INSERT INTO experience_input_records
35
- (record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary, evidence_json, injected_node_ids_json, created_at)
37
+ (record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary, evidence_json, injected_node_ids_json, created_at)
36
38
  VALUES
37
- (@record_id, @scope_id, @session_id, @task_type, @task_summary, @outcome_signal, @context_summary, @evidence_json, @injected_node_ids_json, @created_at)
39
+ (@record_id, @episode_id, @scope_id, @session_id, @task_type, @task_summary, @outcome_signal, @context_summary, @evidence_json, @injected_node_ids_json, @created_at)
38
40
  ON CONFLICT(record_id) DO UPDATE SET
41
+ episode_id = excluded.episode_id,
39
42
  outcome_signal = excluded.outcome_signal,
40
43
  context_summary = excluded.context_summary,
41
44
  evidence_json = excluded.evidence_json,
@@ -45,7 +48,7 @@ export class InputRecordRepository {
45
48
  }
46
49
  getLatest() {
47
50
  const row = this.db
48
- .prepare(`SELECT record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
51
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
49
52
  evidence_json, injected_node_ids_json, created_at
50
53
  FROM experience_input_records
51
54
  ORDER BY created_at DESC
@@ -55,7 +58,7 @@ export class InputRecordRepository {
55
58
  }
56
59
  getLatestInjected() {
57
60
  const row = this.db
58
- .prepare(`SELECT record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
61
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
59
62
  evidence_json, injected_node_ids_json, created_at
60
63
  FROM experience_input_records
61
64
  WHERE injected_node_ids_json != '[]'
@@ -66,7 +69,7 @@ export class InputRecordRepository {
66
69
  }
67
70
  getLatestInjectedByScope(scopeId) {
68
71
  const row = this.db
69
- .prepare(`SELECT record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
72
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
70
73
  evidence_json, injected_node_ids_json, created_at
71
74
  FROM experience_input_records
72
75
  WHERE scope_id = ? AND injected_node_ids_json != '[]'
@@ -77,7 +80,7 @@ export class InputRecordRepository {
77
80
  }
78
81
  getLatestBySessionId(sessionId) {
79
82
  const row = this.db
80
- .prepare(`SELECT record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
83
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
81
84
  evidence_json, injected_node_ids_json, created_at
82
85
  FROM experience_input_records
83
86
  WHERE session_id = ?
@@ -88,7 +91,7 @@ export class InputRecordRepository {
88
91
  }
89
92
  getLatestByScope(scopeId) {
90
93
  const row = this.db
91
- .prepare(`SELECT record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
94
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
92
95
  evidence_json, injected_node_ids_json, created_at
93
96
  FROM experience_input_records
94
97
  WHERE scope_id = ?
@@ -103,18 +106,28 @@ export class InputRecordRepository {
103
106
  }
104
107
  const placeholders = recordIds.map(() => "?").join(", ");
105
108
  return this.db
106
- .prepare(`SELECT record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
109
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
107
110
  evidence_json, injected_node_ids_json, created_at
108
111
  FROM experience_input_records
109
112
  WHERE record_id IN (${placeholders})`)
110
113
  .all(...recordIds)
111
114
  .map((row) => this.mapRecord(row));
112
115
  }
116
+ listByEpisodeId(episodeId) {
117
+ return this.db
118
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
119
+ evidence_json, injected_node_ids_json, created_at
120
+ FROM experience_input_records
121
+ WHERE episode_id = ?
122
+ ORDER BY created_at DESC`)
123
+ .all(episodeId)
124
+ .map((row) => this.mapRecord(row));
125
+ }
113
126
  listRecent(options = {}) {
114
127
  const limit = options.limit ?? 10;
115
128
  const whereClause = options.injectedOnly ? "WHERE injected_node_ids_json != '[]'" : "";
116
129
  return this.db
117
- .prepare(`SELECT record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
130
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
118
131
  evidence_json, injected_node_ids_json, created_at
119
132
  FROM experience_input_records
120
133
  ${whereClause}
@@ -125,7 +138,7 @@ export class InputRecordRepository {
125
138
  }
126
139
  listRecentByScope(scopeId, limit = 10) {
127
140
  return this.db
128
- .prepare(`SELECT record_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
141
+ .prepare(`SELECT record_id, episode_id, scope_id, session_id, task_type, task_summary, outcome_signal, context_summary,
129
142
  evidence_json, injected_node_ids_json, created_at
130
143
  FROM experience_input_records
131
144
  WHERE scope_id = ?
@@ -1 +1 @@
1
- {"version":3,"file":"input-record-repo.js","sourceRoot":"","sources":["../../../../src/store/sqlite/repositories/input-record-repo.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"input-record-repo.js","sourceRoot":"","sources":["../../../../src/store/sqlite/repositories/input-record-repo.ts"],"names":[],"mappings":"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"}
@@ -12,6 +12,8 @@ export declare class NodeRepository {
12
12
  getById(id: string): ExperienceNode | undefined;
13
13
  listByIds(ids: string[]): ExperienceNode[];
14
14
  listLiveInjectableByExactScope(scopeId: string): ExperienceNode[];
15
+ listConservativeCrossScopeCandidates(scopeId: string): ExperienceNode[];
16
+ listDiagnosticCandidatesByExactScope(scopeId: string): ExperienceNode[];
15
17
  listShadowEligibleByExactScope(scopeId: string): ExperienceNode[];
16
18
  listInjectableByExactScope(scopeId: string): ExperienceNode[];
17
19
  listInjectableByScope(scopeId: string): ExperienceNode[];
@@ -243,6 +243,25 @@ export class NodeRepository {
243
243
  .all(scopeId)
244
244
  .map((row) => this.mapNode(row));
245
245
  }
246
+ listConservativeCrossScopeCandidates(scopeId) {
247
+ return this.db
248
+ .prepare(`SELECT * FROM experience_nodes
249
+ WHERE scope_id != ?
250
+ AND delivery_state IN ('eligible', 'conservative_only')
251
+ ORDER BY updated_at DESC`)
252
+ .all(scopeId)
253
+ .map((row) => this.mapNode(row));
254
+ }
255
+ listDiagnosticCandidatesByExactScope(scopeId) {
256
+ return this.db
257
+ .prepare(`SELECT * FROM experience_nodes
258
+ WHERE scope_id = ?
259
+ AND state = 'candidate'
260
+ AND delivery_state = 'shadow_only'
261
+ ORDER BY updated_at DESC`)
262
+ .all(scopeId)
263
+ .map((row) => this.mapNode(row));
264
+ }
246
265
  listShadowEligibleByExactScope(scopeId) {
247
266
  return this.db
248
267
  .prepare(`SELECT * FROM experience_nodes