@claude-flow/cli 3.0.2 → 3.1.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1012) hide show
  1. package/.claude/agents/analysis/analyze-code-quality.md +179 -0
  2. package/.claude/agents/analysis/code-analyzer.md +210 -0
  3. package/.claude/agents/analysis/code-review/analyze-code-quality.md +179 -0
  4. package/.claude/agents/architecture/arch-system-design.md +157 -0
  5. package/.claude/agents/architecture/system-design/arch-system-design.md +155 -0
  6. package/.claude/agents/browser/browser-agent.yaml +182 -0
  7. package/.claude/agents/consensus/byzantine-coordinator.md +63 -0
  8. package/.claude/agents/consensus/crdt-synchronizer.md +997 -0
  9. package/.claude/agents/consensus/gossip-coordinator.md +63 -0
  10. package/.claude/agents/consensus/performance-benchmarker.md +851 -0
  11. package/.claude/agents/consensus/quorum-manager.md +823 -0
  12. package/.claude/agents/consensus/raft-manager.md +63 -0
  13. package/.claude/agents/consensus/security-manager.md +622 -0
  14. package/.claude/agents/core/coder.md +453 -0
  15. package/.claude/agents/core/planner.md +375 -0
  16. package/.claude/agents/core/researcher.md +369 -0
  17. package/.claude/agents/core/reviewer.md +520 -0
  18. package/.claude/agents/core/tester.md +512 -0
  19. package/.claude/agents/custom/test-long-runner.md +44 -0
  20. package/.claude/agents/data/data-ml-model.md +445 -0
  21. package/.claude/agents/data/ml/data-ml-model.md +193 -0
  22. package/.claude/agents/development/backend/dev-backend-api.md +142 -0
  23. package/.claude/agents/development/dev-backend-api.md +345 -0
  24. package/.claude/agents/devops/ci-cd/ops-cicd-github.md +164 -0
  25. package/.claude/agents/devops/ops-cicd-github.md +165 -0
  26. package/.claude/agents/documentation/api-docs/docs-api-openapi.md +174 -0
  27. package/.claude/agents/documentation/docs-api-openapi.md +355 -0
  28. package/.claude/agents/flow-nexus/app-store.md +88 -0
  29. package/.claude/agents/flow-nexus/authentication.md +69 -0
  30. package/.claude/agents/flow-nexus/challenges.md +81 -0
  31. package/.claude/agents/flow-nexus/neural-network.md +88 -0
  32. package/.claude/agents/flow-nexus/payments.md +83 -0
  33. package/.claude/agents/flow-nexus/sandbox.md +76 -0
  34. package/.claude/agents/flow-nexus/swarm.md +76 -0
  35. package/.claude/agents/flow-nexus/user-tools.md +96 -0
  36. package/.claude/agents/flow-nexus/workflow.md +84 -0
  37. package/.claude/agents/github/code-review-swarm.md +377 -0
  38. package/.claude/agents/github/github-modes.md +173 -0
  39. package/.claude/agents/github/issue-tracker.md +576 -0
  40. package/.claude/agents/github/multi-repo-swarm.md +553 -0
  41. package/.claude/agents/github/pr-manager.md +438 -0
  42. package/.claude/agents/github/project-board-sync.md +509 -0
  43. package/.claude/agents/github/release-manager.md +605 -0
  44. package/.claude/agents/github/release-swarm.md +583 -0
  45. package/.claude/agents/github/repo-architect.md +398 -0
  46. package/.claude/agents/github/swarm-issue.md +573 -0
  47. package/.claude/agents/github/swarm-pr.md +428 -0
  48. package/.claude/agents/github/sync-coordinator.md +452 -0
  49. package/.claude/agents/github/workflow-automation.md +903 -0
  50. package/.claude/agents/goal/agent.md +816 -0
  51. package/.claude/agents/goal/goal-planner.md +73 -0
  52. package/.claude/agents/optimization/benchmark-suite.md +665 -0
  53. package/.claude/agents/optimization/load-balancer.md +431 -0
  54. package/.claude/agents/optimization/performance-monitor.md +672 -0
  55. package/.claude/agents/optimization/resource-allocator.md +674 -0
  56. package/.claude/agents/optimization/topology-optimizer.md +808 -0
  57. package/.claude/agents/payments/agentic-payments.md +126 -0
  58. package/.claude/agents/sona/sona-learning-optimizer.md +74 -0
  59. package/.claude/agents/sparc/architecture.md +699 -0
  60. package/.claude/agents/sparc/pseudocode.md +520 -0
  61. package/.claude/agents/sparc/refinement.md +802 -0
  62. package/.claude/agents/sparc/specification.md +478 -0
  63. package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +225 -0
  64. package/.claude/agents/specialized/spec-mobile-react-native.md +227 -0
  65. package/.claude/agents/sublinear/consensus-coordinator.md +338 -0
  66. package/.claude/agents/sublinear/matrix-optimizer.md +185 -0
  67. package/.claude/agents/sublinear/pagerank-analyzer.md +299 -0
  68. package/.claude/agents/sublinear/performance-optimizer.md +368 -0
  69. package/.claude/agents/sublinear/trading-predictor.md +246 -0
  70. package/.claude/agents/swarm/adaptive-coordinator.md +1127 -0
  71. package/.claude/agents/swarm/hierarchical-coordinator.md +710 -0
  72. package/.claude/agents/swarm/mesh-coordinator.md +963 -0
  73. package/.claude/agents/templates/automation-smart-agent.md +205 -0
  74. package/.claude/agents/templates/base-template-generator.md +268 -0
  75. package/.claude/agents/templates/coordinator-swarm-init.md +90 -0
  76. package/.claude/agents/templates/github-pr-manager.md +177 -0
  77. package/.claude/agents/templates/implementer-sparc-coder.md +259 -0
  78. package/.claude/agents/templates/memory-coordinator.md +187 -0
  79. package/.claude/agents/templates/orchestrator-task.md +139 -0
  80. package/.claude/agents/templates/performance-analyzer.md +199 -0
  81. package/.claude/agents/templates/sparc-coordinator.md +514 -0
  82. package/.claude/agents/testing/production-validator.md +395 -0
  83. package/.claude/agents/testing/tdd-london-swarm.md +244 -0
  84. package/.claude/agents/v3/adr-architect.md +184 -0
  85. package/.claude/agents/v3/aidefence-guardian.md +282 -0
  86. package/.claude/agents/v3/claims-authorizer.md +208 -0
  87. package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -0
  88. package/.claude/agents/v3/ddd-domain-expert.md +220 -0
  89. package/.claude/agents/v3/injection-analyst.md +236 -0
  90. package/.claude/agents/v3/memory-specialist.md +995 -0
  91. package/.claude/agents/v3/performance-engineer.md +1233 -0
  92. package/.claude/agents/v3/pii-detector.md +151 -0
  93. package/.claude/agents/v3/reasoningbank-learner.md +213 -0
  94. package/.claude/agents/v3/security-architect-aidefence.md +410 -0
  95. package/.claude/agents/v3/security-architect.md +867 -0
  96. package/.claude/agents/v3/security-auditor.md +771 -0
  97. package/.claude/agents/v3/sparc-orchestrator.md +182 -0
  98. package/.claude/agents/v3/swarm-memory-manager.md +157 -0
  99. package/.claude/agents/v3/v3-integration-architect.md +205 -0
  100. package/.claude/commands/agents/README.md +50 -0
  101. package/.claude/commands/agents/agent-capabilities.md +140 -0
  102. package/.claude/commands/agents/agent-coordination.md +28 -0
  103. package/.claude/commands/agents/agent-spawning.md +28 -0
  104. package/.claude/commands/agents/agent-types.md +216 -0
  105. package/.claude/commands/agents/health.md +139 -0
  106. package/.claude/commands/agents/list.md +100 -0
  107. package/.claude/commands/agents/logs.md +130 -0
  108. package/.claude/commands/agents/metrics.md +122 -0
  109. package/.claude/commands/agents/pool.md +127 -0
  110. package/.claude/commands/agents/spawn.md +140 -0
  111. package/.claude/commands/agents/status.md +115 -0
  112. package/.claude/commands/agents/stop.md +102 -0
  113. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
  114. package/.claude/commands/analysis/README.md +9 -0
  115. package/.claude/commands/analysis/bottleneck-detect.md +162 -0
  116. package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
  117. package/.claude/commands/analysis/performance-report.md +25 -0
  118. package/.claude/commands/analysis/token-efficiency.md +45 -0
  119. package/.claude/commands/analysis/token-usage.md +25 -0
  120. package/.claude/commands/automation/README.md +9 -0
  121. package/.claude/commands/automation/auto-agent.md +122 -0
  122. package/.claude/commands/automation/self-healing.md +106 -0
  123. package/.claude/commands/automation/session-memory.md +90 -0
  124. package/.claude/commands/automation/smart-agents.md +73 -0
  125. package/.claude/commands/automation/smart-spawn.md +25 -0
  126. package/.claude/commands/automation/workflow-select.md +25 -0
  127. package/.claude/commands/claude-flow-help.md +103 -0
  128. package/.claude/commands/claude-flow-memory.md +107 -0
  129. package/.claude/commands/claude-flow-swarm.md +205 -0
  130. package/.claude/commands/coordination/README.md +9 -0
  131. package/.claude/commands/coordination/agent-spawn.md +25 -0
  132. package/.claude/commands/coordination/init.md +44 -0
  133. package/.claude/commands/coordination/orchestrate.md +43 -0
  134. package/.claude/commands/coordination/spawn.md +45 -0
  135. package/.claude/commands/coordination/swarm-init.md +85 -0
  136. package/.claude/commands/coordination/task-orchestrate.md +25 -0
  137. package/.claude/commands/flow-nexus/app-store.md +124 -0
  138. package/.claude/commands/flow-nexus/challenges.md +120 -0
  139. package/.claude/commands/flow-nexus/login-registration.md +65 -0
  140. package/.claude/commands/flow-nexus/neural-network.md +134 -0
  141. package/.claude/commands/flow-nexus/payments.md +116 -0
  142. package/.claude/commands/flow-nexus/sandbox.md +83 -0
  143. package/.claude/commands/flow-nexus/swarm.md +87 -0
  144. package/.claude/commands/flow-nexus/user-tools.md +152 -0
  145. package/.claude/commands/flow-nexus/workflow.md +115 -0
  146. package/.claude/commands/github/README.md +11 -0
  147. package/.claude/commands/github/code-review-swarm.md +514 -0
  148. package/.claude/commands/github/code-review.md +25 -0
  149. package/.claude/commands/github/github-modes.md +147 -0
  150. package/.claude/commands/github/github-swarm.md +121 -0
  151. package/.claude/commands/github/issue-tracker.md +292 -0
  152. package/.claude/commands/github/issue-triage.md +25 -0
  153. package/.claude/commands/github/multi-repo-swarm.md +519 -0
  154. package/.claude/commands/github/pr-enhance.md +26 -0
  155. package/.claude/commands/github/pr-manager.md +170 -0
  156. package/.claude/commands/github/project-board-sync.md +471 -0
  157. package/.claude/commands/github/release-manager.md +338 -0
  158. package/.claude/commands/github/release-swarm.md +544 -0
  159. package/.claude/commands/github/repo-analyze.md +25 -0
  160. package/.claude/commands/github/repo-architect.md +367 -0
  161. package/.claude/commands/github/swarm-issue.md +482 -0
  162. package/.claude/commands/github/swarm-pr.md +285 -0
  163. package/.claude/commands/github/sync-coordinator.md +301 -0
  164. package/.claude/commands/github/workflow-automation.md +442 -0
  165. package/.claude/commands/hive-mind/README.md +17 -0
  166. package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -0
  167. package/.claude/commands/hive-mind/hive-mind-init.md +18 -0
  168. package/.claude/commands/hive-mind/hive-mind-memory.md +8 -0
  169. package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -0
  170. package/.claude/commands/hive-mind/hive-mind-resume.md +8 -0
  171. package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -0
  172. package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -0
  173. package/.claude/commands/hive-mind/hive-mind-status.md +8 -0
  174. package/.claude/commands/hive-mind/hive-mind-stop.md +8 -0
  175. package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -0
  176. package/.claude/commands/hive-mind/hive-mind.md +27 -0
  177. package/.claude/commands/hooks/README.md +11 -0
  178. package/.claude/commands/hooks/overview.md +58 -0
  179. package/.claude/commands/hooks/post-edit.md +117 -0
  180. package/.claude/commands/hooks/post-task.md +112 -0
  181. package/.claude/commands/hooks/pre-edit.md +113 -0
  182. package/.claude/commands/hooks/pre-task.md +111 -0
  183. package/.claude/commands/hooks/session-end.md +118 -0
  184. package/.claude/commands/hooks/setup.md +103 -0
  185. package/.claude/commands/memory/README.md +9 -0
  186. package/.claude/commands/memory/memory-persist.md +25 -0
  187. package/.claude/commands/memory/memory-search.md +25 -0
  188. package/.claude/commands/memory/memory-usage.md +25 -0
  189. package/.claude/commands/memory/neural.md +47 -0
  190. package/.claude/commands/monitoring/README.md +9 -0
  191. package/.claude/commands/monitoring/agent-metrics.md +25 -0
  192. package/.claude/commands/monitoring/agents.md +44 -0
  193. package/.claude/commands/monitoring/real-time-view.md +25 -0
  194. package/.claude/commands/monitoring/status.md +46 -0
  195. package/.claude/commands/monitoring/swarm-monitor.md +25 -0
  196. package/.claude/commands/optimization/README.md +9 -0
  197. package/.claude/commands/optimization/auto-topology.md +62 -0
  198. package/.claude/commands/optimization/cache-manage.md +25 -0
  199. package/.claude/commands/optimization/parallel-execute.md +25 -0
  200. package/.claude/commands/optimization/parallel-execution.md +50 -0
  201. package/.claude/commands/optimization/topology-optimize.md +25 -0
  202. package/.claude/commands/pair/README.md +261 -0
  203. package/.claude/commands/pair/commands.md +546 -0
  204. package/.claude/commands/pair/config.md +510 -0
  205. package/.claude/commands/pair/examples.md +512 -0
  206. package/.claude/commands/pair/modes.md +348 -0
  207. package/.claude/commands/pair/session.md +407 -0
  208. package/.claude/commands/pair/start.md +209 -0
  209. package/.claude/commands/sparc/analyzer.md +52 -0
  210. package/.claude/commands/sparc/architect.md +53 -0
  211. package/.claude/commands/sparc/ask.md +97 -0
  212. package/.claude/commands/sparc/batch-executor.md +54 -0
  213. package/.claude/commands/sparc/code.md +89 -0
  214. package/.claude/commands/sparc/coder.md +54 -0
  215. package/.claude/commands/sparc/debug.md +83 -0
  216. package/.claude/commands/sparc/debugger.md +54 -0
  217. package/.claude/commands/sparc/designer.md +53 -0
  218. package/.claude/commands/sparc/devops.md +109 -0
  219. package/.claude/commands/sparc/docs-writer.md +80 -0
  220. package/.claude/commands/sparc/documenter.md +54 -0
  221. package/.claude/commands/sparc/innovator.md +54 -0
  222. package/.claude/commands/sparc/integration.md +83 -0
  223. package/.claude/commands/sparc/mcp.md +117 -0
  224. package/.claude/commands/sparc/memory-manager.md +54 -0
  225. package/.claude/commands/sparc/optimizer.md +54 -0
  226. package/.claude/commands/sparc/orchestrator.md +132 -0
  227. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -0
  228. package/.claude/commands/sparc/refinement-optimization-mode.md +83 -0
  229. package/.claude/commands/sparc/researcher.md +54 -0
  230. package/.claude/commands/sparc/reviewer.md +54 -0
  231. package/.claude/commands/sparc/security-review.md +80 -0
  232. package/.claude/commands/sparc/sparc-modes.md +174 -0
  233. package/.claude/commands/sparc/sparc.md +111 -0
  234. package/.claude/commands/sparc/spec-pseudocode.md +80 -0
  235. package/.claude/commands/sparc/supabase-admin.md +348 -0
  236. package/.claude/commands/sparc/swarm-coordinator.md +54 -0
  237. package/.claude/commands/sparc/tdd.md +54 -0
  238. package/.claude/commands/sparc/tester.md +54 -0
  239. package/.claude/commands/sparc/tutorial.md +79 -0
  240. package/.claude/commands/sparc/workflow-manager.md +54 -0
  241. package/.claude/commands/sparc.md +166 -0
  242. package/.claude/commands/stream-chain/pipeline.md +121 -0
  243. package/.claude/commands/stream-chain/run.md +70 -0
  244. package/.claude/commands/swarm/README.md +15 -0
  245. package/.claude/commands/swarm/analysis.md +95 -0
  246. package/.claude/commands/swarm/development.md +96 -0
  247. package/.claude/commands/swarm/examples.md +168 -0
  248. package/.claude/commands/swarm/maintenance.md +102 -0
  249. package/.claude/commands/swarm/optimization.md +117 -0
  250. package/.claude/commands/swarm/research.md +136 -0
  251. package/.claude/commands/swarm/swarm-analysis.md +8 -0
  252. package/.claude/commands/swarm/swarm-background.md +8 -0
  253. package/.claude/commands/swarm/swarm-init.md +19 -0
  254. package/.claude/commands/swarm/swarm-modes.md +8 -0
  255. package/.claude/commands/swarm/swarm-monitor.md +8 -0
  256. package/.claude/commands/swarm/swarm-spawn.md +19 -0
  257. package/.claude/commands/swarm/swarm-status.md +8 -0
  258. package/.claude/commands/swarm/swarm-strategies.md +8 -0
  259. package/.claude/commands/swarm/swarm.md +87 -0
  260. package/.claude/commands/swarm/testing.md +131 -0
  261. package/.claude/commands/training/README.md +9 -0
  262. package/.claude/commands/training/model-update.md +25 -0
  263. package/.claude/commands/training/neural-patterns.md +108 -0
  264. package/.claude/commands/training/neural-train.md +75 -0
  265. package/.claude/commands/training/pattern-learn.md +25 -0
  266. package/.claude/commands/training/specialization.md +63 -0
  267. package/.claude/commands/truth/start.md +143 -0
  268. package/.claude/commands/verify/check.md +50 -0
  269. package/.claude/commands/verify/start.md +128 -0
  270. package/.claude/commands/workflows/README.md +9 -0
  271. package/.claude/commands/workflows/development.md +78 -0
  272. package/.claude/commands/workflows/research.md +63 -0
  273. package/.claude/commands/workflows/workflow-create.md +25 -0
  274. package/.claude/commands/workflows/workflow-execute.md +25 -0
  275. package/.claude/commands/workflows/workflow-export.md +25 -0
  276. package/.claude/helpers/README.md +97 -0
  277. package/.claude/helpers/adr-compliance.sh +186 -0
  278. package/.claude/helpers/auto-commit.sh +178 -0
  279. package/.claude/helpers/checkpoint-manager.sh +251 -0
  280. package/.claude/helpers/daemon-manager.sh +252 -0
  281. package/.claude/helpers/ddd-tracker.sh +144 -0
  282. package/.claude/helpers/github-safe.js +106 -0
  283. package/.claude/helpers/github-setup.sh +28 -0
  284. package/.claude/helpers/guidance-hook.sh +13 -0
  285. package/.claude/helpers/guidance-hooks.sh +102 -0
  286. package/.claude/helpers/health-monitor.sh +108 -0
  287. package/.claude/helpers/learning-hooks.sh +329 -0
  288. package/.claude/helpers/learning-optimizer.sh +127 -0
  289. package/.claude/helpers/learning-service.mjs +1144 -0
  290. package/.claude/helpers/memory.js +83 -0
  291. package/.claude/helpers/metrics-db.mjs +488 -0
  292. package/.claude/helpers/pattern-consolidator.sh +86 -0
  293. package/.claude/helpers/perf-worker.sh +160 -0
  294. package/.claude/helpers/post-commit +16 -0
  295. package/.claude/helpers/pre-commit +26 -0
  296. package/.claude/helpers/quick-start.sh +19 -0
  297. package/.claude/helpers/router.js +66 -0
  298. package/.claude/helpers/security-scanner.sh +127 -0
  299. package/.claude/helpers/session.js +127 -0
  300. package/.claude/helpers/setup-mcp.sh +18 -0
  301. package/.claude/helpers/standard-checkpoint-hooks.sh +189 -0
  302. package/.claude/helpers/statusline-hook.sh +21 -0
  303. package/.claude/helpers/statusline.cjs +509 -0
  304. package/.claude/helpers/statusline.js +316 -0
  305. package/.claude/helpers/swarm-comms.sh +353 -0
  306. package/.claude/helpers/swarm-hooks.sh +761 -0
  307. package/.claude/helpers/swarm-monitor.sh +211 -0
  308. package/.claude/helpers/sync-v3-metrics.sh +245 -0
  309. package/.claude/helpers/update-v3-progress.sh +166 -0
  310. package/.claude/helpers/v3-quick-status.sh +58 -0
  311. package/.claude/helpers/v3.sh +111 -0
  312. package/.claude/helpers/validate-v3-config.sh +216 -0
  313. package/.claude/helpers/worker-manager.sh +170 -0
  314. package/.claude/settings.json +237 -0
  315. package/.claude/skills/agentdb-advanced/SKILL.md +550 -0
  316. package/.claude/skills/agentdb-learning/SKILL.md +545 -0
  317. package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -0
  318. package/.claude/skills/agentdb-optimization/SKILL.md +509 -0
  319. package/.claude/skills/agentdb-vector-search/SKILL.md +339 -0
  320. package/.claude/skills/agentic-jujutsu/SKILL.md +645 -0
  321. package/.claude/skills/aidefence-scan.md +151 -0
  322. package/.claude/skills/aidefence.yaml +297 -0
  323. package/.claude/skills/browser/SKILL.md +204 -0
  324. package/.claude/skills/flow-nexus-neural/SKILL.md +738 -0
  325. package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -0
  326. package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -0
  327. package/.claude/skills/github-code-review/SKILL.md +1140 -0
  328. package/.claude/skills/github-multi-repo/SKILL.md +874 -0
  329. package/.claude/skills/github-project-management/SKILL.md +1277 -0
  330. package/.claude/skills/github-release-management/SKILL.md +1081 -0
  331. package/.claude/skills/github-workflow-automation/SKILL.md +1065 -0
  332. package/.claude/skills/hive-mind-advanced/SKILL.md +712 -0
  333. package/.claude/skills/hooks-automation/SKILL.md +1201 -0
  334. package/.claude/skills/pair-programming/SKILL.md +1202 -0
  335. package/.claude/skills/performance-analysis/SKILL.md +563 -0
  336. package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -0
  337. package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
  338. package/.claude/skills/secure-review.md +181 -0
  339. package/{.claude-flow → .claude/skills/skill-builder/.claude-flow}/metrics/performance.json +3 -3
  340. package/.claude/skills/skill-builder/.claude-flow/metrics/task-metrics.json +10 -0
  341. package/.claude/skills/skill-builder/SKILL.md +910 -0
  342. package/.claude/skills/sparc-methodology/SKILL.md +1115 -0
  343. package/.claude/skills/stream-chain/SKILL.md +563 -0
  344. package/.claude/skills/swarm-advanced/SKILL.md +973 -0
  345. package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
  346. package/.claude/skills/v3-cli-modernization/SKILL.md +872 -0
  347. package/.claude/skills/v3-core-implementation/SKILL.md +797 -0
  348. package/.claude/skills/v3-ddd-architecture/SKILL.md +442 -0
  349. package/.claude/skills/v3-integration-deep/SKILL.md +241 -0
  350. package/.claude/skills/v3-mcp-optimization/SKILL.md +777 -0
  351. package/.claude/skills/v3-memory-unification/SKILL.md +174 -0
  352. package/.claude/skills/v3-performance-optimization/SKILL.md +390 -0
  353. package/.claude/skills/v3-security-overhaul/SKILL.md +82 -0
  354. package/.claude/skills/v3-swarm-coordination/SKILL.md +340 -0
  355. package/.claude/skills/verification-quality/SKILL.md +649 -0
  356. package/.claude/skills/worker-benchmarks/skill.md +135 -0
  357. package/.claude/skills/worker-integration/skill.md +154 -0
  358. package/README.md +6512 -850
  359. package/bin/cli.js +144 -6
  360. package/bin/mcp-server.js +189 -0
  361. package/dist/src/benchmarks/pretrain/index.d.ts +58 -0
  362. package/dist/src/benchmarks/pretrain/index.d.ts.map +1 -0
  363. package/dist/src/benchmarks/pretrain/index.js +404 -0
  364. package/dist/src/benchmarks/pretrain/index.js.map +1 -0
  365. package/dist/src/commands/agent.d.ts.map +1 -1
  366. package/dist/src/commands/agent.js +49 -33
  367. package/dist/src/commands/agent.js.map +1 -1
  368. package/dist/src/commands/analyze.d.ts +19 -0
  369. package/dist/src/commands/analyze.d.ts.map +1 -0
  370. package/dist/src/commands/analyze.js +1823 -0
  371. package/dist/src/commands/analyze.js.map +1 -0
  372. package/dist/src/commands/benchmark.d.ts +10 -0
  373. package/dist/src/commands/benchmark.d.ts.map +1 -0
  374. package/dist/src/commands/benchmark.js +459 -0
  375. package/dist/src/commands/benchmark.js.map +1 -0
  376. package/dist/src/commands/categories.d.ts +75 -0
  377. package/dist/src/commands/categories.d.ts.map +1 -0
  378. package/dist/src/commands/categories.js +178 -0
  379. package/dist/src/commands/categories.js.map +1 -0
  380. package/dist/src/commands/claims.d.ts +10 -0
  381. package/dist/src/commands/claims.d.ts.map +1 -0
  382. package/dist/src/commands/claims.js +373 -0
  383. package/dist/src/commands/claims.js.map +1 -0
  384. package/dist/src/commands/completions.d.ts +10 -0
  385. package/dist/src/commands/completions.d.ts.map +1 -0
  386. package/dist/src/commands/completions.js +539 -0
  387. package/dist/src/commands/completions.js.map +1 -0
  388. package/dist/src/commands/config.js +1 -1
  389. package/dist/src/commands/config.js.map +1 -1
  390. package/dist/src/commands/daemon.d.ts +8 -0
  391. package/dist/src/commands/daemon.d.ts.map +1 -0
  392. package/dist/src/commands/daemon.js +593 -0
  393. package/dist/src/commands/daemon.js.map +1 -0
  394. package/dist/src/commands/deployment.d.ts +10 -0
  395. package/dist/src/commands/deployment.d.ts.map +1 -0
  396. package/dist/src/commands/deployment.js +289 -0
  397. package/dist/src/commands/deployment.js.map +1 -0
  398. package/dist/src/commands/doctor.d.ts +10 -0
  399. package/dist/src/commands/doctor.d.ts.map +1 -0
  400. package/dist/src/commands/doctor.js +571 -0
  401. package/dist/src/commands/doctor.js.map +1 -0
  402. package/dist/src/commands/embeddings.d.ts +18 -0
  403. package/dist/src/commands/embeddings.d.ts.map +1 -0
  404. package/dist/src/commands/embeddings.js +1576 -0
  405. package/dist/src/commands/embeddings.js.map +1 -0
  406. package/dist/src/commands/guidance.d.ts +8 -0
  407. package/dist/src/commands/guidance.d.ts.map +1 -0
  408. package/dist/src/commands/guidance.js +560 -0
  409. package/dist/src/commands/guidance.js.map +1 -0
  410. package/dist/src/commands/hive-mind.d.ts +3 -0
  411. package/dist/src/commands/hive-mind.d.ts.map +1 -1
  412. package/dist/src/commands/hive-mind.js +673 -70
  413. package/dist/src/commands/hive-mind.js.map +1 -1
  414. package/dist/src/commands/hooks.d.ts.map +1 -1
  415. package/dist/src/commands/hooks.js +1503 -52
  416. package/dist/src/commands/hooks.js.map +1 -1
  417. package/dist/src/commands/index.d.ts +70 -13
  418. package/dist/src/commands/index.d.ts.map +1 -1
  419. package/dist/src/commands/index.js +287 -33
  420. package/dist/src/commands/index.js.map +1 -1
  421. package/dist/src/commands/init.d.ts.map +1 -1
  422. package/dist/src/commands/init.js +259 -13
  423. package/dist/src/commands/init.js.map +1 -1
  424. package/dist/src/commands/issues.d.ts +21 -0
  425. package/dist/src/commands/issues.d.ts.map +1 -0
  426. package/dist/src/commands/issues.js +567 -0
  427. package/dist/src/commands/issues.js.map +1 -0
  428. package/dist/src/commands/mcp.d.ts.map +1 -1
  429. package/dist/src/commands/mcp.js +75 -37
  430. package/dist/src/commands/mcp.js.map +1 -1
  431. package/dist/src/commands/memory.d.ts.map +1 -1
  432. package/dist/src/commands/memory.js +355 -74
  433. package/dist/src/commands/memory.js.map +1 -1
  434. package/dist/src/commands/migrate.d.ts.map +1 -1
  435. package/dist/src/commands/migrate.js +15 -3
  436. package/dist/src/commands/migrate.js.map +1 -1
  437. package/dist/src/commands/neural.d.ts +10 -0
  438. package/dist/src/commands/neural.d.ts.map +1 -0
  439. package/dist/src/commands/neural.js +1448 -0
  440. package/dist/src/commands/neural.js.map +1 -0
  441. package/dist/src/commands/performance.d.ts +10 -0
  442. package/dist/src/commands/performance.d.ts.map +1 -0
  443. package/dist/src/commands/performance.js +579 -0
  444. package/dist/src/commands/performance.js.map +1 -0
  445. package/dist/src/commands/plugins.d.ts +11 -0
  446. package/dist/src/commands/plugins.d.ts.map +1 -0
  447. package/dist/src/commands/plugins.js +820 -0
  448. package/dist/src/commands/plugins.js.map +1 -0
  449. package/dist/src/commands/progress.d.ts +11 -0
  450. package/dist/src/commands/progress.d.ts.map +1 -0
  451. package/dist/src/commands/progress.js +259 -0
  452. package/dist/src/commands/progress.js.map +1 -0
  453. package/dist/src/commands/providers.d.ts +10 -0
  454. package/dist/src/commands/providers.d.ts.map +1 -0
  455. package/dist/src/commands/providers.js +232 -0
  456. package/dist/src/commands/providers.js.map +1 -0
  457. package/dist/src/commands/route.d.ts +16 -0
  458. package/dist/src/commands/route.d.ts.map +1 -0
  459. package/dist/src/commands/route.js +813 -0
  460. package/dist/src/commands/route.js.map +1 -0
  461. package/dist/src/commands/ruvector/backup.d.ts +11 -0
  462. package/dist/src/commands/ruvector/backup.d.ts.map +1 -0
  463. package/dist/src/commands/ruvector/backup.js +746 -0
  464. package/dist/src/commands/ruvector/backup.js.map +1 -0
  465. package/dist/src/commands/ruvector/benchmark.d.ts +11 -0
  466. package/dist/src/commands/ruvector/benchmark.d.ts.map +1 -0
  467. package/dist/src/commands/ruvector/benchmark.js +480 -0
  468. package/dist/src/commands/ruvector/benchmark.js.map +1 -0
  469. package/dist/src/commands/ruvector/import.d.ts +18 -0
  470. package/dist/src/commands/ruvector/import.d.ts.map +1 -0
  471. package/dist/src/commands/ruvector/import.js +349 -0
  472. package/dist/src/commands/ruvector/import.js.map +1 -0
  473. package/dist/src/commands/ruvector/index.d.ts +29 -0
  474. package/dist/src/commands/ruvector/index.d.ts.map +1 -0
  475. package/dist/src/commands/ruvector/index.js +129 -0
  476. package/dist/src/commands/ruvector/index.js.map +1 -0
  477. package/dist/src/commands/ruvector/init.d.ts +11 -0
  478. package/dist/src/commands/ruvector/init.d.ts.map +1 -0
  479. package/dist/src/commands/ruvector/init.js +431 -0
  480. package/dist/src/commands/ruvector/init.js.map +1 -0
  481. package/dist/src/commands/ruvector/migrate.d.ts +11 -0
  482. package/dist/src/commands/ruvector/migrate.d.ts.map +1 -0
  483. package/dist/src/commands/ruvector/migrate.js +481 -0
  484. package/dist/src/commands/ruvector/migrate.js.map +1 -0
  485. package/dist/src/commands/ruvector/optimize.d.ts +11 -0
  486. package/dist/src/commands/ruvector/optimize.d.ts.map +1 -0
  487. package/dist/src/commands/ruvector/optimize.js +503 -0
  488. package/dist/src/commands/ruvector/optimize.js.map +1 -0
  489. package/dist/src/commands/ruvector/setup.d.ts +18 -0
  490. package/dist/src/commands/ruvector/setup.d.ts.map +1 -0
  491. package/dist/src/commands/ruvector/setup.js +765 -0
  492. package/dist/src/commands/ruvector/setup.js.map +1 -0
  493. package/dist/src/commands/ruvector/status.d.ts +11 -0
  494. package/dist/src/commands/ruvector/status.d.ts.map +1 -0
  495. package/dist/src/commands/ruvector/status.js +456 -0
  496. package/dist/src/commands/ruvector/status.js.map +1 -0
  497. package/dist/src/commands/security.d.ts +10 -0
  498. package/dist/src/commands/security.d.ts.map +1 -0
  499. package/dist/src/commands/security.js +575 -0
  500. package/dist/src/commands/security.js.map +1 -0
  501. package/dist/src/commands/session.js +9 -9
  502. package/dist/src/commands/start.d.ts.map +1 -1
  503. package/dist/src/commands/start.js +27 -7
  504. package/dist/src/commands/start.js.map +1 -1
  505. package/dist/src/commands/status.js +7 -7
  506. package/dist/src/commands/swarm.d.ts.map +1 -1
  507. package/dist/src/commands/swarm.js +214 -39
  508. package/dist/src/commands/swarm.js.map +1 -1
  509. package/dist/src/commands/task.js +8 -8
  510. package/dist/src/commands/transfer-store.d.ts +13 -0
  511. package/dist/src/commands/transfer-store.d.ts.map +1 -0
  512. package/dist/src/commands/transfer-store.js +428 -0
  513. package/dist/src/commands/transfer-store.js.map +1 -0
  514. package/dist/src/commands/update.d.ts +8 -0
  515. package/dist/src/commands/update.d.ts.map +1 -0
  516. package/dist/src/commands/update.js +276 -0
  517. package/dist/src/commands/update.js.map +1 -0
  518. package/dist/src/commands/workflow.js +5 -5
  519. package/dist/src/config-adapter.js +2 -1
  520. package/dist/src/config-adapter.js.map +1 -1
  521. package/dist/src/index.d.ts +22 -1
  522. package/dist/src/index.d.ts.map +1 -1
  523. package/dist/src/index.js +153 -12
  524. package/dist/src/index.js.map +1 -1
  525. package/dist/src/init/claudemd-generator.d.ts +15 -5
  526. package/dist/src/init/claudemd-generator.d.ts.map +1 -1
  527. package/dist/src/init/claudemd-generator.js +399 -539
  528. package/dist/src/init/claudemd-generator.js.map +1 -1
  529. package/dist/src/init/executor.d.ts +24 -0
  530. package/dist/src/init/executor.d.ts.map +1 -1
  531. package/dist/src/init/executor.js +874 -38
  532. package/dist/src/init/executor.js.map +1 -1
  533. package/dist/src/init/helpers-generator.js +1 -1
  534. package/dist/src/init/helpers-generator.js.map +1 -1
  535. package/dist/src/init/index.d.ts +4 -3
  536. package/dist/src/init/index.d.ts.map +1 -1
  537. package/dist/src/init/index.js +2 -2
  538. package/dist/src/init/index.js.map +1 -1
  539. package/dist/src/init/mcp-generator.d.ts +9 -0
  540. package/dist/src/init/mcp-generator.d.ts.map +1 -1
  541. package/dist/src/init/mcp-generator.js +57 -28
  542. package/dist/src/init/mcp-generator.js.map +1 -1
  543. package/dist/src/init/settings-generator.d.ts.map +1 -1
  544. package/dist/src/init/settings-generator.js +126 -89
  545. package/dist/src/init/settings-generator.js.map +1 -1
  546. package/dist/src/init/statusline-generator.d.ts +6 -0
  547. package/dist/src/init/statusline-generator.d.ts.map +1 -1
  548. package/dist/src/init/statusline-generator.js +1119 -84
  549. package/dist/src/init/statusline-generator.js.map +1 -1
  550. package/dist/src/init/types.d.ts +37 -2
  551. package/dist/src/init/types.d.ts.map +1 -1
  552. package/dist/src/init/types.js +40 -3
  553. package/dist/src/init/types.js.map +1 -1
  554. package/dist/src/mcp-client.d.ts +3 -3
  555. package/dist/src/mcp-client.d.ts.map +1 -1
  556. package/dist/src/mcp-client.js +46 -4
  557. package/dist/src/mcp-client.js.map +1 -1
  558. package/dist/src/mcp-server.d.ts +9 -1
  559. package/dist/src/mcp-server.d.ts.map +1 -1
  560. package/dist/src/mcp-server.js +194 -46
  561. package/dist/src/mcp-server.js.map +1 -1
  562. package/dist/src/mcp-tools/agent-tools.d.ts +2 -1
  563. package/dist/src/mcp-tools/agent-tools.d.ts.map +1 -1
  564. package/dist/src/mcp-tools/agent-tools.js +479 -20
  565. package/dist/src/mcp-tools/agent-tools.js.map +1 -1
  566. package/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
  567. package/dist/src/mcp-tools/analyze-tools.d.ts.map +1 -0
  568. package/dist/src/mcp-tools/analyze-tools.js +317 -0
  569. package/dist/src/mcp-tools/analyze-tools.js.map +1 -0
  570. package/dist/src/mcp-tools/auto-install.d.ts +83 -0
  571. package/dist/src/mcp-tools/auto-install.d.ts.map +1 -0
  572. package/dist/src/mcp-tools/auto-install.js +131 -0
  573. package/dist/src/mcp-tools/auto-install.js.map +1 -0
  574. package/dist/src/mcp-tools/browser-tools.d.ts +13 -0
  575. package/dist/src/mcp-tools/browser-tools.d.ts.map +1 -0
  576. package/dist/src/mcp-tools/browser-tools.js +550 -0
  577. package/dist/src/mcp-tools/browser-tools.js.map +1 -0
  578. package/dist/src/mcp-tools/claims-tools.d.ts +12 -0
  579. package/dist/src/mcp-tools/claims-tools.d.ts.map +1 -0
  580. package/dist/src/mcp-tools/claims-tools.js +732 -0
  581. package/dist/src/mcp-tools/claims-tools.js.map +1 -0
  582. package/dist/src/mcp-tools/config-tools.d.ts +1 -1
  583. package/dist/src/mcp-tools/config-tools.d.ts.map +1 -1
  584. package/dist/src/mcp-tools/config-tools.js +266 -19
  585. package/dist/src/mcp-tools/config-tools.js.map +1 -1
  586. package/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
  587. package/dist/src/mcp-tools/coordination-tools.d.ts.map +1 -0
  588. package/dist/src/mcp-tools/coordination-tools.js +486 -0
  589. package/dist/src/mcp-tools/coordination-tools.js.map +1 -0
  590. package/dist/src/mcp-tools/daa-tools.d.ts +13 -0
  591. package/dist/src/mcp-tools/daa-tools.d.ts.map +1 -0
  592. package/dist/src/mcp-tools/daa-tools.js +426 -0
  593. package/dist/src/mcp-tools/daa-tools.js.map +1 -0
  594. package/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
  595. package/dist/src/mcp-tools/embeddings-tools.d.ts.map +1 -0
  596. package/dist/src/mcp-tools/embeddings-tools.js +782 -0
  597. package/dist/src/mcp-tools/embeddings-tools.js.map +1 -0
  598. package/dist/src/mcp-tools/github-tools.d.ts +13 -0
  599. package/dist/src/mcp-tools/github-tools.d.ts.map +1 -0
  600. package/dist/src/mcp-tools/github-tools.js +373 -0
  601. package/dist/src/mcp-tools/github-tools.js.map +1 -0
  602. package/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
  603. package/dist/src/mcp-tools/hive-mind-tools.d.ts.map +1 -0
  604. package/dist/src/mcp-tools/hive-mind-tools.js +583 -0
  605. package/dist/src/mcp-tools/hive-mind-tools.js.map +1 -0
  606. package/dist/src/mcp-tools/hooks-tools.d.ts +3 -0
  607. package/dist/src/mcp-tools/hooks-tools.d.ts.map +1 -1
  608. package/dist/src/mcp-tools/hooks-tools.js +1307 -182
  609. package/dist/src/mcp-tools/hooks-tools.js.map +1 -1
  610. package/dist/src/mcp-tools/index.d.ts +9 -0
  611. package/dist/src/mcp-tools/index.d.ts.map +1 -1
  612. package/dist/src/mcp-tools/index.js +9 -0
  613. package/dist/src/mcp-tools/index.js.map +1 -1
  614. package/dist/src/mcp-tools/memory-tools.d.ts +8 -2
  615. package/dist/src/mcp-tools/memory-tools.d.ts.map +1 -1
  616. package/dist/src/mcp-tools/memory-tools.js +376 -132
  617. package/dist/src/mcp-tools/memory-tools.js.map +1 -1
  618. package/dist/src/mcp-tools/neural-tools.d.ts +16 -0
  619. package/dist/src/mcp-tools/neural-tools.d.ts.map +1 -0
  620. package/dist/src/mcp-tools/neural-tools.js +456 -0
  621. package/dist/src/mcp-tools/neural-tools.js.map +1 -0
  622. package/dist/src/mcp-tools/performance-tools.d.ts +16 -0
  623. package/dist/src/mcp-tools/performance-tools.d.ts.map +1 -0
  624. package/dist/src/mcp-tools/performance-tools.js +534 -0
  625. package/dist/src/mcp-tools/performance-tools.js.map +1 -0
  626. package/dist/src/mcp-tools/progress-tools.d.ts +14 -0
  627. package/dist/src/mcp-tools/progress-tools.d.ts.map +1 -0
  628. package/dist/src/mcp-tools/progress-tools.js +348 -0
  629. package/dist/src/mcp-tools/progress-tools.js.map +1 -0
  630. package/dist/src/mcp-tools/security-tools.d.ts +18 -0
  631. package/dist/src/mcp-tools/security-tools.d.ts.map +1 -0
  632. package/dist/src/mcp-tools/security-tools.js +434 -0
  633. package/dist/src/mcp-tools/security-tools.js.map +1 -0
  634. package/dist/src/mcp-tools/session-tools.d.ts +1 -1
  635. package/dist/src/mcp-tools/session-tools.d.ts.map +1 -1
  636. package/dist/src/mcp-tools/session-tools.js +241 -26
  637. package/dist/src/mcp-tools/session-tools.js.map +1 -1
  638. package/dist/src/mcp-tools/swarm-tools.js +4 -4
  639. package/dist/src/mcp-tools/system-tools.d.ts +13 -0
  640. package/dist/src/mcp-tools/system-tools.d.ts.map +1 -0
  641. package/dist/src/mcp-tools/system-tools.js +314 -0
  642. package/dist/src/mcp-tools/system-tools.js.map +1 -0
  643. package/dist/src/mcp-tools/task-tools.d.ts +1 -1
  644. package/dist/src/mcp-tools/task-tools.d.ts.map +1 -1
  645. package/dist/src/mcp-tools/task-tools.js +223 -21
  646. package/dist/src/mcp-tools/task-tools.js.map +1 -1
  647. package/dist/src/mcp-tools/terminal-tools.d.ts +13 -0
  648. package/dist/src/mcp-tools/terminal-tools.d.ts.map +1 -0
  649. package/dist/src/mcp-tools/terminal-tools.js +246 -0
  650. package/dist/src/mcp-tools/terminal-tools.js.map +1 -0
  651. package/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
  652. package/dist/src/mcp-tools/transfer-tools.d.ts.map +1 -0
  653. package/dist/src/mcp-tools/transfer-tools.js +396 -0
  654. package/dist/src/mcp-tools/transfer-tools.js.map +1 -0
  655. package/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
  656. package/dist/src/mcp-tools/workflow-tools.d.ts.map +1 -0
  657. package/dist/src/mcp-tools/workflow-tools.js +481 -0
  658. package/dist/src/mcp-tools/workflow-tools.js.map +1 -0
  659. package/dist/src/memory/ewc-consolidation.d.ts +271 -0
  660. package/dist/src/memory/ewc-consolidation.d.ts.map +1 -0
  661. package/dist/src/memory/ewc-consolidation.js +542 -0
  662. package/dist/src/memory/ewc-consolidation.js.map +1 -0
  663. package/dist/src/memory/intelligence.d.ts +285 -0
  664. package/dist/src/memory/intelligence.d.ts.map +1 -0
  665. package/dist/src/memory/intelligence.js +766 -0
  666. package/dist/src/memory/intelligence.js.map +1 -0
  667. package/dist/src/memory/memory-initializer.d.ts +395 -0
  668. package/dist/src/memory/memory-initializer.d.ts.map +1 -0
  669. package/dist/src/memory/memory-initializer.js +1924 -0
  670. package/dist/src/memory/memory-initializer.js.map +1 -0
  671. package/dist/src/memory/sona-optimizer.d.ts +227 -0
  672. package/dist/src/memory/sona-optimizer.d.ts.map +1 -0
  673. package/dist/src/memory/sona-optimizer.js +633 -0
  674. package/dist/src/memory/sona-optimizer.js.map +1 -0
  675. package/dist/src/output.d.ts +16 -0
  676. package/dist/src/output.d.ts.map +1 -1
  677. package/dist/src/output.js +42 -0
  678. package/dist/src/output.js.map +1 -1
  679. package/dist/src/parser.d.ts.map +1 -1
  680. package/dist/src/parser.js +27 -3
  681. package/dist/src/parser.js.map +1 -1
  682. package/dist/src/plugins/manager.d.ts +133 -0
  683. package/dist/src/plugins/manager.d.ts.map +1 -0
  684. package/dist/src/plugins/manager.js +383 -0
  685. package/dist/src/plugins/manager.js.map +1 -0
  686. package/dist/src/plugins/store/discovery.d.ts +88 -0
  687. package/dist/src/plugins/store/discovery.d.ts.map +1 -0
  688. package/dist/src/plugins/store/discovery.js +1147 -0
  689. package/dist/src/plugins/store/discovery.js.map +1 -0
  690. package/dist/src/plugins/store/index.d.ts +76 -0
  691. package/dist/src/plugins/store/index.d.ts.map +1 -0
  692. package/dist/src/plugins/store/index.js +141 -0
  693. package/dist/src/plugins/store/index.js.map +1 -0
  694. package/dist/src/plugins/store/search.d.ts +46 -0
  695. package/dist/src/plugins/store/search.d.ts.map +1 -0
  696. package/dist/src/plugins/store/search.js +230 -0
  697. package/dist/src/plugins/store/search.js.map +1 -0
  698. package/dist/src/plugins/store/types.d.ts +274 -0
  699. package/dist/src/plugins/store/types.d.ts.map +1 -0
  700. package/dist/src/plugins/store/types.js +7 -0
  701. package/dist/src/plugins/store/types.js.map +1 -0
  702. package/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
  703. package/dist/src/plugins/tests/demo-plugin-store.d.ts.map +1 -0
  704. package/dist/src/plugins/tests/demo-plugin-store.js +126 -0
  705. package/dist/src/plugins/tests/demo-plugin-store.js.map +1 -0
  706. package/dist/src/plugins/tests/standalone-test.d.ts +12 -0
  707. package/dist/src/plugins/tests/standalone-test.d.ts.map +1 -0
  708. package/dist/src/plugins/tests/standalone-test.js +188 -0
  709. package/dist/src/plugins/tests/standalone-test.js.map +1 -0
  710. package/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
  711. package/dist/src/plugins/tests/test-plugin-store.d.ts.map +1 -0
  712. package/dist/src/plugins/tests/test-plugin-store.js +206 -0
  713. package/dist/src/plugins/tests/test-plugin-store.js.map +1 -0
  714. package/dist/src/production/circuit-breaker.d.ts +101 -0
  715. package/dist/src/production/circuit-breaker.d.ts.map +1 -0
  716. package/dist/src/production/circuit-breaker.js +241 -0
  717. package/dist/src/production/circuit-breaker.js.map +1 -0
  718. package/dist/src/production/error-handler.d.ts +92 -0
  719. package/dist/src/production/error-handler.d.ts.map +1 -0
  720. package/dist/src/production/error-handler.js +299 -0
  721. package/dist/src/production/error-handler.js.map +1 -0
  722. package/dist/src/production/index.d.ts +23 -0
  723. package/dist/src/production/index.d.ts.map +1 -0
  724. package/dist/src/production/index.js +18 -0
  725. package/dist/src/production/index.js.map +1 -0
  726. package/dist/src/production/monitoring.d.ts +161 -0
  727. package/dist/src/production/monitoring.d.ts.map +1 -0
  728. package/dist/src/production/monitoring.js +356 -0
  729. package/dist/src/production/monitoring.js.map +1 -0
  730. package/dist/src/production/rate-limiter.d.ts +80 -0
  731. package/dist/src/production/rate-limiter.d.ts.map +1 -0
  732. package/dist/src/production/rate-limiter.js +201 -0
  733. package/dist/src/production/rate-limiter.js.map +1 -0
  734. package/dist/src/production/retry.d.ts +48 -0
  735. package/dist/src/production/retry.d.ts.map +1 -0
  736. package/dist/src/production/retry.js +179 -0
  737. package/dist/src/production/retry.js.map +1 -0
  738. package/dist/src/runtime/headless.d.ts +60 -0
  739. package/dist/src/runtime/headless.d.ts.map +1 -0
  740. package/dist/src/runtime/headless.js +284 -0
  741. package/dist/src/runtime/headless.js.map +1 -0
  742. package/dist/src/ruvector/ast-analyzer.d.ts +67 -0
  743. package/dist/src/ruvector/ast-analyzer.d.ts.map +1 -0
  744. package/dist/src/ruvector/ast-analyzer.js +277 -0
  745. package/dist/src/ruvector/ast-analyzer.js.map +1 -0
  746. package/dist/src/ruvector/coverage-router.d.ts +160 -0
  747. package/dist/src/ruvector/coverage-router.d.ts.map +1 -0
  748. package/dist/src/ruvector/coverage-router.js +529 -0
  749. package/dist/src/ruvector/coverage-router.js.map +1 -0
  750. package/dist/src/ruvector/coverage-tools.d.ts +33 -0
  751. package/dist/src/ruvector/coverage-tools.d.ts.map +1 -0
  752. package/dist/src/ruvector/coverage-tools.js +157 -0
  753. package/dist/src/ruvector/coverage-tools.js.map +1 -0
  754. package/dist/src/ruvector/diff-classifier.d.ts +175 -0
  755. package/dist/src/ruvector/diff-classifier.d.ts.map +1 -0
  756. package/dist/src/ruvector/diff-classifier.js +698 -0
  757. package/dist/src/ruvector/diff-classifier.js.map +1 -0
  758. package/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
  759. package/dist/src/ruvector/enhanced-model-router.d.ts.map +1 -0
  760. package/dist/src/ruvector/enhanced-model-router.js +519 -0
  761. package/dist/src/ruvector/enhanced-model-router.js.map +1 -0
  762. package/dist/src/ruvector/flash-attention.d.ts +195 -0
  763. package/dist/src/ruvector/flash-attention.d.ts.map +1 -0
  764. package/dist/src/ruvector/flash-attention.js +643 -0
  765. package/dist/src/ruvector/flash-attention.js.map +1 -0
  766. package/dist/src/ruvector/graph-analyzer.d.ts +187 -0
  767. package/dist/src/ruvector/graph-analyzer.d.ts.map +1 -0
  768. package/dist/src/ruvector/graph-analyzer.js +929 -0
  769. package/dist/src/ruvector/graph-analyzer.js.map +1 -0
  770. package/dist/src/ruvector/index.d.ts +34 -0
  771. package/dist/src/ruvector/index.d.ts.map +1 -0
  772. package/dist/src/ruvector/index.js +60 -0
  773. package/dist/src/ruvector/index.js.map +1 -0
  774. package/dist/src/ruvector/lora-adapter.d.ts +218 -0
  775. package/dist/src/ruvector/lora-adapter.d.ts.map +1 -0
  776. package/dist/src/ruvector/lora-adapter.js +455 -0
  777. package/dist/src/ruvector/lora-adapter.js.map +1 -0
  778. package/dist/src/ruvector/model-router.d.ts +220 -0
  779. package/dist/src/ruvector/model-router.d.ts.map +1 -0
  780. package/dist/src/ruvector/model-router.js +488 -0
  781. package/dist/src/ruvector/model-router.js.map +1 -0
  782. package/dist/src/ruvector/moe-router.d.ts +206 -0
  783. package/dist/src/ruvector/moe-router.d.ts.map +1 -0
  784. package/dist/src/ruvector/moe-router.js +626 -0
  785. package/dist/src/ruvector/moe-router.js.map +1 -0
  786. package/dist/src/ruvector/q-learning-router.d.ts +211 -0
  787. package/dist/src/ruvector/q-learning-router.d.ts.map +1 -0
  788. package/dist/src/ruvector/q-learning-router.js +681 -0
  789. package/dist/src/ruvector/q-learning-router.js.map +1 -0
  790. package/dist/src/ruvector/semantic-router.d.ts +77 -0
  791. package/dist/src/ruvector/semantic-router.d.ts.map +1 -0
  792. package/dist/src/ruvector/semantic-router.js +178 -0
  793. package/dist/src/ruvector/semantic-router.js.map +1 -0
  794. package/dist/src/ruvector/vector-db.d.ts +69 -0
  795. package/dist/src/ruvector/vector-db.d.ts.map +1 -0
  796. package/dist/src/ruvector/vector-db.js +243 -0
  797. package/dist/src/ruvector/vector-db.js.map +1 -0
  798. package/dist/src/services/claim-service.d.ts +204 -0
  799. package/dist/src/services/claim-service.d.ts.map +1 -0
  800. package/dist/src/services/claim-service.js +818 -0
  801. package/dist/src/services/claim-service.js.map +1 -0
  802. package/dist/src/services/container-worker-pool.d.ts +197 -0
  803. package/dist/src/services/container-worker-pool.d.ts.map +1 -0
  804. package/dist/src/services/container-worker-pool.js +581 -0
  805. package/dist/src/services/container-worker-pool.js.map +1 -0
  806. package/dist/src/services/headless-worker-executor.d.ts +304 -0
  807. package/dist/src/services/headless-worker-executor.d.ts.map +1 -0
  808. package/dist/src/services/headless-worker-executor.js +999 -0
  809. package/dist/src/services/headless-worker-executor.js.map +1 -0
  810. package/dist/src/services/index.d.ts +13 -0
  811. package/dist/src/services/index.d.ts.map +1 -0
  812. package/dist/src/services/index.js +11 -0
  813. package/dist/src/services/index.js.map +1 -0
  814. package/dist/src/services/registry-api.d.ts +58 -0
  815. package/dist/src/services/registry-api.d.ts.map +1 -0
  816. package/dist/src/services/registry-api.js +146 -0
  817. package/dist/src/services/registry-api.js.map +1 -0
  818. package/dist/src/services/ruvector-training.d.ts +213 -0
  819. package/dist/src/services/ruvector-training.d.ts.map +1 -0
  820. package/dist/src/services/ruvector-training.js +498 -0
  821. package/dist/src/services/ruvector-training.js.map +1 -0
  822. package/dist/src/services/worker-daemon.d.ts +203 -0
  823. package/dist/src/services/worker-daemon.d.ts.map +1 -0
  824. package/dist/src/services/worker-daemon.js +756 -0
  825. package/dist/src/services/worker-daemon.js.map +1 -0
  826. package/dist/src/services/worker-queue.d.ts +194 -0
  827. package/dist/src/services/worker-queue.d.ts.map +1 -0
  828. package/dist/src/services/worker-queue.js +511 -0
  829. package/dist/src/services/worker-queue.js.map +1 -0
  830. package/dist/src/suggest.d.ts +53 -0
  831. package/dist/src/suggest.d.ts.map +1 -0
  832. package/dist/src/suggest.js +200 -0
  833. package/dist/src/suggest.js.map +1 -0
  834. package/dist/src/tests/ruvector-integration-benchmark.d.ts +6 -0
  835. package/dist/src/tests/ruvector-integration-benchmark.d.ts.map +1 -0
  836. package/dist/src/tests/ruvector-integration-benchmark.js +385 -0
  837. package/dist/src/tests/ruvector-integration-benchmark.js.map +1 -0
  838. package/dist/src/transfer/anonymization/index.d.ts +25 -0
  839. package/dist/src/transfer/anonymization/index.d.ts.map +1 -0
  840. package/dist/src/transfer/anonymization/index.js +175 -0
  841. package/dist/src/transfer/anonymization/index.js.map +1 -0
  842. package/dist/src/transfer/deploy-seraphine.d.ts +13 -0
  843. package/dist/src/transfer/deploy-seraphine.d.ts.map +1 -0
  844. package/dist/src/transfer/deploy-seraphine.js +205 -0
  845. package/dist/src/transfer/deploy-seraphine.js.map +1 -0
  846. package/dist/src/transfer/export.d.ts +25 -0
  847. package/dist/src/transfer/export.d.ts.map +1 -0
  848. package/dist/src/transfer/export.js +113 -0
  849. package/dist/src/transfer/export.js.map +1 -0
  850. package/dist/src/transfer/index.d.ts +12 -0
  851. package/dist/src/transfer/index.d.ts.map +1 -0
  852. package/dist/src/transfer/index.js +31 -0
  853. package/dist/src/transfer/index.js.map +1 -0
  854. package/dist/src/transfer/ipfs/client.d.ts +109 -0
  855. package/dist/src/transfer/ipfs/client.d.ts.map +1 -0
  856. package/dist/src/transfer/ipfs/client.js +299 -0
  857. package/dist/src/transfer/ipfs/client.js.map +1 -0
  858. package/dist/src/transfer/ipfs/upload.d.ts +95 -0
  859. package/dist/src/transfer/ipfs/upload.d.ts.map +1 -0
  860. package/dist/src/transfer/ipfs/upload.js +413 -0
  861. package/dist/src/transfer/ipfs/upload.js.map +1 -0
  862. package/dist/src/transfer/models/seraphine.d.ts +72 -0
  863. package/dist/src/transfer/models/seraphine.d.ts.map +1 -0
  864. package/dist/src/transfer/models/seraphine.js +373 -0
  865. package/dist/src/transfer/models/seraphine.js.map +1 -0
  866. package/dist/src/transfer/serialization/cfp.d.ts +49 -0
  867. package/dist/src/transfer/serialization/cfp.d.ts.map +1 -0
  868. package/dist/src/transfer/serialization/cfp.js +180 -0
  869. package/dist/src/transfer/serialization/cfp.js.map +1 -0
  870. package/dist/src/transfer/storage/gcs.d.ts +82 -0
  871. package/dist/src/transfer/storage/gcs.d.ts.map +1 -0
  872. package/dist/src/transfer/storage/gcs.js +230 -0
  873. package/dist/src/transfer/storage/gcs.js.map +1 -0
  874. package/dist/src/transfer/storage/index.d.ts +6 -0
  875. package/dist/src/transfer/storage/index.d.ts.map +1 -0
  876. package/dist/src/transfer/storage/index.js +6 -0
  877. package/dist/src/transfer/storage/index.js.map +1 -0
  878. package/dist/src/transfer/store/discovery.d.ts +84 -0
  879. package/dist/src/transfer/store/discovery.d.ts.map +1 -0
  880. package/dist/src/transfer/store/discovery.js +382 -0
  881. package/dist/src/transfer/store/discovery.js.map +1 -0
  882. package/dist/src/transfer/store/download.d.ts +70 -0
  883. package/dist/src/transfer/store/download.d.ts.map +1 -0
  884. package/dist/src/transfer/store/download.js +334 -0
  885. package/dist/src/transfer/store/download.js.map +1 -0
  886. package/dist/src/transfer/store/index.d.ts +84 -0
  887. package/dist/src/transfer/store/index.d.ts.map +1 -0
  888. package/dist/src/transfer/store/index.js +153 -0
  889. package/dist/src/transfer/store/index.js.map +1 -0
  890. package/dist/src/transfer/store/publish.d.ts +76 -0
  891. package/dist/src/transfer/store/publish.d.ts.map +1 -0
  892. package/dist/src/transfer/store/publish.js +294 -0
  893. package/dist/src/transfer/store/publish.js.map +1 -0
  894. package/dist/src/transfer/store/registry.d.ts +58 -0
  895. package/dist/src/transfer/store/registry.d.ts.map +1 -0
  896. package/dist/src/transfer/store/registry.js +285 -0
  897. package/dist/src/transfer/store/registry.js.map +1 -0
  898. package/dist/src/transfer/store/search.d.ts +54 -0
  899. package/dist/src/transfer/store/search.d.ts.map +1 -0
  900. package/dist/src/transfer/store/search.js +232 -0
  901. package/dist/src/transfer/store/search.js.map +1 -0
  902. package/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
  903. package/dist/src/transfer/store/tests/standalone-test.d.ts.map +1 -0
  904. package/dist/src/transfer/store/tests/standalone-test.js +190 -0
  905. package/dist/src/transfer/store/tests/standalone-test.js.map +1 -0
  906. package/dist/src/transfer/store/types.d.ts +193 -0
  907. package/dist/src/transfer/store/types.d.ts.map +1 -0
  908. package/dist/src/transfer/store/types.js +6 -0
  909. package/dist/src/transfer/store/types.js.map +1 -0
  910. package/dist/src/transfer/test-seraphine.d.ts +6 -0
  911. package/dist/src/transfer/test-seraphine.d.ts.map +1 -0
  912. package/dist/src/transfer/test-seraphine.js +105 -0
  913. package/dist/src/transfer/test-seraphine.js.map +1 -0
  914. package/dist/src/transfer/tests/test-store.d.ts +7 -0
  915. package/dist/src/transfer/tests/test-store.d.ts.map +1 -0
  916. package/dist/src/transfer/tests/test-store.js +214 -0
  917. package/dist/src/transfer/tests/test-store.js.map +1 -0
  918. package/dist/src/transfer/types.d.ts +245 -0
  919. package/dist/src/transfer/types.d.ts.map +1 -0
  920. package/dist/src/transfer/types.js +6 -0
  921. package/dist/src/transfer/types.js.map +1 -0
  922. package/dist/src/types.d.ts +1 -1
  923. package/dist/src/types.d.ts.map +1 -1
  924. package/dist/src/update/checker.d.ts +34 -0
  925. package/dist/src/update/checker.d.ts.map +1 -0
  926. package/dist/src/update/checker.js +190 -0
  927. package/dist/src/update/checker.js.map +1 -0
  928. package/dist/src/update/executor.d.ts +32 -0
  929. package/dist/src/update/executor.d.ts.map +1 -0
  930. package/dist/src/update/executor.js +181 -0
  931. package/dist/src/update/executor.js.map +1 -0
  932. package/dist/src/update/index.d.ts +33 -0
  933. package/dist/src/update/index.d.ts.map +1 -0
  934. package/dist/src/update/index.js +64 -0
  935. package/dist/src/update/index.js.map +1 -0
  936. package/dist/src/update/rate-limiter.d.ts +20 -0
  937. package/dist/src/update/rate-limiter.d.ts.map +1 -0
  938. package/dist/src/update/rate-limiter.js +96 -0
  939. package/dist/src/update/rate-limiter.js.map +1 -0
  940. package/dist/src/update/validator.d.ts +17 -0
  941. package/dist/src/update/validator.d.ts.map +1 -0
  942. package/dist/src/update/validator.js +123 -0
  943. package/dist/src/update/validator.js.map +1 -0
  944. package/dist/tsconfig.tsbuildinfo +1 -1
  945. package/package.json +88 -11
  946. package/.agentic-flow/intelligence.json +0 -17
  947. package/.claude-flow/metrics/task-metrics.json +0 -10
  948. package/__tests__/README.md +0 -140
  949. package/__tests__/TEST_SUMMARY.md +0 -144
  950. package/__tests__/cli.test.ts +0 -558
  951. package/__tests__/commands.test.ts +0 -726
  952. package/__tests__/config-adapter.test.ts +0 -362
  953. package/__tests__/config-loading.test.ts +0 -106
  954. package/__tests__/coverage/.tmp/coverage-0.json +0 -1
  955. package/__tests__/coverage/.tmp/coverage-1.json +0 -1
  956. package/__tests__/coverage/.tmp/coverage-2.json +0 -1
  957. package/__tests__/coverage/.tmp/coverage-3.json +0 -1
  958. package/__tests__/coverage/.tmp/coverage-4.json +0 -1
  959. package/__tests__/coverage/.tmp/coverage-5.json +0 -1
  960. package/__tests__/mcp-client.test.ts +0 -480
  961. package/__tests__/p1-commands.test.ts +0 -1064
  962. package/docs/CONFIG_LOADING.md +0 -236
  963. package/docs/IMPLEMENTATION_COMPLETE.md +0 -421
  964. package/docs/MCP_CLIENT_GUIDE.md +0 -620
  965. package/docs/REFACTORING_SUMMARY.md +0 -247
  966. package/src/commands/agent.ts +0 -941
  967. package/src/commands/config.ts +0 -452
  968. package/src/commands/hive-mind.ts +0 -762
  969. package/src/commands/hooks.ts +0 -2603
  970. package/src/commands/index.ts +0 -115
  971. package/src/commands/init.ts +0 -597
  972. package/src/commands/mcp.ts +0 -753
  973. package/src/commands/memory.ts +0 -1161
  974. package/src/commands/migrate.ts +0 -447
  975. package/src/commands/process.ts +0 -695
  976. package/src/commands/session.ts +0 -891
  977. package/src/commands/start.ts +0 -457
  978. package/src/commands/status.ts +0 -736
  979. package/src/commands/swarm.ts +0 -648
  980. package/src/commands/task.ts +0 -792
  981. package/src/commands/workflow.ts +0 -742
  982. package/src/config-adapter.ts +0 -210
  983. package/src/index.ts +0 -400
  984. package/src/infrastructure/in-memory-repositories.ts +0 -310
  985. package/src/init/claudemd-generator.ts +0 -631
  986. package/src/init/executor.ts +0 -762
  987. package/src/init/helpers-generator.ts +0 -628
  988. package/src/init/index.ts +0 -60
  989. package/src/init/mcp-generator.ts +0 -83
  990. package/src/init/settings-generator.ts +0 -274
  991. package/src/init/statusline-generator.ts +0 -211
  992. package/src/init/types.ts +0 -447
  993. package/src/mcp-client.ts +0 -229
  994. package/src/mcp-server.ts +0 -577
  995. package/src/mcp-tools/agent-tools.ts +0 -92
  996. package/src/mcp-tools/config-tools.ts +0 -88
  997. package/src/mcp-tools/hooks-tools.ts +0 -1849
  998. package/src/mcp-tools/index.ts +0 -14
  999. package/src/mcp-tools/memory-tools.ts +0 -270
  1000. package/src/mcp-tools/session-tools.ts +0 -102
  1001. package/src/mcp-tools/swarm-tools.ts +0 -105
  1002. package/src/mcp-tools/task-tools.ts +0 -102
  1003. package/src/mcp-tools/types.ts +0 -33
  1004. package/src/output.ts +0 -593
  1005. package/src/parser.ts +0 -417
  1006. package/src/prompt.ts +0 -619
  1007. package/src/types.ts +0 -287
  1008. package/tsconfig.json +0 -16
  1009. package/tsconfig.tsbuildinfo +0 -1
  1010. package/vitest.config.ts +0 -13
  1011. /package/{tmp.json → .claude/agents/tmp.json} +0 -0
  1012. /package/{.claude-flow → .claude/skills/skill-builder/.claude-flow}/metrics/agent-metrics.json +0 -0
@@ -0,0 +1,1924 @@
1
+ /**
2
+ * V3 Memory Initializer
3
+ * Properly initializes the memory database with sql.js (WASM SQLite)
4
+ * Includes pattern tables, vector embeddings, migration state tracking
5
+ *
6
+ * @module v3/cli/memory-initializer
7
+ */
8
+ import * as fs from 'fs';
9
+ import * as path from 'path';
10
+ /**
11
+ * Enhanced schema with pattern confidence, temporal decay, versioning
12
+ * Vector embeddings enabled for semantic search
13
+ */
14
+ export const MEMORY_SCHEMA_V3 = `
15
+ -- Claude Flow V3 Memory Database
16
+ -- Version: 3.0.0
17
+ -- Features: Pattern learning, vector embeddings, temporal decay, migration tracking
18
+
19
+ PRAGMA journal_mode = WAL;
20
+ PRAGMA synchronous = NORMAL;
21
+ PRAGMA foreign_keys = ON;
22
+
23
+ -- ============================================
24
+ -- CORE MEMORY TABLES
25
+ -- ============================================
26
+
27
+ -- Memory entries (main storage)
28
+ CREATE TABLE IF NOT EXISTS memory_entries (
29
+ id TEXT PRIMARY KEY,
30
+ key TEXT NOT NULL,
31
+ namespace TEXT DEFAULT 'default',
32
+ content TEXT NOT NULL,
33
+ type TEXT DEFAULT 'semantic' CHECK(type IN ('semantic', 'episodic', 'procedural', 'working', 'pattern')),
34
+
35
+ -- Vector embedding for semantic search (stored as JSON array)
36
+ embedding TEXT,
37
+ embedding_model TEXT DEFAULT 'local',
38
+ embedding_dimensions INTEGER,
39
+
40
+ -- Metadata
41
+ tags TEXT, -- JSON array
42
+ metadata TEXT, -- JSON object
43
+ owner_id TEXT,
44
+
45
+ -- Timestamps
46
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
47
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
48
+ expires_at INTEGER,
49
+ last_accessed_at INTEGER,
50
+
51
+ -- Access tracking for hot/cold detection
52
+ access_count INTEGER DEFAULT 0,
53
+
54
+ -- Status
55
+ status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deleted')),
56
+
57
+ UNIQUE(namespace, key)
58
+ );
59
+
60
+ -- Indexes for memory entries
61
+ CREATE INDEX IF NOT EXISTS idx_memory_namespace ON memory_entries(namespace);
62
+ CREATE INDEX IF NOT EXISTS idx_memory_key ON memory_entries(key);
63
+ CREATE INDEX IF NOT EXISTS idx_memory_type ON memory_entries(type);
64
+ CREATE INDEX IF NOT EXISTS idx_memory_status ON memory_entries(status);
65
+ CREATE INDEX IF NOT EXISTS idx_memory_created ON memory_entries(created_at);
66
+ CREATE INDEX IF NOT EXISTS idx_memory_accessed ON memory_entries(last_accessed_at);
67
+ CREATE INDEX IF NOT EXISTS idx_memory_owner ON memory_entries(owner_id);
68
+
69
+ -- ============================================
70
+ -- PATTERN LEARNING TABLES
71
+ -- ============================================
72
+
73
+ -- Learned patterns with confidence scoring and versioning
74
+ CREATE TABLE IF NOT EXISTS patterns (
75
+ id TEXT PRIMARY KEY,
76
+
77
+ -- Pattern identification
78
+ name TEXT NOT NULL,
79
+ pattern_type TEXT NOT NULL CHECK(pattern_type IN (
80
+ 'task-routing', 'error-recovery', 'optimization', 'learning',
81
+ 'coordination', 'prediction', 'code-pattern', 'workflow'
82
+ )),
83
+
84
+ -- Pattern definition
85
+ condition TEXT NOT NULL, -- Regex or semantic match
86
+ action TEXT NOT NULL, -- What to do when pattern matches
87
+ description TEXT,
88
+
89
+ -- Confidence scoring (0.0 - 1.0)
90
+ confidence REAL DEFAULT 0.5,
91
+ success_count INTEGER DEFAULT 0,
92
+ failure_count INTEGER DEFAULT 0,
93
+
94
+ -- Temporal decay
95
+ decay_rate REAL DEFAULT 0.01, -- How fast confidence decays
96
+ half_life_days INTEGER DEFAULT 30, -- Days until confidence halves without use
97
+
98
+ -- Vector embedding for semantic pattern matching
99
+ embedding TEXT,
100
+ embedding_dimensions INTEGER,
101
+
102
+ -- Versioning
103
+ version INTEGER DEFAULT 1,
104
+ parent_id TEXT REFERENCES patterns(id),
105
+
106
+ -- Metadata
107
+ tags TEXT, -- JSON array
108
+ metadata TEXT, -- JSON object
109
+ source TEXT, -- Where the pattern was learned from
110
+
111
+ -- Timestamps
112
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
113
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
114
+ last_matched_at INTEGER,
115
+ last_success_at INTEGER,
116
+ last_failure_at INTEGER,
117
+
118
+ -- Status
119
+ status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deprecated', 'experimental'))
120
+ );
121
+
122
+ -- Indexes for patterns
123
+ CREATE INDEX IF NOT EXISTS idx_patterns_type ON patterns(pattern_type);
124
+ CREATE INDEX IF NOT EXISTS idx_patterns_confidence ON patterns(confidence DESC);
125
+ CREATE INDEX IF NOT EXISTS idx_patterns_status ON patterns(status);
126
+ CREATE INDEX IF NOT EXISTS idx_patterns_last_matched ON patterns(last_matched_at);
127
+
128
+ -- Pattern evolution history (for versioning)
129
+ CREATE TABLE IF NOT EXISTS pattern_history (
130
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
131
+ pattern_id TEXT NOT NULL REFERENCES patterns(id),
132
+ version INTEGER NOT NULL,
133
+
134
+ -- Snapshot of pattern state
135
+ confidence REAL,
136
+ success_count INTEGER,
137
+ failure_count INTEGER,
138
+ condition TEXT,
139
+ action TEXT,
140
+
141
+ -- What changed
142
+ change_type TEXT CHECK(change_type IN ('created', 'updated', 'success', 'failure', 'decay', 'merged', 'split')),
143
+ change_reason TEXT,
144
+
145
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
146
+ );
147
+
148
+ CREATE INDEX IF NOT EXISTS idx_pattern_history_pattern ON pattern_history(pattern_id);
149
+
150
+ -- ============================================
151
+ -- LEARNING & TRAJECTORY TABLES
152
+ -- ============================================
153
+
154
+ -- Learning trajectories (SONA integration)
155
+ CREATE TABLE IF NOT EXISTS trajectories (
156
+ id TEXT PRIMARY KEY,
157
+ session_id TEXT,
158
+
159
+ -- Trajectory state
160
+ status TEXT DEFAULT 'active' CHECK(status IN ('active', 'completed', 'failed', 'abandoned')),
161
+ verdict TEXT CHECK(verdict IN ('success', 'failure', 'partial', NULL)),
162
+
163
+ -- Context
164
+ task TEXT,
165
+ context TEXT, -- JSON object
166
+
167
+ -- Metrics
168
+ total_steps INTEGER DEFAULT 0,
169
+ total_reward REAL DEFAULT 0,
170
+
171
+ -- Timestamps
172
+ started_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
173
+ ended_at INTEGER,
174
+
175
+ -- Reference to extracted pattern (if any)
176
+ extracted_pattern_id TEXT REFERENCES patterns(id)
177
+ );
178
+
179
+ -- Trajectory steps
180
+ CREATE TABLE IF NOT EXISTS trajectory_steps (
181
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
182
+ trajectory_id TEXT NOT NULL REFERENCES trajectories(id),
183
+ step_number INTEGER NOT NULL,
184
+
185
+ -- Step data
186
+ action TEXT NOT NULL,
187
+ observation TEXT,
188
+ reward REAL DEFAULT 0,
189
+
190
+ -- Metadata
191
+ metadata TEXT, -- JSON object
192
+
193
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
194
+ );
195
+
196
+ CREATE INDEX IF NOT EXISTS idx_steps_trajectory ON trajectory_steps(trajectory_id);
197
+
198
+ -- ============================================
199
+ -- MIGRATION STATE TRACKING
200
+ -- ============================================
201
+
202
+ -- Migration state (for resume capability)
203
+ CREATE TABLE IF NOT EXISTS migration_state (
204
+ id TEXT PRIMARY KEY,
205
+ migration_type TEXT NOT NULL, -- 'v2-to-v3', 'pattern', 'memory', etc.
206
+
207
+ -- Progress tracking
208
+ status TEXT DEFAULT 'pending' CHECK(status IN ('pending', 'in_progress', 'completed', 'failed', 'rolled_back')),
209
+ total_items INTEGER DEFAULT 0,
210
+ processed_items INTEGER DEFAULT 0,
211
+ failed_items INTEGER DEFAULT 0,
212
+ skipped_items INTEGER DEFAULT 0,
213
+
214
+ -- Current position (for resume)
215
+ current_batch INTEGER DEFAULT 0,
216
+ last_processed_id TEXT,
217
+
218
+ -- Source/destination info
219
+ source_path TEXT,
220
+ source_type TEXT,
221
+ destination_path TEXT,
222
+
223
+ -- Backup info
224
+ backup_path TEXT,
225
+ backup_created_at INTEGER,
226
+
227
+ -- Error tracking
228
+ last_error TEXT,
229
+ errors TEXT, -- JSON array of errors
230
+
231
+ -- Timestamps
232
+ started_at INTEGER,
233
+ completed_at INTEGER,
234
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
235
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
236
+ );
237
+
238
+ -- ============================================
239
+ -- SESSION MANAGEMENT
240
+ -- ============================================
241
+
242
+ -- Sessions for context persistence
243
+ CREATE TABLE IF NOT EXISTS sessions (
244
+ id TEXT PRIMARY KEY,
245
+
246
+ -- Session state
247
+ state TEXT NOT NULL, -- JSON object with full session state
248
+ status TEXT DEFAULT 'active' CHECK(status IN ('active', 'paused', 'completed', 'expired')),
249
+
250
+ -- Context
251
+ project_path TEXT,
252
+ branch TEXT,
253
+
254
+ -- Metrics
255
+ tasks_completed INTEGER DEFAULT 0,
256
+ patterns_learned INTEGER DEFAULT 0,
257
+
258
+ -- Timestamps
259
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
260
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
261
+ expires_at INTEGER
262
+ );
263
+
264
+ -- ============================================
265
+ -- VECTOR INDEX METADATA (for HNSW)
266
+ -- ============================================
267
+
268
+ -- Track HNSW index state
269
+ CREATE TABLE IF NOT EXISTS vector_indexes (
270
+ id TEXT PRIMARY KEY,
271
+ name TEXT NOT NULL UNIQUE,
272
+
273
+ -- Index configuration
274
+ dimensions INTEGER NOT NULL,
275
+ metric TEXT DEFAULT 'cosine' CHECK(metric IN ('cosine', 'euclidean', 'dot')),
276
+
277
+ -- HNSW parameters
278
+ hnsw_m INTEGER DEFAULT 16,
279
+ hnsw_ef_construction INTEGER DEFAULT 200,
280
+ hnsw_ef_search INTEGER DEFAULT 100,
281
+
282
+ -- Quantization
283
+ quantization_type TEXT CHECK(quantization_type IN ('none', 'scalar', 'product')),
284
+ quantization_bits INTEGER DEFAULT 8,
285
+
286
+ -- Statistics
287
+ total_vectors INTEGER DEFAULT 0,
288
+ last_rebuild_at INTEGER,
289
+
290
+ created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
291
+ updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
292
+ );
293
+
294
+ -- ============================================
295
+ -- SYSTEM METADATA
296
+ -- ============================================
297
+
298
+ CREATE TABLE IF NOT EXISTS metadata (
299
+ key TEXT PRIMARY KEY,
300
+ value TEXT NOT NULL,
301
+ updated_at INTEGER DEFAULT (strftime('%s', 'now') * 1000)
302
+ );
303
+ `;
304
+ let hnswIndex = null;
305
+ let hnswInitializing = false;
306
+ /**
307
+ * Get or create the HNSW index singleton
308
+ * Lazily initializes from SQLite data on first use
309
+ */
310
+ export async function getHNSWIndex(options) {
311
+ const dimensions = options?.dimensions ?? 384;
312
+ // Return existing index if already initialized
313
+ if (hnswIndex?.initialized && !options?.forceRebuild) {
314
+ return hnswIndex;
315
+ }
316
+ // Prevent concurrent initialization
317
+ if (hnswInitializing) {
318
+ // Wait for initialization to complete
319
+ while (hnswInitializing) {
320
+ await new Promise(resolve => setTimeout(resolve, 10));
321
+ }
322
+ return hnswIndex;
323
+ }
324
+ hnswInitializing = true;
325
+ try {
326
+ // Import @ruvector/core dynamically
327
+ // Handle both ESM (default export) and CJS patterns
328
+ const ruvectorModule = await import('@ruvector/core').catch(() => null);
329
+ if (!ruvectorModule) {
330
+ hnswInitializing = false;
331
+ return null; // HNSW not available
332
+ }
333
+ // ESM returns { default: { VectorDb, ... } }, CJS returns { VectorDb, ... }
334
+ const ruvectorCore = ruvectorModule.default || ruvectorModule;
335
+ if (!ruvectorCore?.VectorDb) {
336
+ hnswInitializing = false;
337
+ return null; // VectorDb not found
338
+ }
339
+ const { VectorDb } = ruvectorCore;
340
+ // Persistent storage paths
341
+ const swarmDir = path.join(process.cwd(), '.swarm');
342
+ if (!fs.existsSync(swarmDir)) {
343
+ fs.mkdirSync(swarmDir, { recursive: true });
344
+ }
345
+ const hnswPath = path.join(swarmDir, 'hnsw.index');
346
+ const metadataPath = path.join(swarmDir, 'hnsw.metadata.json');
347
+ const dbPath = options?.dbPath || path.join(swarmDir, 'memory.db');
348
+ // Create HNSW index with persistent storage
349
+ // @ruvector/core uses string enum for distanceMetric: 'Cosine', 'Euclidean', 'DotProduct', 'Manhattan'
350
+ const db = new VectorDb({
351
+ dimensions,
352
+ distanceMetric: 'Cosine',
353
+ storagePath: hnswPath // Persistent storage!
354
+ });
355
+ // Load metadata (entry info) if exists
356
+ const entries = new Map();
357
+ if (fs.existsSync(metadataPath)) {
358
+ try {
359
+ const metadataJson = fs.readFileSync(metadataPath, 'utf-8');
360
+ const metadata = JSON.parse(metadataJson);
361
+ for (const [key, value] of metadata) {
362
+ entries.set(key, value);
363
+ }
364
+ }
365
+ catch {
366
+ // Metadata load failed, will rebuild
367
+ }
368
+ }
369
+ hnswIndex = {
370
+ db,
371
+ entries,
372
+ dimensions,
373
+ initialized: false
374
+ };
375
+ // Check if index already has data (from persistent storage)
376
+ const existingLen = await db.len();
377
+ if (existingLen > 0 && entries.size > 0) {
378
+ // Index loaded from disk, skip SQLite sync
379
+ hnswIndex.initialized = true;
380
+ hnswInitializing = false;
381
+ return hnswIndex;
382
+ }
383
+ if (fs.existsSync(dbPath)) {
384
+ try {
385
+ const initSqlJs = (await import('sql.js')).default;
386
+ const SQL = await initSqlJs();
387
+ const fileBuffer = fs.readFileSync(dbPath);
388
+ const sqlDb = new SQL.Database(fileBuffer);
389
+ // Load all entries with embeddings
390
+ const result = sqlDb.exec(`
391
+ SELECT id, key, namespace, content, embedding
392
+ FROM memory_entries
393
+ WHERE status = 'active' AND embedding IS NOT NULL
394
+ LIMIT 10000
395
+ `);
396
+ if (result[0]?.values) {
397
+ for (const row of result[0].values) {
398
+ const [id, key, ns, content, embeddingJson] = row;
399
+ if (embeddingJson) {
400
+ try {
401
+ const embedding = JSON.parse(embeddingJson);
402
+ const vector = new Float32Array(embedding);
403
+ await db.insert({
404
+ id: String(id),
405
+ vector
406
+ });
407
+ hnswIndex.entries.set(String(id), {
408
+ id: String(id),
409
+ key: key || String(id),
410
+ namespace: ns || 'default',
411
+ content: content || ''
412
+ });
413
+ }
414
+ catch {
415
+ // Skip invalid embeddings
416
+ }
417
+ }
418
+ }
419
+ }
420
+ sqlDb.close();
421
+ }
422
+ catch {
423
+ // SQLite load failed, start with empty index
424
+ }
425
+ }
426
+ hnswIndex.initialized = true;
427
+ hnswInitializing = false;
428
+ return hnswIndex;
429
+ }
430
+ catch {
431
+ hnswInitializing = false;
432
+ return null;
433
+ }
434
+ }
435
+ /**
436
+ * Save HNSW metadata to disk for persistence
437
+ */
438
+ function saveHNSWMetadata() {
439
+ if (!hnswIndex?.entries)
440
+ return;
441
+ try {
442
+ const swarmDir = path.join(process.cwd(), '.swarm');
443
+ const metadataPath = path.join(swarmDir, 'hnsw.metadata.json');
444
+ const metadata = Array.from(hnswIndex.entries.entries());
445
+ fs.writeFileSync(metadataPath, JSON.stringify(metadata));
446
+ }
447
+ catch {
448
+ // Silently fail - metadata save is best-effort
449
+ }
450
+ }
451
+ /**
452
+ * Add entry to HNSW index (with automatic persistence)
453
+ */
454
+ export async function addToHNSWIndex(id, embedding, entry) {
455
+ const index = await getHNSWIndex({ dimensions: embedding.length });
456
+ if (!index)
457
+ return false;
458
+ try {
459
+ const vector = new Float32Array(embedding);
460
+ await index.db.insert({
461
+ id,
462
+ vector
463
+ });
464
+ index.entries.set(id, entry);
465
+ // Save metadata for persistence (debounced would be better for high-volume)
466
+ saveHNSWMetadata();
467
+ return true;
468
+ }
469
+ catch {
470
+ return false;
471
+ }
472
+ }
473
+ /**
474
+ * Search HNSW index (150x faster than brute-force)
475
+ * Returns results sorted by similarity (highest first)
476
+ */
477
+ export async function searchHNSWIndex(queryEmbedding, options) {
478
+ const index = await getHNSWIndex({ dimensions: queryEmbedding.length });
479
+ if (!index)
480
+ return null;
481
+ try {
482
+ const vector = new Float32Array(queryEmbedding);
483
+ const k = options?.k ?? 10;
484
+ // HNSW search returns results with cosine distance (lower = more similar)
485
+ const results = await index.db.search({ vector, k: k * 2 }); // Get extra for filtering
486
+ const filtered = [];
487
+ for (const result of results) {
488
+ const entry = index.entries.get(result.id);
489
+ if (!entry)
490
+ continue;
491
+ // Filter by namespace if specified
492
+ if (options?.namespace && options.namespace !== 'all' && entry.namespace !== options.namespace) {
493
+ continue;
494
+ }
495
+ // Convert cosine distance to similarity score (1 - distance)
496
+ // Cosine distance from @ruvector/core: 0 = identical, 2 = opposite
497
+ const score = 1 - (result.score / 2);
498
+ filtered.push({
499
+ id: entry.id.substring(0, 12),
500
+ key: entry.key || entry.id.substring(0, 15),
501
+ content: entry.content.substring(0, 60) + (entry.content.length > 60 ? '...' : ''),
502
+ score,
503
+ namespace: entry.namespace
504
+ });
505
+ if (filtered.length >= k)
506
+ break;
507
+ }
508
+ // Sort by score descending (highest similarity first)
509
+ filtered.sort((a, b) => b.score - a.score);
510
+ return filtered;
511
+ }
512
+ catch {
513
+ return null;
514
+ }
515
+ }
516
+ /**
517
+ * Get HNSW index status
518
+ */
519
+ export function getHNSWStatus() {
520
+ return {
521
+ available: hnswIndex !== null,
522
+ initialized: hnswIndex?.initialized ?? false,
523
+ entryCount: hnswIndex?.entries.size ?? 0,
524
+ dimensions: hnswIndex?.dimensions ?? 384
525
+ };
526
+ }
527
+ /**
528
+ * Clear the HNSW index (for rebuilding)
529
+ */
530
+ export function clearHNSWIndex() {
531
+ hnswIndex = null;
532
+ }
533
+ // ============================================================================
534
+ // INT8 VECTOR QUANTIZATION (4x memory reduction)
535
+ // ============================================================================
536
+ /**
537
+ * Quantize a Float32 embedding to Int8 (4x memory reduction)
538
+ * Uses symmetric quantization with scale factor stored per-vector
539
+ *
540
+ * @param embedding - Float32 embedding array
541
+ * @returns Quantized Int8 array with scale factor
542
+ */
543
+ export function quantizeInt8(embedding) {
544
+ const arr = embedding instanceof Float32Array ? embedding : new Float32Array(embedding);
545
+ // Find min/max for symmetric quantization
546
+ let min = Infinity, max = -Infinity;
547
+ for (let i = 0; i < arr.length; i++) {
548
+ if (arr[i] < min)
549
+ min = arr[i];
550
+ if (arr[i] > max)
551
+ max = arr[i];
552
+ }
553
+ // Symmetric quantization: scale = max(|min|, |max|) / 127
554
+ const absMax = Math.max(Math.abs(min), Math.abs(max));
555
+ const scale = absMax / 127 || 1e-10; // Avoid division by zero
556
+ const zeroPoint = 0; // Symmetric quantization
557
+ // Quantize
558
+ const quantized = new Int8Array(arr.length);
559
+ for (let i = 0; i < arr.length; i++) {
560
+ // Clamp to [-127, 127] to leave room for potential rounding
561
+ const q = Math.round(arr[i] / scale);
562
+ quantized[i] = Math.max(-127, Math.min(127, q));
563
+ }
564
+ return { quantized, scale, zeroPoint };
565
+ }
566
+ /**
567
+ * Dequantize Int8 back to Float32
568
+ *
569
+ * @param quantized - Int8 quantized array
570
+ * @param scale - Scale factor from quantization
571
+ * @param zeroPoint - Zero point (usually 0 for symmetric)
572
+ * @returns Float32Array
573
+ */
574
+ export function dequantizeInt8(quantized, scale, zeroPoint = 0) {
575
+ const result = new Float32Array(quantized.length);
576
+ for (let i = 0; i < quantized.length; i++) {
577
+ result[i] = (quantized[i] - zeroPoint) * scale;
578
+ }
579
+ return result;
580
+ }
581
+ /**
582
+ * Compute cosine similarity between quantized vectors
583
+ * Faster than dequantizing first
584
+ */
585
+ export function quantizedCosineSim(a, aScale, b, bScale) {
586
+ if (a.length !== b.length)
587
+ return 0;
588
+ let dot = 0, normA = 0, normB = 0;
589
+ for (let i = 0; i < a.length; i++) {
590
+ dot += a[i] * b[i];
591
+ normA += a[i] * a[i];
592
+ normB += b[i] * b[i];
593
+ }
594
+ // Scales cancel out in cosine similarity for normalized vectors
595
+ const mag = Math.sqrt(normA * normB);
596
+ return mag === 0 ? 0 : dot / mag;
597
+ }
598
+ /**
599
+ * Get quantization statistics for an embedding
600
+ */
601
+ export function getQuantizationStats(embedding) {
602
+ const len = embedding.length;
603
+ const originalBytes = len * 4; // Float32 = 4 bytes
604
+ const quantizedBytes = len + 8; // Int8 = 1 byte + 8 bytes for scale/zeroPoint
605
+ const compressionRatio = originalBytes / quantizedBytes;
606
+ return { originalBytes, quantizedBytes, compressionRatio };
607
+ }
608
+ // ============================================================================
609
+ // FLASH ATTENTION-STYLE BATCH OPERATIONS (V8-Optimized)
610
+ // ============================================================================
611
+ /**
612
+ * Batch cosine similarity - compute query against multiple vectors
613
+ * Optimized for V8 JIT with typed arrays
614
+ * ~50μs per 1000 vectors (384-dim)
615
+ */
616
+ export function batchCosineSim(query, vectors) {
617
+ const n = vectors.length;
618
+ const scores = new Float32Array(n);
619
+ if (n === 0 || query.length === 0)
620
+ return scores;
621
+ // Pre-compute query norm
622
+ let queryNorm = 0;
623
+ for (let i = 0; i < query.length; i++) {
624
+ queryNorm += query[i] * query[i];
625
+ }
626
+ queryNorm = Math.sqrt(queryNorm);
627
+ if (queryNorm === 0)
628
+ return scores;
629
+ // Compute similarities
630
+ for (let v = 0; v < n; v++) {
631
+ const vec = vectors[v];
632
+ const len = Math.min(query.length, vec.length);
633
+ let dot = 0, vecNorm = 0;
634
+ for (let i = 0; i < len; i++) {
635
+ dot += query[i] * vec[i];
636
+ vecNorm += vec[i] * vec[i];
637
+ }
638
+ vecNorm = Math.sqrt(vecNorm);
639
+ scores[v] = vecNorm === 0 ? 0 : dot / (queryNorm * vecNorm);
640
+ }
641
+ return scores;
642
+ }
643
+ /**
644
+ * Softmax normalization for attention scores
645
+ * Numerically stable implementation
646
+ */
647
+ export function softmaxAttention(scores, temperature = 1.0) {
648
+ const n = scores.length;
649
+ const result = new Float32Array(n);
650
+ if (n === 0)
651
+ return result;
652
+ // Find max for numerical stability
653
+ let max = scores[0];
654
+ for (let i = 1; i < n; i++) {
655
+ if (scores[i] > max)
656
+ max = scores[i];
657
+ }
658
+ // Compute exp and sum
659
+ let sum = 0;
660
+ for (let i = 0; i < n; i++) {
661
+ result[i] = Math.exp((scores[i] - max) / temperature);
662
+ sum += result[i];
663
+ }
664
+ // Normalize
665
+ if (sum > 0) {
666
+ for (let i = 0; i < n; i++) {
667
+ result[i] /= sum;
668
+ }
669
+ }
670
+ return result;
671
+ }
672
+ /**
673
+ * Top-K selection with partial sort (O(n + k log k))
674
+ * More efficient than full sort for small k
675
+ */
676
+ export function topKIndices(scores, k) {
677
+ const n = scores.length;
678
+ if (k >= n) {
679
+ // Return all indices sorted by score
680
+ return Array.from({ length: n }, (_, i) => i)
681
+ .sort((a, b) => scores[b] - scores[a]);
682
+ }
683
+ // Build min-heap of size k
684
+ const heap = [];
685
+ for (let i = 0; i < n; i++) {
686
+ if (heap.length < k) {
687
+ heap.push({ idx: i, score: scores[i] });
688
+ // Bubble up
689
+ let j = heap.length - 1;
690
+ while (j > 0) {
691
+ const parent = Math.floor((j - 1) / 2);
692
+ if (heap[j].score < heap[parent].score) {
693
+ [heap[j], heap[parent]] = [heap[parent], heap[j]];
694
+ j = parent;
695
+ }
696
+ else
697
+ break;
698
+ }
699
+ }
700
+ else if (scores[i] > heap[0].score) {
701
+ // Replace min and heapify down
702
+ heap[0] = { idx: i, score: scores[i] };
703
+ let j = 0;
704
+ while (true) {
705
+ const left = 2 * j + 1, right = 2 * j + 2;
706
+ let smallest = j;
707
+ if (left < k && heap[left].score < heap[smallest].score)
708
+ smallest = left;
709
+ if (right < k && heap[right].score < heap[smallest].score)
710
+ smallest = right;
711
+ if (smallest === j)
712
+ break;
713
+ [heap[j], heap[smallest]] = [heap[smallest], heap[j]];
714
+ j = smallest;
715
+ }
716
+ }
717
+ }
718
+ // Extract and sort descending
719
+ return heap.sort((a, b) => b.score - a.score).map(h => h.idx);
720
+ }
721
+ /**
722
+ * Flash Attention-style search
723
+ * Combines batch similarity, softmax, and top-k in one pass
724
+ * Returns indices and attention weights
725
+ */
726
+ export function flashAttentionSearch(query, vectors, options = {}) {
727
+ const { k = 10, temperature = 1.0, threshold = 0 } = options;
728
+ // Compute batch similarity
729
+ const scores = batchCosineSim(query, vectors);
730
+ // Get top-k indices
731
+ const indices = topKIndices(scores, k);
732
+ // Filter by threshold
733
+ const filtered = indices.filter(i => scores[i] >= threshold);
734
+ // Extract scores for filtered results
735
+ const topScores = new Float32Array(filtered.length);
736
+ for (let i = 0; i < filtered.length; i++) {
737
+ topScores[i] = scores[filtered[i]];
738
+ }
739
+ // Compute attention weights (softmax over top-k)
740
+ const weights = softmaxAttention(topScores, temperature);
741
+ return { indices: filtered, scores: topScores, weights };
742
+ }
743
+ // ============================================================================
744
+ // METADATA AND INITIALIZATION
745
+ // ============================================================================
746
+ /**
747
+ * Initial metadata to insert after schema creation
748
+ */
749
+ export function getInitialMetadata(backend) {
750
+ return `
751
+ INSERT OR REPLACE INTO metadata (key, value) VALUES
752
+ ('schema_version', '3.0.0'),
753
+ ('backend', '${backend}'),
754
+ ('created_at', '${new Date().toISOString()}'),
755
+ ('sql_js', 'true'),
756
+ ('vector_embeddings', 'enabled'),
757
+ ('pattern_learning', 'enabled'),
758
+ ('temporal_decay', 'enabled'),
759
+ ('hnsw_indexing', 'enabled');
760
+
761
+ -- Create default vector index configuration
762
+ INSERT OR IGNORE INTO vector_indexes (id, name, dimensions) VALUES
763
+ ('default', 'default', 768),
764
+ ('patterns', 'patterns', 768);
765
+ `;
766
+ }
767
+ /**
768
+ * Ensure memory_entries table has all required columns
769
+ * Adds missing columns for older databases (e.g., 'content' column)
770
+ */
771
+ export async function ensureSchemaColumns(dbPath) {
772
+ const columnsAdded = [];
773
+ try {
774
+ if (!fs.existsSync(dbPath)) {
775
+ return { success: true, columnsAdded: [] };
776
+ }
777
+ const initSqlJs = (await import('sql.js')).default;
778
+ const SQL = await initSqlJs();
779
+ const fileBuffer = fs.readFileSync(dbPath);
780
+ const db = new SQL.Database(fileBuffer);
781
+ // Get current columns in memory_entries
782
+ const tableInfo = db.exec("PRAGMA table_info(memory_entries)");
783
+ const existingColumns = new Set(tableInfo[0]?.values?.map(row => row[1]) || []);
784
+ // Required columns that may be missing in older schemas
785
+ // Issue #977: 'type' column was missing from this list, causing store failures on older DBs
786
+ const requiredColumns = [
787
+ { name: 'content', definition: "content TEXT DEFAULT ''" },
788
+ { name: 'type', definition: "type TEXT DEFAULT 'semantic'" },
789
+ { name: 'embedding', definition: 'embedding TEXT' },
790
+ { name: 'embedding_model', definition: "embedding_model TEXT DEFAULT 'local'" },
791
+ { name: 'embedding_dimensions', definition: 'embedding_dimensions INTEGER' },
792
+ { name: 'tags', definition: 'tags TEXT' },
793
+ { name: 'metadata', definition: 'metadata TEXT' },
794
+ { name: 'owner_id', definition: 'owner_id TEXT' },
795
+ { name: 'expires_at', definition: 'expires_at INTEGER' },
796
+ { name: 'last_accessed_at', definition: 'last_accessed_at INTEGER' },
797
+ { name: 'access_count', definition: 'access_count INTEGER DEFAULT 0' },
798
+ { name: 'status', definition: "status TEXT DEFAULT 'active'" }
799
+ ];
800
+ let modified = false;
801
+ for (const col of requiredColumns) {
802
+ if (!existingColumns.has(col.name)) {
803
+ try {
804
+ db.run(`ALTER TABLE memory_entries ADD COLUMN ${col.definition}`);
805
+ columnsAdded.push(col.name);
806
+ modified = true;
807
+ }
808
+ catch (e) {
809
+ // Column might already exist or other error - continue
810
+ }
811
+ }
812
+ }
813
+ if (modified) {
814
+ // Save updated database
815
+ const data = db.export();
816
+ fs.writeFileSync(dbPath, Buffer.from(data));
817
+ }
818
+ db.close();
819
+ return { success: true, columnsAdded };
820
+ }
821
+ catch (error) {
822
+ return {
823
+ success: false,
824
+ columnsAdded,
825
+ error: error instanceof Error ? error.message : String(error)
826
+ };
827
+ }
828
+ }
829
+ /**
830
+ * Check for legacy database installations and migrate if needed
831
+ */
832
+ export async function checkAndMigrateLegacy(options) {
833
+ const { dbPath, verbose = false } = options;
834
+ // Check for legacy locations
835
+ const legacyPaths = [
836
+ path.join(process.cwd(), 'memory.db'),
837
+ path.join(process.cwd(), '.claude/memory.db'),
838
+ path.join(process.cwd(), 'data/memory.db'),
839
+ path.join(process.cwd(), '.claude-flow/memory.db')
840
+ ];
841
+ for (const legacyPath of legacyPaths) {
842
+ if (fs.existsSync(legacyPath) && legacyPath !== dbPath) {
843
+ try {
844
+ const initSqlJs = (await import('sql.js')).default;
845
+ const SQL = await initSqlJs();
846
+ const legacyBuffer = fs.readFileSync(legacyPath);
847
+ const legacyDb = new SQL.Database(legacyBuffer);
848
+ // Check if it has data
849
+ const countResult = legacyDb.exec('SELECT COUNT(*) FROM memory_entries');
850
+ const count = countResult[0]?.values[0]?.[0] || 0;
851
+ // Get version if available
852
+ let version = 'unknown';
853
+ try {
854
+ const versionResult = legacyDb.exec("SELECT value FROM metadata WHERE key='schema_version'");
855
+ version = versionResult[0]?.values[0]?.[0] || 'unknown';
856
+ }
857
+ catch { /* no metadata table */ }
858
+ legacyDb.close();
859
+ if (count > 0) {
860
+ return {
861
+ needsMigration: true,
862
+ legacyVersion: version,
863
+ legacyEntries: count
864
+ };
865
+ }
866
+ }
867
+ catch {
868
+ // Not a valid SQLite database, skip
869
+ }
870
+ }
871
+ }
872
+ return { needsMigration: false };
873
+ }
874
+ /**
875
+ * Initialize the memory database properly using sql.js
876
+ */
877
+ export async function initializeMemoryDatabase(options) {
878
+ const { backend = 'hybrid', dbPath: customPath, force = false, verbose = false, migrate = true } = options;
879
+ const swarmDir = path.join(process.cwd(), '.swarm');
880
+ const dbPath = customPath || path.join(swarmDir, 'memory.db');
881
+ const dbDir = path.dirname(dbPath);
882
+ try {
883
+ // Create directory if needed
884
+ if (!fs.existsSync(dbDir)) {
885
+ fs.mkdirSync(dbDir, { recursive: true });
886
+ }
887
+ // Check for legacy installations
888
+ if (migrate) {
889
+ const legacyCheck = await checkAndMigrateLegacy({ dbPath, verbose });
890
+ if (legacyCheck.needsMigration && verbose) {
891
+ console.log(`Found legacy database (v${legacyCheck.legacyVersion}) with ${legacyCheck.legacyEntries} entries`);
892
+ }
893
+ }
894
+ // Check existing database
895
+ if (fs.existsSync(dbPath) && !force) {
896
+ return {
897
+ success: false,
898
+ backend,
899
+ dbPath,
900
+ schemaVersion: '3.0.0',
901
+ tablesCreated: [],
902
+ indexesCreated: [],
903
+ features: {
904
+ vectorEmbeddings: false,
905
+ patternLearning: false,
906
+ temporalDecay: false,
907
+ hnswIndexing: false,
908
+ migrationTracking: false
909
+ },
910
+ error: 'Database already exists. Use --force to reinitialize.'
911
+ };
912
+ }
913
+ // Try to use sql.js (WASM SQLite)
914
+ let db;
915
+ let usedSqlJs = false;
916
+ try {
917
+ // Dynamic import of sql.js
918
+ const initSqlJs = (await import('sql.js')).default;
919
+ const SQL = await initSqlJs();
920
+ // Load existing database or create new
921
+ if (fs.existsSync(dbPath) && force) {
922
+ fs.unlinkSync(dbPath);
923
+ }
924
+ db = new SQL.Database();
925
+ usedSqlJs = true;
926
+ }
927
+ catch (e) {
928
+ // sql.js not available, fall back to writing schema file
929
+ if (verbose) {
930
+ console.log('sql.js not available, writing schema file for later initialization');
931
+ }
932
+ }
933
+ if (usedSqlJs && db) {
934
+ // Execute schema
935
+ db.run(MEMORY_SCHEMA_V3);
936
+ // Insert initial metadata
937
+ db.run(getInitialMetadata(backend));
938
+ // Save to file
939
+ const data = db.export();
940
+ const buffer = Buffer.from(data);
941
+ fs.writeFileSync(dbPath, buffer);
942
+ // Close database
943
+ db.close();
944
+ // Also create schema file for reference
945
+ const schemaPath = path.join(dbDir, 'schema.sql');
946
+ fs.writeFileSync(schemaPath, MEMORY_SCHEMA_V3 + '\n' + getInitialMetadata(backend));
947
+ return {
948
+ success: true,
949
+ backend,
950
+ dbPath,
951
+ schemaVersion: '3.0.0',
952
+ tablesCreated: [
953
+ 'memory_entries',
954
+ 'patterns',
955
+ 'pattern_history',
956
+ 'trajectories',
957
+ 'trajectory_steps',
958
+ 'migration_state',
959
+ 'sessions',
960
+ 'vector_indexes',
961
+ 'metadata'
962
+ ],
963
+ indexesCreated: [
964
+ 'idx_memory_namespace',
965
+ 'idx_memory_key',
966
+ 'idx_memory_type',
967
+ 'idx_memory_status',
968
+ 'idx_memory_created',
969
+ 'idx_memory_accessed',
970
+ 'idx_memory_owner',
971
+ 'idx_patterns_type',
972
+ 'idx_patterns_confidence',
973
+ 'idx_patterns_status',
974
+ 'idx_patterns_last_matched',
975
+ 'idx_pattern_history_pattern',
976
+ 'idx_steps_trajectory'
977
+ ],
978
+ features: {
979
+ vectorEmbeddings: true,
980
+ patternLearning: true,
981
+ temporalDecay: true,
982
+ hnswIndexing: true,
983
+ migrationTracking: true
984
+ }
985
+ };
986
+ }
987
+ else {
988
+ // Fall back to schema file approach
989
+ const schemaPath = path.join(dbDir, 'schema.sql');
990
+ fs.writeFileSync(schemaPath, MEMORY_SCHEMA_V3 + '\n' + getInitialMetadata(backend));
991
+ // Create minimal valid SQLite file
992
+ const sqliteHeader = Buffer.alloc(4096, 0);
993
+ // SQLite format 3 header
994
+ Buffer.from('SQLite format 3\0').copy(sqliteHeader, 0);
995
+ sqliteHeader[16] = 0x10; // page size high byte (4096)
996
+ sqliteHeader[17] = 0x00; // page size low byte
997
+ sqliteHeader[18] = 0x01; // file format write version
998
+ sqliteHeader[19] = 0x01; // file format read version
999
+ sqliteHeader[24] = 0x00; // max embedded payload
1000
+ sqliteHeader[25] = 0x40;
1001
+ sqliteHeader[26] = 0x20; // min embedded payload
1002
+ sqliteHeader[27] = 0x20; // leaf payload
1003
+ fs.writeFileSync(dbPath, sqliteHeader);
1004
+ return {
1005
+ success: true,
1006
+ backend,
1007
+ dbPath,
1008
+ schemaVersion: '3.0.0',
1009
+ tablesCreated: [
1010
+ 'memory_entries (pending)',
1011
+ 'patterns (pending)',
1012
+ 'pattern_history (pending)',
1013
+ 'trajectories (pending)',
1014
+ 'trajectory_steps (pending)',
1015
+ 'migration_state (pending)',
1016
+ 'sessions (pending)',
1017
+ 'vector_indexes (pending)',
1018
+ 'metadata (pending)'
1019
+ ],
1020
+ indexesCreated: [],
1021
+ features: {
1022
+ vectorEmbeddings: true,
1023
+ patternLearning: true,
1024
+ temporalDecay: true,
1025
+ hnswIndexing: true,
1026
+ migrationTracking: true
1027
+ }
1028
+ };
1029
+ }
1030
+ }
1031
+ catch (error) {
1032
+ return {
1033
+ success: false,
1034
+ backend,
1035
+ dbPath,
1036
+ schemaVersion: '3.0.0',
1037
+ tablesCreated: [],
1038
+ indexesCreated: [],
1039
+ features: {
1040
+ vectorEmbeddings: false,
1041
+ patternLearning: false,
1042
+ temporalDecay: false,
1043
+ hnswIndexing: false,
1044
+ migrationTracking: false
1045
+ },
1046
+ error: error instanceof Error ? error.message : String(error)
1047
+ };
1048
+ }
1049
+ }
1050
+ /**
1051
+ * Check if memory database is properly initialized
1052
+ */
1053
+ export async function checkMemoryInitialization(dbPath) {
1054
+ const swarmDir = path.join(process.cwd(), '.swarm');
1055
+ const path_ = dbPath || path.join(swarmDir, 'memory.db');
1056
+ if (!fs.existsSync(path_)) {
1057
+ return { initialized: false };
1058
+ }
1059
+ try {
1060
+ // Try to load with sql.js
1061
+ const initSqlJs = (await import('sql.js')).default;
1062
+ const SQL = await initSqlJs();
1063
+ const fileBuffer = fs.readFileSync(path_);
1064
+ const db = new SQL.Database(fileBuffer);
1065
+ // Check for metadata table
1066
+ const tables = db.exec("SELECT name FROM sqlite_master WHERE type='table'");
1067
+ const tableNames = tables[0]?.values?.map(v => v[0]) || [];
1068
+ // Get version
1069
+ let version = 'unknown';
1070
+ let backend = 'unknown';
1071
+ try {
1072
+ const versionResult = db.exec("SELECT value FROM metadata WHERE key='schema_version'");
1073
+ version = versionResult[0]?.values[0]?.[0] || 'unknown';
1074
+ const backendResult = db.exec("SELECT value FROM metadata WHERE key='backend'");
1075
+ backend = backendResult[0]?.values[0]?.[0] || 'unknown';
1076
+ }
1077
+ catch {
1078
+ // Metadata table might not exist
1079
+ }
1080
+ db.close();
1081
+ return {
1082
+ initialized: true,
1083
+ version,
1084
+ backend,
1085
+ features: {
1086
+ vectorEmbeddings: tableNames.includes('vector_indexes'),
1087
+ patternLearning: tableNames.includes('patterns'),
1088
+ temporalDecay: tableNames.includes('pattern_history')
1089
+ },
1090
+ tables: tableNames
1091
+ };
1092
+ }
1093
+ catch {
1094
+ // Could not read database
1095
+ return { initialized: false };
1096
+ }
1097
+ }
1098
+ /**
1099
+ * Apply temporal decay to patterns
1100
+ * Reduces confidence of patterns that haven't been used recently
1101
+ */
1102
+ export async function applyTemporalDecay(dbPath) {
1103
+ const swarmDir = path.join(process.cwd(), '.swarm');
1104
+ const path_ = dbPath || path.join(swarmDir, 'memory.db');
1105
+ try {
1106
+ const initSqlJs = (await import('sql.js')).default;
1107
+ const SQL = await initSqlJs();
1108
+ const fileBuffer = fs.readFileSync(path_);
1109
+ const db = new SQL.Database(fileBuffer);
1110
+ // Apply decay: confidence *= exp(-decay_rate * days_since_last_use)
1111
+ const now = Date.now();
1112
+ const decayQuery = `
1113
+ UPDATE patterns
1114
+ SET
1115
+ confidence = confidence * (1.0 - decay_rate * ((? - COALESCE(last_matched_at, created_at)) / 86400000.0)),
1116
+ updated_at = ?
1117
+ WHERE status = 'active'
1118
+ AND confidence > 0.1
1119
+ AND (? - COALESCE(last_matched_at, created_at)) > 86400000
1120
+ `;
1121
+ db.run(decayQuery, [now, now, now]);
1122
+ const changes = db.getRowsModified();
1123
+ // Save
1124
+ const data = db.export();
1125
+ fs.writeFileSync(path_, Buffer.from(data));
1126
+ db.close();
1127
+ return {
1128
+ success: true,
1129
+ patternsDecayed: changes
1130
+ };
1131
+ }
1132
+ catch (error) {
1133
+ return {
1134
+ success: false,
1135
+ patternsDecayed: 0,
1136
+ error: error instanceof Error ? error.message : String(error)
1137
+ };
1138
+ }
1139
+ }
1140
+ let embeddingModelState = null;
1141
+ /**
1142
+ * Lazy load ONNX embedding model
1143
+ * Only loads when first embedding is requested
1144
+ */
1145
+ export async function loadEmbeddingModel(options) {
1146
+ const { verbose = false } = options || {};
1147
+ const startTime = Date.now();
1148
+ // Already loaded
1149
+ if (embeddingModelState?.loaded) {
1150
+ return {
1151
+ success: true,
1152
+ dimensions: embeddingModelState.dimensions,
1153
+ modelName: 'cached',
1154
+ loadTime: 0
1155
+ };
1156
+ }
1157
+ try {
1158
+ // Try to import @xenova/transformers for ONNX embeddings
1159
+ const transformers = await import('@xenova/transformers').catch(() => null);
1160
+ if (transformers) {
1161
+ if (verbose) {
1162
+ console.log('Loading ONNX embedding model (all-MiniLM-L6-v2)...');
1163
+ }
1164
+ // Use small, fast model for local embeddings
1165
+ const { pipeline } = transformers;
1166
+ const embedder = await pipeline('feature-extraction', 'Xenova/all-MiniLM-L6-v2');
1167
+ embeddingModelState = {
1168
+ loaded: true,
1169
+ model: embedder,
1170
+ tokenizer: null,
1171
+ dimensions: 384 // MiniLM-L6 produces 384-dim vectors
1172
+ };
1173
+ return {
1174
+ success: true,
1175
+ dimensions: 384,
1176
+ modelName: 'all-MiniLM-L6-v2',
1177
+ loadTime: Date.now() - startTime
1178
+ };
1179
+ }
1180
+ // Fallback: Check for agentic-flow ONNX
1181
+ const agenticFlow = await import('agentic-flow').catch(() => null);
1182
+ if (agenticFlow && agenticFlow.embeddings) {
1183
+ if (verbose) {
1184
+ console.log('Loading agentic-flow embedding model...');
1185
+ }
1186
+ embeddingModelState = {
1187
+ loaded: true,
1188
+ model: agenticFlow.embeddings,
1189
+ tokenizer: null,
1190
+ dimensions: 768
1191
+ };
1192
+ return {
1193
+ success: true,
1194
+ dimensions: 768,
1195
+ modelName: 'agentic-flow',
1196
+ loadTime: Date.now() - startTime
1197
+ };
1198
+ }
1199
+ // No ONNX model available - use fallback
1200
+ embeddingModelState = {
1201
+ loaded: true,
1202
+ model: null, // Will use simple hash-based fallback
1203
+ tokenizer: null,
1204
+ dimensions: 128 // Smaller fallback dimensions
1205
+ };
1206
+ return {
1207
+ success: true,
1208
+ dimensions: 128,
1209
+ modelName: 'hash-fallback',
1210
+ loadTime: Date.now() - startTime
1211
+ };
1212
+ }
1213
+ catch (error) {
1214
+ return {
1215
+ success: false,
1216
+ dimensions: 0,
1217
+ modelName: 'none',
1218
+ error: error instanceof Error ? error.message : String(error)
1219
+ };
1220
+ }
1221
+ }
1222
+ /**
1223
+ * Generate real embedding for text
1224
+ * Uses ONNX model if available, falls back to deterministic hash
1225
+ */
1226
+ export async function generateEmbedding(text) {
1227
+ // Ensure model is loaded
1228
+ if (!embeddingModelState?.loaded) {
1229
+ await loadEmbeddingModel();
1230
+ }
1231
+ const state = embeddingModelState;
1232
+ // Use ONNX model if available
1233
+ if (state.model && typeof state.model === 'function') {
1234
+ try {
1235
+ const output = await state.model(text, { pooling: 'mean', normalize: true });
1236
+ const embedding = Array.from(output.data);
1237
+ return {
1238
+ embedding,
1239
+ dimensions: embedding.length,
1240
+ model: 'onnx'
1241
+ };
1242
+ }
1243
+ catch {
1244
+ // Fall through to fallback
1245
+ }
1246
+ }
1247
+ // Deterministic hash-based fallback (for testing/demo without ONNX)
1248
+ const embedding = generateHashEmbedding(text, state.dimensions);
1249
+ return {
1250
+ embedding,
1251
+ dimensions: state.dimensions,
1252
+ model: 'hash-fallback'
1253
+ };
1254
+ }
1255
+ /**
1256
+ * Generate embeddings for multiple texts
1257
+ * Uses parallel execution for API-based providers (2-4x faster)
1258
+ * Note: Local ONNX inference is CPU-bound, so parallelism has limited benefit
1259
+ *
1260
+ * @param texts - Array of texts to embed
1261
+ * @param options - Batch options
1262
+ * @returns Array of embedding results with timing info
1263
+ */
1264
+ export async function generateBatchEmbeddings(texts, options) {
1265
+ const { concurrency = texts.length, onProgress } = options || {};
1266
+ const startTime = Date.now();
1267
+ // Ensure model is loaded first (prevents cold start in parallel)
1268
+ if (!embeddingModelState?.loaded) {
1269
+ await loadEmbeddingModel();
1270
+ }
1271
+ // Process in parallel with optional concurrency limit
1272
+ if (concurrency >= texts.length) {
1273
+ // Full parallelism
1274
+ const embeddings = await Promise.all(texts.map(async (text, i) => {
1275
+ const result = await generateEmbedding(text);
1276
+ onProgress?.(i + 1, texts.length);
1277
+ return { text, ...result };
1278
+ }));
1279
+ const totalTime = Date.now() - startTime;
1280
+ return {
1281
+ results: embeddings,
1282
+ totalTime,
1283
+ avgTime: totalTime / texts.length
1284
+ };
1285
+ }
1286
+ // Limited concurrency using chunking
1287
+ const results = [];
1288
+ let completed = 0;
1289
+ for (let i = 0; i < texts.length; i += concurrency) {
1290
+ const chunk = texts.slice(i, i + concurrency);
1291
+ const chunkResults = await Promise.all(chunk.map(async (text) => {
1292
+ const result = await generateEmbedding(text);
1293
+ completed++;
1294
+ onProgress?.(completed, texts.length);
1295
+ return { text, ...result };
1296
+ }));
1297
+ results.push(...chunkResults);
1298
+ }
1299
+ const totalTime = Date.now() - startTime;
1300
+ return {
1301
+ results,
1302
+ totalTime,
1303
+ avgTime: totalTime / texts.length
1304
+ };
1305
+ }
1306
+ /**
1307
+ * Generate deterministic hash-based embedding
1308
+ * Not semantic, but deterministic and useful for testing
1309
+ */
1310
+ function generateHashEmbedding(text, dimensions) {
1311
+ const embedding = new Array(dimensions).fill(0);
1312
+ // Simple hash-based approach for reproducibility
1313
+ const words = text.toLowerCase().split(/\s+/);
1314
+ for (let i = 0; i < words.length; i++) {
1315
+ const word = words[i];
1316
+ for (let j = 0; j < word.length; j++) {
1317
+ const charCode = word.charCodeAt(j);
1318
+ const idx = (charCode * (i + 1) * (j + 1)) % dimensions;
1319
+ embedding[idx] += Math.sin(charCode * 0.1) * 0.1;
1320
+ }
1321
+ }
1322
+ // Normalize to unit vector
1323
+ const magnitude = Math.sqrt(embedding.reduce((sum, v) => sum + v * v, 0)) || 1;
1324
+ return embedding.map(v => v / magnitude);
1325
+ }
1326
+ /**
1327
+ * Verify memory initialization works correctly
1328
+ * Tests: write, read, search, patterns
1329
+ */
1330
+ export async function verifyMemoryInit(dbPath, options) {
1331
+ const { verbose = false } = options || {};
1332
+ const tests = [];
1333
+ try {
1334
+ const initSqlJs = (await import('sql.js')).default;
1335
+ const SQL = await initSqlJs();
1336
+ const fs = await import('fs');
1337
+ // Load database
1338
+ const fileBuffer = fs.readFileSync(dbPath);
1339
+ const db = new SQL.Database(fileBuffer);
1340
+ // Test 1: Schema verification
1341
+ const schemaStart = Date.now();
1342
+ const tables = db.exec("SELECT name FROM sqlite_master WHERE type='table'");
1343
+ const tableNames = tables[0]?.values?.map(v => v[0]) || [];
1344
+ const expectedTables = ['memory_entries', 'patterns', 'metadata', 'vector_indexes'];
1345
+ const missingTables = expectedTables.filter(t => !tableNames.includes(t));
1346
+ tests.push({
1347
+ name: 'Schema verification',
1348
+ passed: missingTables.length === 0,
1349
+ details: missingTables.length > 0 ? `Missing: ${missingTables.join(', ')}` : `${tableNames.length} tables found`,
1350
+ duration: Date.now() - schemaStart
1351
+ });
1352
+ // Test 2: Write entry
1353
+ const writeStart = Date.now();
1354
+ const testId = `test_${Date.now()}`;
1355
+ const testKey = 'verification_test';
1356
+ const testValue = 'This is a verification test entry for memory initialization';
1357
+ try {
1358
+ db.run(`
1359
+ INSERT INTO memory_entries (id, key, namespace, content, type, created_at, updated_at)
1360
+ VALUES (?, ?, 'test', ?, 'semantic', ?, ?)
1361
+ `, [testId, testKey, testValue, Date.now(), Date.now()]);
1362
+ tests.push({
1363
+ name: 'Write entry',
1364
+ passed: true,
1365
+ details: 'Entry written successfully',
1366
+ duration: Date.now() - writeStart
1367
+ });
1368
+ }
1369
+ catch (e) {
1370
+ tests.push({
1371
+ name: 'Write entry',
1372
+ passed: false,
1373
+ details: e instanceof Error ? e.message : 'Write failed',
1374
+ duration: Date.now() - writeStart
1375
+ });
1376
+ }
1377
+ // Test 3: Read entry
1378
+ const readStart = Date.now();
1379
+ try {
1380
+ const result = db.exec(`SELECT content FROM memory_entries WHERE id = ?`, [testId]);
1381
+ const content = result[0]?.values[0]?.[0];
1382
+ tests.push({
1383
+ name: 'Read entry',
1384
+ passed: content === testValue,
1385
+ details: content === testValue ? 'Content matches' : 'Content mismatch',
1386
+ duration: Date.now() - readStart
1387
+ });
1388
+ }
1389
+ catch (e) {
1390
+ tests.push({
1391
+ name: 'Read entry',
1392
+ passed: false,
1393
+ details: e instanceof Error ? e.message : 'Read failed',
1394
+ duration: Date.now() - readStart
1395
+ });
1396
+ }
1397
+ // Test 4: Write with embedding
1398
+ const embeddingStart = Date.now();
1399
+ try {
1400
+ const { embedding, dimensions, model } = await generateEmbedding(testValue);
1401
+ const embeddingJson = JSON.stringify(embedding);
1402
+ db.run(`
1403
+ UPDATE memory_entries
1404
+ SET embedding = ?, embedding_dimensions = ?, embedding_model = ?
1405
+ WHERE id = ?
1406
+ `, [embeddingJson, dimensions, model, testId]);
1407
+ tests.push({
1408
+ name: 'Generate embedding',
1409
+ passed: true,
1410
+ details: `${dimensions}-dim vector (${model})`,
1411
+ duration: Date.now() - embeddingStart
1412
+ });
1413
+ }
1414
+ catch (e) {
1415
+ tests.push({
1416
+ name: 'Generate embedding',
1417
+ passed: false,
1418
+ details: e instanceof Error ? e.message : 'Embedding failed',
1419
+ duration: Date.now() - embeddingStart
1420
+ });
1421
+ }
1422
+ // Test 5: Pattern storage
1423
+ const patternStart = Date.now();
1424
+ try {
1425
+ const patternId = `pattern_${Date.now()}`;
1426
+ db.run(`
1427
+ INSERT INTO patterns (id, name, pattern_type, condition, action, confidence, created_at, updated_at)
1428
+ VALUES (?, 'test-pattern', 'task-routing', 'test condition', 'test action', 0.5, ?, ?)
1429
+ `, [patternId, Date.now(), Date.now()]);
1430
+ tests.push({
1431
+ name: 'Pattern storage',
1432
+ passed: true,
1433
+ details: 'Pattern stored with confidence scoring',
1434
+ duration: Date.now() - patternStart
1435
+ });
1436
+ // Cleanup test pattern
1437
+ db.run(`DELETE FROM patterns WHERE id = ?`, [patternId]);
1438
+ }
1439
+ catch (e) {
1440
+ tests.push({
1441
+ name: 'Pattern storage',
1442
+ passed: false,
1443
+ details: e instanceof Error ? e.message : 'Pattern storage failed',
1444
+ duration: Date.now() - patternStart
1445
+ });
1446
+ }
1447
+ // Test 6: Vector index configuration
1448
+ const indexStart = Date.now();
1449
+ try {
1450
+ const indexResult = db.exec(`SELECT name, dimensions, hnsw_m, hnsw_ef_construction FROM vector_indexes`);
1451
+ const indexes = indexResult[0]?.values || [];
1452
+ tests.push({
1453
+ name: 'Vector index config',
1454
+ passed: indexes.length > 0,
1455
+ details: `${indexes.length} indexes configured (HNSW M=16, ef=200)`,
1456
+ duration: Date.now() - indexStart
1457
+ });
1458
+ }
1459
+ catch (e) {
1460
+ tests.push({
1461
+ name: 'Vector index config',
1462
+ passed: false,
1463
+ details: e instanceof Error ? e.message : 'Index check failed',
1464
+ duration: Date.now() - indexStart
1465
+ });
1466
+ }
1467
+ // Cleanup test entry
1468
+ db.run(`DELETE FROM memory_entries WHERE id = ?`, [testId]);
1469
+ // Save changes
1470
+ const data = db.export();
1471
+ fs.writeFileSync(dbPath, Buffer.from(data));
1472
+ db.close();
1473
+ const passed = tests.filter(t => t.passed).length;
1474
+ const failed = tests.filter(t => !t.passed).length;
1475
+ return {
1476
+ success: failed === 0,
1477
+ tests,
1478
+ summary: {
1479
+ passed,
1480
+ failed,
1481
+ total: tests.length
1482
+ }
1483
+ };
1484
+ }
1485
+ catch (error) {
1486
+ return {
1487
+ success: false,
1488
+ tests: [{
1489
+ name: 'Database access',
1490
+ passed: false,
1491
+ details: error instanceof Error ? error.message : 'Unknown error'
1492
+ }],
1493
+ summary: { passed: 0, failed: 1, total: 1 }
1494
+ };
1495
+ }
1496
+ }
1497
+ /**
1498
+ * Store an entry directly using sql.js
1499
+ * This bypasses MCP and writes directly to the database
1500
+ */
1501
+ export async function storeEntry(options) {
1502
+ const { key, value, namespace = 'default', generateEmbeddingFlag = true, tags = [], ttl, dbPath: customPath } = options;
1503
+ const swarmDir = path.join(process.cwd(), '.swarm');
1504
+ const dbPath = customPath || path.join(swarmDir, 'memory.db');
1505
+ try {
1506
+ if (!fs.existsSync(dbPath)) {
1507
+ return { success: false, id: '', error: 'Database not initialized. Run: claude-flow memory init' };
1508
+ }
1509
+ // Ensure schema has all required columns (migration for older DBs)
1510
+ await ensureSchemaColumns(dbPath);
1511
+ const initSqlJs = (await import('sql.js')).default;
1512
+ const SQL = await initSqlJs();
1513
+ const fileBuffer = fs.readFileSync(dbPath);
1514
+ const db = new SQL.Database(fileBuffer);
1515
+ const id = `entry_${Date.now()}_${Math.random().toString(36).substring(7)}`;
1516
+ const now = Date.now();
1517
+ // Generate embedding if requested
1518
+ let embeddingJson = null;
1519
+ let embeddingDimensions = null;
1520
+ let embeddingModel = null;
1521
+ if (generateEmbeddingFlag && value.length > 0) {
1522
+ const embResult = await generateEmbedding(value);
1523
+ embeddingJson = JSON.stringify(embResult.embedding);
1524
+ embeddingDimensions = embResult.dimensions;
1525
+ embeddingModel = embResult.model;
1526
+ }
1527
+ // Insert entry
1528
+ db.run(`
1529
+ INSERT INTO memory_entries (
1530
+ id, key, namespace, content, type,
1531
+ embedding, embedding_dimensions, embedding_model,
1532
+ tags, metadata, created_at, updated_at, expires_at, status
1533
+ ) VALUES (?, ?, ?, ?, 'semantic', ?, ?, ?, ?, ?, ?, ?, ?, 'active')
1534
+ `, [
1535
+ id,
1536
+ key,
1537
+ namespace,
1538
+ value,
1539
+ embeddingJson,
1540
+ embeddingDimensions,
1541
+ embeddingModel,
1542
+ tags.length > 0 ? JSON.stringify(tags) : null,
1543
+ '{}',
1544
+ now,
1545
+ now,
1546
+ ttl ? now + (ttl * 1000) : null
1547
+ ]);
1548
+ // Save
1549
+ const data = db.export();
1550
+ fs.writeFileSync(dbPath, Buffer.from(data));
1551
+ db.close();
1552
+ // Add to HNSW index for faster future searches
1553
+ if (embeddingJson) {
1554
+ const embResult = JSON.parse(embeddingJson);
1555
+ await addToHNSWIndex(id, embResult, {
1556
+ id,
1557
+ key,
1558
+ namespace,
1559
+ content: value
1560
+ });
1561
+ }
1562
+ return {
1563
+ success: true,
1564
+ id,
1565
+ embedding: embeddingJson ? { dimensions: embeddingDimensions, model: embeddingModel } : undefined
1566
+ };
1567
+ }
1568
+ catch (error) {
1569
+ return {
1570
+ success: false,
1571
+ id: '',
1572
+ error: error instanceof Error ? error.message : String(error)
1573
+ };
1574
+ }
1575
+ }
1576
+ /**
1577
+ * Search entries using sql.js with vector similarity
1578
+ * Uses HNSW index for 150x faster search when available
1579
+ */
1580
+ export async function searchEntries(options) {
1581
+ const { query, namespace = 'default', limit = 10, threshold = 0.3, dbPath: customPath } = options;
1582
+ const swarmDir = path.join(process.cwd(), '.swarm');
1583
+ const dbPath = customPath || path.join(swarmDir, 'memory.db');
1584
+ const startTime = Date.now();
1585
+ try {
1586
+ if (!fs.existsSync(dbPath)) {
1587
+ return { success: false, results: [], searchTime: 0, error: 'Database not found' };
1588
+ }
1589
+ // Ensure schema has all required columns (migration for older DBs)
1590
+ await ensureSchemaColumns(dbPath);
1591
+ // Generate query embedding
1592
+ const queryEmb = await generateEmbedding(query);
1593
+ const queryEmbedding = queryEmb.embedding;
1594
+ // Try HNSW search first (150x faster)
1595
+ const hnswResults = await searchHNSWIndex(queryEmbedding, { k: limit, namespace });
1596
+ if (hnswResults && hnswResults.length > 0) {
1597
+ // Filter by threshold
1598
+ const filtered = hnswResults.filter(r => r.score >= threshold);
1599
+ return {
1600
+ success: true,
1601
+ results: filtered,
1602
+ searchTime: Date.now() - startTime
1603
+ };
1604
+ }
1605
+ // Fall back to brute-force SQLite search
1606
+ const initSqlJs = (await import('sql.js')).default;
1607
+ const SQL = await initSqlJs();
1608
+ const fileBuffer = fs.readFileSync(dbPath);
1609
+ const db = new SQL.Database(fileBuffer);
1610
+ // Get entries with embeddings
1611
+ const entries = db.exec(`
1612
+ SELECT id, key, namespace, content, embedding
1613
+ FROM memory_entries
1614
+ WHERE status = 'active'
1615
+ ${namespace !== 'all' ? `AND namespace = '${namespace.replace(/'/g, "''")}'` : ''}
1616
+ LIMIT 1000
1617
+ `);
1618
+ const results = [];
1619
+ if (entries[0]?.values) {
1620
+ for (const row of entries[0].values) {
1621
+ const [id, key, ns, content, embeddingJson] = row;
1622
+ let score = 0;
1623
+ if (embeddingJson) {
1624
+ try {
1625
+ const embedding = JSON.parse(embeddingJson);
1626
+ score = cosineSim(queryEmbedding, embedding);
1627
+ }
1628
+ catch {
1629
+ // Invalid embedding, use keyword score
1630
+ }
1631
+ }
1632
+ // Fallback to keyword matching
1633
+ if (score < threshold) {
1634
+ const lowerContent = (content || '').toLowerCase();
1635
+ const lowerQuery = query.toLowerCase();
1636
+ const words = lowerQuery.split(/\s+/);
1637
+ const matchCount = words.filter(w => lowerContent.includes(w)).length;
1638
+ const keywordScore = matchCount / words.length * 0.5;
1639
+ score = Math.max(score, keywordScore);
1640
+ }
1641
+ if (score >= threshold) {
1642
+ results.push({
1643
+ id: id.substring(0, 12),
1644
+ key: key || id.substring(0, 15),
1645
+ content: (content || '').substring(0, 60) + ((content || '').length > 60 ? '...' : ''),
1646
+ score,
1647
+ namespace: ns || 'default'
1648
+ });
1649
+ }
1650
+ }
1651
+ }
1652
+ db.close();
1653
+ // Sort by score
1654
+ results.sort((a, b) => b.score - a.score);
1655
+ return {
1656
+ success: true,
1657
+ results: results.slice(0, limit),
1658
+ searchTime: Date.now() - startTime
1659
+ };
1660
+ }
1661
+ catch (error) {
1662
+ return {
1663
+ success: false,
1664
+ results: [],
1665
+ searchTime: Date.now() - startTime,
1666
+ error: error instanceof Error ? error.message : String(error)
1667
+ };
1668
+ }
1669
+ }
1670
+ /**
1671
+ * Optimized cosine similarity
1672
+ * V8 JIT-friendly - avoids manual unrolling which can hurt performance
1673
+ * ~0.5μs per 384-dim vector comparison
1674
+ */
1675
+ function cosineSim(a, b) {
1676
+ if (!a || !b || a.length === 0 || b.length === 0)
1677
+ return 0;
1678
+ const len = Math.min(a.length, b.length);
1679
+ let dot = 0, normA = 0, normB = 0;
1680
+ // Simple loop - V8 optimizes this well
1681
+ for (let i = 0; i < len; i++) {
1682
+ const ai = a[i], bi = b[i];
1683
+ dot += ai * bi;
1684
+ normA += ai * ai;
1685
+ normB += bi * bi;
1686
+ }
1687
+ // Combined sqrt for slightly better performance
1688
+ const mag = Math.sqrt(normA * normB);
1689
+ return mag === 0 ? 0 : dot / mag;
1690
+ }
1691
+ /**
1692
+ * List all entries from the memory database
1693
+ */
1694
+ export async function listEntries(options) {
1695
+ const { namespace, limit = 20, offset = 0, dbPath: customPath } = options;
1696
+ const swarmDir = path.join(process.cwd(), '.swarm');
1697
+ const dbPath = customPath || path.join(swarmDir, 'memory.db');
1698
+ try {
1699
+ if (!fs.existsSync(dbPath)) {
1700
+ return { success: false, entries: [], total: 0, error: 'Database not found' };
1701
+ }
1702
+ // Ensure schema has all required columns (migration for older DBs)
1703
+ await ensureSchemaColumns(dbPath);
1704
+ const initSqlJs = (await import('sql.js')).default;
1705
+ const SQL = await initSqlJs();
1706
+ const fileBuffer = fs.readFileSync(dbPath);
1707
+ const db = new SQL.Database(fileBuffer);
1708
+ // Get total count
1709
+ const countQuery = namespace
1710
+ ? `SELECT COUNT(*) as cnt FROM memory_entries WHERE status = 'active' AND namespace = '${namespace.replace(/'/g, "''")}'`
1711
+ : `SELECT COUNT(*) as cnt FROM memory_entries WHERE status = 'active'`;
1712
+ const countResult = db.exec(countQuery);
1713
+ const total = countResult[0]?.values?.[0]?.[0] || 0;
1714
+ // Get entries
1715
+ const listQuery = `
1716
+ SELECT id, key, namespace, content, embedding, access_count, created_at, updated_at
1717
+ FROM memory_entries
1718
+ WHERE status = 'active'
1719
+ ${namespace ? `AND namespace = '${namespace.replace(/'/g, "''")}'` : ''}
1720
+ ORDER BY updated_at DESC
1721
+ LIMIT ${limit} OFFSET ${offset}
1722
+ `;
1723
+ const result = db.exec(listQuery);
1724
+ const entries = [];
1725
+ if (result[0]?.values) {
1726
+ for (const row of result[0].values) {
1727
+ const [id, key, ns, content, embedding, accessCount, createdAt, updatedAt] = row;
1728
+ entries.push({
1729
+ id: String(id).substring(0, 20),
1730
+ key: key || String(id).substring(0, 15),
1731
+ namespace: ns || 'default',
1732
+ size: (content || '').length,
1733
+ accessCount: accessCount || 0,
1734
+ createdAt: createdAt || new Date().toISOString(),
1735
+ updatedAt: updatedAt || new Date().toISOString(),
1736
+ hasEmbedding: !!embedding && embedding.length > 10
1737
+ });
1738
+ }
1739
+ }
1740
+ db.close();
1741
+ return { success: true, entries, total };
1742
+ }
1743
+ catch (error) {
1744
+ return {
1745
+ success: false,
1746
+ entries: [],
1747
+ total: 0,
1748
+ error: error instanceof Error ? error.message : String(error)
1749
+ };
1750
+ }
1751
+ }
1752
+ /**
1753
+ * Get a specific entry from the memory database
1754
+ */
1755
+ export async function getEntry(options) {
1756
+ const { key, namespace = 'default', dbPath: customPath } = options;
1757
+ const swarmDir = path.join(process.cwd(), '.swarm');
1758
+ const dbPath = customPath || path.join(swarmDir, 'memory.db');
1759
+ try {
1760
+ if (!fs.existsSync(dbPath)) {
1761
+ return { success: false, found: false, error: 'Database not found' };
1762
+ }
1763
+ // Ensure schema has all required columns (migration for older DBs)
1764
+ await ensureSchemaColumns(dbPath);
1765
+ const initSqlJs = (await import('sql.js')).default;
1766
+ const SQL = await initSqlJs();
1767
+ const fileBuffer = fs.readFileSync(dbPath);
1768
+ const db = new SQL.Database(fileBuffer);
1769
+ // Find entry by key
1770
+ const result = db.exec(`
1771
+ SELECT id, key, namespace, content, embedding, access_count, created_at, updated_at, tags
1772
+ FROM memory_entries
1773
+ WHERE status = 'active'
1774
+ AND key = '${key.replace(/'/g, "''")}'
1775
+ AND namespace = '${namespace.replace(/'/g, "''")}'
1776
+ LIMIT 1
1777
+ `);
1778
+ if (!result[0]?.values?.[0]) {
1779
+ db.close();
1780
+ return { success: true, found: false };
1781
+ }
1782
+ const [id, entryKey, ns, content, embedding, accessCount, createdAt, updatedAt, tagsJson] = result[0].values[0];
1783
+ // Update access count
1784
+ db.run(`
1785
+ UPDATE memory_entries
1786
+ SET access_count = access_count + 1, last_accessed_at = strftime('%s', 'now') * 1000
1787
+ WHERE id = '${String(id).replace(/'/g, "''")}'
1788
+ `);
1789
+ // Save updated database
1790
+ const data = db.export();
1791
+ fs.writeFileSync(dbPath, Buffer.from(data));
1792
+ db.close();
1793
+ let tags = [];
1794
+ if (tagsJson) {
1795
+ try {
1796
+ tags = JSON.parse(tagsJson);
1797
+ }
1798
+ catch {
1799
+ // Invalid JSON
1800
+ }
1801
+ }
1802
+ return {
1803
+ success: true,
1804
+ found: true,
1805
+ entry: {
1806
+ id: String(id),
1807
+ key: entryKey || String(id),
1808
+ namespace: ns || 'default',
1809
+ content: content || '',
1810
+ accessCount: (accessCount || 0) + 1,
1811
+ createdAt: createdAt || new Date().toISOString(),
1812
+ updatedAt: updatedAt || new Date().toISOString(),
1813
+ hasEmbedding: !!embedding && embedding.length > 10,
1814
+ tags
1815
+ }
1816
+ };
1817
+ }
1818
+ catch (error) {
1819
+ return {
1820
+ success: false,
1821
+ found: false,
1822
+ error: error instanceof Error ? error.message : String(error)
1823
+ };
1824
+ }
1825
+ }
1826
+ /**
1827
+ * Delete a memory entry by key and namespace
1828
+ * Issue #980: Properly supports namespaced entries
1829
+ */
1830
+ export async function deleteEntry(options) {
1831
+ const { key, namespace = 'default', dbPath: customPath } = options;
1832
+ const swarmDir = path.join(process.cwd(), '.swarm');
1833
+ const dbPath = customPath || path.join(swarmDir, 'memory.db');
1834
+ try {
1835
+ if (!fs.existsSync(dbPath)) {
1836
+ return {
1837
+ success: false,
1838
+ deleted: false,
1839
+ key,
1840
+ namespace,
1841
+ remainingEntries: 0,
1842
+ error: 'Database not found'
1843
+ };
1844
+ }
1845
+ // Ensure schema has all required columns (migration for older DBs)
1846
+ await ensureSchemaColumns(dbPath);
1847
+ const initSqlJs = (await import('sql.js')).default;
1848
+ const SQL = await initSqlJs();
1849
+ const fileBuffer = fs.readFileSync(dbPath);
1850
+ const db = new SQL.Database(fileBuffer);
1851
+ // Check if entry exists first
1852
+ const checkResult = db.exec(`
1853
+ SELECT id FROM memory_entries
1854
+ WHERE status = 'active'
1855
+ AND key = '${key.replace(/'/g, "''")}'
1856
+ AND namespace = '${namespace.replace(/'/g, "''")}'
1857
+ LIMIT 1
1858
+ `);
1859
+ if (!checkResult[0]?.values?.[0]) {
1860
+ // Get remaining count before closing
1861
+ const countResult = db.exec(`SELECT COUNT(*) FROM memory_entries WHERE status = 'active'`);
1862
+ const remainingEntries = countResult[0]?.values?.[0]?.[0] || 0;
1863
+ db.close();
1864
+ return {
1865
+ success: true,
1866
+ deleted: false,
1867
+ key,
1868
+ namespace,
1869
+ remainingEntries,
1870
+ error: `Key '${key}' not found in namespace '${namespace}'`
1871
+ };
1872
+ }
1873
+ // Delete the entry (soft delete by setting status to 'deleted')
1874
+ db.run(`
1875
+ UPDATE memory_entries
1876
+ SET status = 'deleted', updated_at = strftime('%s', 'now') * 1000
1877
+ WHERE key = '${key.replace(/'/g, "''")}'
1878
+ AND namespace = '${namespace.replace(/'/g, "''")}'
1879
+ AND status = 'active'
1880
+ `);
1881
+ // Get remaining count
1882
+ const countResult = db.exec(`SELECT COUNT(*) FROM memory_entries WHERE status = 'active'`);
1883
+ const remainingEntries = countResult[0]?.values?.[0]?.[0] || 0;
1884
+ // Save updated database
1885
+ const data = db.export();
1886
+ fs.writeFileSync(dbPath, Buffer.from(data));
1887
+ db.close();
1888
+ return {
1889
+ success: true,
1890
+ deleted: true,
1891
+ key,
1892
+ namespace,
1893
+ remainingEntries
1894
+ };
1895
+ }
1896
+ catch (error) {
1897
+ return {
1898
+ success: false,
1899
+ deleted: false,
1900
+ key,
1901
+ namespace,
1902
+ remainingEntries: 0,
1903
+ error: error instanceof Error ? error.message : String(error)
1904
+ };
1905
+ }
1906
+ }
1907
+ export default {
1908
+ initializeMemoryDatabase,
1909
+ checkMemoryInitialization,
1910
+ checkAndMigrateLegacy,
1911
+ ensureSchemaColumns,
1912
+ applyTemporalDecay,
1913
+ loadEmbeddingModel,
1914
+ generateEmbedding,
1915
+ verifyMemoryInit,
1916
+ storeEntry,
1917
+ searchEntries,
1918
+ listEntries,
1919
+ getEntry,
1920
+ deleteEntry,
1921
+ MEMORY_SCHEMA_V3,
1922
+ getInitialMetadata
1923
+ };
1924
+ //# sourceMappingURL=memory-initializer.js.map