moflo 4.8.16 → 4.8.17

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 (466) hide show
  1. package/.claude/agents/browser/browser-agent.yaml +182 -182
  2. package/.claude/agents/core/coder.md +265 -265
  3. package/.claude/agents/core/planner.md +167 -167
  4. package/.claude/agents/core/researcher.md +189 -189
  5. package/.claude/agents/core/reviewer.md +325 -325
  6. package/.claude/agents/core/tester.md +318 -318
  7. package/.claude/agents/database-specialist.yaml +21 -21
  8. package/.claude/agents/dual-mode/codex-coordinator.md +224 -224
  9. package/.claude/agents/dual-mode/codex-worker.md +211 -211
  10. package/.claude/agents/dual-mode/dual-orchestrator.md +291 -291
  11. package/.claude/agents/github/code-review-swarm.md +537 -537
  12. package/.claude/agents/github/github-modes.md +172 -172
  13. package/.claude/agents/github/issue-tracker.md +318 -318
  14. package/.claude/agents/github/multi-repo-swarm.md +552 -552
  15. package/.claude/agents/github/pr-manager.md +190 -190
  16. package/.claude/agents/github/project-board-sync.md +508 -508
  17. package/.claude/agents/github/release-manager.md +366 -366
  18. package/.claude/agents/github/release-swarm.md +582 -582
  19. package/.claude/agents/github/repo-architect.md +397 -397
  20. package/.claude/agents/github/swarm-issue.md +572 -572
  21. package/.claude/agents/github/swarm-pr.md +427 -427
  22. package/.claude/agents/github/sync-coordinator.md +451 -451
  23. package/.claude/agents/github/workflow-automation.md +634 -634
  24. package/.claude/agents/goal/code-goal-planner.md +445 -445
  25. package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +129 -129
  26. package/.claude/agents/hive-mind/queen-coordinator.md +202 -202
  27. package/.claude/agents/hive-mind/scout-explorer.md +241 -241
  28. package/.claude/agents/hive-mind/swarm-memory-manager.md +192 -192
  29. package/.claude/agents/hive-mind/worker-specialist.md +216 -216
  30. package/.claude/agents/index.yaml +17 -17
  31. package/.claude/agents/neural/safla-neural.md +73 -73
  32. package/.claude/agents/project-coordinator.yaml +15 -15
  33. package/.claude/agents/python-specialist.yaml +21 -21
  34. package/.claude/agents/reasoning/goal-planner.md +72 -72
  35. package/.claude/agents/security-auditor.yaml +20 -20
  36. package/.claude/agents/swarm/adaptive-coordinator.md +395 -395
  37. package/.claude/agents/swarm/hierarchical-coordinator.md +326 -326
  38. package/.claude/agents/swarm/mesh-coordinator.md +391 -391
  39. package/.claude/agents/templates/migration-plan.md +745 -745
  40. package/.claude/agents/typescript-specialist.yaml +21 -21
  41. package/.claude/checkpoints/1767754460.json +8 -8
  42. package/.claude/commands/agents/agent-spawning.md +28 -28
  43. package/.claude/commands/github/github-modes.md +146 -146
  44. package/.claude/commands/github/github-swarm.md +121 -121
  45. package/.claude/commands/github/issue-tracker.md +291 -291
  46. package/.claude/commands/github/pr-manager.md +169 -169
  47. package/.claude/commands/github/release-manager.md +337 -337
  48. package/.claude/commands/github/repo-architect.md +366 -366
  49. package/.claude/commands/github/sync-coordinator.md +300 -300
  50. package/.claude/commands/memory/neural.md +47 -47
  51. package/.claude/commands/sparc/analyzer.md +51 -51
  52. package/.claude/commands/sparc/architect.md +53 -53
  53. package/.claude/commands/sparc/ask.md +97 -97
  54. package/.claude/commands/sparc/batch-executor.md +54 -54
  55. package/.claude/commands/sparc/code.md +89 -89
  56. package/.claude/commands/sparc/coder.md +54 -54
  57. package/.claude/commands/sparc/debug.md +83 -83
  58. package/.claude/commands/sparc/debugger.md +54 -54
  59. package/.claude/commands/sparc/designer.md +53 -53
  60. package/.claude/commands/sparc/devops.md +109 -109
  61. package/.claude/commands/sparc/docs-writer.md +80 -80
  62. package/.claude/commands/sparc/documenter.md +54 -54
  63. package/.claude/commands/sparc/innovator.md +54 -54
  64. package/.claude/commands/sparc/integration.md +83 -83
  65. package/.claude/commands/sparc/mcp.md +117 -117
  66. package/.claude/commands/sparc/memory-manager.md +54 -54
  67. package/.claude/commands/sparc/optimizer.md +54 -54
  68. package/.claude/commands/sparc/orchestrator.md +131 -131
  69. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -83
  70. package/.claude/commands/sparc/refinement-optimization-mode.md +83 -83
  71. package/.claude/commands/sparc/researcher.md +54 -54
  72. package/.claude/commands/sparc/reviewer.md +54 -54
  73. package/.claude/commands/sparc/security-review.md +80 -80
  74. package/.claude/commands/sparc/sparc-modes.md +174 -174
  75. package/.claude/commands/sparc/sparc.md +111 -111
  76. package/.claude/commands/sparc/spec-pseudocode.md +80 -80
  77. package/.claude/commands/sparc/supabase-admin.md +348 -348
  78. package/.claude/commands/sparc/swarm-coordinator.md +54 -54
  79. package/.claude/commands/sparc/tdd.md +54 -54
  80. package/.claude/commands/sparc/tester.md +54 -54
  81. package/.claude/commands/sparc/tutorial.md +79 -79
  82. package/.claude/commands/sparc/workflow-manager.md +54 -54
  83. package/.claude/commands/sparc.md +166 -166
  84. package/.claude/commands/swarm/analysis.md +95 -95
  85. package/.claude/commands/swarm/development.md +96 -96
  86. package/.claude/commands/swarm/examples.md +168 -168
  87. package/.claude/commands/swarm/maintenance.md +102 -102
  88. package/.claude/commands/swarm/optimization.md +117 -117
  89. package/.claude/commands/swarm/research.md +136 -136
  90. package/.claude/commands/swarm/testing.md +131 -131
  91. package/.claude/commands/workflows/development.md +77 -77
  92. package/.claude/commands/workflows/research.md +62 -62
  93. package/.claude/guidance/moflo-bootstrap.md +126 -126
  94. package/.claude/guidance/shipped/agent-bootstrap.md +126 -126
  95. package/.claude/guidance/shipped/guidance-memory-strategy.md +262 -262
  96. package/.claude/guidance/shipped/memory-strategy.md +204 -204
  97. package/.claude/guidance/shipped/moflo.md +608 -608
  98. package/.claude/guidance/shipped/task-swarm-integration.md +441 -441
  99. package/.claude/helpers/intelligence.cjs +207 -207
  100. package/.claude/helpers/statusline.cjs +851 -851
  101. package/.claude/skills/fl/SKILL.md +583 -583
  102. package/.claude/skills/flo/SKILL.md +583 -583
  103. package/.claude/skills/github-code-review/SKILL.md +1140 -1140
  104. package/.claude/skills/github-multi-repo/SKILL.md +874 -874
  105. package/.claude/skills/github-project-management/SKILL.md +1277 -1277
  106. package/.claude/skills/github-release-management/SKILL.md +1081 -1081
  107. package/.claude/skills/github-workflow-automation/SKILL.md +1065 -1065
  108. package/.claude/skills/hive-mind-advanced/SKILL.md +712 -712
  109. package/.claude/skills/hooks-automation/SKILL.md +1201 -1201
  110. package/.claude/skills/performance-analysis/SKILL.md +563 -563
  111. package/.claude/skills/sparc-methodology/SKILL.md +1115 -1115
  112. package/.claude/skills/swarm-advanced/SKILL.md +973 -973
  113. package/LICENSE +21 -21
  114. package/README.md +685 -685
  115. package/bin/cli.js +0 -0
  116. package/bin/gate-hook.mjs +50 -50
  117. package/bin/gate.cjs +138 -138
  118. package/bin/hook-handler.cjs +83 -83
  119. package/bin/hooks.mjs +656 -656
  120. package/bin/index-guidance.mjs +892 -892
  121. package/bin/index-tests.mjs +709 -709
  122. package/bin/lib/process-manager.mjs +243 -243
  123. package/bin/lib/registry-cleanup.cjs +41 -41
  124. package/bin/prompt-hook.mjs +72 -72
  125. package/bin/semantic-search.mjs +472 -472
  126. package/bin/session-start-launcher.mjs +238 -226
  127. package/bin/setup-project.mjs +250 -250
  128. package/package.json +123 -121
  129. package/src/@claude-flow/cli/README.md +452 -452
  130. package/src/@claude-flow/cli/bin/cli.js +175 -175
  131. package/src/@claude-flow/cli/bin/preinstall.cjs +2 -2
  132. package/src/@claude-flow/cli/dist/src/commands/completions.js +409 -409
  133. package/src/@claude-flow/cli/dist/src/commands/doctor.js +1091 -1091
  134. package/src/@claude-flow/cli/dist/src/commands/embeddings.js +25 -25
  135. package/src/@claude-flow/cli/dist/src/commands/github.js +61 -61
  136. package/src/@claude-flow/cli/dist/src/commands/hive-mind.js +90 -90
  137. package/src/@claude-flow/cli/dist/src/commands/hooks.js +9 -9
  138. package/src/@claude-flow/cli/dist/src/commands/ruvector/import.js +14 -14
  139. package/src/@claude-flow/cli/dist/src/commands/ruvector/setup.js +624 -624
  140. package/src/@claude-flow/cli/dist/src/config/moflo-config.js +91 -91
  141. package/src/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts +29 -29
  142. package/src/@claude-flow/cli/dist/src/init/claudemd-generator.js +43 -43
  143. package/src/@claude-flow/cli/dist/src/init/executor.js +485 -453
  144. package/src/@claude-flow/cli/dist/src/init/helpers-generator.js +482 -482
  145. package/src/@claude-flow/cli/dist/src/init/moflo-init.d.ts +30 -30
  146. package/src/@claude-flow/cli/dist/src/init/moflo-init.js +839 -839
  147. package/src/@claude-flow/cli/dist/src/init/settings-generator.js +6 -2
  148. package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +786 -786
  149. package/src/@claude-flow/cli/dist/src/memory/memory-initializer.js +371 -371
  150. package/src/@claude-flow/cli/dist/src/runtime/headless.js +28 -28
  151. package/src/@claude-flow/cli/dist/src/services/headless-worker-executor.js +84 -84
  152. package/src/@claude-flow/cli/package.json +1 -1
  153. package/src/@claude-flow/guidance/README.md +1195 -1195
  154. package/src/@claude-flow/guidance/dist/adversarial.d.ts +284 -0
  155. package/src/@claude-flow/guidance/dist/adversarial.js +572 -0
  156. package/src/@claude-flow/guidance/dist/analyzer.d.ts +530 -0
  157. package/src/@claude-flow/guidance/dist/analyzer.js +2518 -0
  158. package/src/@claude-flow/guidance/dist/artifacts.d.ts +283 -0
  159. package/src/@claude-flow/guidance/dist/artifacts.js +356 -0
  160. package/src/@claude-flow/guidance/dist/authority.d.ts +290 -0
  161. package/src/@claude-flow/guidance/dist/authority.js +558 -0
  162. package/src/@claude-flow/guidance/dist/capabilities.d.ts +209 -0
  163. package/src/@claude-flow/guidance/dist/capabilities.js +485 -0
  164. package/src/@claude-flow/guidance/dist/coherence.d.ts +233 -0
  165. package/src/@claude-flow/guidance/dist/coherence.js +372 -0
  166. package/src/@claude-flow/guidance/dist/compiler.d.ts +87 -0
  167. package/src/@claude-flow/guidance/dist/compiler.js +419 -0
  168. package/src/@claude-flow/guidance/dist/conformance-kit.d.ts +225 -0
  169. package/src/@claude-flow/guidance/dist/conformance-kit.js +629 -0
  170. package/src/@claude-flow/guidance/dist/continue-gate.d.ts +214 -0
  171. package/src/@claude-flow/guidance/dist/continue-gate.js +353 -0
  172. package/src/@claude-flow/guidance/dist/crypto-utils.d.ts +17 -0
  173. package/src/@claude-flow/guidance/dist/crypto-utils.js +24 -0
  174. package/src/@claude-flow/guidance/dist/evolution.d.ts +282 -0
  175. package/src/@claude-flow/guidance/dist/evolution.js +500 -0
  176. package/src/@claude-flow/guidance/dist/gates.d.ts +79 -0
  177. package/src/@claude-flow/guidance/dist/gates.js +302 -0
  178. package/src/@claude-flow/guidance/dist/gateway.d.ts +206 -0
  179. package/src/@claude-flow/guidance/dist/gateway.js +452 -0
  180. package/src/@claude-flow/guidance/dist/generators.d.ts +153 -0
  181. package/src/@claude-flow/guidance/dist/generators.js +682 -0
  182. package/src/@claude-flow/guidance/dist/headless.d.ts +177 -0
  183. package/src/@claude-flow/guidance/dist/headless.js +342 -0
  184. package/src/@claude-flow/guidance/dist/hooks.d.ts +109 -0
  185. package/src/@claude-flow/guidance/dist/hooks.js +347 -0
  186. package/src/@claude-flow/guidance/dist/index.d.ts +205 -0
  187. package/src/@claude-flow/guidance/dist/index.js +321 -0
  188. package/src/@claude-flow/guidance/dist/ledger.d.ts +162 -0
  189. package/src/@claude-flow/guidance/dist/ledger.js +375 -0
  190. package/src/@claude-flow/guidance/dist/manifest-validator.d.ts +289 -0
  191. package/src/@claude-flow/guidance/dist/manifest-validator.js +838 -0
  192. package/src/@claude-flow/guidance/dist/memory-gate.d.ts +222 -0
  193. package/src/@claude-flow/guidance/dist/memory-gate.js +382 -0
  194. package/src/@claude-flow/guidance/dist/meta-governance.d.ts +265 -0
  195. package/src/@claude-flow/guidance/dist/meta-governance.js +348 -0
  196. package/src/@claude-flow/guidance/dist/optimizer.d.ts +104 -0
  197. package/src/@claude-flow/guidance/dist/optimizer.js +329 -0
  198. package/src/@claude-flow/guidance/dist/persistence.d.ts +189 -0
  199. package/src/@claude-flow/guidance/dist/persistence.js +464 -0
  200. package/src/@claude-flow/guidance/dist/proof.d.ts +185 -0
  201. package/src/@claude-flow/guidance/dist/proof.js +238 -0
  202. package/src/@claude-flow/guidance/dist/retriever.d.ts +116 -0
  203. package/src/@claude-flow/guidance/dist/retriever.js +394 -0
  204. package/src/@claude-flow/guidance/dist/ruvbot-integration.d.ts +370 -0
  205. package/src/@claude-flow/guidance/dist/ruvbot-integration.js +738 -0
  206. package/src/@claude-flow/guidance/dist/temporal.d.ts +426 -0
  207. package/src/@claude-flow/guidance/dist/temporal.js +658 -0
  208. package/src/@claude-flow/guidance/dist/trust.d.ts +283 -0
  209. package/src/@claude-flow/guidance/dist/trust.js +473 -0
  210. package/src/@claude-flow/guidance/dist/truth-anchors.d.ts +276 -0
  211. package/src/@claude-flow/guidance/dist/truth-anchors.js +488 -0
  212. package/src/@claude-flow/guidance/dist/types.d.ts +378 -0
  213. package/src/@claude-flow/guidance/dist/types.js +10 -0
  214. package/src/@claude-flow/guidance/dist/uncertainty.d.ts +372 -0
  215. package/src/@claude-flow/guidance/dist/uncertainty.js +619 -0
  216. package/src/@claude-flow/guidance/dist/wasm-kernel.d.ts +48 -0
  217. package/src/@claude-flow/guidance/dist/wasm-kernel.js +158 -0
  218. package/src/@claude-flow/guidance/package.json +198 -198
  219. package/src/@claude-flow/memory/README.md +587 -587
  220. package/src/@claude-flow/memory/package.json +44 -44
  221. package/src/@claude-flow/shared/README.md +323 -323
  222. package/src/README.md +493 -493
  223. package/.claude/settings.local.json +0 -18
  224. package/.claude/workflow-state.json +0 -9
  225. package/src/@claude-flow/cli/dist/src/services/container-worker-pool.d.ts +0 -197
  226. package/src/@claude-flow/cli/dist/src/services/container-worker-pool.js +0 -584
  227. package/src/@claude-flow/memory/dist/agent-memory-scope.d.ts +0 -131
  228. package/src/@claude-flow/memory/dist/agent-memory-scope.js +0 -223
  229. package/src/@claude-flow/memory/dist/agent-memory-scope.test.d.ts +0 -8
  230. package/src/@claude-flow/memory/dist/agent-memory-scope.test.js +0 -463
  231. package/src/@claude-flow/memory/dist/agentdb-adapter.d.ts +0 -165
  232. package/src/@claude-flow/memory/dist/agentdb-adapter.js +0 -806
  233. package/src/@claude-flow/memory/dist/agentdb-backend.d.ts +0 -214
  234. package/src/@claude-flow/memory/dist/agentdb-backend.js +0 -844
  235. package/src/@claude-flow/memory/dist/agentdb-backend.test.d.ts +0 -7
  236. package/src/@claude-flow/memory/dist/agentdb-backend.test.js +0 -258
  237. package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.d.ts +0 -65
  238. package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.js +0 -129
  239. package/src/@claude-flow/memory/dist/application/commands/store-memory.command.d.ts +0 -48
  240. package/src/@claude-flow/memory/dist/application/commands/store-memory.command.js +0 -72
  241. package/src/@claude-flow/memory/dist/application/index.d.ts +0 -12
  242. package/src/@claude-flow/memory/dist/application/index.js +0 -15
  243. package/src/@claude-flow/memory/dist/application/queries/search-memory.query.d.ts +0 -72
  244. package/src/@claude-flow/memory/dist/application/queries/search-memory.query.js +0 -143
  245. package/src/@claude-flow/memory/dist/application/services/memory-application-service.d.ts +0 -121
  246. package/src/@claude-flow/memory/dist/application/services/memory-application-service.js +0 -190
  247. package/src/@claude-flow/memory/dist/auto-memory-bridge.d.ts +0 -226
  248. package/src/@claude-flow/memory/dist/auto-memory-bridge.js +0 -709
  249. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.d.ts +0 -8
  250. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +0 -754
  251. package/src/@claude-flow/memory/dist/benchmark.test.d.ts +0 -2
  252. package/src/@claude-flow/memory/dist/benchmark.test.js +0 -277
  253. package/src/@claude-flow/memory/dist/cache-manager.d.ts +0 -134
  254. package/src/@claude-flow/memory/dist/cache-manager.js +0 -407
  255. package/src/@claude-flow/memory/dist/controller-registry.d.ts +0 -216
  256. package/src/@claude-flow/memory/dist/controller-registry.js +0 -893
  257. package/src/@claude-flow/memory/dist/controller-registry.test.d.ts +0 -14
  258. package/src/@claude-flow/memory/dist/controller-registry.test.js +0 -636
  259. package/src/@claude-flow/memory/dist/database-provider.d.ts +0 -87
  260. package/src/@claude-flow/memory/dist/database-provider.js +0 -375
  261. package/src/@claude-flow/memory/dist/database-provider.test.d.ts +0 -7
  262. package/src/@claude-flow/memory/dist/database-provider.test.js +0 -285
  263. package/src/@claude-flow/memory/dist/domain/entities/memory-entry.d.ts +0 -143
  264. package/src/@claude-flow/memory/dist/domain/entities/memory-entry.js +0 -226
  265. package/src/@claude-flow/memory/dist/domain/index.d.ts +0 -11
  266. package/src/@claude-flow/memory/dist/domain/index.js +0 -12
  267. package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.d.ts +0 -102
  268. package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.js +0 -11
  269. package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.d.ts +0 -105
  270. package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.js +0 -297
  271. package/src/@claude-flow/memory/dist/hnsw-index.d.ts +0 -111
  272. package/src/@claude-flow/memory/dist/hnsw-index.js +0 -781
  273. package/src/@claude-flow/memory/dist/hnsw-lite.d.ts +0 -23
  274. package/src/@claude-flow/memory/dist/hnsw-lite.js +0 -168
  275. package/src/@claude-flow/memory/dist/hybrid-backend.d.ts +0 -245
  276. package/src/@claude-flow/memory/dist/hybrid-backend.js +0 -569
  277. package/src/@claude-flow/memory/dist/hybrid-backend.test.d.ts +0 -8
  278. package/src/@claude-flow/memory/dist/hybrid-backend.test.js +0 -320
  279. package/src/@claude-flow/memory/dist/index.d.ts +0 -207
  280. package/src/@claude-flow/memory/dist/index.js +0 -361
  281. package/src/@claude-flow/memory/dist/infrastructure/index.d.ts +0 -17
  282. package/src/@claude-flow/memory/dist/infrastructure/index.js +0 -16
  283. package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.d.ts +0 -66
  284. package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.js +0 -409
  285. package/src/@claude-flow/memory/dist/learning-bridge.d.ts +0 -137
  286. package/src/@claude-flow/memory/dist/learning-bridge.js +0 -335
  287. package/src/@claude-flow/memory/dist/learning-bridge.test.d.ts +0 -8
  288. package/src/@claude-flow/memory/dist/learning-bridge.test.js +0 -578
  289. package/src/@claude-flow/memory/dist/memory-graph.d.ts +0 -100
  290. package/src/@claude-flow/memory/dist/memory-graph.js +0 -333
  291. package/src/@claude-flow/memory/dist/memory-graph.test.d.ts +0 -8
  292. package/src/@claude-flow/memory/dist/memory-graph.test.js +0 -609
  293. package/src/@claude-flow/memory/dist/migration.d.ts +0 -68
  294. package/src/@claude-flow/memory/dist/migration.js +0 -513
  295. package/src/@claude-flow/memory/dist/persistent-sona.d.ts +0 -144
  296. package/src/@claude-flow/memory/dist/persistent-sona.js +0 -332
  297. package/src/@claude-flow/memory/dist/query-builder.d.ts +0 -211
  298. package/src/@claude-flow/memory/dist/query-builder.js +0 -438
  299. package/src/@claude-flow/memory/dist/rvf-backend.d.ts +0 -51
  300. package/src/@claude-flow/memory/dist/rvf-backend.js +0 -481
  301. package/src/@claude-flow/memory/dist/rvf-learning-store.d.ts +0 -139
  302. package/src/@claude-flow/memory/dist/rvf-learning-store.js +0 -295
  303. package/src/@claude-flow/memory/dist/rvf-migration.d.ts +0 -45
  304. package/src/@claude-flow/memory/dist/rvf-migration.js +0 -234
  305. package/src/@claude-flow/memory/dist/sqlite-backend.d.ts +0 -121
  306. package/src/@claude-flow/memory/dist/sqlite-backend.js +0 -572
  307. package/src/@claude-flow/memory/dist/sqljs-backend.d.ts +0 -128
  308. package/src/@claude-flow/memory/dist/sqljs-backend.js +0 -601
  309. package/src/@claude-flow/memory/dist/types.d.ts +0 -484
  310. package/src/@claude-flow/memory/dist/types.js +0 -58
  311. package/src/@claude-flow/shared/dist/core/config/defaults.d.ts +0 -41
  312. package/src/@claude-flow/shared/dist/core/config/defaults.js +0 -186
  313. package/src/@claude-flow/shared/dist/core/config/index.d.ts +0 -8
  314. package/src/@claude-flow/shared/dist/core/config/index.js +0 -12
  315. package/src/@claude-flow/shared/dist/core/config/loader.d.ts +0 -45
  316. package/src/@claude-flow/shared/dist/core/config/loader.js +0 -222
  317. package/src/@claude-flow/shared/dist/core/config/schema.d.ts +0 -1134
  318. package/src/@claude-flow/shared/dist/core/config/schema.js +0 -158
  319. package/src/@claude-flow/shared/dist/core/config/validator.d.ts +0 -92
  320. package/src/@claude-flow/shared/dist/core/config/validator.js +0 -147
  321. package/src/@claude-flow/shared/dist/core/event-bus.d.ts +0 -31
  322. package/src/@claude-flow/shared/dist/core/event-bus.js +0 -197
  323. package/src/@claude-flow/shared/dist/core/index.d.ts +0 -15
  324. package/src/@claude-flow/shared/dist/core/index.js +0 -19
  325. package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +0 -200
  326. package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.js +0 -6
  327. package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +0 -310
  328. package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +0 -7
  329. package/src/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +0 -224
  330. package/src/@claude-flow/shared/dist/core/interfaces/event.interface.js +0 -46
  331. package/src/@claude-flow/shared/dist/core/interfaces/index.d.ts +0 -10
  332. package/src/@claude-flow/shared/dist/core/interfaces/index.js +0 -15
  333. package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +0 -298
  334. package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.js +0 -7
  335. package/src/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +0 -185
  336. package/src/@claude-flow/shared/dist/core/interfaces/task.interface.js +0 -6
  337. package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +0 -35
  338. package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +0 -101
  339. package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +0 -60
  340. package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +0 -166
  341. package/src/@claude-flow/shared/dist/core/orchestrator/index.d.ts +0 -46
  342. package/src/@claude-flow/shared/dist/core/orchestrator/index.js +0 -64
  343. package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +0 -56
  344. package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +0 -195
  345. package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +0 -83
  346. package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.js +0 -193
  347. package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +0 -49
  348. package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.js +0 -253
  349. package/src/@claude-flow/shared/dist/events/domain-events.d.ts +0 -282
  350. package/src/@claude-flow/shared/dist/events/domain-events.js +0 -165
  351. package/src/@claude-flow/shared/dist/events/event-store.d.ts +0 -126
  352. package/src/@claude-flow/shared/dist/events/event-store.js +0 -416
  353. package/src/@claude-flow/shared/dist/events/event-store.test.d.ts +0 -8
  354. package/src/@claude-flow/shared/dist/events/event-store.test.js +0 -293
  355. package/src/@claude-flow/shared/dist/events/example-usage.d.ts +0 -10
  356. package/src/@claude-flow/shared/dist/events/example-usage.js +0 -193
  357. package/src/@claude-flow/shared/dist/events/index.d.ts +0 -21
  358. package/src/@claude-flow/shared/dist/events/index.js +0 -22
  359. package/src/@claude-flow/shared/dist/events/projections.d.ts +0 -177
  360. package/src/@claude-flow/shared/dist/events/projections.js +0 -421
  361. package/src/@claude-flow/shared/dist/events/rvf-event-log.d.ts +0 -82
  362. package/src/@claude-flow/shared/dist/events/rvf-event-log.js +0 -340
  363. package/src/@claude-flow/shared/dist/events/state-reconstructor.d.ts +0 -101
  364. package/src/@claude-flow/shared/dist/events/state-reconstructor.js +0 -263
  365. package/src/@claude-flow/shared/dist/events.d.ts +0 -80
  366. package/src/@claude-flow/shared/dist/events.js +0 -249
  367. package/src/@claude-flow/shared/dist/hooks/example-usage.d.ts +0 -42
  368. package/src/@claude-flow/shared/dist/hooks/example-usage.js +0 -351
  369. package/src/@claude-flow/shared/dist/hooks/executor.d.ts +0 -100
  370. package/src/@claude-flow/shared/dist/hooks/executor.js +0 -264
  371. package/src/@claude-flow/shared/dist/hooks/hooks.test.d.ts +0 -9
  372. package/src/@claude-flow/shared/dist/hooks/hooks.test.js +0 -322
  373. package/src/@claude-flow/shared/dist/hooks/index.d.ts +0 -52
  374. package/src/@claude-flow/shared/dist/hooks/index.js +0 -51
  375. package/src/@claude-flow/shared/dist/hooks/registry.d.ts +0 -133
  376. package/src/@claude-flow/shared/dist/hooks/registry.js +0 -277
  377. package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +0 -105
  378. package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.js +0 -481
  379. package/src/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +0 -144
  380. package/src/@claude-flow/shared/dist/hooks/safety/file-organization.js +0 -328
  381. package/src/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +0 -158
  382. package/src/@claude-flow/shared/dist/hooks/safety/git-commit.js +0 -450
  383. package/src/@claude-flow/shared/dist/hooks/safety/index.d.ts +0 -17
  384. package/src/@claude-flow/shared/dist/hooks/safety/index.js +0 -17
  385. package/src/@claude-flow/shared/dist/hooks/session-hooks.d.ts +0 -234
  386. package/src/@claude-flow/shared/dist/hooks/session-hooks.js +0 -334
  387. package/src/@claude-flow/shared/dist/hooks/task-hooks.d.ts +0 -163
  388. package/src/@claude-flow/shared/dist/hooks/task-hooks.js +0 -326
  389. package/src/@claude-flow/shared/dist/hooks/types.d.ts +0 -267
  390. package/src/@claude-flow/shared/dist/hooks/types.js +0 -62
  391. package/src/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +0 -9
  392. package/src/@claude-flow/shared/dist/hooks/verify-exports.test.js +0 -93
  393. package/src/@claude-flow/shared/dist/index.d.ts +0 -20
  394. package/src/@claude-flow/shared/dist/index.js +0 -50
  395. package/src/@claude-flow/shared/dist/mcp/connection-pool.d.ts +0 -98
  396. package/src/@claude-flow/shared/dist/mcp/connection-pool.js +0 -364
  397. package/src/@claude-flow/shared/dist/mcp/index.d.ts +0 -69
  398. package/src/@claude-flow/shared/dist/mcp/index.js +0 -84
  399. package/src/@claude-flow/shared/dist/mcp/server.d.ts +0 -166
  400. package/src/@claude-flow/shared/dist/mcp/server.js +0 -593
  401. package/src/@claude-flow/shared/dist/mcp/session-manager.d.ts +0 -136
  402. package/src/@claude-flow/shared/dist/mcp/session-manager.js +0 -335
  403. package/src/@claude-flow/shared/dist/mcp/tool-registry.d.ts +0 -178
  404. package/src/@claude-flow/shared/dist/mcp/tool-registry.js +0 -439
  405. package/src/@claude-flow/shared/dist/mcp/transport/http.d.ts +0 -104
  406. package/src/@claude-flow/shared/dist/mcp/transport/http.js +0 -476
  407. package/src/@claude-flow/shared/dist/mcp/transport/index.d.ts +0 -102
  408. package/src/@claude-flow/shared/dist/mcp/transport/index.js +0 -238
  409. package/src/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +0 -104
  410. package/src/@claude-flow/shared/dist/mcp/transport/stdio.js +0 -263
  411. package/src/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +0 -133
  412. package/src/@claude-flow/shared/dist/mcp/transport/websocket.js +0 -396
  413. package/src/@claude-flow/shared/dist/mcp/types.d.ts +0 -438
  414. package/src/@claude-flow/shared/dist/mcp/types.js +0 -54
  415. package/src/@claude-flow/shared/dist/plugin-interface.d.ts +0 -544
  416. package/src/@claude-flow/shared/dist/plugin-interface.js +0 -23
  417. package/src/@claude-flow/shared/dist/plugin-loader.d.ts +0 -139
  418. package/src/@claude-flow/shared/dist/plugin-loader.js +0 -434
  419. package/src/@claude-flow/shared/dist/plugin-registry.d.ts +0 -183
  420. package/src/@claude-flow/shared/dist/plugin-registry.js +0 -457
  421. package/src/@claude-flow/shared/dist/plugins/index.d.ts +0 -10
  422. package/src/@claude-flow/shared/dist/plugins/index.js +0 -10
  423. package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +0 -106
  424. package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +0 -241
  425. package/src/@claude-flow/shared/dist/plugins/official/index.d.ts +0 -10
  426. package/src/@claude-flow/shared/dist/plugins/official/index.js +0 -10
  427. package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +0 -121
  428. package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +0 -355
  429. package/src/@claude-flow/shared/dist/plugins/types.d.ts +0 -93
  430. package/src/@claude-flow/shared/dist/plugins/types.js +0 -9
  431. package/src/@claude-flow/shared/dist/resilience/bulkhead.d.ts +0 -105
  432. package/src/@claude-flow/shared/dist/resilience/bulkhead.js +0 -206
  433. package/src/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +0 -132
  434. package/src/@claude-flow/shared/dist/resilience/circuit-breaker.js +0 -233
  435. package/src/@claude-flow/shared/dist/resilience/index.d.ts +0 -19
  436. package/src/@claude-flow/shared/dist/resilience/index.js +0 -19
  437. package/src/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +0 -168
  438. package/src/@claude-flow/shared/dist/resilience/rate-limiter.js +0 -314
  439. package/src/@claude-flow/shared/dist/resilience/retry.d.ts +0 -91
  440. package/src/@claude-flow/shared/dist/resilience/retry.js +0 -159
  441. package/src/@claude-flow/shared/dist/security/index.d.ts +0 -10
  442. package/src/@claude-flow/shared/dist/security/index.js +0 -12
  443. package/src/@claude-flow/shared/dist/security/input-validation.d.ts +0 -73
  444. package/src/@claude-flow/shared/dist/security/input-validation.js +0 -201
  445. package/src/@claude-flow/shared/dist/security/secure-random.d.ts +0 -92
  446. package/src/@claude-flow/shared/dist/security/secure-random.js +0 -142
  447. package/src/@claude-flow/shared/dist/services/index.d.ts +0 -7
  448. package/src/@claude-flow/shared/dist/services/index.js +0 -7
  449. package/src/@claude-flow/shared/dist/services/v3-progress.service.d.ts +0 -124
  450. package/src/@claude-flow/shared/dist/services/v3-progress.service.js +0 -402
  451. package/src/@claude-flow/shared/dist/types/agent.types.d.ts +0 -137
  452. package/src/@claude-flow/shared/dist/types/agent.types.js +0 -6
  453. package/src/@claude-flow/shared/dist/types/index.d.ts +0 -11
  454. package/src/@claude-flow/shared/dist/types/index.js +0 -17
  455. package/src/@claude-flow/shared/dist/types/mcp.types.d.ts +0 -266
  456. package/src/@claude-flow/shared/dist/types/mcp.types.js +0 -7
  457. package/src/@claude-flow/shared/dist/types/memory.types.d.ts +0 -236
  458. package/src/@claude-flow/shared/dist/types/memory.types.js +0 -7
  459. package/src/@claude-flow/shared/dist/types/swarm.types.d.ts +0 -186
  460. package/src/@claude-flow/shared/dist/types/swarm.types.js +0 -65
  461. package/src/@claude-flow/shared/dist/types/task.types.d.ts +0 -178
  462. package/src/@claude-flow/shared/dist/types/task.types.js +0 -32
  463. package/src/@claude-flow/shared/dist/types.d.ts +0 -197
  464. package/src/@claude-flow/shared/dist/types.js +0 -21
  465. package/src/@claude-flow/shared/dist/utils/secure-logger.d.ts +0 -69
  466. package/src/@claude-flow/shared/dist/utils/secure-logger.js +0 -208
@@ -66,295 +66,295 @@ async function getBridge() {
66
66
  * Enhanced schema with pattern confidence, temporal decay, versioning
67
67
  * Vector embeddings enabled for semantic search
68
68
  */
69
- export const MEMORY_SCHEMA_V3 = `
70
- -- MoFlo Memory Database
71
- -- Version: 3.0.0
72
- -- Features: Pattern learning, vector embeddings, temporal decay, migration tracking
73
-
74
- PRAGMA journal_mode = WAL;
75
- PRAGMA synchronous = NORMAL;
76
- PRAGMA foreign_keys = ON;
77
-
78
- -- ============================================
79
- -- CORE MEMORY TABLES
80
- -- ============================================
81
-
82
- -- Memory entries (main storage)
83
- CREATE TABLE IF NOT EXISTS memory_entries (
84
- id TEXT PRIMARY KEY,
85
- key TEXT NOT NULL,
86
- namespace TEXT DEFAULT 'default',
87
- content TEXT NOT NULL,
88
- type TEXT DEFAULT 'semantic' CHECK(type IN ('semantic', 'episodic', 'procedural', 'working', 'pattern')),
89
-
90
- -- Vector embedding for semantic search (stored as JSON array)
91
- embedding TEXT,
92
- embedding_model TEXT DEFAULT 'local',
93
- embedding_dimensions INTEGER,
94
-
95
- -- Metadata
96
- tags TEXT, -- JSON array
97
- metadata TEXT, -- JSON object
98
- owner_id TEXT,
99
-
100
- -- Timestamps
101
- created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
102
- updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
103
- expires_at INTEGER,
104
- last_accessed_at INTEGER,
105
-
106
- -- Access tracking for hot/cold detection
107
- access_count INTEGER DEFAULT 0,
108
-
109
- -- Status
110
- status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deleted')),
111
-
112
- UNIQUE(namespace, key)
113
- );
114
-
115
- -- Indexes for memory entries
116
- CREATE INDEX IF NOT EXISTS idx_memory_namespace ON memory_entries(namespace);
117
- CREATE INDEX IF NOT EXISTS idx_memory_key ON memory_entries(key);
118
- CREATE INDEX IF NOT EXISTS idx_memory_type ON memory_entries(type);
119
- CREATE INDEX IF NOT EXISTS idx_memory_status ON memory_entries(status);
120
- CREATE INDEX IF NOT EXISTS idx_memory_created ON memory_entries(created_at);
121
- CREATE INDEX IF NOT EXISTS idx_memory_accessed ON memory_entries(last_accessed_at);
122
- CREATE INDEX IF NOT EXISTS idx_memory_owner ON memory_entries(owner_id);
123
-
124
- -- ============================================
125
- -- PATTERN LEARNING TABLES
126
- -- ============================================
127
-
128
- -- Learned patterns with confidence scoring and versioning
129
- CREATE TABLE IF NOT EXISTS patterns (
130
- id TEXT PRIMARY KEY,
131
-
132
- -- Pattern identification
133
- name TEXT NOT NULL,
134
- pattern_type TEXT NOT NULL CHECK(pattern_type IN (
135
- 'task-routing', 'error-recovery', 'optimization', 'learning',
136
- 'coordination', 'prediction', 'code-pattern', 'workflow'
137
- )),
138
-
139
- -- Pattern definition
140
- condition TEXT NOT NULL, -- Regex or semantic match
141
- action TEXT NOT NULL, -- What to do when pattern matches
142
- description TEXT,
143
-
144
- -- Confidence scoring (0.0 - 1.0)
145
- confidence REAL DEFAULT 0.5,
146
- success_count INTEGER DEFAULT 0,
147
- failure_count INTEGER DEFAULT 0,
148
-
149
- -- Temporal decay
150
- decay_rate REAL DEFAULT 0.01, -- How fast confidence decays
151
- half_life_days INTEGER DEFAULT 30, -- Days until confidence halves without use
152
-
153
- -- Vector embedding for semantic pattern matching
154
- embedding TEXT,
155
- embedding_dimensions INTEGER,
156
-
157
- -- Versioning
158
- version INTEGER DEFAULT 1,
159
- parent_id TEXT REFERENCES patterns(id),
160
-
161
- -- Metadata
162
- tags TEXT, -- JSON array
163
- metadata TEXT, -- JSON object
164
- source TEXT, -- Where the pattern was learned from
165
-
166
- -- Timestamps
167
- created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
168
- updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
169
- last_matched_at INTEGER,
170
- last_success_at INTEGER,
171
- last_failure_at INTEGER,
172
-
173
- -- Status
174
- status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deprecated', 'experimental'))
175
- );
176
-
177
- -- Indexes for patterns
178
- CREATE INDEX IF NOT EXISTS idx_patterns_type ON patterns(pattern_type);
179
- CREATE INDEX IF NOT EXISTS idx_patterns_confidence ON patterns(confidence DESC);
180
- CREATE INDEX IF NOT EXISTS idx_patterns_status ON patterns(status);
181
- CREATE INDEX IF NOT EXISTS idx_patterns_last_matched ON patterns(last_matched_at);
182
-
183
- -- Pattern evolution history (for versioning)
184
- CREATE TABLE IF NOT EXISTS pattern_history (
185
- id INTEGER PRIMARY KEY AUTOINCREMENT,
186
- pattern_id TEXT NOT NULL REFERENCES patterns(id),
187
- version INTEGER NOT NULL,
188
-
189
- -- Snapshot of pattern state
190
- confidence REAL,
191
- success_count INTEGER,
192
- failure_count INTEGER,
193
- condition TEXT,
194
- action TEXT,
195
-
196
- -- What changed
197
- change_type TEXT CHECK(change_type IN ('created', 'updated', 'success', 'failure', 'decay', 'merged', 'split')),
198
- change_reason TEXT,
199
-
200
- created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
201
- );
202
-
203
- CREATE INDEX IF NOT EXISTS idx_pattern_history_pattern ON pattern_history(pattern_id);
204
-
205
- -- ============================================
206
- -- LEARNING & TRAJECTORY TABLES
207
- -- ============================================
208
-
209
- -- Learning trajectories (SONA integration)
210
- CREATE TABLE IF NOT EXISTS trajectories (
211
- id TEXT PRIMARY KEY,
212
- session_id TEXT,
213
-
214
- -- Trajectory state
215
- status TEXT DEFAULT 'active' CHECK(status IN ('active', 'completed', 'failed', 'abandoned')),
216
- verdict TEXT CHECK(verdict IN ('success', 'failure', 'partial', NULL)),
217
-
218
- -- Context
219
- task TEXT,
220
- context TEXT, -- JSON object
221
-
222
- -- Metrics
223
- total_steps INTEGER DEFAULT 0,
224
- total_reward REAL DEFAULT 0,
225
-
226
- -- Timestamps
227
- started_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
228
- ended_at INTEGER,
229
-
230
- -- Reference to extracted pattern (if any)
231
- extracted_pattern_id TEXT REFERENCES patterns(id)
232
- );
233
-
234
- -- Trajectory steps
235
- CREATE TABLE IF NOT EXISTS trajectory_steps (
236
- id INTEGER PRIMARY KEY AUTOINCREMENT,
237
- trajectory_id TEXT NOT NULL REFERENCES trajectories(id),
238
- step_number INTEGER NOT NULL,
239
-
240
- -- Step data
241
- action TEXT NOT NULL,
242
- observation TEXT,
243
- reward REAL DEFAULT 0,
244
-
245
- -- Metadata
246
- metadata TEXT, -- JSON object
247
-
248
- created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
249
- );
250
-
251
- CREATE INDEX IF NOT EXISTS idx_steps_trajectory ON trajectory_steps(trajectory_id);
252
-
253
- -- ============================================
254
- -- MIGRATION STATE TRACKING
255
- -- ============================================
256
-
257
- -- Migration state (for resume capability)
258
- CREATE TABLE IF NOT EXISTS migration_state (
259
- id TEXT PRIMARY KEY,
260
- migration_type TEXT NOT NULL, -- 'v2-to-v3', 'pattern', 'memory', etc.
261
-
262
- -- Progress tracking
263
- status TEXT DEFAULT 'pending' CHECK(status IN ('pending', 'in_progress', 'completed', 'failed', 'rolled_back')),
264
- total_items INTEGER DEFAULT 0,
265
- processed_items INTEGER DEFAULT 0,
266
- failed_items INTEGER DEFAULT 0,
267
- skipped_items INTEGER DEFAULT 0,
268
-
269
- -- Current position (for resume)
270
- current_batch INTEGER DEFAULT 0,
271
- last_processed_id TEXT,
272
-
273
- -- Source/destination info
274
- source_path TEXT,
275
- source_type TEXT,
276
- destination_path TEXT,
277
-
278
- -- Backup info
279
- backup_path TEXT,
280
- backup_created_at INTEGER,
281
-
282
- -- Error tracking
283
- last_error TEXT,
284
- errors TEXT, -- JSON array of errors
285
-
286
- -- Timestamps
287
- started_at INTEGER,
288
- completed_at INTEGER,
289
- created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
290
- updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
291
- );
292
-
293
- -- ============================================
294
- -- SESSION MANAGEMENT
295
- -- ============================================
296
-
297
- -- Sessions for context persistence
298
- CREATE TABLE IF NOT EXISTS sessions (
299
- id TEXT PRIMARY KEY,
300
-
301
- -- Session state
302
- state TEXT NOT NULL, -- JSON object with full session state
303
- status TEXT DEFAULT 'active' CHECK(status IN ('active', 'paused', 'completed', 'expired')),
304
-
305
- -- Context
306
- project_path TEXT,
307
- branch TEXT,
308
-
309
- -- Metrics
310
- tasks_completed INTEGER DEFAULT 0,
311
- patterns_learned INTEGER DEFAULT 0,
312
-
313
- -- Timestamps
314
- created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
315
- updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
316
- expires_at INTEGER
317
- );
318
-
319
- -- ============================================
320
- -- VECTOR INDEX METADATA (for HNSW)
321
- -- ============================================
322
-
323
- -- Track HNSW index state
324
- CREATE TABLE IF NOT EXISTS vector_indexes (
325
- id TEXT PRIMARY KEY,
326
- name TEXT NOT NULL UNIQUE,
327
-
328
- -- Index configuration
329
- dimensions INTEGER NOT NULL,
330
- metric TEXT DEFAULT 'cosine' CHECK(metric IN ('cosine', 'euclidean', 'dot')),
331
-
332
- -- HNSW parameters
333
- hnsw_m INTEGER DEFAULT 16,
334
- hnsw_ef_construction INTEGER DEFAULT 200,
335
- hnsw_ef_search INTEGER DEFAULT 100,
336
-
337
- -- Quantization
338
- quantization_type TEXT CHECK(quantization_type IN ('none', 'scalar', 'product')),
339
- quantization_bits INTEGER DEFAULT 8,
340
-
341
- -- Statistics
342
- total_vectors INTEGER DEFAULT 0,
343
- last_rebuild_at INTEGER,
344
-
345
- created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
346
- updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
347
- );
348
-
349
- -- ============================================
350
- -- SYSTEM METADATA
351
- -- ============================================
352
-
353
- CREATE TABLE IF NOT EXISTS metadata (
354
- key TEXT PRIMARY KEY,
355
- value TEXT NOT NULL,
356
- updated_at INTEGER DEFAULT (strftime('%s', 'now') * 1000)
357
- );
69
+ export const MEMORY_SCHEMA_V3 = `
70
+ -- MoFlo Memory Database
71
+ -- Version: 3.0.0
72
+ -- Features: Pattern learning, vector embeddings, temporal decay, migration tracking
73
+
74
+ PRAGMA journal_mode = WAL;
75
+ PRAGMA synchronous = NORMAL;
76
+ PRAGMA foreign_keys = ON;
77
+
78
+ -- ============================================
79
+ -- CORE MEMORY TABLES
80
+ -- ============================================
81
+
82
+ -- Memory entries (main storage)
83
+ CREATE TABLE IF NOT EXISTS memory_entries (
84
+ id TEXT PRIMARY KEY,
85
+ key TEXT NOT NULL,
86
+ namespace TEXT DEFAULT 'default',
87
+ content TEXT NOT NULL,
88
+ type TEXT DEFAULT 'semantic' CHECK(type IN ('semantic', 'episodic', 'procedural', 'working', 'pattern')),
89
+
90
+ -- Vector embedding for semantic search (stored as JSON array)
91
+ embedding TEXT,
92
+ embedding_model TEXT DEFAULT 'local',
93
+ embedding_dimensions INTEGER,
94
+
95
+ -- Metadata
96
+ tags TEXT, -- JSON array
97
+ metadata TEXT, -- JSON object
98
+ owner_id TEXT,
99
+
100
+ -- Timestamps
101
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
102
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
103
+ expires_at INTEGER,
104
+ last_accessed_at INTEGER,
105
+
106
+ -- Access tracking for hot/cold detection
107
+ access_count INTEGER DEFAULT 0,
108
+
109
+ -- Status
110
+ status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deleted')),
111
+
112
+ UNIQUE(namespace, key)
113
+ );
114
+
115
+ -- Indexes for memory entries
116
+ CREATE INDEX IF NOT EXISTS idx_memory_namespace ON memory_entries(namespace);
117
+ CREATE INDEX IF NOT EXISTS idx_memory_key ON memory_entries(key);
118
+ CREATE INDEX IF NOT EXISTS idx_memory_type ON memory_entries(type);
119
+ CREATE INDEX IF NOT EXISTS idx_memory_status ON memory_entries(status);
120
+ CREATE INDEX IF NOT EXISTS idx_memory_created ON memory_entries(created_at);
121
+ CREATE INDEX IF NOT EXISTS idx_memory_accessed ON memory_entries(last_accessed_at);
122
+ CREATE INDEX IF NOT EXISTS idx_memory_owner ON memory_entries(owner_id);
123
+
124
+ -- ============================================
125
+ -- PATTERN LEARNING TABLES
126
+ -- ============================================
127
+
128
+ -- Learned patterns with confidence scoring and versioning
129
+ CREATE TABLE IF NOT EXISTS patterns (
130
+ id TEXT PRIMARY KEY,
131
+
132
+ -- Pattern identification
133
+ name TEXT NOT NULL,
134
+ pattern_type TEXT NOT NULL CHECK(pattern_type IN (
135
+ 'task-routing', 'error-recovery', 'optimization', 'learning',
136
+ 'coordination', 'prediction', 'code-pattern', 'workflow'
137
+ )),
138
+
139
+ -- Pattern definition
140
+ condition TEXT NOT NULL, -- Regex or semantic match
141
+ action TEXT NOT NULL, -- What to do when pattern matches
142
+ description TEXT,
143
+
144
+ -- Confidence scoring (0.0 - 1.0)
145
+ confidence REAL DEFAULT 0.5,
146
+ success_count INTEGER DEFAULT 0,
147
+ failure_count INTEGER DEFAULT 0,
148
+
149
+ -- Temporal decay
150
+ decay_rate REAL DEFAULT 0.01, -- How fast confidence decays
151
+ half_life_days INTEGER DEFAULT 30, -- Days until confidence halves without use
152
+
153
+ -- Vector embedding for semantic pattern matching
154
+ embedding TEXT,
155
+ embedding_dimensions INTEGER,
156
+
157
+ -- Versioning
158
+ version INTEGER DEFAULT 1,
159
+ parent_id TEXT REFERENCES patterns(id),
160
+
161
+ -- Metadata
162
+ tags TEXT, -- JSON array
163
+ metadata TEXT, -- JSON object
164
+ source TEXT, -- Where the pattern was learned from
165
+
166
+ -- Timestamps
167
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
168
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
169
+ last_matched_at INTEGER,
170
+ last_success_at INTEGER,
171
+ last_failure_at INTEGER,
172
+
173
+ -- Status
174
+ status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deprecated', 'experimental'))
175
+ );
176
+
177
+ -- Indexes for patterns
178
+ CREATE INDEX IF NOT EXISTS idx_patterns_type ON patterns(pattern_type);
179
+ CREATE INDEX IF NOT EXISTS idx_patterns_confidence ON patterns(confidence DESC);
180
+ CREATE INDEX IF NOT EXISTS idx_patterns_status ON patterns(status);
181
+ CREATE INDEX IF NOT EXISTS idx_patterns_last_matched ON patterns(last_matched_at);
182
+
183
+ -- Pattern evolution history (for versioning)
184
+ CREATE TABLE IF NOT EXISTS pattern_history (
185
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
186
+ pattern_id TEXT NOT NULL REFERENCES patterns(id),
187
+ version INTEGER NOT NULL,
188
+
189
+ -- Snapshot of pattern state
190
+ confidence REAL,
191
+ success_count INTEGER,
192
+ failure_count INTEGER,
193
+ condition TEXT,
194
+ action TEXT,
195
+
196
+ -- What changed
197
+ change_type TEXT CHECK(change_type IN ('created', 'updated', 'success', 'failure', 'decay', 'merged', 'split')),
198
+ change_reason TEXT,
199
+
200
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
201
+ );
202
+
203
+ CREATE INDEX IF NOT EXISTS idx_pattern_history_pattern ON pattern_history(pattern_id);
204
+
205
+ -- ============================================
206
+ -- LEARNING & TRAJECTORY TABLES
207
+ -- ============================================
208
+
209
+ -- Learning trajectories (SONA integration)
210
+ CREATE TABLE IF NOT EXISTS trajectories (
211
+ id TEXT PRIMARY KEY,
212
+ session_id TEXT,
213
+
214
+ -- Trajectory state
215
+ status TEXT DEFAULT 'active' CHECK(status IN ('active', 'completed', 'failed', 'abandoned')),
216
+ verdict TEXT CHECK(verdict IN ('success', 'failure', 'partial', NULL)),
217
+
218
+ -- Context
219
+ task TEXT,
220
+ context TEXT, -- JSON object
221
+
222
+ -- Metrics
223
+ total_steps INTEGER DEFAULT 0,
224
+ total_reward REAL DEFAULT 0,
225
+
226
+ -- Timestamps
227
+ started_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
228
+ ended_at INTEGER,
229
+
230
+ -- Reference to extracted pattern (if any)
231
+ extracted_pattern_id TEXT REFERENCES patterns(id)
232
+ );
233
+
234
+ -- Trajectory steps
235
+ CREATE TABLE IF NOT EXISTS trajectory_steps (
236
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
237
+ trajectory_id TEXT NOT NULL REFERENCES trajectories(id),
238
+ step_number INTEGER NOT NULL,
239
+
240
+ -- Step data
241
+ action TEXT NOT NULL,
242
+ observation TEXT,
243
+ reward REAL DEFAULT 0,
244
+
245
+ -- Metadata
246
+ metadata TEXT, -- JSON object
247
+
248
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
249
+ );
250
+
251
+ CREATE INDEX IF NOT EXISTS idx_steps_trajectory ON trajectory_steps(trajectory_id);
252
+
253
+ -- ============================================
254
+ -- MIGRATION STATE TRACKING
255
+ -- ============================================
256
+
257
+ -- Migration state (for resume capability)
258
+ CREATE TABLE IF NOT EXISTS migration_state (
259
+ id TEXT PRIMARY KEY,
260
+ migration_type TEXT NOT NULL, -- 'v2-to-v3', 'pattern', 'memory', etc.
261
+
262
+ -- Progress tracking
263
+ status TEXT DEFAULT 'pending' CHECK(status IN ('pending', 'in_progress', 'completed', 'failed', 'rolled_back')),
264
+ total_items INTEGER DEFAULT 0,
265
+ processed_items INTEGER DEFAULT 0,
266
+ failed_items INTEGER DEFAULT 0,
267
+ skipped_items INTEGER DEFAULT 0,
268
+
269
+ -- Current position (for resume)
270
+ current_batch INTEGER DEFAULT 0,
271
+ last_processed_id TEXT,
272
+
273
+ -- Source/destination info
274
+ source_path TEXT,
275
+ source_type TEXT,
276
+ destination_path TEXT,
277
+
278
+ -- Backup info
279
+ backup_path TEXT,
280
+ backup_created_at INTEGER,
281
+
282
+ -- Error tracking
283
+ last_error TEXT,
284
+ errors TEXT, -- JSON array of errors
285
+
286
+ -- Timestamps
287
+ started_at INTEGER,
288
+ completed_at INTEGER,
289
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
290
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
291
+ );
292
+
293
+ -- ============================================
294
+ -- SESSION MANAGEMENT
295
+ -- ============================================
296
+
297
+ -- Sessions for context persistence
298
+ CREATE TABLE IF NOT EXISTS sessions (
299
+ id TEXT PRIMARY KEY,
300
+
301
+ -- Session state
302
+ state TEXT NOT NULL, -- JSON object with full session state
303
+ status TEXT DEFAULT 'active' CHECK(status IN ('active', 'paused', 'completed', 'expired')),
304
+
305
+ -- Context
306
+ project_path TEXT,
307
+ branch TEXT,
308
+
309
+ -- Metrics
310
+ tasks_completed INTEGER DEFAULT 0,
311
+ patterns_learned INTEGER DEFAULT 0,
312
+
313
+ -- Timestamps
314
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
315
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
316
+ expires_at INTEGER
317
+ );
318
+
319
+ -- ============================================
320
+ -- VECTOR INDEX METADATA (for HNSW)
321
+ -- ============================================
322
+
323
+ -- Track HNSW index state
324
+ CREATE TABLE IF NOT EXISTS vector_indexes (
325
+ id TEXT PRIMARY KEY,
326
+ name TEXT NOT NULL UNIQUE,
327
+
328
+ -- Index configuration
329
+ dimensions INTEGER NOT NULL,
330
+ metric TEXT DEFAULT 'cosine' CHECK(metric IN ('cosine', 'euclidean', 'dot')),
331
+
332
+ -- HNSW parameters
333
+ hnsw_m INTEGER DEFAULT 16,
334
+ hnsw_ef_construction INTEGER DEFAULT 200,
335
+ hnsw_ef_search INTEGER DEFAULT 100,
336
+
337
+ -- Quantization
338
+ quantization_type TEXT CHECK(quantization_type IN ('none', 'scalar', 'product')),
339
+ quantization_bits INTEGER DEFAULT 8,
340
+
341
+ -- Statistics
342
+ total_vectors INTEGER DEFAULT 0,
343
+ last_rebuild_at INTEGER,
344
+
345
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
346
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
347
+ );
348
+
349
+ -- ============================================
350
+ -- SYSTEM METADATA
351
+ -- ============================================
352
+
353
+ CREATE TABLE IF NOT EXISTS metadata (
354
+ key TEXT PRIMARY KEY,
355
+ value TEXT NOT NULL,
356
+ updated_at INTEGER DEFAULT (strftime('%s', 'now') * 1000)
357
+ );
358
358
  `;
359
359
  let hnswIndex = null;
360
360
  let hnswInitializing = false;
@@ -442,11 +442,11 @@ export async function getHNSWIndex(options) {
442
442
  const fileBuffer = fs.readFileSync(dbPath);
443
443
  const sqlDb = new SQL.Database(fileBuffer);
444
444
  // Load all entries with embeddings
445
- const result = sqlDb.exec(`
446
- SELECT id, key, namespace, content, embedding
447
- FROM memory_entries
448
- WHERE status = 'active' AND embedding IS NOT NULL
449
- LIMIT 10000
445
+ const result = sqlDb.exec(`
446
+ SELECT id, key, namespace, content, embedding
447
+ FROM memory_entries
448
+ WHERE status = 'active' AND embedding IS NOT NULL
449
+ LIMIT 10000
450
450
  `);
451
451
  if (result[0]?.values) {
452
452
  for (const row of result[0].values) {
@@ -826,21 +826,21 @@ export function flashAttentionSearch(query, vectors, options = {}) {
826
826
  * Initial metadata to insert after schema creation
827
827
  */
828
828
  export function getInitialMetadata(backend) {
829
- return `
830
- INSERT OR REPLACE INTO metadata (key, value) VALUES
831
- ('schema_version', '3.0.0'),
832
- ('backend', '${backend}'),
833
- ('created_at', '${new Date().toISOString()}'),
834
- ('sql_js', 'true'),
835
- ('vector_embeddings', 'enabled'),
836
- ('pattern_learning', 'enabled'),
837
- ('temporal_decay', 'enabled'),
838
- ('hnsw_indexing', 'enabled');
839
-
840
- -- Create default vector index configuration
841
- INSERT OR IGNORE INTO vector_indexes (id, name, dimensions) VALUES
842
- ('default', 'default', 768),
843
- ('patterns', 'patterns', 768);
829
+ return `
830
+ INSERT OR REPLACE INTO metadata (key, value) VALUES
831
+ ('schema_version', '3.0.0'),
832
+ ('backend', '${backend}'),
833
+ ('created_at', '${new Date().toISOString()}'),
834
+ ('sql_js', 'true'),
835
+ ('vector_embeddings', 'enabled'),
836
+ ('pattern_learning', 'enabled'),
837
+ ('temporal_decay', 'enabled'),
838
+ ('hnsw_indexing', 'enabled');
839
+
840
+ -- Create default vector index configuration
841
+ INSERT OR IGNORE INTO vector_indexes (id, name, dimensions) VALUES
842
+ ('default', 'default', 768),
843
+ ('patterns', 'patterns', 768);
844
844
  `;
845
845
  }
846
846
  /**
@@ -1240,14 +1240,14 @@ export async function applyTemporalDecay(dbPath) {
1240
1240
  const db = new SQL.Database(fileBuffer);
1241
1241
  // Apply decay: confidence *= exp(-decay_rate * days_since_last_use)
1242
1242
  const now = Date.now();
1243
- const decayQuery = `
1244
- UPDATE patterns
1245
- SET
1246
- confidence = confidence * (1.0 - decay_rate * ((? - COALESCE(last_matched_at, created_at)) / 86400000.0)),
1247
- updated_at = ?
1248
- WHERE status = 'active'
1249
- AND confidence > 0.1
1250
- AND (? - COALESCE(last_matched_at, created_at)) > 86400000
1243
+ const decayQuery = `
1244
+ UPDATE patterns
1245
+ SET
1246
+ confidence = confidence * (1.0 - decay_rate * ((? - COALESCE(last_matched_at, created_at)) / 86400000.0)),
1247
+ updated_at = ?
1248
+ WHERE status = 'active'
1249
+ AND confidence > 0.1
1250
+ AND (? - COALESCE(last_matched_at, created_at)) > 86400000
1251
1251
  `;
1252
1252
  db.run(decayQuery, [now, now, now]);
1253
1253
  const changes = db.getRowsModified();
@@ -1639,9 +1639,9 @@ export async function verifyMemoryInit(dbPath, options) {
1639
1639
  const testKey = 'verification_test';
1640
1640
  const testValue = 'This is a verification test entry for memory initialization';
1641
1641
  try {
1642
- db.run(`
1643
- INSERT INTO memory_entries (id, key, namespace, content, type, created_at, updated_at)
1644
- VALUES (?, ?, 'test', ?, 'semantic', ?, ?)
1642
+ db.run(`
1643
+ INSERT INTO memory_entries (id, key, namespace, content, type, created_at, updated_at)
1644
+ VALUES (?, ?, 'test', ?, 'semantic', ?, ?)
1645
1645
  `, [testId, testKey, testValue, Date.now(), Date.now()]);
1646
1646
  tests.push({
1647
1647
  name: 'Write entry',
@@ -1683,10 +1683,10 @@ export async function verifyMemoryInit(dbPath, options) {
1683
1683
  try {
1684
1684
  const { embedding, dimensions, model } = await generateEmbedding(testValue);
1685
1685
  const embeddingJson = JSON.stringify(embedding);
1686
- db.run(`
1687
- UPDATE memory_entries
1688
- SET embedding = ?, embedding_dimensions = ?, embedding_model = ?
1689
- WHERE id = ?
1686
+ db.run(`
1687
+ UPDATE memory_entries
1688
+ SET embedding = ?, embedding_dimensions = ?, embedding_model = ?
1689
+ WHERE id = ?
1690
1690
  `, [embeddingJson, dimensions, model, testId]);
1691
1691
  tests.push({
1692
1692
  name: 'Generate embedding',
@@ -1707,9 +1707,9 @@ export async function verifyMemoryInit(dbPath, options) {
1707
1707
  const patternStart = Date.now();
1708
1708
  try {
1709
1709
  const patternId = `pattern_${Date.now()}`;
1710
- db.run(`
1711
- INSERT INTO patterns (id, name, pattern_type, condition, action, confidence, created_at, updated_at)
1712
- VALUES (?, 'test-pattern', 'task-routing', 'test condition', 'test action', 0.5, ?, ?)
1710
+ db.run(`
1711
+ INSERT INTO patterns (id, name, pattern_type, condition, action, confidence, created_at, updated_at)
1712
+ VALUES (?, 'test-pattern', 'task-routing', 'test condition', 'test action', 0.5, ?, ?)
1713
1713
  `, [patternId, Date.now(), Date.now()]);
1714
1714
  tests.push({
1715
1715
  name: 'Pattern storage',
@@ -1823,15 +1823,15 @@ export async function storeEntry(options) {
1823
1823
  }
1824
1824
  // Insert or update entry (upsert mode uses REPLACE)
1825
1825
  const insertSql = upsert
1826
- ? `INSERT OR REPLACE INTO memory_entries (
1827
- id, key, namespace, content, type,
1828
- embedding, embedding_dimensions, embedding_model,
1829
- tags, metadata, created_at, updated_at, expires_at, status
1826
+ ? `INSERT OR REPLACE INTO memory_entries (
1827
+ id, key, namespace, content, type,
1828
+ embedding, embedding_dimensions, embedding_model,
1829
+ tags, metadata, created_at, updated_at, expires_at, status
1830
1830
  ) VALUES (?, ?, ?, ?, 'semantic', ?, ?, ?, ?, ?, ?, ?, ?, 'active')`
1831
- : `INSERT INTO memory_entries (
1832
- id, key, namespace, content, type,
1833
- embedding, embedding_dimensions, embedding_model,
1834
- tags, metadata, created_at, updated_at, expires_at, status
1831
+ : `INSERT INTO memory_entries (
1832
+ id, key, namespace, content, type,
1833
+ embedding, embedding_dimensions, embedding_model,
1834
+ tags, metadata, created_at, updated_at, expires_at, status
1835
1835
  ) VALUES (?, ?, ?, ?, 'semantic', ?, ?, ?, ?, ?, ?, ?, ?, 'active')`;
1836
1836
  db.run(insertSql, [
1837
1837
  id,
@@ -1929,12 +1929,12 @@ export async function searchEntries(options) {
1929
1929
  const fileBuffer = fs.readFileSync(dbPath);
1930
1930
  const db = new SQL.Database(fileBuffer);
1931
1931
  // Get entries with embeddings
1932
- const entries = db.exec(`
1933
- SELECT id, key, namespace, content, embedding
1934
- FROM memory_entries
1935
- WHERE status = 'active'
1936
- ${namespace !== 'all' ? `AND namespace = '${namespace.replace(/'/g, "''")}'` : ''}
1937
- LIMIT 1000
1932
+ const entries = db.exec(`
1933
+ SELECT id, key, namespace, content, embedding
1934
+ FROM memory_entries
1935
+ WHERE status = 'active'
1936
+ ${namespace !== 'all' ? `AND namespace = '${namespace.replace(/'/g, "''")}'` : ''}
1937
+ LIMIT 1000
1938
1938
  `);
1939
1939
  const results = [];
1940
1940
  if (entries[0]?.values) {
@@ -2041,13 +2041,13 @@ export async function listEntries(options) {
2041
2041
  const countResult = db.exec(countQuery);
2042
2042
  const total = countResult[0]?.values?.[0]?.[0] || 0;
2043
2043
  // Get entries
2044
- const listQuery = `
2045
- SELECT id, key, namespace, content, embedding, access_count, created_at, updated_at
2046
- FROM memory_entries
2047
- WHERE status = 'active'
2048
- ${namespace ? `AND namespace = '${namespace.replace(/'/g, "''")}'` : ''}
2049
- ORDER BY updated_at DESC
2050
- LIMIT ${limit} OFFSET ${offset}
2044
+ const listQuery = `
2045
+ SELECT id, key, namespace, content, embedding, access_count, created_at, updated_at
2046
+ FROM memory_entries
2047
+ WHERE status = 'active'
2048
+ ${namespace ? `AND namespace = '${namespace.replace(/'/g, "''")}'` : ''}
2049
+ ORDER BY updated_at DESC
2050
+ LIMIT ${limit} OFFSET ${offset}
2051
2051
  `;
2052
2052
  const result = db.exec(listQuery);
2053
2053
  const entries = [];
@@ -2104,13 +2104,13 @@ export async function getEntry(options) {
2104
2104
  const fileBuffer = fs.readFileSync(dbPath);
2105
2105
  const db = new SQL.Database(fileBuffer);
2106
2106
  // Find entry by key
2107
- const result = db.exec(`
2108
- SELECT id, key, namespace, content, embedding, access_count, created_at, updated_at, tags
2109
- FROM memory_entries
2110
- WHERE status = 'active'
2111
- AND key = '${key.replace(/'/g, "''")}'
2112
- AND namespace = '${namespace.replace(/'/g, "''")}'
2113
- LIMIT 1
2107
+ const result = db.exec(`
2108
+ SELECT id, key, namespace, content, embedding, access_count, created_at, updated_at, tags
2109
+ FROM memory_entries
2110
+ WHERE status = 'active'
2111
+ AND key = '${key.replace(/'/g, "''")}'
2112
+ AND namespace = '${namespace.replace(/'/g, "''")}'
2113
+ LIMIT 1
2114
2114
  `);
2115
2115
  if (!result[0]?.values?.[0]) {
2116
2116
  db.close();
@@ -2118,10 +2118,10 @@ export async function getEntry(options) {
2118
2118
  }
2119
2119
  const [id, entryKey, ns, content, embedding, accessCount, createdAt, updatedAt, tagsJson] = result[0].values[0];
2120
2120
  // Update access count
2121
- db.run(`
2122
- UPDATE memory_entries
2123
- SET access_count = access_count + 1, last_accessed_at = strftime('%s', 'now') * 1000
2124
- WHERE id = '${String(id).replace(/'/g, "''")}'
2121
+ db.run(`
2122
+ UPDATE memory_entries
2123
+ SET access_count = access_count + 1, last_accessed_at = strftime('%s', 'now') * 1000
2124
+ WHERE id = '${String(id).replace(/'/g, "''")}'
2125
2125
  `);
2126
2126
  // Save updated database
2127
2127
  const data = db.export();
@@ -2194,12 +2194,12 @@ export async function deleteEntry(options) {
2194
2194
  const fileBuffer = fs.readFileSync(dbPath);
2195
2195
  const db = new SQL.Database(fileBuffer);
2196
2196
  // Check if entry exists first
2197
- const checkResult = db.exec(`
2198
- SELECT id FROM memory_entries
2199
- WHERE status = 'active'
2200
- AND key = '${key.replace(/'/g, "''")}'
2201
- AND namespace = '${namespace.replace(/'/g, "''")}'
2202
- LIMIT 1
2197
+ const checkResult = db.exec(`
2198
+ SELECT id FROM memory_entries
2199
+ WHERE status = 'active'
2200
+ AND key = '${key.replace(/'/g, "''")}'
2201
+ AND namespace = '${namespace.replace(/'/g, "''")}'
2202
+ LIMIT 1
2203
2203
  `);
2204
2204
  if (!checkResult[0]?.values?.[0]) {
2205
2205
  // Get remaining count before closing
@@ -2216,12 +2216,12 @@ export async function deleteEntry(options) {
2216
2216
  };
2217
2217
  }
2218
2218
  // Delete the entry (soft delete by setting status to 'deleted')
2219
- db.run(`
2220
- UPDATE memory_entries
2221
- SET status = 'deleted', updated_at = strftime('%s', 'now') * 1000
2222
- WHERE key = '${key.replace(/'/g, "''")}'
2223
- AND namespace = '${namespace.replace(/'/g, "''")}'
2224
- AND status = 'active'
2219
+ db.run(`
2220
+ UPDATE memory_entries
2221
+ SET status = 'deleted', updated_at = strftime('%s', 'now') * 1000
2222
+ WHERE key = '${key.replace(/'/g, "''")}'
2223
+ AND namespace = '${namespace.replace(/'/g, "''")}'
2224
+ AND status = 'active'
2225
2225
  `);
2226
2226
  // Get remaining count
2227
2227
  const countResult = db.exec(`SELECT COUNT(*) FROM memory_entries WHERE status = 'active'`);