claude-memory-layer 1.0.27 → 1.0.28

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 (329) hide show
  1. package/.env.example +7 -0
  2. package/AGENTS.md +11 -0
  3. package/README.md +184 -41
  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 +9 -5
  56. package/scripts/build.ts +25 -8
  57. package/scripts/generate-session-qrels.ts +126 -0
  58. package/scripts/replay-retrieval-benchmark.ts +69 -0
  59. package/specs/thin-core-refactor/context.md +275 -0
  60. package/specs/thin-core-refactor/plan.md +536 -0
  61. package/specs/thin-core-refactor/spec.md +465 -0
  62. package/src/adapters/claude/capture/index.ts +3 -0
  63. package/src/adapters/claude/context/index.ts +3 -0
  64. package/src/adapters/claude/hooks/index.ts +21 -0
  65. package/src/adapters/claude/hooks/post-tool-use.ts +239 -0
  66. package/src/adapters/claude/hooks/prompt-injection-policy.ts +104 -0
  67. package/src/adapters/claude/hooks/semantic-daemon-client.ts +209 -0
  68. package/src/adapters/claude/hooks/semantic-daemon.ts +283 -0
  69. package/src/adapters/claude/hooks/session-end.ts +59 -0
  70. package/src/adapters/claude/hooks/session-start.ts +73 -0
  71. package/src/adapters/claude/hooks/stop.ts +128 -0
  72. package/src/adapters/claude/hooks/user-prompt-submit.ts +361 -0
  73. package/src/adapters/claude/index.ts +4 -0
  74. package/src/adapters/claude/transcript/index.ts +4 -0
  75. package/src/adapters/claude/transcript/transcript-reader.ts +57 -0
  76. package/src/adapters/claude/transcript/turn-reconstructor.ts +65 -0
  77. package/src/apps/cli/claude-settings-hooks.ts +138 -0
  78. package/src/apps/cli/codex-import-runner.ts +125 -0
  79. package/src/apps/cli/codex-validation-output.ts +95 -0
  80. package/src/apps/cli/hermes-import-runner.ts +130 -0
  81. package/src/apps/cli/hermes-validation-output.ts +91 -0
  82. package/src/apps/cli/index.ts +1731 -0
  83. package/src/apps/cli/mcp-install.ts +106 -0
  84. package/src/apps/cli/retrieval-disclosure-output.ts +196 -0
  85. package/src/apps/dashboard/assets/js/bootstrap.js +244 -0
  86. package/src/apps/dashboard/assets/js/chat.js +373 -0
  87. package/src/apps/dashboard/assets/js/disclosure.js +232 -0
  88. package/src/apps/dashboard/assets/js/modals.js +298 -0
  89. package/src/apps/dashboard/assets/js/overview.js +655 -0
  90. package/src/apps/dashboard/assets/js/state.js +72 -0
  91. package/src/apps/dashboard/assets/js/views.js +468 -0
  92. package/src/{ui → apps/dashboard}/index.html +43 -1
  93. package/src/apps/dashboard/index.ts +3 -0
  94. package/src/{ui → apps/dashboard}/style.css +222 -0
  95. package/src/apps/index.ts +5 -0
  96. package/src/apps/server/api/chat.ts +244 -0
  97. package/src/apps/server/api/citations.ts +105 -0
  98. package/src/apps/server/api/events.ts +137 -0
  99. package/src/apps/server/api/health.ts +53 -0
  100. package/src/apps/server/api/index.ts +26 -0
  101. package/src/apps/server/api/projects.ts +74 -0
  102. package/src/apps/server/api/search.ts +184 -0
  103. package/src/apps/server/api/sessions.ts +115 -0
  104. package/src/apps/server/api/stats.ts +723 -0
  105. package/src/apps/server/api/turns.ts +143 -0
  106. package/src/apps/server/api/utils.ts +65 -0
  107. package/src/apps/server/index.ts +111 -0
  108. package/src/cli/index.ts +2 -1311
  109. package/src/cli/retrieval-disclosure-output.ts +2 -0
  110. package/src/compat/index.ts +5 -0
  111. package/src/core/derive/fact-deriver.ts +170 -0
  112. package/src/core/derive/index.ts +2 -0
  113. package/src/core/derive/summary-deriver.ts +76 -0
  114. package/src/core/embedder.ts +4 -152
  115. package/src/core/engine/embedding-maintenance-service.ts +187 -0
  116. package/src/core/engine/endless-memory-services.ts +4 -0
  117. package/src/core/engine/index.ts +19 -0
  118. package/src/core/engine/memory-engine-services.ts +170 -0
  119. package/src/core/engine/memory-ingest-service.ts +317 -0
  120. package/src/core/engine/memory-query-service.ts +173 -0
  121. package/src/core/engine/memory-runtime-service.ts +162 -0
  122. package/src/core/engine/memory-service-composition.ts +231 -0
  123. package/src/core/engine/retrieval-analytics-service.ts +181 -0
  124. package/src/core/engine/retrieval-disclosure-service.ts +420 -0
  125. package/src/core/engine/retrieval-orchestrator.ts +377 -0
  126. package/src/core/engine/retrieval-services.ts +176 -0
  127. package/src/core/engine/shared-memory-services.ts +4 -0
  128. package/src/core/entity-repo.ts +1 -3
  129. package/src/core/event-store.ts +3 -3
  130. package/src/core/evidence-aligner.ts +2 -2
  131. package/src/core/external-market-context.ts +582 -0
  132. package/src/core/graduation.ts +2 -3
  133. package/src/core/index.ts +21 -0
  134. package/src/core/matcher.ts +2 -4
  135. package/src/core/model/memory-fact.ts +30 -0
  136. package/src/core/model/memory-rule.ts +14 -0
  137. package/src/core/model/memory-summary.ts +21 -0
  138. package/src/core/model/raw-event.ts +28 -0
  139. package/src/core/model/retrieval-result.ts +35 -0
  140. package/src/core/privacy/filter.ts +21 -10
  141. package/src/core/product-validation-matrix.ts +314 -0
  142. package/src/core/progressive-retriever.ts +1 -2
  143. package/src/core/registry/project-path.ts +54 -0
  144. package/src/core/registry/session-registry.ts +69 -0
  145. package/src/core/replay-evaluator.ts +625 -0
  146. package/src/core/retrieval-benchmark.ts +117 -0
  147. package/src/core/retrieval-quality.ts +109 -0
  148. package/src/core/retriever.ts +53 -15
  149. package/src/core/session-qrels.ts +360 -0
  150. package/src/core/shared-event-store.ts +1 -1
  151. package/src/core/sqlite-event-store.ts +35 -11
  152. package/src/core/task/blocker-resolver.ts +2 -2
  153. package/src/core/task/task-resolver.ts +0 -1
  154. package/src/core/vector-outbox.ts +1 -10
  155. package/src/core/vector-worker.ts +1 -1
  156. package/src/extensions/endless-memory/endless-memory-services.ts +350 -0
  157. package/src/extensions/endless-memory/index.ts +1 -0
  158. package/src/extensions/index.ts +5 -0
  159. package/src/extensions/mcp/handlers.ts +960 -0
  160. package/src/extensions/mcp/index.ts +48 -0
  161. package/src/extensions/mcp/tools.ts +252 -0
  162. package/src/extensions/shared-memory/index.ts +1 -0
  163. package/src/extensions/shared-memory/shared-memory-services.ts +211 -0
  164. package/src/extensions/vector/embedder.ts +197 -0
  165. package/src/extensions/vector/index.ts +1 -0
  166. package/src/hooks/post-tool-use.ts +3 -236
  167. package/src/hooks/semantic-daemon-client.ts +1 -208
  168. package/src/hooks/semantic-daemon.ts +6 -271
  169. package/src/hooks/session-end.ts +4 -79
  170. package/src/hooks/session-start.ts +4 -73
  171. package/src/hooks/stop.ts +3 -173
  172. package/src/hooks/user-prompt-submit.ts +3 -338
  173. package/src/index.ts +13 -0
  174. package/src/mcp/handlers.ts +2 -212
  175. package/src/mcp/index.ts +3 -46
  176. package/src/mcp/tools.ts +2 -78
  177. package/src/server/api/chat.ts +2 -244
  178. package/src/server/api/citations.ts +2 -105
  179. package/src/server/api/events.ts +2 -137
  180. package/src/server/api/health.ts +2 -53
  181. package/src/server/api/index.ts +2 -26
  182. package/src/server/api/projects.ts +2 -74
  183. package/src/server/api/search.ts +2 -102
  184. package/src/server/api/sessions.ts +2 -115
  185. package/src/server/api/stats.ts +2 -724
  186. package/src/server/api/turns.ts +2 -143
  187. package/src/server/api/utils.ts +2 -46
  188. package/src/server/index.ts +2 -100
  189. package/src/services/bootstrap-organizer.ts +46 -26
  190. package/src/services/codex-session-history-importer.ts +521 -29
  191. package/src/services/hermes-session-history-importer.ts +733 -0
  192. package/src/services/memory-service-config.ts +36 -0
  193. package/src/services/memory-service-registry.ts +150 -0
  194. package/src/services/memory-service.ts +211 -1325
  195. package/src/services/session-history-importer.ts +58 -14
  196. package/tests/README.md +23 -0
  197. package/tests/adapters/claude/claude-semantic-daemon-adapter.test.ts +54 -0
  198. package/tests/adapters/claude/claude-transcript-reconstructor.test.ts +98 -0
  199. package/tests/adapters/claude-hook-prompt-injection-policy.test.ts +99 -0
  200. package/tests/apps/app-layer-boundary.test.ts +48 -0
  201. package/tests/apps/claude-settings-hooks.test.ts +107 -0
  202. package/tests/apps/cli-disclosure-output.test.ts +212 -0
  203. package/tests/apps/codex-import-runner.test.ts +99 -0
  204. package/tests/apps/codex-validation-output.test.ts +100 -0
  205. package/tests/apps/hermes-import-runner.test.ts +99 -0
  206. package/tests/apps/mcp-install-command.test.ts +59 -0
  207. package/tests/apps/package-build-entrypoints.test.ts +30 -0
  208. package/tests/apps/search-api-disclosure.test.ts +162 -0
  209. package/tests/apps/stats-api-lightweight.test.ts +67 -0
  210. package/tests/apps/ui-disclosure-output.test.ts +140 -0
  211. package/tests/{bootstrap-organizer.test.ts → core/bootstrap-organizer.test.ts} +1 -1
  212. package/tests/{canonical-key.test.ts → core/canonical-key.test.ts} +1 -1
  213. package/tests/core/codex-session-history-importer-validation.test.ts +185 -0
  214. package/tests/{consolidation-worker.test.ts → core/consolidation-worker.test.ts} +2 -2
  215. package/tests/core/embedding-maintenance-service.test.ts +282 -0
  216. package/tests/{evidence-aligner.test.ts → core/evidence-aligner.test.ts} +1 -1
  217. package/tests/core/external-market-context.test.ts +209 -0
  218. package/tests/core/fact-deriver.test.ts +79 -0
  219. package/tests/core/hermes-session-history-importer-validation.test.ts +609 -0
  220. package/tests/{ingest-interceptor.test.ts → core/ingest-interceptor.test.ts} +1 -1
  221. package/tests/{markdown-mirror.test.ts → core/markdown-mirror.test.ts} +2 -2
  222. package/tests/{matcher.test.ts → core/matcher.test.ts} +1 -1
  223. package/tests/{md-mirror.test.ts → core/md-mirror.test.ts} +2 -2
  224. package/tests/core/memory-engine-services.test.ts +240 -0
  225. package/tests/core/memory-ingest-service.test.ts +296 -0
  226. package/tests/core/memory-query-service.test.ts +129 -0
  227. package/tests/core/memory-runtime-service.test.ts +201 -0
  228. package/tests/core/memory-service-composition.test.ts +192 -0
  229. package/tests/core/memory-service-config.test.ts +41 -0
  230. package/tests/core/memory-service-facade.test.ts +30 -0
  231. package/tests/core/memory-service-registry.test.ts +206 -0
  232. package/tests/core/product-validation-matrix.test.ts +61 -0
  233. package/tests/core/project-registry.test.ts +78 -0
  234. package/tests/core/replay-evaluator.test.ts +181 -0
  235. package/tests/core/retrieval-analytics-service.test.ts +210 -0
  236. package/tests/core/retrieval-benchmark.test.ts +93 -0
  237. package/tests/core/retrieval-disclosure-service.test.ts +264 -0
  238. package/tests/core/retrieval-orchestrator.test.ts +403 -0
  239. package/tests/core/retrieval-quality.test.ts +31 -0
  240. package/tests/core/retrieval-services.test.ts +185 -0
  241. package/tests/{retriever-fallback-chain.test.ts → core/retriever-fallback-chain.test.ts} +3 -3
  242. package/tests/{retriever-strategy-scope.test.ts → core/retriever-strategy-scope.test.ts} +70 -3
  243. package/tests/{retriever.memu-adoption.test.ts → core/retriever.memu-adoption.test.ts} +3 -3
  244. package/tests/core/session-history-importer-filter.test.ts +78 -0
  245. package/tests/core/session-qrels.test.ts +250 -0
  246. package/tests/{sqlite-event-store-replication.test.ts → core/sqlite-event-store-replication.test.ts} +36 -1
  247. package/tests/core/summary-deriver.test.ts +66 -0
  248. package/tests/extensions/embedder-warning-suppression.test.ts +53 -0
  249. package/tests/extensions/endless-memory-extension-boundary.test.ts +17 -0
  250. package/tests/extensions/endless-memory-services.test.ts +325 -0
  251. package/tests/extensions/mcp-context-tools.test.ts +905 -0
  252. package/tests/extensions/mcp-extension-boundary.test.ts +21 -0
  253. package/tests/extensions/mcp-package-build.test.ts +22 -0
  254. package/tests/extensions/mcp-project-aware-tools.test.ts +102 -0
  255. package/tests/extensions/shared-memory-extension-boundary.test.ts +24 -0
  256. package/tests/extensions/shared-memory-services.test.ts +309 -0
  257. package/tests/extensions/vector-extension-boundary.test.ts +21 -0
  258. package/.claude/settings.local.json +0 -25
  259. package/.npm-cache/_cacache/content-v2/sha512/04/76/c098f88dfe584a2b80870bff7421b05d17d3d9ee1027f77772332a22d3f93a9a57101a2855107f6ad82077a818bba912b2bc317f2361b5ddb09ad284d9ce +0 -0
  260. package/.npm-cache/_cacache/content-v2/sha512/60/25/d2ecd39cfc7cab58351162814be77f935c6d6491c10c3745d456da7ddb2117ffd90c10e53fe3c0f1ed16b403307841543634504398b16ee4e6b6dd8e0c45 +0 -0
  261. package/.npm-cache/_cacache/index-v5/2b/9a/7f8f40206ed8a2e0a84efaa953ccaed1f5d001e14b931083f2e7a0738007 +0 -2
  262. package/.npm-cache/_cacache/index-v5/2e/d9/fcfa5c6a6abdc2a3644ab84a95936047298c465a2f47ee03db8f7fe1e946 +0 -3
  263. package/.npm-cache/_cacache/index-v5/a9/42/e519633356d12d3d2f19da66a8301016d496c8f5c3e0554124aaa62dc043 +0 -2
  264. package/.npm-cache/_logs/2026-02-26T12_04_52_729Z-debug-0.log +0 -256
  265. package/.npm-cache/_logs/2026-02-26T12_05_36_835Z-debug-0.log +0 -18
  266. package/.npm-cache/_logs/2026-02-26T12_05_45_982Z-debug-0.log +0 -32
  267. package/.npm-cache/_logs/2026-02-26T12_05_48_515Z-debug-0.log +0 -260
  268. package/.npm-cache/_logs/2026-02-26T12_05_53_567Z-debug-0.log +0 -69
  269. package/.npm-cache/_update-notifier-last-checked +0 -0
  270. package/bootstrap-kb/decisions/decisions.md +0 -244
  271. package/bootstrap-kb/glossary/glossary.md +0 -46
  272. package/bootstrap-kb/modules/.claude-plugin.md +0 -22
  273. package/bootstrap-kb/modules/agents.md.md +0 -15
  274. package/bootstrap-kb/modules/claude.md.md +0 -15
  275. package/bootstrap-kb/modules/context.md.md +0 -15
  276. package/bootstrap-kb/modules/docs.md +0 -18
  277. package/bootstrap-kb/modules/handoff.md.md +0 -15
  278. package/bootstrap-kb/modules/package-lock.json.md +0 -15
  279. package/bootstrap-kb/modules/package.json.md +0 -15
  280. package/bootstrap-kb/modules/plan.md.md +0 -15
  281. package/bootstrap-kb/modules/readme.md.md +0 -15
  282. package/bootstrap-kb/modules/scripts.md +0 -26
  283. package/bootstrap-kb/modules/spec.md.md +0 -15
  284. package/bootstrap-kb/modules/specs.md +0 -20
  285. package/bootstrap-kb/modules/src.md +0 -51
  286. package/bootstrap-kb/modules/tests.md +0 -42
  287. package/bootstrap-kb/modules/tsconfig.json.md +0 -15
  288. package/bootstrap-kb/modules/vitest.config.ts.md +0 -15
  289. package/bootstrap-kb/overview/overview.md +0 -40
  290. package/bootstrap-kb/sources/manifest.json +0 -950
  291. package/bootstrap-kb/sources/manifest.md +0 -227
  292. package/bootstrap-kb/timeline/timeline.md +0 -57
  293. package/claude-memory-layer-1.0.14.tgz +0 -0
  294. package/d.sh +0 -3
  295. package/deploy.sh +0 -3
  296. package/dist/ui/app.js +0 -2101
  297. package/memory/.claude-plugin/commands/2026-02-25.md +0 -263
  298. package/memory/_index.md +0 -419
  299. package/memory/agent_response/uncategorized/2026-02-26.md +0 -176
  300. package/memory/agent_response/uncategorized/2026-03-03.md +0 -14
  301. package/memory/agent_response/uncategorized/2026-03-04.md +0 -1421
  302. package/memory/agent_response/uncategorized/2026-03-05.md +0 -157
  303. package/memory/default/uncategorized/2026-02-25.md +0 -4839
  304. package/memory/session_summary/uncategorized/2026-02-26.md +0 -13
  305. package/memory/session_summary/uncategorized/2026-03-03.md +0 -5
  306. package/memory/session_summary/uncategorized/2026-03-04.md +0 -50
  307. package/memory/specs/20260207-dashboard-upgrade/2026-02-25.md +0 -142
  308. package/memory/specs/citations-system/2026-02-25.md +0 -1121
  309. package/memory/specs/endless-mode/2026-02-25.md +0 -1392
  310. package/memory/specs/entity-edge-model/2026-02-25.md +0 -1263
  311. package/memory/specs/evidence-aligner-v2/2026-02-25.md +0 -1028
  312. package/memory/specs/mcp-desktop-integration/2026-02-25.md +0 -1334
  313. package/memory/specs/post-tool-use-hook/2026-02-25.md +0 -1164
  314. package/memory/specs/private-tags/2026-02-25.md +0 -1057
  315. package/memory/specs/progressive-disclosure/2026-02-25.md +0 -1436
  316. package/memory/specs/task-entity-system/2026-02-25.md +0 -924
  317. package/memory/specs/vector-outbox-v2/2026-02-25.md +0 -1510
  318. package/memory/specs/web-viewer-ui/2026-02-25.md +0 -1709
  319. package/memory/tool_observation/uncategorized/2026-02-26.md +0 -209
  320. package/memory/tool_observation/uncategorized/2026-03-03.md +0 -21
  321. package/memory/tool_observation/uncategorized/2026-03-04.md +0 -1033
  322. package/memory/tool_observation/uncategorized/2026-03-05.md +0 -33
  323. package/memory/user_prompt/uncategorized/2026-02-26.md +0 -25
  324. package/memory/user_prompt/uncategorized/2026-03-04.md +0 -634
  325. package/memory/user_prompt/uncategorized/2026-03-05.md +0 -6
  326. package/specs/optional-duckdb/context.md +0 -77
  327. package/specs/optional-duckdb/plan.md +0 -142
  328. package/specs/optional-duckdb/spec.md +0 -35
  329. package/src/ui/app.js +0 -2101
@@ -0,0 +1,48 @@
1
+ #!/usr/bin/env node
2
+ /**
3
+ * MCP Server for Claude Desktop
4
+ * Provides memory search tools via Model Context Protocol
5
+ */
6
+
7
+ import { Server } from '@modelcontextprotocol/sdk/server/index.js';
8
+ import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
9
+ import {
10
+ ListToolsRequestSchema,
11
+ CallToolRequestSchema
12
+ } from '@modelcontextprotocol/sdk/types.js';
13
+ import type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';
14
+
15
+ import { tools } from './tools.js';
16
+ import { handleToolCall } from './handlers.js';
17
+
18
+ const server = new Server(
19
+ {
20
+ name: 'claude-memory-layer-mcp',
21
+ version: '1.0.0'
22
+ },
23
+ {
24
+ capabilities: {
25
+ tools: {}
26
+ }
27
+ }
28
+ );
29
+
30
+ // Tool listing handler
31
+ server.setRequestHandler(ListToolsRequestSchema, async () => {
32
+ return { tools };
33
+ });
34
+
35
+ // Tool call handler
36
+ server.setRequestHandler(CallToolRequestSchema, async (request): Promise<CallToolResult> => {
37
+ const { name, arguments: args } = request.params;
38
+ return handleToolCall(name, args || {});
39
+ });
40
+
41
+ // Start server
42
+ async function main() {
43
+ const transport = new StdioServerTransport();
44
+ await server.connect(transport);
45
+ console.error('claude-memory-layer MCP server started');
46
+ }
47
+
48
+ main().catch(console.error);
@@ -0,0 +1,252 @@
1
+ /**
2
+ * MCP Tool Definitions
3
+ * Available tools for Claude Desktop
4
+ */
5
+
6
+ import type { Tool } from '@modelcontextprotocol/sdk/types.js';
7
+
8
+ const projectPathProperty = {
9
+ type: 'string',
10
+ description: 'Optional: absolute project path to search a project-scoped claude-memory-layer store instead of the global store'
11
+ } as const;
12
+
13
+ export const tools: Tool[] = [
14
+ {
15
+ name: 'external-market-context',
16
+ description: 'Read-only external market/company context from DART, FRED, and Finnhub with structured MarketContextSnapshot bull/bear/risk/catalyst analysis.',
17
+ inputSchema: {
18
+ type: 'object',
19
+ properties: {
20
+ company: { type: 'string', description: 'Optional company name for report subject and DART fallback search' },
21
+ dartCorpCode: { type: 'string', description: 'Optional exact DART corp_code for issuer-specific filings' },
22
+ symbol: { type: 'string', description: 'Optional listed ticker for Finnhub company profile' },
23
+ providers: { type: 'array', items: { type: 'string', enum: ['dart', 'fred', 'finnhub'] }, description: 'Providers to fetch (default: dart, fred, finnhub)' },
24
+ fredSeries: { type: 'array', items: { type: 'string' }, description: 'Optional FRED series IDs (default: FEDFUNDS, CPIAUCSL, UNRATE)' },
25
+ includeSnapshot: { type: 'boolean', description: 'Include structured MarketContextSnapshot and DART company snapshot (default: true)' },
26
+ projectPath: projectPathProperty
27
+ }
28
+ }
29
+ },
30
+ {
31
+ name: 'mem-search',
32
+ description: 'Search claude-memory-layer for relevant past conversations and insights. Returns a compact index of results - use mem-details to get full content.',
33
+ inputSchema: {
34
+ type: 'object',
35
+ properties: {
36
+ query: {
37
+ type: 'string',
38
+ description: 'Natural language search query'
39
+ },
40
+ topK: {
41
+ type: 'number',
42
+ description: 'Maximum number of results (default: 5, max: 20)'
43
+ },
44
+ sessionId: {
45
+ type: 'string',
46
+ description: 'Optional: filter by specific session ID'
47
+ },
48
+ projectPath: projectPathProperty,
49
+ eventType: {
50
+ type: 'string',
51
+ enum: ['user_prompt', 'agent_response', 'tool_observation', 'session_summary'],
52
+ description: 'Optional: filter by event type'
53
+ }
54
+ },
55
+ required: ['query']
56
+ }
57
+ },
58
+ {
59
+ name: 'mem-timeline',
60
+ description: 'Get chronological context around specific memories. Useful for understanding the conversation flow.',
61
+ inputSchema: {
62
+ type: 'object',
63
+ properties: {
64
+ ids: {
65
+ type: 'array',
66
+ items: { type: 'string' },
67
+ description: 'Memory IDs (from mem-search) to get timeline for'
68
+ },
69
+ windowSize: {
70
+ type: 'number',
71
+ description: 'Number of items before/after each ID (default: 3)'
72
+ },
73
+ projectPath: projectPathProperty
74
+ },
75
+ required: ['ids']
76
+ }
77
+ },
78
+ {
79
+ name: 'mem-details',
80
+ description: 'Get full content of specific memories. Use after mem-search to get complete information.',
81
+ inputSchema: {
82
+ type: 'object',
83
+ properties: {
84
+ ids: {
85
+ type: 'array',
86
+ items: { type: 'string' },
87
+ description: 'Memory IDs to fetch full details for'
88
+ },
89
+ projectPath: projectPathProperty
90
+ },
91
+ required: ['ids']
92
+ }
93
+ },
94
+ {
95
+ name: 'mem-stats',
96
+ description: 'Get statistics about the memory storage (total events, sessions, etc.)',
97
+ inputSchema: {
98
+ type: 'object',
99
+ properties: {
100
+ projectPath: projectPathProperty
101
+ }
102
+ }
103
+ },
104
+ {
105
+ name: 'mem-context-pack',
106
+ description: 'Build a compact, agent-ready project context pack from relevant memories plus recent project timeline. Use at the start of Hermes/Codex work to recover the important project state without reading raw transcripts.',
107
+ inputSchema: {
108
+ type: 'object',
109
+ properties: {
110
+ query: {
111
+ type: 'string',
112
+ description: 'Optional task/topic query. Defaults to recent project context.'
113
+ },
114
+ topK: {
115
+ type: 'number',
116
+ description: 'Maximum relevant memories to include (default: 5, max: 12)'
117
+ },
118
+ recentLimit: {
119
+ type: 'number',
120
+ description: 'Maximum recent events to inspect for project timeline (default: 30, max: 200)'
121
+ },
122
+ sessionLimit: {
123
+ type: 'number',
124
+ description: 'Maximum recent sessions to summarize (default: 5, max: 20)'
125
+ },
126
+ sessionId: {
127
+ type: 'string',
128
+ description: 'Optional: filter relevant memories by specific session ID'
129
+ },
130
+ projectPath: projectPathProperty,
131
+ refreshLatest: {
132
+ type: 'boolean',
133
+ description: 'Explicit opt-in: import latest local session history before retrieval. Requires absolute projectPath and mutates project memory (default: false).'
134
+ },
135
+ refreshSources: {
136
+ type: 'array',
137
+ items: { type: 'string', enum: ['claude', 'codex', 'hermes'] },
138
+ description: 'Sources to refresh when refreshLatest is true (default: hermes and codex)'
139
+ },
140
+ refreshSessionLimit: {
141
+ type: 'number',
142
+ description: 'Maximum recent matching sessions per refresh source (default: 1, max: 10)'
143
+ },
144
+ refreshMessageLimit: {
145
+ type: 'number',
146
+ description: 'Maximum messages/memories per refresh source (default: 200, max: 1000)'
147
+ },
148
+ refreshForce: {
149
+ type: 'boolean',
150
+ description: 'Force reimport during refresh by deleting existing events for imported sessions first (default: false)'
151
+ },
152
+ refreshEmbeddings: {
153
+ type: 'boolean',
154
+ description: 'Process pending embeddings after refresh (default: false for fast context retrieval)'
155
+ },
156
+ sessionsDir: {
157
+ type: 'string',
158
+ description: 'Optional Codex sessions directory override for refreshLatest'
159
+ },
160
+ stateDb: {
161
+ type: 'string',
162
+ description: 'Optional Hermes state database path override for refreshLatest'
163
+ }
164
+ }
165
+ }
166
+ },
167
+ {
168
+ name: 'mem-import-latest',
169
+ description: 'Explicitly import the latest local Claude Code, Codex, and/or Hermes session history into project-scoped memory before retrieving context. This mutates memory; use for freshness jobs before mem-context-pack.',
170
+ inputSchema: {
171
+ type: 'object',
172
+ properties: {
173
+ projectPath: {
174
+ type: 'string',
175
+ description: 'Required absolute project path. Import is always project-scoped to avoid cross-project memory mixing.'
176
+ },
177
+ sources: {
178
+ type: 'array',
179
+ items: { type: 'string', enum: ['claude', 'codex', 'hermes'] },
180
+ description: 'Sources to import (default: hermes and codex)'
181
+ },
182
+ sessionLimit: {
183
+ type: 'number',
184
+ description: 'Maximum recent matching sessions per source to import (default: 1, max: 10)'
185
+ },
186
+ messageLimit: {
187
+ type: 'number',
188
+ description: 'Maximum messages/memories per source import (default: 200, max: 1000)'
189
+ },
190
+ force: {
191
+ type: 'boolean',
192
+ description: 'Force reimport by deleting existing events for imported sessions first (default: false)'
193
+ },
194
+ processEmbeddings: {
195
+ type: 'boolean',
196
+ description: 'Process pending embeddings after import (default: false for fast freshness imports)'
197
+ },
198
+ sessionsDir: {
199
+ type: 'string',
200
+ description: 'Optional Codex sessions directory override'
201
+ },
202
+ stateDb: {
203
+ type: 'string',
204
+ description: 'Optional Hermes state database path override'
205
+ }
206
+ },
207
+ required: ['projectPath']
208
+ }
209
+ },
210
+ {
211
+ name: 'mem-project-timeline',
212
+ description: 'Summarize recent project memory by session, source agent, event counts, and safe previews. Useful for understanding what happened recently before continuing work.',
213
+ inputSchema: {
214
+ type: 'object',
215
+ properties: {
216
+ limit: {
217
+ type: 'number',
218
+ description: 'Maximum recent events to inspect (default: 50, max: 500)'
219
+ },
220
+ sessionLimit: {
221
+ type: 'number',
222
+ description: 'Maximum sessions to summarize (default: 10, max: 50)'
223
+ },
224
+ projectPath: projectPathProperty
225
+ }
226
+ }
227
+ },
228
+ {
229
+ name: 'mem-source-ref',
230
+ description: 'Resolve memory IDs, mem citation IDs, or event: IDs into privacy-safe source references with redacted previews and safe metadata only. Prefer this before mem-details when raw transcript exposure is unnecessary.',
231
+ inputSchema: {
232
+ type: 'object',
233
+ properties: {
234
+ ids: {
235
+ type: 'array',
236
+ items: { type: 'string' },
237
+ description: 'Memory/event IDs to resolve. Accepts full event IDs, event:<id>, mem:<citation>, or bare citation IDs.'
238
+ },
239
+ maxContentChars: {
240
+ type: 'number',
241
+ description: 'Maximum redacted preview characters per source (default: 500, max: 2000)'
242
+ },
243
+ lookupLimit: {
244
+ type: 'number',
245
+ description: 'Maximum recent events to scan for ID resolution (default: 10000, max: 50000)'
246
+ },
247
+ projectPath: projectPathProperty
248
+ },
249
+ required: ['ids']
250
+ }
251
+ }
252
+ ];
@@ -0,0 +1 @@
1
+ export * from './shared-memory-services.js';
@@ -0,0 +1,211 @@
1
+ import * as fs from 'fs';
2
+ import * as path from 'path';
3
+ import type { Embedder } from '../vector/index.js';
4
+ import { createSharedEventStore, type SharedEventStore } from '../../core/shared-event-store.js';
5
+ import { createSharedPromoter, type PromotionResult, type SharedPromoter } from '../../core/shared-promoter.js';
6
+ import { createSharedStore, type SharedStore } from '../../core/shared-store.js';
7
+ import { createSharedVectorStore, type SharedVectorStore } from '../../core/shared-vector-store.js';
8
+ import type { Entry, SharedStoreConfig, SharedTroubleshootingEntry } from '../../core/types.js';
9
+
10
+ export interface SharedMemoryRetriever {
11
+ setSharedStores(sharedStore: SharedStore, sharedVectorStore: SharedVectorStore): void;
12
+ }
13
+
14
+ export interface SharedMemoryServicesFactories {
15
+ existsSync?: (targetPath: string) => boolean;
16
+ mkdirSync?: (targetPath: string) => void;
17
+ createSharedEventStore?: (dbPath: string) => SharedEventStore;
18
+ createSharedStore?: (sharedEventStore: SharedEventStore) => SharedStore;
19
+ createSharedVectorStore?: (dbPath: string) => SharedVectorStore;
20
+ createSharedPromoter?: (
21
+ sharedStore: SharedStore,
22
+ sharedVectorStore: SharedVectorStore,
23
+ embedder: Embedder,
24
+ config?: SharedStoreConfig
25
+ ) => SharedPromoter;
26
+ }
27
+
28
+ export interface SharedMemoryServicesOptions {
29
+ config: SharedStoreConfig | null;
30
+ defaultSharedStoragePath: string;
31
+ readOnly: boolean;
32
+ expandPath: (targetPath: string) => string;
33
+ embedder: Embedder;
34
+ retriever: SharedMemoryRetriever;
35
+ factories?: SharedMemoryServicesFactories;
36
+ }
37
+
38
+ export type SharedStoreStats = {
39
+ total: number;
40
+ averageConfidence: number;
41
+ topTopics: Array<{ topic: string; count: number }>;
42
+ totalUsageCount: number;
43
+ };
44
+
45
+ export class SharedMemoryServices {
46
+ private sharedEventStore: SharedEventStore | null = null;
47
+ private sharedStore: SharedStore | null = null;
48
+ private sharedVectorStore: SharedVectorStore | null = null;
49
+ private sharedPromoter: SharedPromoter | null = null;
50
+ private openStorePromise: Promise<SharedStore> | null = null;
51
+
52
+ constructor(private readonly options: SharedMemoryServicesOptions) {}
53
+
54
+ get eventStore(): SharedEventStore | null {
55
+ return this.sharedEventStore;
56
+ }
57
+
58
+ get store(): SharedStore | null {
59
+ return this.sharedStore;
60
+ }
61
+
62
+ get vectorStore(): SharedVectorStore | null {
63
+ return this.sharedVectorStore;
64
+ }
65
+
66
+ get promoter(): SharedPromoter | null {
67
+ return this.sharedPromoter;
68
+ }
69
+
70
+ isEnabled(): boolean {
71
+ return this.sharedStore !== null;
72
+ }
73
+
74
+ getSharedStoragePath(): string {
75
+ return this.options.config?.sharedStoragePath
76
+ ? this.options.expandPath(this.options.config.sharedStoragePath)
77
+ : this.options.defaultSharedStoragePath;
78
+ }
79
+
80
+ async initialize(): Promise<void> {
81
+ if (this.options.config?.enabled === false || this.options.readOnly) return;
82
+
83
+ const sharedPath = this.getSharedStoragePath();
84
+ this.ensureDirectory(sharedPath, { allowCreate: true });
85
+
86
+ const store = await this.openStore(sharedPath);
87
+
88
+ this.sharedVectorStore = this.factories.createSharedVectorStore(
89
+ path.join(sharedPath, 'vectors')
90
+ );
91
+ await this.sharedVectorStore.initialize();
92
+
93
+ this.sharedPromoter = this.factories.createSharedPromoter(
94
+ store,
95
+ this.sharedVectorStore,
96
+ this.options.embedder,
97
+ this.options.config || undefined
98
+ );
99
+
100
+ this.options.retriever.setSharedStores(store, this.sharedVectorStore);
101
+ }
102
+
103
+ async ensureStoreForRead(): Promise<SharedStore | null> {
104
+ if (this.options.config?.enabled === false) return null;
105
+ if (this.sharedStore) return this.sharedStore;
106
+
107
+ const sharedPath = this.getSharedStoragePath();
108
+ const directoryReady = this.ensureDirectory(sharedPath, { allowCreate: !this.options.readOnly });
109
+ if (!directoryReady) return null;
110
+
111
+ return this.openStore(sharedPath);
112
+ }
113
+
114
+ async getEntryForDisclosure(entryId: string): Promise<SharedTroubleshootingEntry | null> {
115
+ const store = await this.ensureStoreForRead();
116
+ return store?.get(entryId) ?? null;
117
+ }
118
+
119
+ async promoteToShared(entry: Entry, projectHash: string | null): Promise<PromotionResult> {
120
+ if (!this.sharedPromoter || !projectHash) {
121
+ return {
122
+ success: false,
123
+ error: 'Shared store not initialized or project hash not set'
124
+ };
125
+ }
126
+
127
+ return this.sharedPromoter.promoteEntry(entry, projectHash);
128
+ }
129
+
130
+ async getStats(): Promise<SharedStoreStats | null> {
131
+ if (!this.sharedStore) return null;
132
+ return this.sharedStore.getStats();
133
+ }
134
+
135
+ async search(
136
+ query: string,
137
+ options?: { topK?: number; minConfidence?: number }
138
+ ): Promise<SharedTroubleshootingEntry[]> {
139
+ if (!this.sharedStore) return [];
140
+ return this.sharedStore.search(query, options);
141
+ }
142
+
143
+ async close(): Promise<void> {
144
+ if (this.openStorePromise) {
145
+ await this.openStorePromise.catch(() => null);
146
+ }
147
+
148
+ if (this.sharedEventStore) {
149
+ await this.sharedEventStore.close();
150
+ }
151
+ this.sharedEventStore = null;
152
+ this.sharedStore = null;
153
+ this.sharedVectorStore = null;
154
+ this.sharedPromoter = null;
155
+ this.openStorePromise = null;
156
+ }
157
+
158
+ private async openStore(sharedPath: string): Promise<SharedStore> {
159
+ if (this.sharedStore) return this.sharedStore;
160
+
161
+ if (!this.openStorePromise) {
162
+ this.openStorePromise = this.createOpenStorePromise(sharedPath);
163
+ }
164
+
165
+ try {
166
+ return await this.openStorePromise;
167
+ } finally {
168
+ this.openStorePromise = null;
169
+ }
170
+ }
171
+
172
+ private async createOpenStorePromise(sharedPath: string): Promise<SharedStore> {
173
+ if (!this.sharedEventStore) {
174
+ const sharedEventStore = this.factories.createSharedEventStore(
175
+ path.join(sharedPath, 'shared.duckdb')
176
+ );
177
+ await sharedEventStore.initialize();
178
+ this.sharedEventStore = sharedEventStore;
179
+ }
180
+
181
+ if (!this.sharedStore) {
182
+ this.sharedStore = this.factories.createSharedStore(this.sharedEventStore);
183
+ }
184
+
185
+ return this.sharedStore;
186
+ }
187
+
188
+ private ensureDirectory(sharedPath: string, options: { allowCreate: boolean }): boolean {
189
+ if (this.factories.existsSync(sharedPath)) return true;
190
+ if (!options.allowCreate) return false;
191
+ this.factories.mkdirSync(sharedPath);
192
+ return true;
193
+ }
194
+
195
+ private get factories(): Required<SharedMemoryServicesFactories> {
196
+ return {
197
+ existsSync: this.options.factories?.existsSync ?? fs.existsSync,
198
+ mkdirSync: this.options.factories?.mkdirSync ?? ((targetPath: string) => {
199
+ fs.mkdirSync(targetPath, { recursive: true });
200
+ }),
201
+ createSharedEventStore: this.options.factories?.createSharedEventStore ?? createSharedEventStore,
202
+ createSharedStore: this.options.factories?.createSharedStore ?? createSharedStore,
203
+ createSharedVectorStore: this.options.factories?.createSharedVectorStore ?? createSharedVectorStore,
204
+ createSharedPromoter: this.options.factories?.createSharedPromoter ?? createSharedPromoter
205
+ };
206
+ }
207
+ }
208
+
209
+ export function createSharedMemoryServices(options: SharedMemoryServicesOptions): SharedMemoryServices {
210
+ return new SharedMemoryServices(options);
211
+ }