claude-memory-layer 1.0.27 → 1.0.29

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 (331) hide show
  1. package/.env.example +7 -0
  2. package/AGENTS.md +11 -0
  3. package/README.md +374 -49
  4. package/benchmarks/replay/anonymized-real-sessions.json +48 -0
  5. package/dist/cli/index.js +10097 -6003
  6. package/dist/cli/index.js.map +4 -4
  7. package/dist/core/index.js +9745 -5587
  8. package/dist/core/index.js.map +4 -4
  9. package/dist/hooks/post-tool-use.js +6545 -5270
  10. package/dist/hooks/post-tool-use.js.map +4 -4
  11. package/dist/hooks/semantic-daemon.js +6646 -5354
  12. package/dist/hooks/semantic-daemon.js.map +4 -4
  13. package/dist/hooks/session-end.js +6618 -5347
  14. package/dist/hooks/session-end.js.map +4 -4
  15. package/dist/hooks/session-start.js +6619 -5354
  16. package/dist/hooks/session-start.js.map +4 -4
  17. package/dist/hooks/stop.js +6614 -5325
  18. package/dist/hooks/stop.js.map +4 -4
  19. package/dist/hooks/user-prompt-submit.js +6702 -5356
  20. package/dist/hooks/user-prompt-submit.js.map +4 -4
  21. package/dist/index.js +13537 -0
  22. package/dist/index.js.map +7 -0
  23. package/dist/mcp/index.js +20770 -0
  24. package/dist/mcp/index.js.map +7 -0
  25. package/dist/server/api/index.js +6632 -5319
  26. package/dist/server/api/index.js.map +4 -4
  27. package/dist/server/index.js +6667 -5340
  28. package/dist/server/index.js.map +4 -4
  29. package/dist/services/memory-service.js +6568 -5350
  30. package/dist/services/memory-service.js.map +4 -4
  31. package/dist/ui/assets/js/bootstrap.js +244 -0
  32. package/dist/ui/assets/js/chat.js +373 -0
  33. package/dist/ui/assets/js/disclosure.js +232 -0
  34. package/dist/ui/assets/js/modals.js +298 -0
  35. package/dist/ui/assets/js/overview.js +655 -0
  36. package/dist/ui/assets/js/state.js +72 -0
  37. package/dist/ui/assets/js/views.js +468 -0
  38. package/dist/ui/index.html +43 -1
  39. package/dist/ui/index.ts +3 -0
  40. package/dist/ui/style.css +222 -0
  41. package/docs/ARCHITECTURE_COMPARISON_AND_RECOMMENDATIONS.md +627 -0
  42. package/docs/HERMES_MEMORY_INGESTION_ANALYSIS.md +440 -0
  43. package/docs/MEMORY_USEFULNESS_AUDIT.md +371 -0
  44. package/docs/MEMORY_USEFULNESS_AUDIT_RAW.json +80 -0
  45. package/docs/MEMSEARCH_PROJECT_STRUCTURE_ANALYSIS.md +333 -0
  46. package/docs/PRODUCT_VALIDATION_MATRIX.md +82 -0
  47. package/docs/PROJECT_STRUCTURE_ANALYSIS.md +421 -0
  48. package/docs/REFACTORING_MILESTONES_AND_ISSUES.md +501 -0
  49. package/docs/REFACTORING_PLAN_THIN_CORE.md +414 -0
  50. package/docs/REFERENCE_PROJECT_ANALYSES.md +25 -0
  51. package/docs/SUPERLOCALMEMORY_PROJECT_STRUCTURE_ANALYSIS.md +452 -0
  52. package/docs/TARGET_ARCHITECTURE_AND_FOLDER_STRUCTURE.md +446 -0
  53. package/docs/architecture/comparison-index.md +47 -0
  54. package/docs/reports/codex-real-data-validation-20260505T040447Z.md +46 -0
  55. package/package.json +12 -5
  56. package/scripts/build.ts +25 -8
  57. package/scripts/generate-session-qrels.ts +126 -0
  58. package/scripts/postinstall-embedding-backend.cjs +142 -0
  59. package/scripts/replay-retrieval-benchmark.ts +69 -0
  60. package/specs/thin-core-refactor/context.md +275 -0
  61. package/specs/thin-core-refactor/plan.md +536 -0
  62. package/specs/thin-core-refactor/spec.md +465 -0
  63. package/src/adapters/claude/capture/index.ts +3 -0
  64. package/src/adapters/claude/context/index.ts +3 -0
  65. package/src/adapters/claude/hooks/index.ts +21 -0
  66. package/src/adapters/claude/hooks/post-tool-use.ts +239 -0
  67. package/src/adapters/claude/hooks/prompt-injection-policy.ts +104 -0
  68. package/src/adapters/claude/hooks/semantic-daemon-client.ts +209 -0
  69. package/src/adapters/claude/hooks/semantic-daemon.ts +283 -0
  70. package/src/adapters/claude/hooks/session-end.ts +59 -0
  71. package/src/adapters/claude/hooks/session-start.ts +73 -0
  72. package/src/adapters/claude/hooks/stop.ts +128 -0
  73. package/src/adapters/claude/hooks/user-prompt-submit.ts +361 -0
  74. package/src/adapters/claude/index.ts +4 -0
  75. package/src/adapters/claude/transcript/index.ts +4 -0
  76. package/src/adapters/claude/transcript/transcript-reader.ts +57 -0
  77. package/src/adapters/claude/transcript/turn-reconstructor.ts +65 -0
  78. package/src/apps/cli/claude-settings-hooks.ts +138 -0
  79. package/src/apps/cli/codex-import-runner.ts +125 -0
  80. package/src/apps/cli/codex-validation-output.ts +95 -0
  81. package/src/apps/cli/hermes-import-runner.ts +130 -0
  82. package/src/apps/cli/hermes-validation-output.ts +91 -0
  83. package/src/apps/cli/index.ts +1731 -0
  84. package/src/apps/cli/mcp-install.ts +106 -0
  85. package/src/apps/cli/retrieval-disclosure-output.ts +196 -0
  86. package/src/apps/dashboard/assets/js/bootstrap.js +244 -0
  87. package/src/apps/dashboard/assets/js/chat.js +373 -0
  88. package/src/apps/dashboard/assets/js/disclosure.js +232 -0
  89. package/src/apps/dashboard/assets/js/modals.js +298 -0
  90. package/src/apps/dashboard/assets/js/overview.js +655 -0
  91. package/src/apps/dashboard/assets/js/state.js +72 -0
  92. package/src/apps/dashboard/assets/js/views.js +468 -0
  93. package/src/{ui → apps/dashboard}/index.html +43 -1
  94. package/src/apps/dashboard/index.ts +3 -0
  95. package/src/{ui → apps/dashboard}/style.css +222 -0
  96. package/src/apps/index.ts +5 -0
  97. package/src/apps/server/api/chat.ts +244 -0
  98. package/src/apps/server/api/citations.ts +105 -0
  99. package/src/apps/server/api/events.ts +137 -0
  100. package/src/apps/server/api/health.ts +53 -0
  101. package/src/apps/server/api/index.ts +26 -0
  102. package/src/apps/server/api/projects.ts +74 -0
  103. package/src/apps/server/api/search.ts +184 -0
  104. package/src/apps/server/api/sessions.ts +115 -0
  105. package/src/apps/server/api/stats.ts +723 -0
  106. package/src/apps/server/api/turns.ts +143 -0
  107. package/src/apps/server/api/utils.ts +65 -0
  108. package/src/apps/server/index.ts +111 -0
  109. package/src/cli/index.ts +2 -1311
  110. package/src/cli/retrieval-disclosure-output.ts +2 -0
  111. package/src/compat/index.ts +5 -0
  112. package/src/core/derive/fact-deriver.ts +170 -0
  113. package/src/core/derive/index.ts +2 -0
  114. package/src/core/derive/summary-deriver.ts +76 -0
  115. package/src/core/embedder.ts +4 -152
  116. package/src/core/engine/embedding-maintenance-service.ts +187 -0
  117. package/src/core/engine/endless-memory-services.ts +4 -0
  118. package/src/core/engine/index.ts +19 -0
  119. package/src/core/engine/memory-engine-services.ts +170 -0
  120. package/src/core/engine/memory-ingest-service.ts +317 -0
  121. package/src/core/engine/memory-query-service.ts +173 -0
  122. package/src/core/engine/memory-runtime-service.ts +162 -0
  123. package/src/core/engine/memory-service-composition.ts +231 -0
  124. package/src/core/engine/retrieval-analytics-service.ts +181 -0
  125. package/src/core/engine/retrieval-disclosure-service.ts +420 -0
  126. package/src/core/engine/retrieval-orchestrator.ts +377 -0
  127. package/src/core/engine/retrieval-services.ts +176 -0
  128. package/src/core/engine/shared-memory-services.ts +4 -0
  129. package/src/core/entity-repo.ts +1 -3
  130. package/src/core/event-store.ts +3 -3
  131. package/src/core/evidence-aligner.ts +2 -2
  132. package/src/core/external-market-context.ts +582 -0
  133. package/src/core/graduation.ts +2 -3
  134. package/src/core/index.ts +21 -0
  135. package/src/core/matcher.ts +2 -4
  136. package/src/core/model/memory-fact.ts +30 -0
  137. package/src/core/model/memory-rule.ts +14 -0
  138. package/src/core/model/memory-summary.ts +21 -0
  139. package/src/core/model/raw-event.ts +28 -0
  140. package/src/core/model/retrieval-result.ts +35 -0
  141. package/src/core/privacy/filter.ts +21 -10
  142. package/src/core/product-validation-matrix.ts +314 -0
  143. package/src/core/progressive-retriever.ts +1 -2
  144. package/src/core/registry/project-path.ts +54 -0
  145. package/src/core/registry/session-registry.ts +69 -0
  146. package/src/core/replay-evaluator.ts +625 -0
  147. package/src/core/retrieval-benchmark.ts +117 -0
  148. package/src/core/retrieval-quality.ts +109 -0
  149. package/src/core/retriever.ts +53 -15
  150. package/src/core/session-qrels.ts +360 -0
  151. package/src/core/shared-event-store.ts +1 -1
  152. package/src/core/sqlite-event-store.ts +35 -11
  153. package/src/core/task/blocker-resolver.ts +2 -2
  154. package/src/core/task/task-resolver.ts +0 -1
  155. package/src/core/vector-outbox.ts +1 -10
  156. package/src/core/vector-worker.ts +1 -1
  157. package/src/extensions/endless-memory/endless-memory-services.ts +350 -0
  158. package/src/extensions/endless-memory/index.ts +1 -0
  159. package/src/extensions/index.ts +5 -0
  160. package/src/extensions/mcp/handlers.ts +960 -0
  161. package/src/extensions/mcp/index.ts +48 -0
  162. package/src/extensions/mcp/tools.ts +252 -0
  163. package/src/extensions/shared-memory/index.ts +1 -0
  164. package/src/extensions/shared-memory/shared-memory-services.ts +211 -0
  165. package/src/extensions/vector/embedder.ts +197 -0
  166. package/src/extensions/vector/index.ts +1 -0
  167. package/src/hooks/post-tool-use.ts +3 -236
  168. package/src/hooks/semantic-daemon-client.ts +1 -208
  169. package/src/hooks/semantic-daemon.ts +6 -271
  170. package/src/hooks/session-end.ts +4 -79
  171. package/src/hooks/session-start.ts +4 -73
  172. package/src/hooks/stop.ts +3 -173
  173. package/src/hooks/user-prompt-submit.ts +3 -338
  174. package/src/index.ts +13 -0
  175. package/src/mcp/handlers.ts +2 -212
  176. package/src/mcp/index.ts +3 -46
  177. package/src/mcp/tools.ts +2 -78
  178. package/src/server/api/chat.ts +2 -244
  179. package/src/server/api/citations.ts +2 -105
  180. package/src/server/api/events.ts +2 -137
  181. package/src/server/api/health.ts +2 -53
  182. package/src/server/api/index.ts +2 -26
  183. package/src/server/api/projects.ts +2 -74
  184. package/src/server/api/search.ts +2 -102
  185. package/src/server/api/sessions.ts +2 -115
  186. package/src/server/api/stats.ts +2 -724
  187. package/src/server/api/turns.ts +2 -143
  188. package/src/server/api/utils.ts +2 -46
  189. package/src/server/index.ts +2 -100
  190. package/src/services/bootstrap-organizer.ts +46 -26
  191. package/src/services/codex-session-history-importer.ts +521 -29
  192. package/src/services/hermes-session-history-importer.ts +733 -0
  193. package/src/services/memory-service-config.ts +36 -0
  194. package/src/services/memory-service-registry.ts +150 -0
  195. package/src/services/memory-service.ts +211 -1325
  196. package/src/services/session-history-importer.ts +58 -14
  197. package/tests/README.md +23 -0
  198. package/tests/adapters/claude/claude-semantic-daemon-adapter.test.ts +54 -0
  199. package/tests/adapters/claude/claude-transcript-reconstructor.test.ts +98 -0
  200. package/tests/adapters/claude-hook-prompt-injection-policy.test.ts +99 -0
  201. package/tests/apps/app-layer-boundary.test.ts +48 -0
  202. package/tests/apps/claude-settings-hooks.test.ts +107 -0
  203. package/tests/apps/cli-disclosure-output.test.ts +212 -0
  204. package/tests/apps/codex-import-runner.test.ts +99 -0
  205. package/tests/apps/codex-validation-output.test.ts +100 -0
  206. package/tests/apps/hermes-import-runner.test.ts +99 -0
  207. package/tests/apps/mcp-install-command.test.ts +59 -0
  208. package/tests/apps/package-build-entrypoints.test.ts +30 -0
  209. package/tests/apps/postinstall-embedding-backend.test.ts +167 -0
  210. package/tests/apps/search-api-disclosure.test.ts +162 -0
  211. package/tests/apps/stats-api-lightweight.test.ts +67 -0
  212. package/tests/apps/ui-disclosure-output.test.ts +140 -0
  213. package/tests/{bootstrap-organizer.test.ts → core/bootstrap-organizer.test.ts} +1 -1
  214. package/tests/{canonical-key.test.ts → core/canonical-key.test.ts} +1 -1
  215. package/tests/core/codex-session-history-importer-validation.test.ts +185 -0
  216. package/tests/{consolidation-worker.test.ts → core/consolidation-worker.test.ts} +2 -2
  217. package/tests/core/embedding-maintenance-service.test.ts +282 -0
  218. package/tests/{evidence-aligner.test.ts → core/evidence-aligner.test.ts} +1 -1
  219. package/tests/core/external-market-context.test.ts +209 -0
  220. package/tests/core/fact-deriver.test.ts +79 -0
  221. package/tests/core/hermes-session-history-importer-validation.test.ts +609 -0
  222. package/tests/{ingest-interceptor.test.ts → core/ingest-interceptor.test.ts} +1 -1
  223. package/tests/{markdown-mirror.test.ts → core/markdown-mirror.test.ts} +2 -2
  224. package/tests/{matcher.test.ts → core/matcher.test.ts} +1 -1
  225. package/tests/{md-mirror.test.ts → core/md-mirror.test.ts} +2 -2
  226. package/tests/core/memory-engine-services.test.ts +240 -0
  227. package/tests/core/memory-ingest-service.test.ts +296 -0
  228. package/tests/core/memory-query-service.test.ts +129 -0
  229. package/tests/core/memory-runtime-service.test.ts +201 -0
  230. package/tests/core/memory-service-composition.test.ts +192 -0
  231. package/tests/core/memory-service-config.test.ts +41 -0
  232. package/tests/core/memory-service-facade.test.ts +30 -0
  233. package/tests/core/memory-service-registry.test.ts +206 -0
  234. package/tests/core/product-validation-matrix.test.ts +61 -0
  235. package/tests/core/project-registry.test.ts +78 -0
  236. package/tests/core/replay-evaluator.test.ts +181 -0
  237. package/tests/core/retrieval-analytics-service.test.ts +210 -0
  238. package/tests/core/retrieval-benchmark.test.ts +93 -0
  239. package/tests/core/retrieval-disclosure-service.test.ts +264 -0
  240. package/tests/core/retrieval-orchestrator.test.ts +403 -0
  241. package/tests/core/retrieval-quality.test.ts +31 -0
  242. package/tests/core/retrieval-services.test.ts +185 -0
  243. package/tests/{retriever-fallback-chain.test.ts → core/retriever-fallback-chain.test.ts} +3 -3
  244. package/tests/{retriever-strategy-scope.test.ts → core/retriever-strategy-scope.test.ts} +70 -3
  245. package/tests/{retriever.memu-adoption.test.ts → core/retriever.memu-adoption.test.ts} +3 -3
  246. package/tests/core/session-history-importer-filter.test.ts +78 -0
  247. package/tests/core/session-qrels.test.ts +250 -0
  248. package/tests/{sqlite-event-store-replication.test.ts → core/sqlite-event-store-replication.test.ts} +36 -1
  249. package/tests/core/summary-deriver.test.ts +66 -0
  250. package/tests/extensions/embedder-warning-suppression.test.ts +53 -0
  251. package/tests/extensions/endless-memory-extension-boundary.test.ts +17 -0
  252. package/tests/extensions/endless-memory-services.test.ts +325 -0
  253. package/tests/extensions/mcp-context-tools.test.ts +905 -0
  254. package/tests/extensions/mcp-extension-boundary.test.ts +21 -0
  255. package/tests/extensions/mcp-package-build.test.ts +22 -0
  256. package/tests/extensions/mcp-project-aware-tools.test.ts +102 -0
  257. package/tests/extensions/shared-memory-extension-boundary.test.ts +24 -0
  258. package/tests/extensions/shared-memory-services.test.ts +309 -0
  259. package/tests/extensions/vector-extension-boundary.test.ts +21 -0
  260. package/.claude/settings.local.json +0 -25
  261. package/.npm-cache/_cacache/content-v2/sha512/04/76/c098f88dfe584a2b80870bff7421b05d17d3d9ee1027f77772332a22d3f93a9a57101a2855107f6ad82077a818bba912b2bc317f2361b5ddb09ad284d9ce +0 -0
  262. package/.npm-cache/_cacache/content-v2/sha512/60/25/d2ecd39cfc7cab58351162814be77f935c6d6491c10c3745d456da7ddb2117ffd90c10e53fe3c0f1ed16b403307841543634504398b16ee4e6b6dd8e0c45 +0 -0
  263. package/.npm-cache/_cacache/index-v5/2b/9a/7f8f40206ed8a2e0a84efaa953ccaed1f5d001e14b931083f2e7a0738007 +0 -2
  264. package/.npm-cache/_cacache/index-v5/2e/d9/fcfa5c6a6abdc2a3644ab84a95936047298c465a2f47ee03db8f7fe1e946 +0 -3
  265. package/.npm-cache/_cacache/index-v5/a9/42/e519633356d12d3d2f19da66a8301016d496c8f5c3e0554124aaa62dc043 +0 -2
  266. package/.npm-cache/_logs/2026-02-26T12_04_52_729Z-debug-0.log +0 -256
  267. package/.npm-cache/_logs/2026-02-26T12_05_36_835Z-debug-0.log +0 -18
  268. package/.npm-cache/_logs/2026-02-26T12_05_45_982Z-debug-0.log +0 -32
  269. package/.npm-cache/_logs/2026-02-26T12_05_48_515Z-debug-0.log +0 -260
  270. package/.npm-cache/_logs/2026-02-26T12_05_53_567Z-debug-0.log +0 -69
  271. package/.npm-cache/_update-notifier-last-checked +0 -0
  272. package/bootstrap-kb/decisions/decisions.md +0 -244
  273. package/bootstrap-kb/glossary/glossary.md +0 -46
  274. package/bootstrap-kb/modules/.claude-plugin.md +0 -22
  275. package/bootstrap-kb/modules/agents.md.md +0 -15
  276. package/bootstrap-kb/modules/claude.md.md +0 -15
  277. package/bootstrap-kb/modules/context.md.md +0 -15
  278. package/bootstrap-kb/modules/docs.md +0 -18
  279. package/bootstrap-kb/modules/handoff.md.md +0 -15
  280. package/bootstrap-kb/modules/package-lock.json.md +0 -15
  281. package/bootstrap-kb/modules/package.json.md +0 -15
  282. package/bootstrap-kb/modules/plan.md.md +0 -15
  283. package/bootstrap-kb/modules/readme.md.md +0 -15
  284. package/bootstrap-kb/modules/scripts.md +0 -26
  285. package/bootstrap-kb/modules/spec.md.md +0 -15
  286. package/bootstrap-kb/modules/specs.md +0 -20
  287. package/bootstrap-kb/modules/src.md +0 -51
  288. package/bootstrap-kb/modules/tests.md +0 -42
  289. package/bootstrap-kb/modules/tsconfig.json.md +0 -15
  290. package/bootstrap-kb/modules/vitest.config.ts.md +0 -15
  291. package/bootstrap-kb/overview/overview.md +0 -40
  292. package/bootstrap-kb/sources/manifest.json +0 -950
  293. package/bootstrap-kb/sources/manifest.md +0 -227
  294. package/bootstrap-kb/timeline/timeline.md +0 -57
  295. package/claude-memory-layer-1.0.14.tgz +0 -0
  296. package/d.sh +0 -3
  297. package/deploy.sh +0 -3
  298. package/dist/ui/app.js +0 -2101
  299. package/memory/.claude-plugin/commands/2026-02-25.md +0 -263
  300. package/memory/_index.md +0 -419
  301. package/memory/agent_response/uncategorized/2026-02-26.md +0 -176
  302. package/memory/agent_response/uncategorized/2026-03-03.md +0 -14
  303. package/memory/agent_response/uncategorized/2026-03-04.md +0 -1421
  304. package/memory/agent_response/uncategorized/2026-03-05.md +0 -157
  305. package/memory/default/uncategorized/2026-02-25.md +0 -4839
  306. package/memory/session_summary/uncategorized/2026-02-26.md +0 -13
  307. package/memory/session_summary/uncategorized/2026-03-03.md +0 -5
  308. package/memory/session_summary/uncategorized/2026-03-04.md +0 -50
  309. package/memory/specs/20260207-dashboard-upgrade/2026-02-25.md +0 -142
  310. package/memory/specs/citations-system/2026-02-25.md +0 -1121
  311. package/memory/specs/endless-mode/2026-02-25.md +0 -1392
  312. package/memory/specs/entity-edge-model/2026-02-25.md +0 -1263
  313. package/memory/specs/evidence-aligner-v2/2026-02-25.md +0 -1028
  314. package/memory/specs/mcp-desktop-integration/2026-02-25.md +0 -1334
  315. package/memory/specs/post-tool-use-hook/2026-02-25.md +0 -1164
  316. package/memory/specs/private-tags/2026-02-25.md +0 -1057
  317. package/memory/specs/progressive-disclosure/2026-02-25.md +0 -1436
  318. package/memory/specs/task-entity-system/2026-02-25.md +0 -924
  319. package/memory/specs/vector-outbox-v2/2026-02-25.md +0 -1510
  320. package/memory/specs/web-viewer-ui/2026-02-25.md +0 -1709
  321. package/memory/tool_observation/uncategorized/2026-02-26.md +0 -209
  322. package/memory/tool_observation/uncategorized/2026-03-03.md +0 -21
  323. package/memory/tool_observation/uncategorized/2026-03-04.md +0 -1033
  324. package/memory/tool_observation/uncategorized/2026-03-05.md +0 -33
  325. package/memory/user_prompt/uncategorized/2026-02-26.md +0 -25
  326. package/memory/user_prompt/uncategorized/2026-03-04.md +0 -634
  327. package/memory/user_prompt/uncategorized/2026-03-05.md +0 -6
  328. package/specs/optional-duckdb/context.md +0 -77
  329. package/specs/optional-duckdb/plan.md +0 -142
  330. package/specs/optional-duckdb/spec.md +0 -35
  331. package/src/ui/app.js +0 -2101
@@ -0,0 +1,420 @@
1
+ /**
2
+ * Retrieval Disclosure Service
3
+ *
4
+ * Provides a product-facing progressive disclosure surface on top of retrieval:
5
+ * search -> expand -> source. Search returns compact, spec-aligned result
6
+ * envelopes; expand adds surrounding context; source resolves to canonical raw
7
+ * events or other source references.
8
+ */
9
+
10
+ import type { RetrievalReason, RetrievalResultEnvelope, RetrievalResultType } from '../model/retrieval-result.js';
11
+ import type { UnifiedRetrievalResult, MemoryWithContext } from '../retriever.js';
12
+ import type { MemoryEvent, SharedTroubleshootingEntry } from '../types.js';
13
+ import type { RetrieveMemoriesOptions } from './retrieval-orchestrator.js';
14
+
15
+ export type RetrievalDisclosureResultType = RetrievalResultType;
16
+ export type RetrievalDisclosureReason = RetrievalReason;
17
+ export type RetrievalDisclosureEnvelope = RetrievalResultEnvelope;
18
+ export type RetrievalDisclosureSourceType =
19
+ | 'raw_event'
20
+ | 'transcript'
21
+ | 'tool_output'
22
+ | 'imported_history'
23
+ | 'shared_troubleshooting';
24
+
25
+ export interface RetrievalDisclosureSearchResponse {
26
+ results: RetrievalResultEnvelope[];
27
+ meta: {
28
+ total: number;
29
+ usedVector: boolean;
30
+ usedKeyword: boolean;
31
+ fallbackApplied: boolean;
32
+ confidence?: UnifiedRetrievalResult['matchResult']['confidence'];
33
+ totalTokens?: number;
34
+ fallbackTrace?: string[];
35
+ };
36
+ }
37
+
38
+ export interface RetrievalDisclosureSourceReference {
39
+ sourceRef: string;
40
+ sourceType: RetrievalDisclosureSourceType;
41
+ eventIds: string[];
42
+ metadata?: Record<string, unknown>;
43
+ }
44
+
45
+ export interface RetrievalDisclosureExpansion {
46
+ target: RetrievalResultEnvelope;
47
+ surroundingFacts?: RetrievalResultEnvelope[];
48
+ summaries?: RetrievalResultEnvelope[];
49
+ relatedSources?: RetrievalDisclosureSourceReference[];
50
+ expandedContext?: string;
51
+ }
52
+
53
+ export interface RetrievalDisclosureSource extends RetrievalDisclosureSourceReference {
54
+ rawEvents: MemoryEvent[];
55
+ primaryEvent?: MemoryEvent;
56
+ }
57
+
58
+ export interface RetrievalDisclosureSearchOptions extends RetrieveMemoriesOptions {}
59
+
60
+ export interface RetrievalDisclosureExpandOptions {
61
+ windowSize?: number;
62
+ }
63
+
64
+ export interface RetrievalDisclosureOrchestrator {
65
+ retrieveMemories(
66
+ query: string,
67
+ options?: RetrievalDisclosureSearchOptions
68
+ ): Promise<UnifiedRetrievalResult>;
69
+ }
70
+
71
+ export interface RetrievalDisclosureEventStore {
72
+ getEvent(id: string): Promise<MemoryEvent | null>;
73
+ getSessionEvents(sessionId: string): Promise<MemoryEvent[]>;
74
+ }
75
+
76
+ export interface RetrievalDisclosureSharedStore {
77
+ get(entryId: string): Promise<SharedTroubleshootingEntry | null>;
78
+ }
79
+
80
+ export interface RetrievalDisclosureServiceDeps {
81
+ initialize: () => Promise<void>;
82
+ retrievalOrchestrator: RetrievalDisclosureOrchestrator;
83
+ eventStore: RetrievalDisclosureEventStore;
84
+ sharedStore?: RetrievalDisclosureSharedStore;
85
+ }
86
+
87
+ export class RetrievalDisclosureService {
88
+ constructor(private readonly deps: RetrievalDisclosureServiceDeps) {}
89
+
90
+ async search(
91
+ query: string,
92
+ options?: RetrievalDisclosureSearchOptions
93
+ ): Promise<RetrievalDisclosureSearchResponse> {
94
+ const result = await this.deps.retrievalOrchestrator.retrieveMemories(query, options);
95
+ const debugByEventId = this.buildDebugIndex(result);
96
+ const projectResults = result.memories.map((memory) => this.memoryToEnvelope(
97
+ memory,
98
+ result,
99
+ debugByEventId.get(memory.event.id)
100
+ ));
101
+ const sharedResults = (result.sharedMemories || []).map((entry) => this.sharedToEnvelope(entry));
102
+ const results = [...projectResults, ...sharedResults];
103
+
104
+ return {
105
+ results,
106
+ meta: {
107
+ total: results.length,
108
+ usedVector: this.usedVector(result),
109
+ usedKeyword: this.usedKeyword(result),
110
+ fallbackApplied: this.fallbackApplied(result),
111
+ confidence: result.matchResult.confidence,
112
+ totalTokens: result.totalTokens,
113
+ fallbackTrace: result.fallbackTrace || []
114
+ }
115
+ };
116
+ }
117
+
118
+ async expand(
119
+ resultId: string,
120
+ options?: RetrievalDisclosureExpandOptions
121
+ ): Promise<RetrievalDisclosureExpansion | null> {
122
+ const parsedId = parseDisclosureResultRef(resultId);
123
+ if (parsedId.kind === 'shared') {
124
+ return this.expandShared(parsedId.entryId);
125
+ }
126
+
127
+ const targetEvent = await this.deps.eventStore.getEvent(parsedId.eventId);
128
+ if (!targetEvent) return null;
129
+
130
+ const windowSize = Math.max(0, options?.windowSize ?? 3);
131
+ const sessionEvents = (await this.deps.eventStore.getSessionEvents(targetEvent.sessionId))
132
+ .slice()
133
+ .sort((a, b) => a.timestamp.getTime() - b.timestamp.getTime());
134
+ const targetIndex = sessionEvents.findIndex((event) => event.id === targetEvent.id);
135
+ const surroundingEvents = targetIndex === -1
136
+ ? []
137
+ : sessionEvents.slice(
138
+ Math.max(0, targetIndex - windowSize),
139
+ Math.min(sessionEvents.length, targetIndex + windowSize + 1)
140
+ );
141
+ const nearbyEvents = surroundingEvents.length > 0 ? surroundingEvents : [targetEvent];
142
+ const nonTargetEvents = nearbyEvents.filter((event) => event.id !== targetEvent.id);
143
+
144
+ return {
145
+ target: this.eventToEnvelope(targetEvent, 1, ['continuity_link']),
146
+ surroundingFacts: nonTargetEvents.map((event) => this.eventToEnvelope(event, 1, this.reasonsForContextEvent(event))),
147
+ summaries: nonTargetEvents
148
+ .filter((event) => event.eventType === 'session_summary')
149
+ .map((event) => this.eventToEnvelope(event, 1, ['summary_fallback'])),
150
+ relatedSources: nearbyEvents.map((event) => this.sourceReferenceForEvent(event)),
151
+ expandedContext: this.formatTimelineContext(nearbyEvents)
152
+ };
153
+ }
154
+
155
+ async source(resultId: string): Promise<RetrievalDisclosureSource | null> {
156
+ const parsedId = parseDisclosureResultRef(resultId);
157
+ if (parsedId.kind === 'shared') {
158
+ return this.sourceShared(parsedId.entryId);
159
+ }
160
+
161
+ const rawEvent = await this.deps.eventStore.getEvent(parsedId.eventId);
162
+ if (!rawEvent) return null;
163
+
164
+ return {
165
+ ...this.sourceReferenceForEvent(rawEvent),
166
+ rawEvents: [rawEvent],
167
+ primaryEvent: rawEvent
168
+ };
169
+ }
170
+
171
+ private async expandShared(entryId: string): Promise<RetrievalDisclosureExpansion | null> {
172
+ const entry = await this.deps.sharedStore?.get(entryId);
173
+ if (!entry) return null;
174
+
175
+ return {
176
+ target: this.sharedToEnvelope(entry),
177
+ surroundingFacts: [],
178
+ summaries: [],
179
+ relatedSources: [this.sourceReferenceForShared(entry)],
180
+ expandedContext: this.formatSharedContext(entry)
181
+ };
182
+ }
183
+
184
+ private async sourceShared(entryId: string): Promise<RetrievalDisclosureSource | null> {
185
+ const entry = await this.deps.sharedStore?.get(entryId);
186
+ if (!entry) return null;
187
+
188
+ const sourceReference = this.sourceReferenceForShared(entry);
189
+ return {
190
+ ...sourceReference,
191
+ rawEvents: [],
192
+ metadata: {
193
+ ...sourceReference.metadata,
194
+ symptoms: entry.symptoms,
195
+ rootCause: entry.rootCause,
196
+ solution: entry.solution,
197
+ technologies: entry.technologies,
198
+ confidence: entry.confidence,
199
+ usageCount: entry.usageCount
200
+ }
201
+ };
202
+ }
203
+
204
+ private memoryToEnvelope(
205
+ memory: MemoryWithContext,
206
+ result: UnifiedRetrievalResult,
207
+ debug?: RetrievalDebugDetail
208
+ ): RetrievalResultEnvelope {
209
+ return this.eventToEnvelope(
210
+ memory.event,
211
+ memory.score,
212
+ this.inferReasons(memory, result, debug),
213
+ {
214
+ semanticScore: debug?.semanticScore,
215
+ lexicalScore: debug?.lexicalScore,
216
+ recencyScore: debug?.recencyScore
217
+ }
218
+ );
219
+ }
220
+
221
+ private eventToEnvelope(
222
+ event: MemoryEvent,
223
+ score: number,
224
+ reasons: RetrievalDisclosureReason[],
225
+ extraMetadata?: Record<string, unknown>
226
+ ): RetrievalResultEnvelope {
227
+ return {
228
+ id: toDisclosureResultId(event.id),
229
+ resultType: this.resultTypeForEvent(event),
230
+ title: this.titleForEvent(event),
231
+ snippet: this.preview(event.content, 240),
232
+ score,
233
+ reasons,
234
+ sourceRef: toDisclosureResultId(event.id),
235
+ sessionId: event.sessionId,
236
+ metadata: {
237
+ eventId: event.id,
238
+ eventType: event.eventType,
239
+ timestamp: event.timestamp.toISOString(),
240
+ canonicalKey: event.canonicalKey,
241
+ ...event.metadata,
242
+ ...extraMetadata
243
+ }
244
+ };
245
+ }
246
+
247
+ private sharedToEnvelope(entry: SharedTroubleshootingEntry): RetrievalResultEnvelope {
248
+ return {
249
+ id: `shared:${entry.entryId}`,
250
+ resultType: 'rule',
251
+ title: entry.title,
252
+ snippet: this.preview(entry.solution || entry.rootCause || entry.symptoms.join(' '), 240),
253
+ score: entry.confidence,
254
+ reasons: ['semantic_match'],
255
+ sourceRef: `shared:${entry.entryId}`,
256
+ metadata: {
257
+ sourceProjectHash: entry.sourceProjectHash,
258
+ sourceEntryId: entry.sourceEntryId,
259
+ topics: entry.topics,
260
+ technologies: entry.technologies,
261
+ confidence: entry.confidence,
262
+ usageCount: entry.usageCount
263
+ }
264
+ };
265
+ }
266
+
267
+ private buildDebugIndex(result: UnifiedRetrievalResult): Map<string, RetrievalDebugDetail> {
268
+ const byEventId = new Map<string, RetrievalDebugDetail>();
269
+
270
+ for (const detail of result.candidateDebug || []) {
271
+ byEventId.set(detail.eventId, detail);
272
+ }
273
+ for (const detail of result.selectedDebug || []) {
274
+ byEventId.set(detail.eventId, detail);
275
+ }
276
+
277
+ return byEventId;
278
+ }
279
+
280
+ private inferReasons(
281
+ memory: MemoryWithContext,
282
+ result: UnifiedRetrievalResult,
283
+ debug?: RetrievalDebugDetail
284
+ ): RetrievalDisclosureReason[] {
285
+ const reasons = new Set<RetrievalDisclosureReason>();
286
+
287
+ const usedVector = this.usedVector(result);
288
+ const usedKeyword = this.usedKeyword(result);
289
+
290
+ if (usedVector && (debug?.semanticScore ?? 0) > 0) reasons.add('semantic_match');
291
+ if ((debug?.lexicalScore ?? 0) > 0 || usedKeyword) reasons.add('keyword_match');
292
+ if ((debug?.recencyScore ?? 0) > 0) reasons.add('recent_relevance');
293
+ if ((result.fallbackTrace || []).some((step) => step === 'fallback:summary')) reasons.add('summary_fallback');
294
+ if (memory.sessionContext) reasons.add('continuity_link');
295
+ if (memory.event.eventType === 'tool_observation') reasons.add('tool_followup');
296
+ if (reasons.size === 0) reasons.add(usedVector ? 'semantic_match' : 'keyword_match');
297
+
298
+ return Array.from(reasons);
299
+ }
300
+
301
+ private reasonsForContextEvent(event: MemoryEvent): RetrievalDisclosureReason[] {
302
+ if (event.eventType === 'tool_observation') return ['tool_followup'];
303
+ if (event.eventType === 'session_summary') return ['summary_fallback'];
304
+ return ['continuity_link'];
305
+ }
306
+
307
+ private resultTypeForEvent(event: MemoryEvent): RetrievalDisclosureResultType {
308
+ if (event.eventType === 'session_summary') return 'summary';
309
+ if (event.eventType === 'tool_observation') return 'tool_evidence';
310
+ return 'source';
311
+ }
312
+
313
+ private sourceReferenceForEvent(event: MemoryEvent): RetrievalDisclosureSourceReference {
314
+ return {
315
+ sourceRef: toDisclosureResultId(event.id),
316
+ sourceType: this.sourceTypeForEvent(event),
317
+ eventIds: [event.id]
318
+ };
319
+ }
320
+
321
+ private sourceReferenceForShared(entry: SharedTroubleshootingEntry): RetrievalDisclosureSourceReference {
322
+ return {
323
+ sourceRef: `shared:${entry.entryId}`,
324
+ sourceType: 'shared_troubleshooting',
325
+ eventIds: [],
326
+ metadata: {
327
+ sourceProjectHash: entry.sourceProjectHash,
328
+ sourceEntryId: entry.sourceEntryId,
329
+ topics: entry.topics
330
+ }
331
+ };
332
+ }
333
+
334
+ private sourceTypeForEvent(event: MemoryEvent): RetrievalDisclosureSourceType {
335
+ const metadata = event.metadata || {};
336
+ if (event.eventType === 'tool_observation') return 'tool_output';
337
+ if (typeof metadata.transcriptPath === 'string') return 'transcript';
338
+ if (typeof metadata.importedFrom === 'string') return 'imported_history';
339
+ return 'raw_event';
340
+ }
341
+
342
+ private titleForEvent(event: MemoryEvent): string {
343
+ if (event.eventType === 'session_summary') return 'Session summary';
344
+ if (event.eventType === 'tool_observation') return 'Tool evidence';
345
+ if (event.eventType === 'agent_response') return 'Agent response';
346
+ return 'User prompt';
347
+ }
348
+
349
+ private usedVector(result: UnifiedRetrievalResult): boolean {
350
+ return (result.fallbackTrace || []).some((step) => step.includes(':deep'));
351
+ }
352
+
353
+ private usedKeyword(result: UnifiedRetrievalResult): boolean {
354
+ return (result.fallbackTrace || []).some((step) => step.includes(':fast')) ||
355
+ [...(result.selectedDebug || []), ...(result.candidateDebug || [])]
356
+ .some((detail) => (detail.lexicalScore ?? 0) > 0);
357
+ }
358
+
359
+ private fallbackApplied(result: UnifiedRetrievalResult): boolean {
360
+ return (result.fallbackTrace || []).some((step) => step.includes('fallback'));
361
+ }
362
+
363
+ private formatTimelineContext(events: MemoryEvent[]): string {
364
+ return events
365
+ .map((event) => `[${event.eventType}] ${event.content}`)
366
+ .join('\n\n');
367
+ }
368
+
369
+ private formatSharedContext(entry: SharedTroubleshootingEntry): string {
370
+ return [
371
+ `[shared_troubleshooting] ${entry.title}`,
372
+ `Symptoms: ${entry.symptoms.join('; ')}`,
373
+ `Root cause: ${entry.rootCause}`,
374
+ `Solution: ${entry.solution}`,
375
+ `Topics: ${entry.topics.join(', ')}`
376
+ ].join('\n');
377
+ }
378
+
379
+ private preview(content: string, maxLength: number): string {
380
+ const normalized = content.replace(/\s+/g, ' ').trim();
381
+ if (normalized.length <= maxLength) return normalized;
382
+ return `${normalized.slice(0, Math.max(0, maxLength - 3))}...`;
383
+ }
384
+ }
385
+
386
+ interface RetrievalDebugDetail {
387
+ eventId: string;
388
+ score: number;
389
+ semanticScore?: number;
390
+ lexicalScore?: number;
391
+ recencyScore?: number;
392
+ }
393
+
394
+ export function toDisclosureResultId(eventId: string): string {
395
+ return eventId.startsWith('event:') ? eventId : `event:${eventId}`;
396
+ }
397
+
398
+ export type ParsedDisclosureResultId =
399
+ | { kind: 'event'; eventId: string }
400
+ | { kind: 'shared'; entryId: string };
401
+
402
+ export function parseDisclosureResultId(resultId: string): string {
403
+ return resultId.startsWith('event:') ? resultId.slice('event:'.length) : resultId;
404
+ }
405
+
406
+ export function parseDisclosureResultRef(resultId: string): ParsedDisclosureResultId {
407
+ if (resultId.startsWith('shared:')) {
408
+ return { kind: 'shared', entryId: resultId.slice('shared:'.length) };
409
+ }
410
+ return {
411
+ kind: 'event',
412
+ eventId: parseDisclosureResultId(resultId)
413
+ };
414
+ }
415
+
416
+ export function createRetrievalDisclosureService(
417
+ deps: RetrievalDisclosureServiceDeps
418
+ ): RetrievalDisclosureService {
419
+ return new RetrievalDisclosureService(deps);
420
+ }