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,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
+ }