nlm-memory 0.5.0 → 0.5.2

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 (257) hide show
  1. package/README.md +89 -34
  2. package/dist/cli/digest.d.ts +20 -0
  3. package/dist/cli/digest.js +142 -0
  4. package/dist/cli/digest.js.map +1 -0
  5. package/dist/cli/nlm.d.ts +1 -0
  6. package/dist/cli/nlm.js +25 -1
  7. package/dist/cli/nlm.js.map +1 -1
  8. package/dist/core/digest/compose.d.ts +38 -0
  9. package/dist/core/digest/compose.js +93 -0
  10. package/dist/core/digest/compose.js.map +1 -0
  11. package/dist/core/digest/hook-liveness.d.ts +32 -0
  12. package/dist/core/digest/hook-liveness.js +54 -0
  13. package/dist/core/digest/hook-liveness.js.map +1 -0
  14. package/dist/http/app.js +2 -1
  15. package/dist/http/app.js.map +1 -1
  16. package/dist/mcp/server.js +20 -1
  17. package/dist/mcp/server.js.map +1 -1
  18. package/dist/ui/assets/{index-C8cpwbYJ.css → index-Beo8psd-.css} +1 -1
  19. package/dist/ui/assets/{index-CB50QnL-.js → index-CSPTTeeM.js} +8 -8
  20. package/dist/ui/index.html +2 -2
  21. package/package.json +26 -1
  22. package/.agents/plugins/marketplace.json +0 -20
  23. package/.github/workflows/ci.yml +0 -30
  24. package/docs/methodology/re-derivation-rate.md +0 -112
  25. package/docs/methodology/useful-hit-rate.md +0 -79
  26. package/docs/plans/2026-05-20-fts5-lexical-recall.md +0 -1088
  27. package/docs/plans/2026-05-20-recall-daemon-wedge-fix.md +0 -662
  28. package/docs/plans/2026-05-20-recall-hook-design.md +0 -131
  29. package/docs/plans/2026-05-20-recall-hook-implementation.md +0 -1222
  30. package/docs/plans/desktop-product.md +0 -69
  31. package/docs/plans/factstore-design.md +0 -236
  32. package/logs/CHANGELOG/CHANGELOG-2026.md +0 -1575
  33. package/logs/CHANGELOG/CHANGELOG.md +0 -209
  34. package/migrations/000_initial_schema.sql +0 -174
  35. package/migrations/001_entity_type_rename.sql +0 -17
  36. package/migrations/002_adapter_state_extend.sql +0 -12
  37. package/migrations/003_session_embeddings.sql +0 -11
  38. package/migrations/004_facts.sql +0 -46
  39. package/migrations/005_sources.sql +0 -31
  40. package/migrations/006_providers.sql +0 -33
  41. package/migrations/007_source_tokens.sql +0 -17
  42. package/migrations/008_fts_rebuild.sql +0 -9
  43. package/migrations/009_session_embedding_chunks.sql +0 -46
  44. package/migrations/010_sources_opencode.sql +0 -30
  45. package/migrations/011_sources_hermes_agent.sql +0 -30
  46. package/migrations/012_sources_aider.sql +0 -30
  47. package/migrations/013_adapter_state_failure_count.sql +0 -12
  48. package/migrations/014_sources_cursor.sql +0 -30
  49. package/migrations/015_sources_windsurf.sql +0 -30
  50. package/plugin-hermes-agent/README.md +0 -49
  51. package/plugin-hermes-agent/__init__.py +0 -75
  52. package/plugin-hermes-agent/plugin.yaml +0 -15
  53. package/scripts/backfill-citations.mjs +0 -0
  54. package/scripts/build-codex-plugin.mjs +0 -61
  55. package/scripts/deepseek-probe.mjs +0 -67
  56. package/scripts/extract-triples.mjs +0 -207
  57. package/scripts/longmemeval/embedding-cache.ts +0 -77
  58. package/scripts/longmemeval/fetch-dataset.sh +0 -25
  59. package/scripts/longmemeval/run-harness.ts +0 -315
  60. package/scripts/longmemeval/scorer.ts +0 -99
  61. package/scripts/longmemeval/tsconfig.json +0 -9
  62. package/scripts/longmemeval/types.ts +0 -35
  63. package/scripts/nlm-daily-digest.py +0 -239
  64. package/scripts/nlm-daily-digest.sh +0 -28
  65. package/src/cli/classify-parity.ts +0 -257
  66. package/src/cli/launchctl-helpers.ts +0 -49
  67. package/src/cli/nlm.ts +0 -1078
  68. package/src/core/actions/actions-log.ts +0 -118
  69. package/src/core/actions/overlay.ts +0 -117
  70. package/src/core/adapters/aider.ts +0 -205
  71. package/src/core/adapters/claude-code.ts +0 -293
  72. package/src/core/adapters/common.ts +0 -54
  73. package/src/core/adapters/cursor.ts +0 -486
  74. package/src/core/adapters/from-source.ts +0 -67
  75. package/src/core/adapters/hermes-agent.ts +0 -240
  76. package/src/core/adapters/hermes.ts +0 -277
  77. package/src/core/adapters/jsonl-generic.ts +0 -208
  78. package/src/core/adapters/opencode.ts +0 -281
  79. package/src/core/adapters/pi.ts +0 -264
  80. package/src/core/adapters/windsurf.ts +0 -386
  81. package/src/core/classifier/prompt.ts +0 -200
  82. package/src/core/dataset/build-dataset.ts +0 -463
  83. package/src/core/embedding/chunk-body.ts +0 -76
  84. package/src/core/embedding/embed-backfill.ts +0 -210
  85. package/src/core/embedding/embed-normalize.ts +0 -135
  86. package/src/core/facts/backfill-facts.ts +0 -254
  87. package/src/core/facts/extract-facts.ts +0 -50
  88. package/src/core/hook/citation-detect.ts +0 -124
  89. package/src/core/hook/cite-memo.ts +0 -68
  90. package/src/core/hook/claude-settings.ts +0 -187
  91. package/src/core/hook/gate.ts +0 -25
  92. package/src/core/hook/hook-log.ts +0 -41
  93. package/src/core/hook/memo-sweep.ts +0 -164
  94. package/src/core/hook/memo.ts +0 -67
  95. package/src/core/hook/pointer-block.ts +0 -26
  96. package/src/core/hook/select.ts +0 -32
  97. package/src/core/hook/transcript.ts +0 -121
  98. package/src/core/ingest/ingest-session.ts +0 -111
  99. package/src/core/providers/provider-models.ts +0 -100
  100. package/src/core/providers/provider-registry.ts +0 -196
  101. package/src/core/recall/citation-log.ts +0 -108
  102. package/src/core/recall/filter.ts +0 -27
  103. package/src/core/recall/index.ts +0 -6
  104. package/src/core/recall/match-fields.ts +0 -40
  105. package/src/core/recall/query-log.ts +0 -149
  106. package/src/core/recall/query-shape.ts +0 -66
  107. package/src/core/recall/recall-service.ts +0 -320
  108. package/src/core/recall/recent-log.ts +0 -59
  109. package/src/core/recall/tokenize.ts +0 -18
  110. package/src/core/recall/useful-scan.ts +0 -336
  111. package/src/core/recall-facts/fact-query-log.ts +0 -150
  112. package/src/core/recall-facts/fact-recall-service.ts +0 -327
  113. package/src/core/scheduler/scan-once.ts +0 -142
  114. package/src/core/scheduler/scheduler.ts +0 -225
  115. package/src/core/sources/source-registry.ts +0 -278
  116. package/src/core/storage/db-restore.ts +0 -133
  117. package/src/core/storage/live-status.ts +0 -45
  118. package/src/core/storage/migrate.ts +0 -72
  119. package/src/core/storage/sqlite-fact-store.ts +0 -304
  120. package/src/core/storage/sqlite-session-store.ts +0 -810
  121. package/src/hook/hook-auth.ts +0 -18
  122. package/src/hook/prompt-recall-hook.ts +0 -180
  123. package/src/hook/session-end-hook.ts +0 -81
  124. package/src/hook/session-start-hook.ts +0 -168
  125. package/src/hook/stop-hook.ts +0 -239
  126. package/src/http/app.ts +0 -1215
  127. package/src/install/claude-code.ts +0 -128
  128. package/src/install/codex.ts +0 -367
  129. package/src/install/cursor.ts +0 -68
  130. package/src/install/hermes-agent.ts +0 -76
  131. package/src/install/hermes.ts +0 -78
  132. package/src/install/nlm-dir-perms.ts +0 -55
  133. package/src/install/ollama.ts +0 -284
  134. package/src/install/setup.ts +0 -489
  135. package/src/install/windsurf.ts +0 -68
  136. package/src/llm/classifier-box.ts +0 -64
  137. package/src/llm/deepseek-client.ts +0 -150
  138. package/src/llm/env-autoload.ts +0 -55
  139. package/src/llm/ollama-client.ts +0 -189
  140. package/src/mcp/server.ts +0 -534
  141. package/src/ports/fact-store.ts +0 -102
  142. package/src/ports/llm-client.ts +0 -52
  143. package/src/ports/logger.ts +0 -16
  144. package/src/ports/session-store.ts +0 -45
  145. package/src/ports/transcript-adapter.ts +0 -55
  146. package/src/shared/types.ts +0 -149
  147. package/src/ui/App.tsx +0 -58
  148. package/src/ui/components/PromoteOpenButton.tsx +0 -65
  149. package/src/ui/components/SessionDrawer.tsx +0 -199
  150. package/src/ui/components/SideNav.tsx +0 -162
  151. package/src/ui/components/Skeleton.tsx +0 -107
  152. package/src/ui/index.html +0 -13
  153. package/src/ui/lib/actions.ts +0 -30
  154. package/src/ui/lib/api.ts +0 -92
  155. package/src/ui/lib/dataset.ts +0 -141
  156. package/src/ui/lib/registries.ts +0 -155
  157. package/src/ui/lib/view-settings.ts +0 -41
  158. package/src/ui/main.tsx +0 -15
  159. package/src/ui/pages/Live.tsx +0 -229
  160. package/src/ui/pages/Pulse.tsx +0 -415
  161. package/src/ui/pages/Recall.tsx +0 -190
  162. package/src/ui/pages/River.tsx +0 -354
  163. package/src/ui/pages/Search.tsx +0 -386
  164. package/src/ui/pages/Stub.tsx +0 -9
  165. package/src/ui/pages/Thread.tsx +0 -473
  166. package/src/ui/pages/settings/Classifier.tsx +0 -227
  167. package/src/ui/pages/settings/Data.tsx +0 -190
  168. package/src/ui/pages/settings/Index.tsx +0 -65
  169. package/src/ui/pages/settings/Labels.tsx +0 -224
  170. package/src/ui/pages/settings/Providers.tsx +0 -305
  171. package/src/ui/pages/settings/SettingsSubnav.tsx +0 -28
  172. package/src/ui/pages/settings/Sources.tsx +0 -326
  173. package/src/ui/pages/settings/Views.tsx +0 -96
  174. package/src/ui/styles.css +0 -1890
  175. package/src/ui/tsconfig.json +0 -21
  176. package/src/ui/vite.config.ts +0 -19
  177. package/tests/fixtures/claude_code/short_session.jsonl +0 -2
  178. package/tests/fixtures/claude_code/standard_iso.jsonl +0 -4
  179. package/tests/fixtures/claude_code/tool_heavy.jsonl +0 -8
  180. package/tests/fixtures/claude_code/with_subagent.jsonl +0 -7
  181. package/tests/fixtures/facts.ts +0 -17
  182. package/tests/fixtures/golden-corpus.ts +0 -85
  183. package/tests/fixtures/hermes/paired_request_dump.json +0 -24
  184. package/tests/fixtures/hermes/paired_session.json +0 -23
  185. package/tests/fixtures/hermes/request_dump.json +0 -28
  186. package/tests/fixtures/hermes/session_iso.json +0 -38
  187. package/tests/fixtures/hermes/session_unix.json +0 -38
  188. package/tests/fixtures/hermes/system_only.json +0 -18
  189. package/tests/fixtures/pi/error-connection-abort.jsonl +0 -8
  190. package/tests/fixtures/pi/short-successful.jsonl +0 -5
  191. package/tests/fixtures/pi/with-custom-message.jsonl +0 -6
  192. package/tests/fixtures/sessions.ts +0 -22
  193. package/tests/integration/backfill-facts.test.ts +0 -362
  194. package/tests/integration/citation-explicit.test.ts +0 -111
  195. package/tests/integration/cite-event.test.ts +0 -169
  196. package/tests/integration/cite-memo.test.ts +0 -87
  197. package/tests/integration/db-restore.test.ts +0 -153
  198. package/tests/integration/embed-backfill.test.ts +0 -176
  199. package/tests/integration/fact-supersedence.test.ts +0 -313
  200. package/tests/integration/fts-index.test.ts +0 -60
  201. package/tests/integration/getbyids-sqlite.test.ts +0 -100
  202. package/tests/integration/hermes-agent-hooks.test.ts +0 -248
  203. package/tests/integration/hook-claude-settings.test.ts +0 -218
  204. package/tests/integration/hook-log.test.ts +0 -54
  205. package/tests/integration/hook-memo.test.ts +0 -68
  206. package/tests/integration/hook-pre-compact.test.ts +0 -105
  207. package/tests/integration/hook-subagent-start.test.ts +0 -102
  208. package/tests/integration/http.test.ts +0 -401
  209. package/tests/integration/keyword-search-fts.test.ts +0 -66
  210. package/tests/integration/mcp-recall-logging.test.ts +0 -88
  211. package/tests/integration/mcp.test.ts +0 -260
  212. package/tests/integration/memo-sweep.test.ts +0 -91
  213. package/tests/integration/prompt-recall-hook.test.ts +0 -88
  214. package/tests/integration/provider-registry.test.ts +0 -107
  215. package/tests/integration/recall-golden.test.ts +0 -59
  216. package/tests/integration/recall-sqlite.test.ts +0 -169
  217. package/tests/integration/scheduler.test.ts +0 -391
  218. package/tests/integration/session-end-hook.test.ts +0 -48
  219. package/tests/integration/session-start-hook.test.ts +0 -126
  220. package/tests/integration/source-registry.test.ts +0 -122
  221. package/tests/integration/sqlite-fact-store.test.ts +0 -346
  222. package/tests/integration/stop-hook.test.ts +0 -560
  223. package/tests/integration/wal-checkpoint.test.ts +0 -49
  224. package/tests/unit/cli/launchctl-helpers.test.ts +0 -60
  225. package/tests/unit/core/adapters/aider.test.ts +0 -230
  226. package/tests/unit/core/adapters/claude-code.test.ts +0 -118
  227. package/tests/unit/core/adapters/cursor.test.ts +0 -485
  228. package/tests/unit/core/adapters/hermes-agent.test.ts +0 -329
  229. package/tests/unit/core/adapters/hermes.test.ts +0 -81
  230. package/tests/unit/core/adapters/jsonl-generic.test.ts +0 -142
  231. package/tests/unit/core/adapters/opencode.test.ts +0 -354
  232. package/tests/unit/core/adapters/pi.test.ts +0 -110
  233. package/tests/unit/core/adapters/windsurf.test.ts +0 -416
  234. package/tests/unit/core/classifier/prompt.test.ts +0 -126
  235. package/tests/unit/core/embedding/chunk-body.test.ts +0 -100
  236. package/tests/unit/core/facts/extract-facts.test.ts +0 -117
  237. package/tests/unit/core/filter.test.ts +0 -40
  238. package/tests/unit/core/hook/citation-detect-cite-session.test.ts +0 -96
  239. package/tests/unit/core/hook/citation-detect.test.ts +0 -124
  240. package/tests/unit/core/hook/gate.test.ts +0 -29
  241. package/tests/unit/core/hook/pointer-block.test.ts +0 -22
  242. package/tests/unit/core/hook/select.test.ts +0 -66
  243. package/tests/unit/core/match-fields.test.ts +0 -39
  244. package/tests/unit/core/mcp-cite-session.test.ts +0 -51
  245. package/tests/unit/core/providers/provider-models.test.ts +0 -101
  246. package/tests/unit/core/query-shape.test.ts +0 -92
  247. package/tests/unit/core/recall-facts/fact-recall-service.test.ts +0 -258
  248. package/tests/unit/core/recall-service.test.ts +0 -200
  249. package/tests/unit/core/storage/live-status.test.ts +0 -54
  250. package/tests/unit/core/tokenize.test.ts +0 -32
  251. package/tests/unit/core/useful-scan.test.ts +0 -537
  252. package/tests/unit/llm/embed.test.ts +0 -93
  253. package/tests/unit/llm/ollama-client.test.ts +0 -124
  254. package/tests/unit/scripts/longmemeval-scorer.test.ts +0 -114
  255. package/tsconfig.json +0 -31
  256. package/tsconfig.test.json +0 -11
  257. package/vitest.config.ts +0 -22
@@ -1,21 +0,0 @@
1
- {
2
- "compilerOptions": {
3
- "target": "ES2022",
4
- "lib": ["ES2022", "DOM", "DOM.Iterable"],
5
- "module": "ESNext",
6
- "moduleResolution": "Bundler",
7
- "jsx": "react-jsx",
8
- "strict": true,
9
- "noUncheckedIndexedAccess": true,
10
- "exactOptionalPropertyTypes": true,
11
- "noImplicitOverride": true,
12
- "esModuleInterop": true,
13
- "skipLibCheck": true,
14
- "resolveJsonModule": true,
15
- "isolatedModules": true,
16
- "verbatimModuleSyntax": true,
17
- "allowImportingTsExtensions": false,
18
- "noEmit": true
19
- },
20
- "include": ["**/*.ts", "**/*.tsx"]
21
- }
@@ -1,19 +0,0 @@
1
- import { defineConfig } from "vite";
2
- import react from "@vitejs/plugin-react";
3
- import { fileURLToPath } from "node:url";
4
-
5
- export default defineConfig({
6
- root: fileURLToPath(new URL(".", import.meta.url)),
7
- base: "/ui/",
8
- build: {
9
- outDir: fileURLToPath(new URL("../../dist/ui", import.meta.url)),
10
- emptyOutDir: true,
11
- },
12
- server: {
13
- port: 5173,
14
- proxy: {
15
- "/api": "http://localhost:3940",
16
- },
17
- },
18
- plugins: [react()],
19
- });
@@ -1,2 +0,0 @@
1
- {"parentUuid":null,"isSidechain":false,"promptId":"prompt-001","type":"user","message":{"role":"user","content":"What is the difference between a list and a tuple in Python?"},"uuid":"evt-010","timestamp":"2026-04-01T09:00:00.000Z","permissionMode":"auto","userType":"human","entrypoint":"cli","cwd":"/home/synth/scratch","sessionId":"session-bbb-002","version":"1.0","gitBranch":""}
2
- {"parentUuid":"evt-010","isSidechain":false,"promptId":"prompt-001","type":"assistant","message":{"role":"assistant","content":"Lists are mutable sequences; tuples are immutable. Use a list when you need to append or modify items, a tuple when the collection is fixed (e.g. coordinates, RGB values). Tuples are slightly faster to iterate and can be used as dict keys."},"uuid":"evt-011","timestamp":"2026-04-01T09:01:45.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/scratch","sessionId":"session-bbb-002","version":"1.0","gitBranch":""}
@@ -1,4 +0,0 @@
1
- {"parentUuid":null,"isSidechain":false,"promptId":"prompt-001","type":"user","message":{"role":"user","content":"Hello, can you help me set up the Widget Project?"},"uuid":"evt-001","timestamp":"2026-03-10T10:00:00.000Z","permissionMode":"auto","userType":"human","entrypoint":"cli","cwd":"/home/synth/projects/widget-project","sessionId":"session-aaa-001","version":"1.0","gitBranch":"main"}
2
- {"parentUuid":"evt-001","isSidechain":false,"promptId":"prompt-001","type":"assistant","message":{"role":"assistant","content":"Sure! To set up the Widget Project, you will need to configure the repository first. What stack are you using?"},"uuid":"evt-002","timestamp":"2026-03-10T10:01:00.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/widget-project","sessionId":"session-aaa-001","version":"1.0","gitBranch":"main"}
3
- {"parentUuid":"evt-002","isSidechain":false,"promptId":"prompt-002","type":"user","message":{"role":"user","content":"We are using Python with a FastAPI backend and a React frontend."},"uuid":"evt-003","timestamp":"2026-03-10T10:02:00.000Z","permissionMode":"auto","userType":"human","entrypoint":"cli","cwd":"/home/synth/projects/widget-project","sessionId":"session-aaa-001","version":"1.0","gitBranch":"main"}
4
- {"parentUuid":"evt-003","isSidechain":false,"promptId":"prompt-002","type":"assistant","message":{"role":"assistant","content":"Great choice. Here is a basic project layout for a FastAPI plus React monorepo: keep backend in `api/`, frontend in `web/`, and shared types in `shared/`. Want me to scaffold the directory structure?"},"uuid":"evt-004","timestamp":"2026-03-10T10:03:30.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/widget-project","sessionId":"session-aaa-001","version":"1.0","gitBranch":"main"}
@@ -1,8 +0,0 @@
1
- {"parentUuid":null,"isSidechain":false,"promptId":"prompt-001","type":"user","message":{"role":"user","content":"Read the file config.yaml and summarize it for me."},"uuid":"evt-020","timestamp":"2026-04-05T14:00:00.000Z","permissionMode":"auto","userType":"human","entrypoint":"cli","cwd":"/home/synth/projects/acme-config","sessionId":"session-ccc-003","version":"1.0","gitBranch":"feature/refactor"}
2
- {"parentUuid":"evt-020","isSidechain":false,"promptId":"prompt-001","type":"assistant","message":{"role":"assistant","content":[{"type":"text","text":"Let me read that file for you."},{"type":"tool_use","id":"tool-001","name":"ExampleReadFile","input":{"path":"config.yaml"}}]},"uuid":"evt-021","timestamp":"2026-04-05T14:00:05.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/acme-config","sessionId":"session-ccc-003","version":"1.0","gitBranch":"feature/refactor"}
3
- {"parentUuid":"evt-021","isSidechain":false,"promptId":"prompt-001","type":"user","message":{"role":"user","content":[{"type":"tool_result","tool_use_id":"tool-001","content":"database:\n host: db.example.internal\n port: 5432\n name: widget_db\napp:\n debug: false\n workers: 4\n"}]},"uuid":"evt-022","timestamp":"2026-04-05T14:00:06.000Z","permissionMode":"auto","userType":"tool","entrypoint":"cli","cwd":"/home/synth/projects/acme-config","sessionId":"session-ccc-003","version":"1.0","gitBranch":"feature/refactor"}
4
- {"parentUuid":"evt-022","isSidechain":false,"promptId":"prompt-001","type":"assistant","message":{"role":"assistant","content":[{"type":"text","text":"The config file sets up a PostgreSQL database at `db.example.internal:5432` (database: widget_db) and configures the app with debug mode off and 4 worker processes."}]},"uuid":"evt-023","timestamp":"2026-04-05T14:00:10.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/acme-config","sessionId":"session-ccc-003","version":"1.0","gitBranch":"feature/refactor"}
5
- {"parentUuid":"evt-023","isSidechain":false,"promptId":"prompt-002","type":"user","message":{"role":"user","content":"Now check if port 5432 is listed in the firewall rules file firewall.txt"},"uuid":"evt-024","timestamp":"2026-04-05T14:01:00.000Z","permissionMode":"auto","userType":"human","entrypoint":"cli","cwd":"/home/synth/projects/acme-config","sessionId":"session-ccc-003","version":"1.0","gitBranch":"feature/refactor"}
6
- {"parentUuid":"evt-024","isSidechain":false,"promptId":"prompt-002","type":"assistant","message":{"role":"assistant","content":[{"type":"text","text":"Checking the firewall rules now."},{"type":"tool_use","id":"tool-002","name":"ExampleBashRun","input":{"command":"grep 5432 firewall.txt"}}]},"uuid":"evt-025","timestamp":"2026-04-05T14:01:05.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/acme-config","sessionId":"session-ccc-003","version":"1.0","gitBranch":"feature/refactor"}
7
- {"parentUuid":"evt-025","isSidechain":false,"promptId":"prompt-002","type":"user","message":{"role":"user","content":[{"type":"tool_result","tool_use_id":"tool-002","content":"ALLOW tcp 5432 from 10.0.0.0/8\n"}]},"uuid":"evt-026","timestamp":"2026-04-05T14:01:06.000Z","permissionMode":"auto","userType":"tool","entrypoint":"cli","cwd":"/home/synth/projects/acme-config","sessionId":"session-ccc-003","version":"1.0","gitBranch":"feature/refactor"}
8
- {"parentUuid":"evt-026","isSidechain":false,"promptId":"prompt-002","type":"assistant","message":{"role":"assistant","content":[{"type":"text","text":"Port 5432 is allowed from the internal 10.0.0.0/8 subnet, so the database should be reachable from within your private network."}]},"uuid":"evt-027","timestamp":"2026-04-05T14:01:15.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/acme-config","sessionId":"session-ccc-003","version":"1.0","gitBranch":"feature/refactor"}
@@ -1,7 +0,0 @@
1
- {"parentUuid":null,"isSidechain":false,"promptId":"prompt-001","type":"user","message":{"role":"user","content":"Dispatch a subagent to draft a project summary for the Acme initiative."},"uuid":"evt-030","timestamp":"2026-04-10T11:00:00.000Z","permissionMode":"auto","userType":"human","entrypoint":"cli","cwd":"/home/synth/projects/acme-initiative","sessionId":"session-ddd-004","version":"1.0","gitBranch":"main"}
2
- {"parentUuid":"evt-030","isSidechain":false,"promptId":"prompt-001","type":"assistant","message":{"role":"assistant","content":"I will spin up a subagent to draft the summary. One moment."},"uuid":"evt-031","timestamp":"2026-04-10T11:00:05.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/acme-initiative","sessionId":"session-ddd-004","version":"1.0","gitBranch":"main"}
3
- {"parentUuid":"evt-031","isSidechain":true,"promptId":"sub-prompt-001","type":"user","message":{"role":"user","content":"Draft a two-paragraph project summary for the Acme initiative. Focus on goals and expected outcomes."},"uuid":"evt-032","timestamp":"2026-04-10T11:00:10.000Z","permissionMode":"auto","userType":"human","entrypoint":"cli","cwd":"/home/synth/projects/acme-initiative","sessionId":"session-ddd-004","version":"1.0","gitBranch":"main"}
4
- {"parentUuid":"evt-032","isSidechain":true,"promptId":"sub-prompt-001","type":"assistant","message":{"role":"assistant","content":"The Acme Initiative aims to streamline order processing for mid-market clients by introducing an automated pipeline that reduces manual intervention by 60 percent.\n\nExpected outcomes include a reduction in fulfillment time from five days to two days and a measurable improvement in client satisfaction scores, with a target NPS increase of 15 points over the next two quarters."},"uuid":"evt-033","timestamp":"2026-04-10T11:00:30.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/acme-initiative","sessionId":"session-ddd-004","version":"1.0","gitBranch":"main"}
5
- {"parentUuid":"evt-031","isSidechain":false,"promptId":"prompt-001","type":"assistant","message":{"role":"assistant","content":"The subagent has finished. Here is the draft summary it produced:\n\n> The Acme Initiative aims to streamline order processing for mid-market clients by introducing an automated pipeline that reduces manual intervention by 60 percent.\n\n> Expected outcomes include a reduction in fulfillment time from five days to two days and a measurable improvement in client satisfaction scores."},"uuid":"evt-034","timestamp":"2026-04-10T11:00:35.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/acme-initiative","sessionId":"session-ddd-004","version":"1.0","gitBranch":"main"}
6
- {"parentUuid":"evt-034","isSidechain":false,"promptId":"prompt-002","type":"user","message":{"role":"user","content":"Looks good. Please save that to acme-summary.md"},"uuid":"evt-035","timestamp":"2026-04-10T11:01:00.000Z","permissionMode":"auto","userType":"human","entrypoint":"cli","cwd":"/home/synth/projects/acme-initiative","sessionId":"session-ddd-004","version":"1.0","gitBranch":"main"}
7
- {"parentUuid":"evt-035","isSidechain":false,"promptId":"prompt-002","type":"assistant","message":{"role":"assistant","content":"Done. The summary has been written to acme-summary.md in the project root."},"uuid":"evt-036","timestamp":"2026-04-10T11:01:10.000Z","permissionMode":"auto","userType":"assistant","entrypoint":"cli","cwd":"/home/synth/projects/acme-initiative","sessionId":"session-ddd-004","version":"1.0","gitBranch":"main"}
@@ -1,17 +0,0 @@
1
- import type { Fact } from "../../src/shared/types.js";
2
-
3
- export function makeFact(overrides: Partial<Fact> = {}): Fact {
4
- const base: Fact = {
5
- id: "fact_test_1",
6
- kind: "decision",
7
- subject: "nlm-memory-ts",
8
- predicate: "framework",
9
- value: "Hono",
10
- sourceSessionId: "cc_test_1",
11
- sourceQuote: null,
12
- createdAt: "2026-05-19T10:30:00Z",
13
- supersededBy: null,
14
- confidence: 0.9,
15
- };
16
- return { ...base, ...overrides };
17
- }
@@ -1,85 +0,0 @@
1
- import type { Session } from "../../src/shared/types.js";
2
- import { makeSession } from "./sessions.js";
3
-
4
- /**
5
- * A fixed, realistic corpus for recall-quality regression testing.
6
- * `body` is populated on every session because FTS5 keyword search indexes
7
- * label + summary + body. Decision/open text is also present in `body`
8
- * (mirrors production: markers are extracted from the body markdown).
9
- */
10
- export const GOLDEN_CORPUS: ReadonlyArray<Session> = [
11
- makeSession({
12
- id: "g_fts",
13
- label: "FTS5 vs pgvector for recall search backend",
14
- summary: "Compared SQLite FTS5 lexical search against pgvector for the recall layer",
15
- body: "Evaluated FTS5 versus pgvector. FTS5 ships with SQLite and stays zero-config. pgvector needs Postgres running which breaks the five-minute install.",
16
- decisions: ["Use FTS5 for the lexical recall leg"],
17
- entities: ["NLM"],
18
- }),
19
- makeSession({
20
- id: "g_hono",
21
- label: "Hono router setup on port 3940",
22
- summary: "Wired the Hono HTTP router and mounted the recall API",
23
- body: "Set up Hono as the HTTP framework. Mounted routes for recall, sessions, and the live dashboard on port 3940.",
24
- decisions: ["Chose Hono over Express for HTTP routing"],
25
- entities: ["NLM"],
26
- }),
27
- makeSession({
28
- id: "g_pgvector",
29
- label: "pgvector migration plan for the power tier",
30
- summary: "Sketched the Postgres mirror behind the SessionStore port",
31
- body: "Planned a PostgresSessionStore satisfying the same port as SqliteSessionStore. pgvector handles the vector index for users already running Postgres.",
32
- open: ["Timing of the SQLite to Postgres cutover"],
33
- entities: ["NLM", "Postgres"],
34
- }),
35
- makeSession({
36
- id: "g_tauri",
37
- label: "Tauri desktop packaging for v2 distribution",
38
- summary: "Plan to wrap the server and SPA in Tauri for signed installers",
39
- body: "Tauri hosts the Vite SPA in a webview and runs the Node server as a sidecar. Produces dmg, exe, and deb installers.",
40
- open: ["Whether to rewrite the server in Rust later"],
41
- entities: ["NLM"],
42
- }),
43
- makeSession({
44
- id: "g_classifier",
45
- label: "Ollama classifier latency during backfill",
46
- summary: "The Ollama classifier runs about one session per second",
47
- body: "Backfilling a year of history is slow because the Ollama classifier processes roughly one session per second. Considered parallelizing the calls.",
48
- open: ["Parallelize classifier calls or document the DeepSeek path"],
49
- entities: ["NLM", "Ollama"],
50
- }),
51
- makeSession({
52
- id: "g_supersede",
53
- label: "Fact supersedence policy on subject predicate collision",
54
- summary: "Deterministic supersedence when a newer fact collides with an older one",
55
- body: "When a new fact shares the same subject and predicate as a current fact, the older row is marked superseded by the new one. Always supersede, even on same value.",
56
- decisions: ["Always supersede on subject predicate collision"],
57
- entities: ["NLM"],
58
- }),
59
- makeSession({
60
- id: "g_toon",
61
- label: "TOON encoding for MCP tool responses",
62
- summary: "Encode MCP responses as TOON to cut token usage",
63
- body: "The MCP server encodes tool responses as TOON when NLM_FORMAT is set to toon. Falls back to JSON when toonEncode throws.",
64
- decisions: ["TOON-encode MCP responses behind the NLM_FORMAT env flag"],
65
- entities: ["NLM"],
66
- }),
67
- makeSession({
68
- id: "g_camofox",
69
- label: "Camofox audit of the search page",
70
- summary: "Ran a Camofox browser audit against the recall search UI",
71
- body: "Camofox audit found the search page returned zero results because the static build ignored query strings. Fixed with client-side hydration.",
72
- open: ["Should entity facet links filter within search"],
73
- entities: ["NLM", "Camofox"],
74
- }),
75
- ];
76
-
77
- /** query → session id expected to appear in the top 3 keyword results. */
78
- export const GOLDEN_QUERIES: ReadonlyArray<{ query: string; expectTop3: string }> = [
79
- { query: "FTS5 pgvector search backend", expectTop3: "g_fts" },
80
- { query: "Hono router", expectTop3: "g_hono" },
81
- { query: "Tauri packaging installers", expectTop3: "g_tauri" },
82
- { query: "Ollama classifier latency", expectTop3: "g_classifier" },
83
- { query: "fact supersedence collision", expectTop3: "g_supersede" },
84
- { query: "TOON encoding MCP", expectTop3: "g_toon" },
85
- ];
@@ -1,24 +0,0 @@
1
- {
2
- "timestamp": "2026-04-15T08:00:30+00:00",
3
- "session_id": "synthetic-test-001",
4
- "reason": "request_captured",
5
- "request": {
6
- "url": "http://localhost:11434/api/chat",
7
- "method": "POST",
8
- "body": {
9
- "model": "synthetic-model-v1",
10
- "messages": [
11
- {
12
- "role": "system",
13
- "content": "You are a helpful assistant."
14
- },
15
- {
16
- "role": "user",
17
- "content": "Summarize the key benefits of containerisation for deployment."
18
- }
19
- ],
20
- "stream": false
21
- }
22
- },
23
- "error": null
24
- }
@@ -1,23 +0,0 @@
1
- {
2
- "session_id": "synthetic-test-001",
3
- "model": "synthetic-model-v1",
4
- "base_url": "http://localhost:11434",
5
- "platform": "ollama",
6
- "session_start": "2026-04-15T08:00:00+00:00",
7
- "last_updated": "2026-04-15T08:10:00+00:00",
8
- "system_prompt": "You are a helpful assistant.",
9
- "tools": [],
10
- "message_count": 2,
11
- "messages": [
12
- {
13
- "role": "user",
14
- "content": "Summarize the key benefits of containerisation for deployment.",
15
- "timestamp": "2026-04-15T08:01:00+00:00"
16
- },
17
- {
18
- "role": "assistant",
19
- "content": "Containerisation provides environment consistency across dev, staging, and production; fast startup times compared to virtual machines; efficient resource utilisation via process-level isolation; and simplified dependency management through images.",
20
- "timestamp": "2026-04-15T08:10:00+00:00"
21
- }
22
- ]
23
- }
@@ -1,28 +0,0 @@
1
- {
2
- "timestamp": "2026-04-05T14:30:00+00:00",
3
- "session_id": "20260405_143000_ghi789",
4
- "reason": "request_captured",
5
- "request": {
6
- "url": "http://localhost:11434/api/chat",
7
- "method": "POST",
8
- "body": {
9
- "model": "synthetic-model-v1",
10
- "messages": [
11
- {
12
- "role": "system",
13
- "content": "You are an assistant helping with data analysis."
14
- },
15
- {
16
- "role": "user",
17
- "content": "What is the median of the following numbers: 3, 7, 2, 9, 5?"
18
- },
19
- {
20
- "role": "assistant",
21
- "content": "Sort the values: 2, 3, 5, 7, 9. The median (middle value of five elements) is 5."
22
- }
23
- ],
24
- "stream": false
25
- }
26
- },
27
- "error": null
28
- }
@@ -1,38 +0,0 @@
1
- {
2
- "session_id": "20260310_100000_abc123",
3
- "model": "synthetic-model-v1",
4
- "base_url": "http://localhost:11434",
5
- "platform": "ollama",
6
- "session_start": "2026-03-10T10:00:00+00:00",
7
- "last_updated": "2026-03-10T10:05:30+00:00",
8
- "system_prompt": "You are a helpful assistant for the Widget Project team.",
9
- "tools": [],
10
- "message_count": 4,
11
- "messages": [
12
- {
13
- "role": "system",
14
- "content": "You are a helpful assistant for the Widget Project team.",
15
- "timestamp": "2026-03-10T10:00:00+00:00"
16
- },
17
- {
18
- "role": "user",
19
- "content": "What is the recommended way to structure environment variables in a Python project?",
20
- "timestamp": "2026-03-10T10:01:00+00:00"
21
- },
22
- {
23
- "role": "assistant",
24
- "content": "The recommended approach is to use a `.env` file at the project root and load it with `python-dotenv`. Keep secrets out of version control by adding `.env` to `.gitignore`. Provide a `.env.example` with placeholder values for new developers.",
25
- "timestamp": "2026-03-10T10:02:45+00:00"
26
- },
27
- {
28
- "role": "user",
29
- "content": "Should we use a secrets manager in production instead?",
30
- "timestamp": "2026-03-10T10:04:00+00:00"
31
- },
32
- {
33
- "role": "assistant",
34
- "content": "Yes. In production, prefer a secrets manager such as AWS Secrets Manager, HashiCorp Vault, or your cloud provider's equivalent. `.env` files are fine for local development but should never reach a production host.",
35
- "timestamp": "2026-03-10T10:05:30+00:00"
36
- }
37
- ]
38
- }
@@ -1,38 +0,0 @@
1
- {
2
- "session_id": "20260401_090000_def456",
3
- "model": "synthetic-model-v1",
4
- "base_url": "http://localhost:11434",
5
- "platform": "ollama",
6
- "session_start": "2026-04-01T09:00:00+00:00",
7
- "last_updated": "2026-04-01T09:08:00+00:00",
8
- "system_prompt": "You are a helpful coding assistant.",
9
- "tools": [],
10
- "message_count": 3,
11
- "messages": [
12
- {
13
- "role": "system",
14
- "content": "You are a helpful coding assistant.",
15
- "timestamp": 1743498000
16
- },
17
- {
18
- "role": "user",
19
- "content": "How do I parse command-line arguments in Python?",
20
- "timestamp": 1743498060
21
- },
22
- {
23
- "role": "assistant",
24
- "content": "Use the built-in `argparse` module. Create an `ArgumentParser`, add arguments with `add_argument()`, and call `parse_args()`. For more complex CLIs consider `click` or `typer`.",
25
- "timestamp": 1743498300
26
- },
27
- {
28
- "role": "user",
29
- "content": "Give me a minimal argparse example.",
30
- "timestamp": 1743498360
31
- },
32
- {
33
- "role": "assistant",
34
- "content": "Here is a minimal example:\n\n```python\nimport argparse\n\nparser = argparse.ArgumentParser(description='A synthetic CLI demo')\nparser.add_argument('--name', type=str, required=True)\nargs = parser.parse_args()\nprint(f'Hello, {args.name}')\n```",
35
- "timestamp": 1743498480
36
- }
37
- ]
38
- }
@@ -1,18 +0,0 @@
1
- {
2
- "session_id": "20260420_120000_jkl000",
3
- "model": "synthetic-model-v1",
4
- "base_url": "http://localhost:11434",
5
- "platform": "ollama",
6
- "session_start": "2026-04-20T12:00:00+00:00",
7
- "last_updated": "2026-04-20T12:00:01+00:00",
8
- "system_prompt": "You are a careful and methodical assistant.",
9
- "tools": [],
10
- "message_count": 1,
11
- "messages": [
12
- {
13
- "role": "system",
14
- "content": "You are a careful and methodical assistant. Always reason step by step before providing your final answer.",
15
- "timestamp": "2026-04-20T12:00:00+00:00"
16
- }
17
- ]
18
- }
@@ -1,8 +0,0 @@
1
- {"type":"session","version":3,"id":"019e3baa-0000-0000-0000-000000000002","timestamp":"2026-05-18T15:17:37.642Z","cwd":"/Users/[REDACTED]/Documents/Coding Projects/pi-sandbox"}
2
- {"type":"model_change","id":"22ab2047","parentId":null,"timestamp":"2026-05-18T15:17:38.029Z","provider":"macpro","modelId":"qwen2.5-3b"}
3
- {"type":"thinking_level_change","id":"dfe53f28","parentId":"22ab2047","timestamp":"2026-05-18T15:17:38.030Z","thinkingLevel":"off"}
4
- {"type":"message","id":"8fa30c6b","parentId":"dfe53f28","timestamp":"2026-05-18T15:17:38.052Z","message":{"role":"user","content":[{"type":"text","text":"What model are you running on? Reply in one short sentence."}],"timestamp":1779117458048}}
5
- {"type":"message","id":"6356b42a","parentId":"8fa30c6b","timestamp":"2026-05-18T15:17:53.900Z","message":{"role":"assistant","content":[],"api":"openai-completions","provider":"macpro","model":"qwen2.5-3b","usage":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"totalTokens":0,"cost":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"total":0}},"stopReason":"error","timestamp":1779117458321,"errorMessage":"Connection error."}}
6
- {"type":"message","id":"76b400ad","parentId":"6356b42a","timestamp":"2026-05-18T15:17:57.512Z","message":{"role":"assistant","content":[],"api":"openai-completions","provider":"macpro","model":"qwen2.5-3b","usage":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"totalTokens":0,"cost":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"total":0}},"stopReason":"error","timestamp":1779117476004,"errorMessage":"Connection error."}}
7
- {"type":"message","id":"859617e5","parentId":"76b400ad","timestamp":"2026-05-18T15:18:03.151Z","message":{"role":"assistant","content":[],"api":"openai-completions","provider":"macpro","model":"qwen2.5-3b","usage":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"totalTokens":0,"cost":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"total":0}},"stopReason":"error","timestamp":1779117481559,"errorMessage":"Connection error."}}
8
- {"type":"message","id":"ce2ef643","parentId":"859617e5","timestamp":"2026-05-18T15:18:13.097Z","message":{"role":"assistant","content":[],"api":"openai-completions","provider":"macpro","model":"qwen2.5-3b","usage":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"totalTokens":0,"cost":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"total":0}},"stopReason":"error","timestamp":1779117481559,"errorMessage":"Connection error."}}
@@ -1,5 +0,0 @@
1
- {"type":"session","version":3,"id":"019e3c80-0000-0000-0000-000000000001","timestamp":"2026-05-18T19:12:20.749Z","cwd":"/private/tmp"}
2
- {"type":"model_change","id":"727bf32b","parentId":null,"timestamp":"2026-05-18T19:12:20.800Z","provider":"macpro","modelId":"qwen3.5-4b"}
3
- {"type":"thinking_level_change","id":"0ff6a420","parentId":"727bf32b","timestamp":"2026-05-18T19:12:20.800Z","thinkingLevel":"off"}
4
- {"type":"message","id":"2ab5d9d4","parentId":"0ff6a420","timestamp":"2026-05-18T19:12:20.803Z","message":{"role":"user","content":[{"type":"text","text":"Say OK"}],"timestamp":1779131540802}}
5
- {"type":"message","id":"a2c2402a","parentId":"2ab5d9d4","timestamp":"2026-05-18T19:13:04.551Z","message":{"role":"assistant","content":[{"type":"text","text":"OK"}],"api":"openai-completions","provider":"macpro","model":"qwen3.5-4b","usage":{"input":415,"output":2,"cacheRead":0,"cacheWrite":0,"totalTokens":417,"cost":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"total":0}},"stopReason":"stop","timestamp":1779131540848,"responseId":"chatcmpl-[REDACTED]"}}
@@ -1,6 +0,0 @@
1
- {"type":"session","version":3,"id":"019e3cab-0000-0000-0000-000000000003","timestamp":"2026-05-18T19:58:58.100Z","cwd":"/private/tmp"}
2
- {"type":"model_change","id":"3d452ec8","parentId":null,"timestamp":"2026-05-18T19:58:58.278Z","provider":"macpro","modelId":"qwen3.5-4b"}
3
- {"type":"thinking_level_change","id":"613b12ed","parentId":"3d452ec8","timestamp":"2026-05-18T19:58:58.278Z","thinkingLevel":"off"}
4
- {"type":"message","id":"c311a9fa","parentId":"613b12ed","timestamp":"2026-05-18T19:58:58.815Z","message":{"role":"user","content":[{"type":"text","text":"Say OK"}],"timestamp":1779134338661}}
5
- {"type":"custom_message","customType":"memory-context","content":"## Memory Context (auto-loaded)\n\nProject: **tmp** | new project | 0 total memories across all projects | 0 personal preferences\n\nUse `memory-save`, `memory-search`, and `memory-get` tools to interact with memory.\n\n**Code not indexed:** Project \"tmp\" has no code index yet. Run `memory-code index-repo --path /private/tmp --name tmp` to enable memory-code analysis.","display":false,"id":"6843374c","parentId":"c311a9fa","timestamp":"2026-05-18T19:58:58.819Z"}
6
- {"type":"message","id":"9dc10468","parentId":"6843374c","timestamp":"2026-05-18T19:59:29.917Z","message":{"role":"assistant","content":[{"type":"text","text":"OK"}],"api":"openai-completions","provider":"macpro","model":"qwen3.5-4b","usage":{"input":515,"output":2,"cacheRead":0,"cacheWrite":0,"totalTokens":517,"cost":{"input":0,"output":0,"cacheRead":0,"cacheWrite":0,"total":0}},"stopReason":"stop","timestamp":1779134338852,"responseId":"chatcmpl-[REDACTED]"}}
@@ -1,22 +0,0 @@
1
- import type { Session } from "../../src/shared/types.js";
2
-
3
- export function makeSession(overrides: Partial<Session> = {}): Session {
4
- const base: Session = {
5
- id: "cc_test_1",
6
- runtime: "claude-code",
7
- runtimeSessionId: "test-1",
8
- startedAt: "2026-05-19T10:00:00Z",
9
- endedAt: "2026-05-19T10:30:00Z",
10
- durationMin: 30,
11
- label: "Untitled session",
12
- summary: "",
13
- status: "closed",
14
- transcriptKind: "claude-code-jsonl",
15
- transcriptPath: null,
16
- body: "",
17
- entities: [],
18
- decisions: [],
19
- open: [],
20
- };
21
- return { ...base, ...overrides };
22
- }