squish-memory 1.1.5 → 1.2.1

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 (646) hide show
  1. package/.env.example +32 -16
  2. package/CHANGELOG.md +147 -0
  3. package/README.md +120 -78
  4. package/{scripts → bin}/dependency-manager.mjs +217 -217
  5. package/{scripts → bin}/detect-clients.mjs +78 -78
  6. package/bin/install-interactive.mjs +321 -0
  7. package/bin/squish-mcp.mjs +44 -0
  8. package/bin/squish.mjs +33 -0
  9. package/config/mcp-migration-map.json +1 -6
  10. package/config/mcp-mode-semantics.json +19 -23
  11. package/config/mcp-remote-auth.json +3 -26
  12. package/config/mcp-universal.schema.json +5 -35
  13. package/config/settings.json +107 -52
  14. package/config.js +5 -0
  15. package/config.ts +218 -0
  16. package/core/adapters/config/claude-code.ts +133 -0
  17. package/core/adapters/config/cursor.ts +90 -0
  18. package/core/adapters/config/opencode.ts +89 -0
  19. package/core/adapters/config/windsurf.ts +90 -0
  20. package/core/adapters/index.ts +102 -0
  21. package/core/adapters/timeline.ts +116 -0
  22. package/core/adapters/types.ts +166 -0
  23. package/core/agent-preferences.ts +140 -0
  24. package/core/algorithms/analytics/token-estimator.ts +216 -0
  25. package/core/algorithms/detection/hash-filters.ts +260 -0
  26. package/core/algorithms/detection/semantic-ranker.ts +194 -0
  27. package/core/algorithms/detection/two-stage-detector.ts +421 -0
  28. package/core/algorithms/handlers/approve-merge.ts +215 -0
  29. package/core/algorithms/handlers/detect-duplicates.ts +192 -0
  30. package/core/algorithms/handlers/get-stats.ts +132 -0
  31. package/core/algorithms/handlers/list-proposals.ts +130 -0
  32. package/core/algorithms/handlers/preview-merge.ts +139 -0
  33. package/core/algorithms/handlers/reject-merge.ts +93 -0
  34. package/core/algorithms/handlers/reverse-merge.ts +155 -0
  35. package/{dist/core/algorithms/index.js → core/algorithms/index.ts} +39 -26
  36. package/core/algorithms/operations/cache-maintenance.ts +182 -0
  37. package/core/algorithms/safety/safety-checks.ts +256 -0
  38. package/core/algorithms/strategies/merge-strategies.ts +381 -0
  39. package/core/algorithms/types.ts +140 -0
  40. package/core/algorithms/utils/response-builder.ts +61 -0
  41. package/core/associations.ts +363 -0
  42. package/core/beliefs/decay.ts +289 -0
  43. package/core/beliefs/extractor.ts +131 -0
  44. package/core/beliefs/store.ts +557 -0
  45. package/core/beliefs/types.ts +38 -0
  46. package/core/commands/mcp-server.ts +5 -0
  47. package/core/compression.ts +177 -0
  48. package/core/config.js +2 -0
  49. package/core/consolidation.ts +330 -0
  50. package/core/context/agent-context.ts +388 -0
  51. package/core/context/context-paging.ts +449 -0
  52. package/core/context/context-window.ts +234 -0
  53. package/core/context/context.ts +35 -0
  54. package/core/embeddings/embeddings.ts +616 -0
  55. package/core/embeddings/google-multimodal.ts +200 -0
  56. package/{dist/core/local-embeddings.js → core/embeddings/local-embeddings.ts} +12 -11
  57. package/core/embeddings/qmd-client.ts +495 -0
  58. package/core/embeddings/transformers-local.ts +261 -0
  59. package/core/embeddings.js +4 -0
  60. package/core/error-handling.ts +206 -0
  61. package/core/external +219 -0
  62. package/core/graph/entity-deduplicator.ts +232 -0
  63. package/core/graph/graph-builder.ts +257 -0
  64. package/core/graph/graph-traversal.ts +490 -0
  65. package/core/graph/index.ts +24 -0
  66. package/core/graph/llm-entity-extractor.ts +402 -0
  67. package/core/graph/multi-hop-retrieval.ts +317 -0
  68. package/core/graph/relationship-extractor.ts +465 -0
  69. package/core/hooks/agent-hooks.ts +653 -0
  70. package/core/hooks/auto-tagger.ts +149 -0
  71. package/core/hooks/capture-filter.ts +169 -0
  72. package/core/hot-cache.ts +388 -0
  73. package/core/index.ts +10 -0
  74. package/core/ingestion/agent-memory.ts +167 -0
  75. package/core/ingestion/core-memory.ts +326 -0
  76. package/core/ingestion/learnings.ts +260 -0
  77. package/core/ingestion/signal-engine.ts +266 -0
  78. package/core/integrations/obsidian-vault.ts +197 -0
  79. package/core/layers/generator.ts +115 -0
  80. package/{dist/core/lib/db-client.d.ts → core/lib/db-client.ts} +168 -114
  81. package/core/lib/parse-embedding.ts +59 -0
  82. package/{dist/core/lib/schemas.js → core/lib/schemas.ts} +102 -87
  83. package/core/lib/types.ts +49 -0
  84. package/core/lib/utils.ts +151 -0
  85. package/core/lib/validation.ts +180 -0
  86. package/core/lifecycle.ts +353 -0
  87. package/core/logger.ts +59 -0
  88. package/core/memory/bridge-discovery.ts +395 -0
  89. package/core/memory/categorizer.ts +390 -0
  90. package/core/memory/conflict-detector.ts +62 -0
  91. package/core/memory/consolidation.ts +372 -0
  92. package/core/memory/context-collector.ts +75 -0
  93. package/core/memory/contradiction-resolver.ts +494 -0
  94. package/core/memory/edit-workflow.ts +174 -0
  95. package/core/memory/entity-extractor.ts +426 -0
  96. package/core/memory/entity-resolver.ts +89 -0
  97. package/core/memory/explain.ts +112 -0
  98. package/core/memory/fact-deriver.ts +300 -0
  99. package/core/memory/fact-extractor.ts +120 -0
  100. package/core/memory/feedback-tracker.ts +200 -0
  101. package/core/memory/hooks.ts +230 -0
  102. package/core/memory/hybrid-retrieval.ts +65 -0
  103. package/core/memory/hybrid-scorer.ts +325 -0
  104. package/core/memory/hybrid-search.ts +748 -0
  105. package/core/memory/importance.ts +319 -0
  106. package/{dist/core/memory/index.js → core/memory/index.ts} +11 -10
  107. package/core/memory/loader.ts +178 -0
  108. package/core/memory/markdown/markdown-storage.ts +318 -0
  109. package/core/memory/memories.ts +565 -0
  110. package/core/memory/memory-lifecycle.ts +51 -0
  111. package/core/memory/memory-manager.ts +53 -0
  112. package/core/memory/migrate.ts +173 -0
  113. package/core/memory/normalization.ts +30 -0
  114. package/core/memory/path-strengthener.ts +211 -0
  115. package/core/memory/progressive-disclosure.ts +392 -0
  116. package/core/memory/query-processor.ts +130 -0
  117. package/core/memory/query-rewriter.ts +153 -0
  118. package/core/memory/response-analyzer.ts +81 -0
  119. package/core/memory/retrieval-feedback.ts +276 -0
  120. package/core/memory/serialization.ts +83 -0
  121. package/core/memory/stale-cleaner.ts +147 -0
  122. package/core/memory/stats.ts +181 -0
  123. package/core/memory/telemetry.ts +392 -0
  124. package/core/memory/temporal-facts.ts +356 -0
  125. package/core/memory/temporal-parser.ts +477 -0
  126. package/core/memory/trigger-detector.ts +104 -0
  127. package/core/memory/write-gate.ts +288 -0
  128. package/{dist/core/places/index.js → core/places/index.ts} +12 -12
  129. package/core/places/memory-places.ts +339 -0
  130. package/core/places/places.ts +406 -0
  131. package/core/places/rules.ts +308 -0
  132. package/core/places/walking.ts +192 -0
  133. package/core/projects +89 -0
  134. package/core/projects.ts +131 -0
  135. package/core/redis.ts +82 -0
  136. package/core/responses.ts +187 -0
  137. package/core/runtime/trust-report.ts +195 -0
  138. package/core/runtime/trust-state.ts +360 -0
  139. package/core/scheduler/cron-scheduler.ts +590 -0
  140. package/core/scheduler/heartbeat.ts +91 -0
  141. package/{dist/core/scheduler/index.js → core/scheduler/index.ts} +8 -8
  142. package/core/scheduler/job-runner.ts +197 -0
  143. package/core/search/conversations.ts +166 -0
  144. package/core/search/entities.ts +46 -0
  145. package/core/search/folder-context.ts +154 -0
  146. package/core/search/graph-boost.ts +22 -0
  147. package/{dist/core/search/index.js → core/search/index.ts} +4 -5
  148. package/core/search/qmd-wrapper.ts +84 -0
  149. package/core/security/encrypt.ts +51 -0
  150. package/core/security/governance.ts +102 -0
  151. package/core/security/privacy.ts +108 -0
  152. package/core/security/secret-detector.ts +122 -0
  153. package/core/session/auto-load.ts +160 -0
  154. package/core/session/entity-tracker.ts +363 -0
  155. package/{dist/core/session/index.js → core/session/index.ts} +7 -7
  156. package/core/session/reference-resolver.ts +158 -0
  157. package/core/session/self-iteration-job.ts +478 -0
  158. package/core/session/session-hooks.ts +69 -0
  159. package/core/session/types.ts +36 -0
  160. package/core/session/working-set.ts +275 -0
  161. package/{dist/core/snapshots/cleanup.js → core/snapshots/cleanup.ts} +13 -12
  162. package/core/snapshots/comparison.ts +59 -0
  163. package/core/snapshots/creation.ts +139 -0
  164. package/core/snapshots/retrieval.ts +44 -0
  165. package/core/snapshots/stats.ts +63 -0
  166. package/core/storage/cache.ts +241 -0
  167. package/core/storage/database.ts +23 -0
  168. package/{dist/core/summarization/cleanup.js → core/summarization/cleanup.ts} +13 -12
  169. package/core/summarization/queries.ts +32 -0
  170. package/core/summarization/stats.ts +64 -0
  171. package/core/summarization/strategies.ts +52 -0
  172. package/core/summarization.ts +248 -0
  173. package/core/temporal-facts.ts +244 -0
  174. package/core/tracing/collector.ts +470 -0
  175. package/core/tracing/visualizer.ts +195 -0
  176. package/core/utils/cleanup-operations.ts +50 -0
  177. package/core/utils/content-extraction.ts +95 -0
  178. package/core/utils/filter-builder.ts +56 -0
  179. package/core/utils/history-traversal.ts +63 -0
  180. package/core/utils/memory-operations.ts +56 -0
  181. package/core/utils/query-operations.ts +83 -0
  182. package/core/utils/summarization-helpers.ts +45 -0
  183. package/core/utils/temporal-queries.ts +39 -0
  184. package/{dist/core/utils/vector-operations.js → core/utils/vector-operations.ts} +135 -129
  185. package/core/utils/version-management.ts +74 -0
  186. package/core/worker.ts +333 -0
  187. package/db/adapter.ts +215 -0
  188. package/{dist/db/bootstrap.js → db/bootstrap.ts} +388 -418
  189. package/db/drizzle/migrations/0000_needy_cerebro.sql +402 -0
  190. package/db/drizzle/migrations/meta/0000_snapshot.json +3451 -0
  191. package/db/drizzle/migrations/meta/_journal.json +13 -0
  192. package/db/drizzle/schema-sqlite.ts +1032 -0
  193. package/db/drizzle/schema.ts +1128 -0
  194. package/db/drizzle.config.ts +12 -0
  195. package/db/index.ts +83 -0
  196. package/db/init.sql +5 -0
  197. package/db/migrations/associations.ts +35 -0
  198. package/db/migrations/beliefs.ts +89 -0
  199. package/db/migrations/core-memory.ts +35 -0
  200. package/db/migrations/fts.ts +59 -0
  201. package/db/migrations/index.ts +54 -0
  202. package/db/migrations/indexes.ts +36 -0
  203. package/db/migrations/learnings.ts +34 -0
  204. package/db/migrations/maintenance.ts +68 -0
  205. package/db/migrations/memories.ts +22 -0
  206. package/db/migrations/memory-places.ts +35 -0
  207. package/db/migrations/places.ts +49 -0
  208. package/db/migrations/projects.ts +21 -0
  209. package/db/migrations/tier-conversion.ts +24 -0
  210. package/db/neon.ts +22 -0
  211. package/db/schema/beliefs.ts +50 -0
  212. package/db/schema/generator.ts +159 -0
  213. package/db/schema/index.ts +58 -0
  214. package/db/schema/learnings.ts +32 -0
  215. package/db/schema/memories.ts +83 -0
  216. package/db/schema/projects.ts +33 -0
  217. package/db/schema.ts +13 -0
  218. package/db/supabase.ts +27 -0
  219. package/mcp.json.example +8 -11
  220. package/package.json +140 -159
  221. package/packages/cli/package.json +22 -0
  222. package/packages/cli/src/commands/clean.ts +68 -0
  223. package/packages/cli/src/commands/context.ts +79 -0
  224. package/packages/cli/src/commands/doctor.ts +357 -0
  225. package/packages/cli/src/commands/forget.ts +72 -0
  226. package/packages/cli/src/commands/health.ts +36 -0
  227. package/packages/cli/src/commands/inspect.ts +41 -0
  228. package/packages/cli/src/commands/link.ts +50 -0
  229. package/packages/cli/src/commands/migrate.ts +93 -0
  230. package/packages/cli/src/commands/recall.ts +99 -0
  231. package/packages/cli/src/commands/recent.ts +57 -0
  232. package/packages/cli/src/commands/remember.ts +139 -0
  233. package/packages/cli/src/commands/run.ts +58 -0
  234. package/packages/cli/src/commands/stale.ts +43 -0
  235. package/packages/cli/src/commands/stats.ts +42 -0
  236. package/packages/cli/src/index.ts +57 -0
  237. package/packages/cli/tsconfig.json +24 -0
  238. package/packages/mcp/package.json +26 -0
  239. package/packages/mcp/src/index.ts +940 -0
  240. package/packages/mcp/tsconfig.json +20 -0
  241. package/skills/squish-memory/SKILL.md +38 -35
  242. package/skills/squish-memory/{scripts/install.sh → install.sh} +1 -1
  243. package/skills/squish-memory/references/claude-desktop.json +12 -0
  244. package/skills/squish-memory/references/openclaw.json +13 -0
  245. package/skills/squish-memory/references/opencode.json +14 -0
  246. package/config/hooks/claude-code-hooks.json +0 -39
  247. package/config/hooks/cursor-hooks.json +0 -30
  248. package/config/hooks/opencode-hooks.json +0 -30
  249. package/config/hooks/windsurf-hooks.json +0 -30
  250. package/config/mcp-cli-fallback-policy.json +0 -22
  251. package/config/mcp.json +0 -38
  252. package/config/plugin-manifest.json +0 -101
  253. package/config/plugin-manifest.schema.json +0 -244
  254. package/config/plugin.json +0 -32
  255. package/config/remote-memory-policy.json +0 -32
  256. package/core/commands/context-paging.md +0 -51
  257. package/core/commands/context-status.md +0 -22
  258. package/core/commands/context.md +0 -5
  259. package/core/commands/core-memory.md +0 -56
  260. package/core/commands/health.md +0 -5
  261. package/core/commands/init.md +0 -39
  262. package/core/commands/merge.md +0 -113
  263. package/core/commands/recall.md +0 -5
  264. package/core/commands/remember.md +0 -11
  265. package/core/commands/search.md +0 -10
  266. package/dist/config.d.ts +0 -83
  267. package/dist/config.js +0 -242
  268. package/dist/core/adapters/config/claude-code.d.ts +0 -45
  269. package/dist/core/adapters/config/claude-code.js +0 -113
  270. package/dist/core/adapters/config/cursor.d.ts +0 -26
  271. package/dist/core/adapters/config/cursor.js +0 -74
  272. package/dist/core/adapters/config/opencode.d.ts +0 -23
  273. package/dist/core/adapters/config/opencode.js +0 -73
  274. package/dist/core/adapters/config/windsurf.d.ts +0 -26
  275. package/dist/core/adapters/config/windsurf.js +0 -74
  276. package/dist/core/adapters/index.d.ts +0 -45
  277. package/dist/core/adapters/index.js +0 -84
  278. package/dist/core/adapters/scripts/install-adapter.d.ts +0 -19
  279. package/dist/core/adapters/scripts/install-adapter.js +0 -149
  280. package/dist/core/adapters/timeline.d.ts +0 -23
  281. package/dist/core/adapters/timeline.js +0 -88
  282. package/dist/core/adapters/types.d.ts +0 -157
  283. package/dist/core/adapters/types.js +0 -50
  284. package/dist/core/algorithms/analytics/token-estimator.d.ts +0 -50
  285. package/dist/core/algorithms/analytics/token-estimator.js +0 -154
  286. package/dist/core/algorithms/detection/hash-filters.d.ts +0 -47
  287. package/dist/core/algorithms/detection/hash-filters.js +0 -190
  288. package/dist/core/algorithms/detection/semantic-ranker.d.ts +0 -32
  289. package/dist/core/algorithms/detection/semantic-ranker.js +0 -118
  290. package/dist/core/algorithms/detection/two-stage-detector.d.ts +0 -52
  291. package/dist/core/algorithms/detection/two-stage-detector.js +0 -299
  292. package/dist/core/algorithms/handlers/approve-merge.d.ts +0 -22
  293. package/dist/core/algorithms/handlers/approve-merge.js +0 -179
  294. package/dist/core/algorithms/handlers/detect-duplicates.d.ts +0 -47
  295. package/dist/core/algorithms/handlers/detect-duplicates.js +0 -145
  296. package/dist/core/algorithms/handlers/get-stats.d.ts +0 -39
  297. package/dist/core/algorithms/handlers/get-stats.js +0 -88
  298. package/dist/core/algorithms/handlers/list-proposals.d.ts +0 -45
  299. package/dist/core/algorithms/handlers/list-proposals.js +0 -83
  300. package/dist/core/algorithms/handlers/preview-merge.d.ts +0 -39
  301. package/dist/core/algorithms/handlers/preview-merge.js +0 -93
  302. package/dist/core/algorithms/handlers/reject-merge.d.ts +0 -28
  303. package/dist/core/algorithms/handlers/reject-merge.js +0 -69
  304. package/dist/core/algorithms/handlers/reverse-merge.d.ts +0 -21
  305. package/dist/core/algorithms/handlers/reverse-merge.js +0 -121
  306. package/dist/core/algorithms/index.d.ts +0 -21
  307. package/dist/core/algorithms/operations/cache-maintenance.d.ts +0 -12
  308. package/dist/core/algorithms/operations/cache-maintenance.js +0 -157
  309. package/dist/core/algorithms/safety/safety-checks.d.ts +0 -22
  310. package/dist/core/algorithms/safety/safety-checks.js +0 -179
  311. package/dist/core/algorithms/strategies/merge-strategies.d.ts +0 -50
  312. package/dist/core/algorithms/strategies/merge-strategies.js +0 -288
  313. package/dist/core/algorithms/types.d.ts +0 -133
  314. package/dist/core/algorithms/types.js +0 -5
  315. package/dist/core/algorithms/utils/response-builder.d.ts +0 -28
  316. package/dist/core/algorithms/utils/response-builder.js +0 -37
  317. package/dist/core/associations.d.ts +0 -31
  318. package/dist/core/associations.js +0 -248
  319. package/dist/core/autosave.d.ts +0 -19
  320. package/dist/core/autosave.js +0 -16
  321. package/dist/core/commands/managed-sync.d.ts +0 -10
  322. package/dist/core/commands/managed-sync.js +0 -64
  323. package/dist/core/commands/mcp-server.d.ts +0 -3
  324. package/dist/core/commands/mcp-server.js +0 -739
  325. package/dist/core/consolidation.d.ts +0 -37
  326. package/dist/core/consolidation.js +0 -248
  327. package/dist/core/context/agent-context.d.ts +0 -106
  328. package/dist/core/context/agent-context.js +0 -274
  329. package/dist/core/context/context-paging.d.ts +0 -80
  330. package/dist/core/context/context-paging.js +0 -328
  331. package/dist/core/context/context-window.d.ts +0 -40
  332. package/dist/core/context/context-window.js +0 -177
  333. package/dist/core/context/context.d.ts +0 -7
  334. package/dist/core/context/context.js +0 -22
  335. package/dist/core/embeddings/google-multimodal.d.ts +0 -14
  336. package/dist/core/embeddings/google-multimodal.js +0 -142
  337. package/dist/core/embeddings/qmd-client.d.ts +0 -136
  338. package/dist/core/embeddings/qmd-client.js +0 -403
  339. package/dist/core/embeddings.d.ts +0 -29
  340. package/dist/core/embeddings.js +0 -454
  341. package/dist/core/error-handling.d.ts +0 -63
  342. package/dist/core/error-handling.js +0 -173
  343. package/dist/core/external-folder/index.d.ts +0 -102
  344. package/dist/core/external-folder/index.js +0 -294
  345. package/dist/core/hooks/agent-hooks.d.ts +0 -74
  346. package/dist/core/hooks/agent-hooks.js +0 -244
  347. package/dist/core/hooks/auto-tagger.d.ts +0 -19
  348. package/dist/core/hooks/auto-tagger.js +0 -155
  349. package/dist/core/hooks/capture-filter.d.ts +0 -41
  350. package/dist/core/hooks/capture-filter.js +0 -128
  351. package/dist/core/index.d.ts +0 -10
  352. package/dist/core/index.js +0 -14
  353. package/dist/core/ingestion/agent-memory.d.ts +0 -22
  354. package/dist/core/ingestion/agent-memory.js +0 -109
  355. package/dist/core/ingestion/core-memory.d.ts +0 -78
  356. package/dist/core/ingestion/core-memory.js +0 -226
  357. package/dist/core/ingestion/learnings.d.ts +0 -57
  358. package/dist/core/ingestion/learnings.js +0 -202
  359. package/dist/core/layers/generator.d.ts +0 -25
  360. package/dist/core/layers/generator.js +0 -76
  361. package/dist/core/lib/db-client.js +0 -130
  362. package/dist/core/lib/schemas.d.ts +0 -129
  363. package/dist/core/lib/utils.d.ts +0 -14
  364. package/dist/core/lib/utils.js +0 -90
  365. package/dist/core/lib/validation.d.ts +0 -38
  366. package/dist/core/lib/validation.js +0 -151
  367. package/dist/core/lifecycle.d.ts +0 -26
  368. package/dist/core/lifecycle.js +0 -302
  369. package/dist/core/local-embeddings.d.ts +0 -11
  370. package/dist/core/logger.d.ts +0 -16
  371. package/dist/core/logger.js +0 -40
  372. package/dist/core/mcp/client.d.ts +0 -17
  373. package/dist/core/mcp/client.js +0 -101
  374. package/dist/core/mcp/index.d.ts +0 -6
  375. package/dist/core/mcp/index.js +0 -6
  376. package/dist/core/mcp/server.d.ts +0 -18
  377. package/dist/core/mcp/server.js +0 -157
  378. package/dist/core/mcp/standalone-server.d.ts +0 -13
  379. package/dist/core/mcp/standalone-server.js +0 -46
  380. package/dist/core/mcp/tools.d.ts +0 -9
  381. package/dist/core/mcp/tools.js +0 -365
  382. package/dist/core/mcp/types.d.ts +0 -315
  383. package/dist/core/mcp/types.js +0 -48
  384. package/dist/core/memory/bridge-discovery.d.ts +0 -50
  385. package/dist/core/memory/bridge-discovery.js +0 -291
  386. package/dist/core/memory/categorizer.d.ts +0 -27
  387. package/dist/core/memory/categorizer.js +0 -305
  388. package/dist/core/memory/conflict-detector.d.ts +0 -7
  389. package/dist/core/memory/conflict-detector.js +0 -43
  390. package/dist/core/memory/consolidation.d.ts +0 -42
  391. package/dist/core/memory/consolidation.js +0 -303
  392. package/dist/core/memory/context-collector.d.ts +0 -10
  393. package/dist/core/memory/context-collector.js +0 -56
  394. package/dist/core/memory/contradiction-resolver.d.ts +0 -40
  395. package/dist/core/memory/contradiction-resolver.js +0 -368
  396. package/dist/core/memory/edit-workflow.d.ts +0 -19
  397. package/dist/core/memory/edit-workflow.js +0 -120
  398. package/dist/core/memory/entity-extractor.d.ts +0 -33
  399. package/dist/core/memory/entity-extractor.js +0 -336
  400. package/dist/core/memory/entity-resolver.d.ts +0 -23
  401. package/dist/core/memory/entity-resolver.js +0 -64
  402. package/dist/core/memory/fact-extractor.d.ts +0 -24
  403. package/dist/core/memory/fact-extractor.js +0 -89
  404. package/dist/core/memory/feedback-tracker.d.ts +0 -12
  405. package/dist/core/memory/feedback-tracker.js +0 -155
  406. package/dist/core/memory/hooks.d.ts +0 -88
  407. package/dist/core/memory/hooks.js +0 -174
  408. package/dist/core/memory/hybrid-retrieval.d.ts +0 -29
  409. package/dist/core/memory/hybrid-retrieval.js +0 -139
  410. package/dist/core/memory/hybrid-scorer.d.ts +0 -40
  411. package/dist/core/memory/hybrid-scorer.js +0 -284
  412. package/dist/core/memory/hybrid-search.d.ts +0 -20
  413. package/dist/core/memory/hybrid-search.js +0 -359
  414. package/dist/core/memory/importance.d.ts +0 -63
  415. package/dist/core/memory/importance.js +0 -298
  416. package/dist/core/memory/index.d.ts +0 -8
  417. package/dist/core/memory/loader.d.ts +0 -31
  418. package/dist/core/memory/loader.js +0 -141
  419. package/dist/core/memory/markdown/markdown-storage.d.ts +0 -72
  420. package/dist/core/memory/markdown/markdown-storage.js +0 -243
  421. package/dist/core/memory/memories.d.ts +0 -47
  422. package/dist/core/memory/memories.js +0 -449
  423. package/dist/core/memory/memory-lifecycle.d.ts +0 -8
  424. package/dist/core/memory/memory-lifecycle.js +0 -55
  425. package/dist/core/memory/memory-manager.d.ts +0 -15
  426. package/dist/core/memory/memory-manager.js +0 -46
  427. package/dist/core/memory/migrate.d.ts +0 -21
  428. package/dist/core/memory/migrate.js +0 -134
  429. package/dist/core/memory/normalization.d.ts +0 -22
  430. package/dist/core/memory/normalization.js +0 -26
  431. package/dist/core/memory/progressive-disclosure.d.ts +0 -43
  432. package/dist/core/memory/progressive-disclosure.js +0 -280
  433. package/dist/core/memory/query-processor.d.ts +0 -21
  434. package/dist/core/memory/query-processor.js +0 -72
  435. package/dist/core/memory/query-rewriter.d.ts +0 -13
  436. package/dist/core/memory/query-rewriter.js +0 -118
  437. package/dist/core/memory/response-analyzer.d.ts +0 -9
  438. package/dist/core/memory/response-analyzer.js +0 -61
  439. package/dist/core/memory/serialization.d.ts +0 -10
  440. package/dist/core/memory/serialization.js +0 -84
  441. package/dist/core/memory/stats.d.ts +0 -22
  442. package/dist/core/memory/stats.js +0 -138
  443. package/dist/core/memory/telemetry.d.ts +0 -69
  444. package/dist/core/memory/telemetry.js +0 -313
  445. package/dist/core/memory/temporal-facts.d.ts +0 -41
  446. package/dist/core/memory/temporal-facts.js +0 -283
  447. package/dist/core/memory/temporal-parser.d.ts +0 -32
  448. package/dist/core/memory/temporal-parser.js +0 -385
  449. package/dist/core/memory/trigger-detector.d.ts +0 -14
  450. package/dist/core/memory/trigger-detector.js +0 -42
  451. package/dist/core/memory/write-gate.d.ts +0 -54
  452. package/dist/core/memory/write-gate.js +0 -210
  453. package/dist/core/namespaces/index.d.ts +0 -71
  454. package/dist/core/namespaces/index.js +0 -305
  455. package/dist/core/namespaces/uri-parser.d.ts +0 -31
  456. package/dist/core/namespaces/uri-parser.js +0 -74
  457. package/dist/core/obsidian-vault.d.ts +0 -30
  458. package/dist/core/obsidian-vault.js +0 -94
  459. package/dist/core/places/index.d.ts +0 -14
  460. package/dist/core/places/memory-places.d.ts +0 -68
  461. package/dist/core/places/memory-places.js +0 -261
  462. package/dist/core/places/places.d.ts +0 -88
  463. package/dist/core/places/places.js +0 -314
  464. package/dist/core/places/rules.d.ts +0 -74
  465. package/dist/core/places/rules.js +0 -240
  466. package/dist/core/places/walking.d.ts +0 -56
  467. package/dist/core/places/walking.js +0 -121
  468. package/dist/core/projects.d.ts +0 -17
  469. package/dist/core/projects.js +0 -108
  470. package/dist/core/redis.d.ts +0 -11
  471. package/dist/core/redis.js +0 -69
  472. package/dist/core/responses.d.ts +0 -96
  473. package/dist/core/responses.js +0 -122
  474. package/dist/core/scheduler/cron-scheduler.d.ts +0 -32
  475. package/dist/core/scheduler/cron-scheduler.js +0 -332
  476. package/dist/core/scheduler/heartbeat.d.ts +0 -11
  477. package/dist/core/scheduler/heartbeat.js +0 -73
  478. package/dist/core/scheduler/index.d.ts +0 -8
  479. package/dist/core/scheduler/job-runner.d.ts +0 -11
  480. package/dist/core/scheduler/job-runner.js +0 -164
  481. package/dist/core/search/conversations.d.ts +0 -25
  482. package/dist/core/search/conversations.js +0 -110
  483. package/dist/core/search/entities.d.ts +0 -12
  484. package/dist/core/search/entities.js +0 -31
  485. package/dist/core/search/folder-context.d.ts +0 -25
  486. package/dist/core/search/folder-context.js +0 -119
  487. package/dist/core/search/graph-boost.d.ts +0 -7
  488. package/dist/core/search/graph-boost.js +0 -23
  489. package/dist/core/search/index.d.ts +0 -4
  490. package/dist/core/search/qmd-search.d.ts +0 -61
  491. package/dist/core/search/qmd-search.js +0 -178
  492. package/dist/core/security/encrypt.d.ts +0 -6
  493. package/dist/core/security/encrypt.js +0 -47
  494. package/dist/core/security/governance.d.ts +0 -26
  495. package/dist/core/security/governance.js +0 -79
  496. package/dist/core/security/privacy.d.ts +0 -23
  497. package/dist/core/security/privacy.js +0 -82
  498. package/dist/core/security/secret-detector.d.ts +0 -32
  499. package/dist/core/security/secret-detector.js +0 -88
  500. package/dist/core/session/auto-load.d.ts +0 -6
  501. package/dist/core/session/auto-load.js +0 -119
  502. package/dist/core/session/index.d.ts +0 -7
  503. package/dist/core/session/self-iteration-job.d.ts +0 -20
  504. package/dist/core/session/self-iteration-job.js +0 -282
  505. package/dist/core/session/session-hooks.d.ts +0 -18
  506. package/dist/core/session/session-hooks.js +0 -58
  507. package/dist/core/session/types.d.ts +0 -26
  508. package/dist/core/session/types.js +0 -10
  509. package/dist/core/session-hooks/self-iteration-job.d.ts +0 -20
  510. package/dist/core/session-hooks/self-iteration-job.js +0 -282
  511. package/dist/core/session-hooks/session-hooks.d.ts +0 -18
  512. package/dist/core/session-hooks/session-hooks.js +0 -58
  513. package/dist/core/snapshots/cleanup.d.ts +0 -9
  514. package/dist/core/snapshots/comparison.d.ts +0 -19
  515. package/dist/core/snapshots/comparison.js +0 -43
  516. package/dist/core/snapshots/creation.d.ts +0 -19
  517. package/dist/core/snapshots/creation.js +0 -126
  518. package/dist/core/snapshots/retrieval.d.ts +0 -7
  519. package/dist/core/snapshots/retrieval.js +0 -41
  520. package/dist/core/snapshots/stats.d.ts +0 -11
  521. package/dist/core/snapshots/stats.js +0 -52
  522. package/dist/core/snapshots.d.ts +0 -29
  523. package/dist/core/snapshots.js +0 -220
  524. package/dist/core/storage/cache.d.ts +0 -13
  525. package/dist/core/storage/cache.js +0 -202
  526. package/dist/core/storage/database.d.ts +0 -12
  527. package/dist/core/storage/database.js +0 -12
  528. package/dist/core/summarization/cleanup.d.ts +0 -9
  529. package/dist/core/summarization/queries.d.ts +0 -9
  530. package/dist/core/summarization/queries.js +0 -28
  531. package/dist/core/summarization/stats.d.ts +0 -14
  532. package/dist/core/summarization/stats.js +0 -52
  533. package/dist/core/summarization/strategies.d.ts +0 -24
  534. package/dist/core/summarization/strategies.js +0 -28
  535. package/dist/core/summarization.d.ts +0 -37
  536. package/dist/core/summarization.js +0 -188
  537. package/dist/core/sync/qmd-sync.d.ts +0 -94
  538. package/dist/core/sync/qmd-sync.js +0 -201
  539. package/dist/core/temporal-facts.d.ts +0 -54
  540. package/dist/core/temporal-facts.js +0 -193
  541. package/dist/core/toon.d.ts +0 -43
  542. package/dist/core/toon.js +0 -160
  543. package/dist/core/tracing/collector.d.ts +0 -111
  544. package/dist/core/tracing/collector.js +0 -350
  545. package/dist/core/tracing/visualizer.d.ts +0 -32
  546. package/dist/core/tracing/visualizer.js +0 -165
  547. package/dist/core/utils/cleanup-operations.d.ts +0 -13
  548. package/dist/core/utils/cleanup-operations.js +0 -44
  549. package/dist/core/utils/content-extraction.d.ts +0 -19
  550. package/dist/core/utils/content-extraction.js +0 -75
  551. package/dist/core/utils/filter-builder.d.ts +0 -13
  552. package/dist/core/utils/filter-builder.js +0 -44
  553. package/dist/core/utils/history-traversal.d.ts +0 -13
  554. package/dist/core/utils/history-traversal.js +0 -50
  555. package/dist/core/utils/memory-operations.d.ts +0 -17
  556. package/dist/core/utils/memory-operations.js +0 -43
  557. package/dist/core/utils/query-operations.d.ts +0 -18
  558. package/dist/core/utils/query-operations.js +0 -65
  559. package/dist/core/utils/summarization-helpers.d.ts +0 -21
  560. package/dist/core/utils/summarization-helpers.js +0 -38
  561. package/dist/core/utils/temporal-queries.d.ts +0 -13
  562. package/dist/core/utils/temporal-queries.js +0 -27
  563. package/dist/core/utils/vector-operations.d.ts +0 -71
  564. package/dist/core/utils/version-management.d.ts +0 -9
  565. package/dist/core/utils/version-management.js +0 -61
  566. package/dist/core/worker.d.ts +0 -82
  567. package/dist/core/worker.js +0 -272
  568. package/dist/db/adapter.d.ts +0 -7
  569. package/dist/db/adapter.js +0 -175
  570. package/dist/db/bootstrap.d.ts +0 -9
  571. package/dist/db/drizzle/schema-sqlite.d.ts +0 -4837
  572. package/dist/db/drizzle/schema-sqlite.js +0 -684
  573. package/dist/db/drizzle/schema.d.ts +0 -4082
  574. package/dist/db/drizzle/schema.js +0 -770
  575. package/dist/db/drizzle.config.d.ts +0 -3
  576. package/dist/db/drizzle.config.js +0 -12
  577. package/dist/db/index.d.ts +0 -7
  578. package/dist/db/index.js +0 -89
  579. package/dist/db/neon.d.ts +0 -8
  580. package/dist/db/neon.js +0 -20
  581. package/dist/db/schema/index.d.ts +0 -40
  582. package/dist/db/schema/index.js +0 -105
  583. package/dist/db/schema/tables/context-sessions.d.ts +0 -9
  584. package/dist/db/schema/tables/context-sessions.js +0 -37
  585. package/dist/db/schema/tables/conversations.d.ts +0 -9
  586. package/dist/db/schema/tables/conversations.js +0 -47
  587. package/dist/db/schema/tables/core-memory.d.ts +0 -9
  588. package/dist/db/schema/tables/core-memory.js +0 -41
  589. package/dist/db/schema/tables/entities.d.ts +0 -9
  590. package/dist/db/schema/tables/entities.js +0 -39
  591. package/dist/db/schema/tables/entity-relations.d.ts +0 -9
  592. package/dist/db/schema/tables/entity-relations.js +0 -31
  593. package/dist/db/schema/tables/learnings.d.ts +0 -9
  594. package/dist/db/schema/tables/learnings.js +0 -66
  595. package/dist/db/schema/tables/memories.d.ts +0 -9
  596. package/dist/db/schema/tables/memories.js +0 -161
  597. package/dist/db/schema/tables/memory-associations.d.ts +0 -9
  598. package/dist/db/schema/tables/memory-associations.js +0 -39
  599. package/dist/db/schema/tables/memory-hash-cache.d.ts +0 -9
  600. package/dist/db/schema/tables/memory-hash-cache.js +0 -29
  601. package/dist/db/schema/tables/memory-merge-history.d.ts +0 -9
  602. package/dist/db/schema/tables/memory-merge-history.js +0 -33
  603. package/dist/db/schema/tables/memory-merge-proposals.d.ts +0 -9
  604. package/dist/db/schema/tables/memory-merge-proposals.js +0 -39
  605. package/dist/db/schema/tables/messages.d.ts +0 -9
  606. package/dist/db/schema/tables/messages.js +0 -41
  607. package/dist/db/schema/tables/namespaces.d.ts +0 -9
  608. package/dist/db/schema/tables/namespaces.js +0 -37
  609. package/dist/db/schema/tables/projects.d.ts +0 -9
  610. package/dist/db/schema/tables/projects.js +0 -31
  611. package/dist/db/schema/tables/users.d.ts +0 -9
  612. package/dist/db/schema/tables/users.js +0 -27
  613. package/dist/db/schema.d.ts +0 -3
  614. package/dist/db/schema.js +0 -11
  615. package/dist/db/supabase.d.ts +0 -9
  616. package/dist/db/supabase.js +0 -24
  617. package/dist/index.d.ts +0 -7
  618. package/dist/index.js +0 -1677
  619. package/dist/vendor/sql.js/sql-wasm.wasm +0 -0
  620. package/dist/webui/server.d.ts +0 -5
  621. package/dist/webui/server.js +0 -642
  622. package/generated/mcp/manifest.json +0 -23
  623. package/generated/mcp/mcp-servers.json +0 -25
  624. package/generated/mcp/mcporter.json +0 -34
  625. package/generated/mcp/openclaw-memory-qmd.json +0 -17
  626. package/generated/mcp/runtime.json +0 -12
  627. package/scripts/README.md +0 -60
  628. package/scripts/build-release.sh +0 -36
  629. package/scripts/check-secrets.js +0 -132
  630. package/scripts/copy-runtime-assets.mjs +0 -26
  631. package/scripts/generate-mcp.mjs +0 -264
  632. package/scripts/github-release.sh +0 -77
  633. package/scripts/init-dirs.mjs +0 -13
  634. package/scripts/install-claude-code.sh +0 -85
  635. package/scripts/install-cursor.sh +0 -56
  636. package/scripts/install-hooks.sh +0 -73
  637. package/scripts/install-interactive.mjs +0 -357
  638. package/scripts/install-opencode.sh +0 -75
  639. package/scripts/install-plugin.mjs +0 -415
  640. package/scripts/install-windsurf.sh +0 -67
  641. package/scripts/remote-preflight.mjs +0 -62
  642. package/scripts/squish-fallback.mjs +0 -132
  643. package/scripts/test-interactive.mjs +0 -131
  644. package/scripts/verify-mcp.mjs +0 -214
  645. package/skills/squish-memory/scripts/install.mjs +0 -335
  646. package/skills/squish-memory/write_skill.js +0 -2
@@ -1,684 +0,0 @@
1
- import { sqliteTable, text, integer, blob, index } from 'drizzle-orm/sqlite-core';
2
- import { sql } from 'drizzle-orm';
3
- // Core Tables - SQLite compatible version
4
- // ============================================================================
5
- /**
6
- * Users - represents Claude Code users
7
- */
8
- export const users = sqliteTable('users', {
9
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
10
- externalId: text('external_id').unique(), // Claude user ID if available
11
- name: text('name'),
12
- email: text('email'),
13
- preferences: text('preferences').$type(),
14
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
15
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
16
- });
17
- /**
18
- * Projects - workspaces that memories are scoped to
19
- */
20
- export const projects = sqliteTable('projects', {
21
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
22
- name: text('name').notNull(),
23
- path: text('path').notNull(),
24
- description: text('description'),
25
- metadata: text('metadata').$type(),
26
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
27
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
28
- }, (table) => [
29
- index('projects_path_idx').on(table.path),
30
- ]);
31
- /**
32
- * Memories - core memory storage
33
- */
34
- export const memories = sqliteTable('memories', {
35
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
36
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
37
- userId: text('user_id').references(() => users.id, { onDelete: 'set null' }),
38
- // Content
39
- type: text('type').notNull().$type(),
40
- content: text('content').notNull(),
41
- summary: text('summary'),
42
- // Embeddings stored as JSON string (not for semantic search in SQLite)
43
- embeddingJson: text('embedding_json'),
44
- // v0.2.0: Vector embedding for local search
45
- embedding: blob('embedding'),
46
- // Metadata
47
- source: text('source'),
48
- confidence: integer('confidence').default(50), // 0-100 confidence score (default: speculative)
49
- confidenceLevel: text('confidence_level').$type().default('speculative'), // Iteration 3: Confidence flags (default: speculative)
50
- tags: text('tags').$type(),
51
- metadata: text('metadata').$type(),
52
- // v0.2.0: Privacy and relevance
53
- isPrivate: integer('is_private', { mode: 'boolean' }).default(false),
54
- hasSecrets: integer('has_secrets', { mode: 'boolean' }).default(false),
55
- relevanceScore: integer('relevance_score').default(50), // 0-100
56
- // Lifecycle
57
- isActive: integer('is_active', { mode: 'boolean' }).default(true),
58
- expiresAt: integer('expires_at', { mode: 'timestamp' }),
59
- accessCount: integer('access_count').default(0),
60
- lastAccessedAt: integer('last_accessed_at', { mode: 'timestamp' }),
61
- // Merge tracking
62
- isMerged: integer('is_merged', { mode: 'boolean' }).default(false),
63
- mergedIntoId: text('merged_into_id').references(() => memories.id),
64
- mergedAt: integer('merged_at', { mode: 'timestamp' }),
65
- isCanonical: integer('is_canonical', { mode: 'boolean' }).default(false),
66
- mergeSourceIds: text('merge_source_ids').$type(),
67
- isMergeable: integer('is_mergeable', { mode: 'boolean' }).default(true),
68
- mergeVersion: integer('merge_version').default(1),
69
- // v0.4.2: Namespace support
70
- namespaceId: text('namespace_id').references(() => namespaces.id, { onDelete: 'set null' }),
71
- namespacePath: text('namespace_path'),
72
- // v1.1.5: Places support (spatial memory organization)
73
- placeId: text('place_id').references(() => places.id, { onDelete: 'set null' }),
74
- placeLociIndex: integer('place_loci_index'),
75
- // v0.4.3: Layer support
76
- hasL0Abstract: integer('has_l0_abstract', { mode: 'boolean' }).default(false),
77
- hasL1Overview: integer('has_l1_overview', { mode: 'boolean' }).default(false),
78
- lastLayerUpdate: integer('last_layer_update', { mode: 'timestamp' }),
79
- // v0.8.0: Importance Scoring
80
- importanceScore: integer('importance_score').default(50), // 0-100
81
- importanceDecayRate: integer('importance_decay_rate').default(30), // days half-life
82
- lastImportanceRecalc: integer('last_importance_recalc', { mode: 'timestamp' }),
83
- // v0.10.0: Echo/Fizzle Tracking - Retrieval Priority
84
- retrievalPriority: integer('retrieval_priority').default(50), // 0-100, adjusted by feedback
85
- // v1.0.x: Token tracking
86
- tokensEstimate: integer('tokens_estimate').default(0).notNull(),
87
- // v0.8.0: Consolidation tracking
88
- consolidatedInto: text('consolidated_into').references(() => memories.id),
89
- consolidatedAt: integer('consolidated_at', { mode: 'timestamp' }),
90
- isConsolidated: integer('is_consolidated', { mode: 'boolean' }).default(false),
91
- // v0.3.0: Memory Lifecycle Management
92
- sector: text('sector').$type().default('episodic'),
93
- tier: text('tier').$type().default('hot'),
94
- status: text('status').notNull().default('active'),
95
- encrypted_content: text('encrypted_content'),
96
- encryption_nonce: text('encryption_nonce'),
97
- is_encrypted: integer('is_encrypted', { mode: 'boolean' }).default(false),
98
- // v0.5.0: Context Status - Track whether memory is in active context or archived
99
- contextStatus: text('context_status').$type().default('out-of-context'),
100
- // Per-memory decay rate (integer percentage, e.g., 30 = 30% decay per cycle)
101
- decayRate: integer('decay_rate').default(30),
102
- coactivationScore: integer('coactivation_score').default(0),
103
- lastDecayAt: integer('last_decay_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`),
104
- // v0.3.0: Agent-Aware Memory
105
- agentId: text('agent_id'),
106
- agentRole: text('agent_role'),
107
- visibilityScope: text('visibility_scope').$type().default('private'),
108
- // v0.3.0: Memory Governance
109
- isProtected: integer('is_protected', { mode: 'boolean' }).default(false),
110
- isPinned: integer('is_pinned', { mode: 'boolean' }).default(false),
111
- isImmutable: integer('is_immutable', { mode: 'boolean' }).default(false),
112
- writeScope: text('write_scope').$type(),
113
- readScope: text('read_scope').$type(),
114
- // v0.3.0: Provenance
115
- triggeredBy: text('triggered_by'),
116
- captureReason: text('capture_reason'),
117
- lastUsedAt: integer('last_used_at', { mode: 'timestamp' }),
118
- usageCount: integer('usage_count').default(0),
119
- // v0.3.0: Temporal Facts
120
- validFrom: integer('valid_from', { mode: 'timestamp' }),
121
- validTo: integer('valid_to', { mode: 'timestamp' }),
122
- recordedAt: integer('recorded_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(), // When agent learned/stored the fact
123
- supersededBy: text('superseded_by').references(() => memories.id),
124
- version: integer('version').default(1),
125
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
126
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
127
- }, (table) => [
128
- index('memories_project_idx').on(table.projectId),
129
- index('memories_type_idx').on(table.type),
130
- index('memories_created_idx').on(table.createdAt),
131
- index('memories_tags_idx').on(table.tags),
132
- index('memories_relevance_idx').on(table.relevanceScore),
133
- index('memories_private_idx').on(table.isPrivate),
134
- index('memories_merged_idx').on(table.isMerged),
135
- index('memories_canonical_idx').on(table.isCanonical),
136
- index('memories_sector_idx').on(table.sector),
137
- index('memories_tier_idx').on(table.tier),
138
- index('memories_agent_idx').on(table.agentId),
139
- index('memories_visibility_idx').on(table.visibilityScope),
140
- index('memories_protected_idx').on(table.isProtected),
141
- index('memories_pinned_idx').on(table.isPinned),
142
- index('memories_valid_from_idx').on(table.validFrom),
143
- index('memories_valid_to_idx').on(table.validTo),
144
- index('memories_context_status_idx').on(table.contextStatus),
145
- // v0.8.0: Importance scoring indexes
146
- index('memories_importance_idx').on(table.importanceScore),
147
- index('memories_consolidated_idx').on(table.isConsolidated),
148
- index('memories_consolidation_query_idx').on(table.projectId, table.isConsolidated, table.importanceScore),
149
- // v0.5.0: Context status composite index for efficient filtering
150
- index('memories_context_query_idx').on(table.projectId, table.contextStatus, table.tier),
151
- // v0.4.2: Composite indexes for performance optimization
152
- // Duplicate detection query optimization
153
- index('memories_duplicate_detection_idx').on(table.projectId, table.isMerged, table.isMergeable, table.isActive),
154
- // Eviction query optimization
155
- index('memories_eviction_idx').on(table.projectId, table.tier, table.relevanceScore, table.createdAt),
156
- // Decay operations optimization
157
- index('memories_decay_idx').on(table.sector, table.lastDecayAt, table.isProtected),
158
- // Temporal query optimization
159
- index('memories_temporal_idx').on(table.projectId, table.validFrom, table.validTo),
160
- // Agent-aware retrieval optimization
161
- index('memories_agent_visibility_idx').on(table.agentId, table.visibilityScope, table.isActive),
162
- ]);
163
- /**
164
- * Conversations - chat session tracking
165
- */
166
- export const conversations = sqliteTable('conversations', {
167
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
168
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
169
- userId: text('user_id').references(() => users.id, { onDelete: 'set null' }),
170
- sessionId: text('session_id').notNull(),
171
- title: text('title'),
172
- summary: text('summary'),
173
- messageCount: integer('message_count').default(0),
174
- tokenCount: integer('token_count').default(0),
175
- startedAt: integer('started_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
176
- endedAt: integer('ended_at', { mode: 'timestamp' }),
177
- metadata: text('metadata').$type(),
178
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
179
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
180
- }, (table) => [
181
- index('conversations_project_idx').on(table.projectId),
182
- index('conversations_session_idx').on(table.sessionId),
183
- index('conversations_started_idx').on(table.startedAt),
184
- ]);
185
- /**
186
- * Messages - individual messages in conversations
187
- */
188
- export const messages = sqliteTable('messages', {
189
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
190
- conversationId: text('conversation_id').notNull().references(() => conversations.id, { onDelete: 'cascade' }),
191
- role: text('role').notNull().$type(),
192
- content: text('content').notNull(),
193
- embeddingJson: text('embedding_json'),
194
- tokenCount: integer('token_count'),
195
- toolCalls: text('tool_calls').$type(),
196
- metadata: text('metadata').$type(),
197
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
198
- }, (table) => [
199
- index('messages_conversation_idx').on(table.conversationId),
200
- index('messages_role_idx').on(table.role),
201
- index('messages_created_idx').on(table.createdAt),
202
- ]);
203
- /**
204
- * Learnings - agent learnings: success, failure, fix, insight
205
- */
206
- export const learnings = sqliteTable('learnings', {
207
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
208
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
209
- conversationId: text('conversation_id').references(() => conversations.id, { onDelete: 'set null' }),
210
- // Learning type: success, failure, fix, insight
211
- type: text('type').notNull().$type(),
212
- action: text('action').notNull(),
213
- target: text('target'),
214
- summary: text('summary').notNull(),
215
- details: text('details').$type(),
216
- // Embeddings
217
- embeddingJson: text('embedding_json'),
218
- embedding: blob('embedding'),
219
- // Optional link to a memory (for bidirectional linking)
220
- memoryId: text('memory_id').references(() => memories.id, { onDelete: 'set null' }),
221
- // Folder-scoped
222
- folderPath: text('folder_path'),
223
- projectPath: text('project_path'),
224
- // Privacy and relevance
225
- isPrivate: integer('is_private', { mode: 'boolean' }).default(false),
226
- hasSecrets: integer('has_secrets', { mode: 'boolean' }).default(false),
227
- relevanceScore: integer('relevance_score').default(50),
228
- category: text('category'),
229
- importance: integer('importance').default(50),
230
- metadata: text('metadata').$type(),
231
- // Migration tracking
232
- isImported: integer('is_imported', { mode: 'boolean' }).default(false),
233
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
234
- }, (table) => [
235
- index('learnings_project_idx').on(table.projectId),
236
- index('learnings_type_idx').on(table.type),
237
- index('learnings_action_idx').on(table.action),
238
- index('learnings_created_idx').on(table.createdAt),
239
- index('learnings_folder_idx').on(table.folderPath),
240
- index('learnings_relevance_idx').on(table.relevanceScore),
241
- index('learnings_private_idx').on(table.isPrivate),
242
- index('learnings_memory_idx').on(table.memoryId),
243
- ]);
244
- /**
245
- * Entities - named entities in the codebase
246
- */
247
- export const entities = sqliteTable('entities', {
248
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
249
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
250
- name: text('name').notNull(),
251
- type: text('type').notNull(),
252
- description: text('description'),
253
- embeddingJson: text('embedding_json'),
254
- properties: text('properties').$type(),
255
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
256
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
257
- }, (table) => [
258
- index('entities_project_idx').on(table.projectId),
259
- index('entities_type_idx').on(table.type),
260
- index('entities_name_idx').on(table.name),
261
- ]);
262
- /**
263
- * Namespaces - Hierarchical folder-like namespaces for memory organization
264
- */
265
- export const namespaces = sqliteTable('namespaces', {
266
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
267
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
268
- name: text('name').notNull(),
269
- parentId: text('parent_id').references(() => namespaces.id, { onDelete: 'set null' }),
270
- type: text('type'),
271
- description: text('description'),
272
- path: text('path'),
273
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
274
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
275
- }, (table) => [
276
- index('namespaces_project_idx').on(table.projectId),
277
- index('namespaces_parent_idx').on(table.parentId),
278
- ]);
279
- /**
280
- * Places - Spatial memory organization (Method of Loci)
281
- */
282
- export const places = sqliteTable('places', {
283
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
284
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }).notNull(),
285
- name: text('name').notNull(),
286
- placeType: text('place_type').notNull(),
287
- parentId: text('parent_id').references(() => places.id, { onDelete: 'set null' }),
288
- lociIndex: integer('loci_index').default(0),
289
- positionX: integer('position_x').default(0),
290
- positionY: integer('position_y').default(0),
291
- description: text('description'),
292
- purpose: text('purpose'),
293
- memoryCount: integer('memory_count').default(0),
294
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
295
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
296
- }, (table) => [
297
- index('places_project_idx').on(table.projectId),
298
- index('places_type_idx').on(table.placeType),
299
- index('places_parent_idx').on(table.parentId),
300
- index('places_loci_idx').on(table.projectId, table.lociIndex),
301
- ]);
302
- /**
303
- * Memory-Place assignments
304
- */
305
- export const memoryPlaces = sqliteTable('memory_places', {
306
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
307
- memoryId: text('memory_id').references(() => memories.id, { onDelete: 'cascade' }).notNull(),
308
- placeId: text('place_id').references(() => places.id, { onDelete: 'cascade' }).notNull(),
309
- isManual: integer('is_manual').default(0),
310
- ruleId: text('rule_id'),
311
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
312
- }, (table) => [
313
- index('memory_places_memory_idx').on(table.memoryId),
314
- index('memory_places_place_idx').on(table.placeId),
315
- ]);
316
- /**
317
- * Place auto-assignment rules
318
- */
319
- export const placeRules = sqliteTable('place_rules', {
320
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
321
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }).notNull(),
322
- name: text('name').notNull(),
323
- placeType: text('place_type').notNull(),
324
- matchTool: text('match_tool'),
325
- matchKeyword: text('match_keyword'),
326
- matchTag: text('match_tag'),
327
- matchMemoryType: text('match_memory_type'),
328
- priority: integer('priority').default(0),
329
- enabled: integer('enabled').default(1),
330
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
331
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
332
- }, (table) => [
333
- index('place_rules_project_idx').on(table.projectId),
334
- index('place_rules_type_idx').on(table.placeType),
335
- ]);
336
- /**
337
- * Memory Layers - Tiered L0/L1/L2 summaries for token-efficient retrieval
338
- */
339
- export const memoryLayers = sqliteTable('memory_layers', {
340
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
341
- memoryId: text('memory_id').references(() => memories.id, { onDelete: 'cascade' }),
342
- layerType: text('layer_type').notNull().$type(),
343
- content: text('content').notNull(),
344
- tokenCount: integer('token_count').default(0),
345
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
346
- }, (table) => [
347
- index('memory_layers_memory_idx').on(table.memoryId),
348
- index('memory_layers_type_idx').on(table.layerType),
349
- ]);
350
- // Progressive Disclosure & Context Paging Tables
351
- // ============================================================================
352
- /**
353
- * Lightweight memory indices for progressive disclosure - previews and metadata
354
- * used for quick filtering before loading full memories
355
- */
356
- export const lightweightMemoryIndices = sqliteTable('lightweight_memory_indices', {
357
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
358
- memoryId: text('memory_id').references(() => memories.id, { onDelete: 'cascade' }),
359
- // Hash for quick comparison
360
- contentHash: text('content_hash').notNull(),
361
- contentPreview: text('content_preview').notNull(),
362
- keyTerms: text('key_terms').$type(),
363
- // Categorization
364
- category: text('category').notNull(),
365
- importanceScore: integer('importance_score').notNull(),
366
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
367
- }, (table) => [
368
- index('lightweight_indices_memory_idx').on(table.memoryId),
369
- index('lightweight_indices_category_idx').on(table.category),
370
- index('lightweight_indices_importance_idx').on(table.importanceScore),
371
- ]);
372
- /**
373
- * Context paging sessions for tracking loaded/preloaded memories
374
- * Agent-controlled memory loading system
375
- */
376
- export const contextPagingSessions = sqliteTable('context_paging_sessions', {
377
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
378
- sessionId: text('session_id').notNull().unique(),
379
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
380
- userId: text('user_id').references(() => users.id, { onDelete: 'set null' }),
381
- // Loaded memories (actively in context)
382
- loadedMemoryIds: text('loaded_memory_ids').$type().default([]),
383
- // Preload candidates (ready to load if needed)
384
- preloadCandidateIds: text('preload_candidate_ids').$type().default([]),
385
- // Token tracking
386
- tokenBudget: integer('token_budget').default(8000).notNull(),
387
- tokensUsed: integer('tokens_used').default(0).notNull(),
388
- loadedMemoriesTokens: integer('loaded_memories_tokens').default(0).notNull(),
389
- // Session metadata
390
- metadata: text('metadata').$type(),
391
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
392
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
393
- }, (table) => [
394
- index('context_paging_session_idx').on(table.sessionId),
395
- index('context_paging_project_idx').on(table.projectId),
396
- index('context_paging_created_idx').on(table.createdAt),
397
- ]);
398
- // Memory Merging Tables
399
- // ============================================================================
400
- /**
401
- * Memory Merge Proposals - tracks suggested merges before user approval
402
- */
403
- export const memoryMergeProposals = sqliteTable('memory_merge_proposals', {
404
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
405
- projectId: text('project_id').notNull().references(() => projects.id, { onDelete: 'cascade' }),
406
- userId: text('user_id').references(() => users.id, { onDelete: 'set null' }),
407
- sourceMemoryIds: text('source_memory_ids').$type().notNull(),
408
- proposedContent: text('proposed_content').notNull(),
409
- proposedSummary: text('proposed_summary'),
410
- proposedTags: text('proposed_tags').$type(),
411
- proposedMetadata: text('proposed_metadata').$type(),
412
- detectionMethod: text('detection_method').notNull().$type(),
413
- similarityScore: text('similarity_score').notNull(),
414
- confidenceLevel: text('confidence_level').notNull().$type(),
415
- mergeReason: text('merge_reason').notNull(),
416
- conflictWarnings: text('conflict_warnings').$type(),
417
- status: text('status').$type().default('pending').notNull(),
418
- reviewedAt: integer('reviewed_at', { mode: 'timestamp' }),
419
- reviewNotes: text('review_notes'),
420
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
421
- expiresAt: integer('expires_at', { mode: 'timestamp' }),
422
- }, (table) => [
423
- index('memory_merge_proposals_project_status_idx').on(table.projectId, table.status),
424
- index('memory_merge_proposals_created_at_idx').on(table.createdAt),
425
- ]);
426
- /**
427
- * Memory Merge History - audit trail of completed merges
428
- */
429
- export const memoryMergeHistory = sqliteTable('memory_merge_history', {
430
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
431
- projectId: text('project_id').notNull().references(() => projects.id, { onDelete: 'cascade' }),
432
- userId: text('user_id').references(() => users.id, { onDelete: 'set null' }),
433
- proposalId: text('proposal_id').references(() => memoryMergeProposals.id, { onDelete: 'set null' }),
434
- sourceMemoryIds: text('source_memory_ids').$type().notNull(),
435
- canonicalMemoryId: text('canonical_memory_id').notNull().references(() => memories.id, { onDelete: 'cascade' }),
436
- sourceMemoriesSnapshot: text('source_memories_snapshot').$type().notNull(),
437
- mergeStrategy: text('merge_strategy').notNull().$type(),
438
- tokensSaved: integer('tokens_saved'),
439
- isReversed: integer('is_reversed', { mode: 'boolean' }).default(false),
440
- reversedAt: integer('reversed_at', { mode: 'timestamp' }),
441
- reversedBy: text('reversed_by'),
442
- mergedAt: integer('merged_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
443
- });
444
- /**
445
- * Memory Hash Cache - cached hash signatures for efficient duplicate detection
446
- */
447
- export const memoryHashCache = sqliteTable('memory_hash_cache', {
448
- memoryId: text('memory_id').primaryKey().references(() => memories.id, { onDelete: 'cascade' }),
449
- projectId: text('project_id').notNull().references(() => projects.id, { onDelete: 'cascade' }),
450
- simhash: text('simhash'),
451
- minhash: text('minhash').$type(),
452
- contentHash: text('content_hash').notNull(),
453
- lastUpdated: integer('last_updated', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
454
- }, (table) => [
455
- index('memory_hash_cache_project_id_idx').on(table.projectId),
456
- index('memory_hash_cache_simhash_idx').on(table.simhash),
457
- ]);
458
- /**
459
- * Entity Relations - relationships between entities
460
- */
461
- export const entityRelations = sqliteTable('entity_relations', {
462
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
463
- fromEntityId: text('from_entity_id').notNull().references(() => entities.id, { onDelete: 'cascade' }),
464
- toEntityId: text('to_entity_id').notNull().references(() => entities.id, { onDelete: 'cascade' }),
465
- type: text('type').notNull(),
466
- weight: integer('weight').default(1),
467
- properties: text('properties').$type(),
468
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
469
- }, (table) => [
470
- index('relations_from_idx').on(table.fromEntityId),
471
- index('relations_to_idx').on(table.toEntityId),
472
- index('relations_type_idx').on(table.type),
473
- ]);
474
- // v0.3.0: Lifecycle Features - Associations, Summarization, Snapshots
475
- // ============================================================================
476
- /**
477
- * Memory Associations - waypoint graph for co-activation tracking
478
- */
479
- export const memoryAssociations = sqliteTable('memory_associations', {
480
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
481
- fromMemoryId: text('from_memory_id').notNull().references(() => memories.id, { onDelete: 'cascade' }),
482
- toMemoryId: text('to_memory_id').notNull().references(() => memories.id, { onDelete: 'cascade' }),
483
- associationType: text('association_type').notNull().$type(),
484
- weight: integer('weight').default(1),
485
- coactivationCount: integer('coactivation_count').default(0),
486
- metadata: text('metadata').$type(),
487
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
488
- lastCoactivatedAt: integer('last_coactivated_at', { mode: 'timestamp' }),
489
- }, (table) => [
490
- index('memory_associations_from_idx').on(table.fromMemoryId),
491
- index('memory_associations_to_idx').on(table.toMemoryId),
492
- index('memory_associations_type_idx').on(table.associationType),
493
- index('memory_associations_weight_idx').on(table.weight),
494
- // v0.4.2: Composite index for graph traversal optimization
495
- index('memory_associations_graph_traversal_idx').on(table.fromMemoryId, table.toMemoryId, table.weight, table.associationType),
496
- ]);
497
- /**
498
- * Session Summaries - incremental and rolling session summaries
499
- */
500
- export const sessionSummaries = sqliteTable('session_summaries', {
501
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
502
- conversationId: text('conversation_id').notNull().references(() => conversations.id, { onDelete: 'cascade' }),
503
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
504
- summaryType: text('summary_type').notNull().$type(),
505
- content: text('content').notNull(),
506
- compressedFrom: integer('compressed_from'),
507
- tokensSaved: integer('tokens_saved'),
508
- embedding: blob('embedding'),
509
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
510
- }, (table) => [
511
- index('session_summaries_conversation_idx').on(table.conversationId),
512
- index('session_summaries_project_idx').on(table.projectId),
513
- index('session_summaries_type_idx').on(table.summaryType),
514
- index('session_summaries_created_idx').on(table.createdAt),
515
- ]);
516
- /**
517
- * Memory Snapshots - before/after diffs for auditability
518
- */
519
- export const memorySnapshots = sqliteTable('memory_snapshots', {
520
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
521
- memoryId: text('memory_id').notNull().references(() => memories.id, { onDelete: 'cascade' }),
522
- snapshotType: text('snapshot_type').notNull().$type(),
523
- content: text('content').notNull(),
524
- metadata: text('metadata').$type(),
525
- diff: text('diff').$type(),
526
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
527
- }, (table) => [
528
- index('memory_snapshots_memory_idx').on(table.memoryId),
529
- index('memory_snapshots_type_idx').on(table.snapshotType),
530
- index('memory_snapshots_created_idx').on(table.createdAt),
531
- ]);
532
- /**
533
- * Core Memory - Always-in-context memory (Tier 1)
534
- * Small, persistent, always-visible memory block (< 2KB total)
535
- */
536
- export const coreMemory = sqliteTable('core_memory', {
537
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
538
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
539
- userId: text('user_id').references(() => users.id, { onDelete: 'set null' }),
540
- // Core memory sections
541
- section: text('section').notNull().$type(),
542
- content: text('content').notNull().default(''),
543
- sizeBytes: integer('size_bytes').default(0).notNull(),
544
- tokensEstimate: integer('tokens_estimate').default(0).notNull(),
545
- // Version tracking
546
- version: integer('version').default(1).notNull(),
547
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
548
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
549
- }, (table) => [
550
- index('core_memory_project_idx').on(table.projectId),
551
- index('core_memory_user_idx').on(table.userId),
552
- index('core_memory_section_idx').on(table.section),
553
- ]);
554
- /**
555
- * Context Sessions - Track loaded memories and context window usage
556
- */
557
- export const contextSessions = sqliteTable('context_sessions', {
558
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
559
- sessionId: text('session_id').notNull().unique(),
560
- projectId: text('project_id').references(() => projects.id, { onDelete: 'cascade' }),
561
- userId: text('user_id').references(() => users.id, { onDelete: 'set null' }),
562
- // Loaded memories (paging system)
563
- loadedMemoryIds: text('loaded_memory_ids').$type().default([]),
564
- // Token tracking
565
- tokenBudget: integer('token_budget').default(8000).notNull(),
566
- tokensUsed: integer('tokens_used').default(0).notNull(),
567
- coreMemoryTokens: integer('core_memory_tokens').default(0).notNull(),
568
- loadedMemoriesTokens: integer('loaded_memories_tokens').default(0).notNull(),
569
- // Session metadata
570
- metadata: text('metadata').$type(),
571
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
572
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
573
- }, (table) => [
574
- index('context_sessions_session_idx').on(table.sessionId),
575
- index('context_sessions_project_idx').on(table.projectId),
576
- index('context_sessions_created_idx').on(table.createdAt),
577
- ]);
578
- // v0.10.0: Echo/Fizzle Tracking & Scheduled Maintenance
579
- // ============================================================================
580
- export const memoryFeedback = sqliteTable('memory_feedback', {
581
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
582
- memoryId: text('memory_id').notNull().references(() => memories.id, { onDelete: 'cascade' }),
583
- sessionId: text('session_id').notNull(),
584
- conversationId: text('conversation_id').references(() => conversations.id, { onDelete: 'set null' }),
585
- wasInjected: integer('was_injected', { mode: 'boolean' }).default(false),
586
- wasReferenced: integer('was_referenced', { mode: 'boolean' }).default(false),
587
- referenceCount: integer('reference_count').default(0),
588
- retrievalPriorityDelta: integer('retrieval_priority_delta').default(0),
589
- injectedAt: integer('injected_at', { mode: 'timestamp' }),
590
- referencedAt: integer('referenced_at', { mode: 'timestamp' }),
591
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
592
- }, (table) => [
593
- index('memory_feedback_memory_idx').on(table.memoryId),
594
- index('memory_feedback_session_idx').on(table.sessionId),
595
- index('memory_feedback_referenced_idx').on(table.wasReferenced),
596
- index('memory_feedback_conversation_idx').on(table.conversationId),
597
- ]);
598
- export const maintenanceJobs = sqliteTable('maintenance_jobs', {
599
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
600
- jobName: text('job_name').notNull().unique(),
601
- jobType: text('job_type').notNull().$type(),
602
- cronExpression: text('cron_expression'),
603
- enabled: integer('enabled', { mode: 'boolean' }).default(true),
604
- lastRunAt: integer('last_run_at', { mode: 'timestamp' }),
605
- nextRunAt: integer('next_run_at', { mode: 'timestamp' }),
606
- lastRunDuration: integer('last_run_duration'),
607
- lastRunStatus: text('last_run_status').$type(),
608
- lastRunError: text('last_run_error'),
609
- totalRuns: integer('total_runs').default(0),
610
- successCount: integer('success_count').default(0),
611
- failureCount: integer('failure_count').default(0),
612
- jobConfig: text('job_config').$type(),
613
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
614
- updatedAt: integer('updated_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
615
- }, (table) => [
616
- index('maintenance_jobs_name_idx').on(table.jobName),
617
- index('maintenance_jobs_next_run_idx').on(table.nextRunAt),
618
- index('maintenance_jobs_type_idx').on(table.jobType),
619
- index('maintenance_jobs_enabled_idx').on(table.enabled),
620
- ]);
621
- export const maintenanceJobHistory = sqliteTable('maintenance_job_history', {
622
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
623
- jobId: text('job_id').notNull().references(() => maintenanceJobs.id, { onDelete: 'cascade' }),
624
- startedAt: integer('started_at', { mode: 'timestamp' }).notNull(),
625
- completedAt: integer('completed_at', { mode: 'timestamp' }),
626
- duration: integer('duration'),
627
- status: text('status').notNull().$type(),
628
- error: text('error'),
629
- recordsProcessed: integer('records_processed').default(0),
630
- resultSummary: text('result_summary').$type(),
631
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
632
- }, (table) => [
633
- index('maintenance_job_history_job_idx').on(table.jobId),
634
- index('maintenance_job_history_started_idx').on(table.startedAt),
635
- index('maintenance_job_history_status_idx').on(table.status),
636
- ]);
637
- // Memory Editing Tables (SQLite)
638
- // ============================================================================
639
- export const memoryEditProposals = sqliteTable('memory_edit_proposals', {
640
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
641
- projectId: text('project_id').notNull().references(() => projects.id, { onDelete: 'cascade' }),
642
- userId: text('user_id').references(() => users.id, { onDelete: 'set null' }),
643
- memoryId: text('memory_id').notNull().references(() => memories.id, { onDelete: 'cascade' }),
644
- currentContent: text('current_content').notNull(),
645
- proposedContent: text('proposed_content').notNull(),
646
- reason: text('reason').notNull(),
647
- conflictWarnings: text('conflict_warnings').$type(),
648
- status: text('status').$type().default('pending').notNull(),
649
- version: integer('version').default(1).notNull(),
650
- createdAt: integer('created_at', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
651
- reviewedAt: integer('reviewed_at', { mode: 'timestamp' }),
652
- reviewNotes: text('review_notes'),
653
- }, (table) => [
654
- index('memory_edit_proposals_memory_idx').on(table.memoryId),
655
- index('memory_edit_proposals_status_idx').on(table.status),
656
- index('memory_edit_proposals_created_at_idx').on(table.createdAt),
657
- ]);
658
- // Phase 3: Retrieval Tracing - Search Traces table
659
- // ============================================================================
660
- /**
661
- * Search Traces - Stores retrieval logs for debugging and performance analysis
662
- */
663
- export const searchTraces = sqliteTable('search_traces', {
664
- id: text('id').primaryKey().$default(() => crypto.randomUUID()),
665
- sessionId: text('session_id').notNull(),
666
- query: text('query').notNull(),
667
- timestamp: integer('timestamp', { mode: 'timestamp' }).default(sql `CURRENT_TIMESTAMP`).notNull(),
668
- // Search pipeline stages (JSONB stored as text for SQLite)
669
- queryRewrite: text('query_rewrite').$type(),
670
- candidateRetrieval: text('candidate_retrieval').$type(),
671
- entityFiltering: text('entity_filtering').$type(),
672
- hybridScoring: text('hybrid_scoring').$type(),
673
- reranking: text('reranking').$type(),
674
- // Final results
675
- resultCount: integer('result_count').default(0),
676
- topResults: text('top_results').$type(),
677
- // Performance metrics
678
- totalDurationMs: integer('total_duration_ms').default(0),
679
- metadata: text('metadata').$type(),
680
- }, (table) => [
681
- index('search_traces_session_idx').on(table.sessionId),
682
- index('search_traces_timestamp_idx').on(table.timestamp),
683
- ]);
684
- //# sourceMappingURL=schema-sqlite.js.map