@claude-flow/cli 3.7.0-alpha.1 → 3.7.0-alpha.10
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.
- package/.claude/agents/analysis/analyze-code-quality.md +178 -178
- package/.claude/agents/analysis/code-analyzer.md +209 -209
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +178 -178
- package/.claude/agents/architecture/arch-system-design.md +156 -156
- package/.claude/agents/architecture/system-design/arch-system-design.md +154 -154
- package/.claude/agents/browser/browser-agent.yaml +182 -182
- package/.claude/agents/consensus/byzantine-coordinator.md +62 -62
- package/.claude/agents/consensus/crdt-synchronizer.md +996 -996
- package/.claude/agents/consensus/gossip-coordinator.md +62 -62
- package/.claude/agents/consensus/performance-benchmarker.md +850 -850
- package/.claude/agents/consensus/quorum-manager.md +822 -822
- package/.claude/agents/consensus/raft-manager.md +62 -62
- package/.claude/agents/consensus/security-manager.md +621 -621
- package/.claude/agents/core/coder.md +452 -452
- package/.claude/agents/core/planner.md +374 -374
- package/.claude/agents/core/researcher.md +368 -368
- package/.claude/agents/core/reviewer.md +519 -519
- package/.claude/agents/core/tester.md +511 -511
- package/.claude/agents/custom/test-long-runner.md +44 -44
- package/.claude/agents/data/data-ml-model.md +444 -444
- package/.claude/agents/data/ml/data-ml-model.md +192 -192
- package/.claude/agents/development/backend/dev-backend-api.md +141 -141
- package/.claude/agents/development/dev-backend-api.md +344 -344
- package/.claude/agents/devops/ci-cd/ops-cicd-github.md +163 -163
- package/.claude/agents/devops/ops-cicd-github.md +164 -164
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +173 -173
- package/.claude/agents/documentation/docs-api-openapi.md +354 -354
- package/.claude/agents/flow-nexus/app-store.md +87 -87
- package/.claude/agents/flow-nexus/authentication.md +68 -68
- package/.claude/agents/flow-nexus/challenges.md +80 -80
- package/.claude/agents/flow-nexus/neural-network.md +87 -87
- package/.claude/agents/flow-nexus/payments.md +82 -82
- package/.claude/agents/flow-nexus/sandbox.md +75 -75
- package/.claude/agents/flow-nexus/swarm.md +75 -75
- package/.claude/agents/flow-nexus/user-tools.md +95 -95
- package/.claude/agents/flow-nexus/workflow.md +83 -83
- package/.claude/agents/github/code-review-swarm.md +377 -377
- package/.claude/agents/github/github-modes.md +172 -172
- package/.claude/agents/github/issue-tracker.md +575 -575
- package/.claude/agents/github/multi-repo-swarm.md +552 -552
- package/.claude/agents/github/pr-manager.md +437 -437
- package/.claude/agents/github/project-board-sync.md +508 -508
- package/.claude/agents/github/release-manager.md +604 -604
- package/.claude/agents/github/release-swarm.md +582 -582
- package/.claude/agents/github/repo-architect.md +397 -397
- package/.claude/agents/github/swarm-issue.md +572 -572
- package/.claude/agents/github/swarm-pr.md +427 -427
- package/.claude/agents/github/sync-coordinator.md +451 -451
- package/.claude/agents/github/workflow-automation.md +902 -902
- package/.claude/agents/goal/agent.md +815 -815
- package/.claude/agents/goal/goal-planner.md +72 -72
- package/.claude/agents/optimization/benchmark-suite.md +664 -664
- package/.claude/agents/optimization/load-balancer.md +430 -430
- package/.claude/agents/optimization/performance-monitor.md +671 -671
- package/.claude/agents/optimization/resource-allocator.md +673 -673
- package/.claude/agents/optimization/topology-optimizer.md +807 -807
- package/.claude/agents/payments/agentic-payments.md +126 -126
- package/.claude/agents/sona/sona-learning-optimizer.md +74 -74
- package/.claude/agents/sparc/architecture.md +698 -698
- package/.claude/agents/sparc/pseudocode.md +519 -519
- package/.claude/agents/sparc/refinement.md +801 -801
- package/.claude/agents/sparc/specification.md +477 -477
- package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +224 -224
- package/.claude/agents/specialized/spec-mobile-react-native.md +226 -226
- package/.claude/agents/sublinear/consensus-coordinator.md +337 -337
- package/.claude/agents/sublinear/matrix-optimizer.md +184 -184
- package/.claude/agents/sublinear/pagerank-analyzer.md +298 -298
- package/.claude/agents/sublinear/performance-optimizer.md +367 -367
- package/.claude/agents/sublinear/trading-predictor.md +245 -245
- package/.claude/agents/swarm/adaptive-coordinator.md +1126 -1126
- package/.claude/agents/swarm/hierarchical-coordinator.md +709 -709
- package/.claude/agents/swarm/mesh-coordinator.md +962 -962
- package/.claude/agents/templates/automation-smart-agent.md +204 -204
- package/.claude/agents/templates/base-template-generator.md +289 -289
- package/.claude/agents/templates/coordinator-swarm-init.md +89 -89
- package/.claude/agents/templates/github-pr-manager.md +176 -176
- package/.claude/agents/templates/implementer-sparc-coder.md +258 -258
- package/.claude/agents/templates/memory-coordinator.md +186 -186
- package/.claude/agents/templates/orchestrator-task.md +138 -138
- package/.claude/agents/templates/performance-analyzer.md +198 -198
- package/.claude/agents/templates/sparc-coordinator.md +513 -513
- package/.claude/agents/testing/production-validator.md +394 -394
- package/.claude/agents/testing/tdd-london-swarm.md +243 -243
- package/.claude/agents/v3/adr-architect.md +184 -184
- package/.claude/agents/v3/aidefence-guardian.md +282 -282
- package/.claude/agents/v3/claims-authorizer.md +208 -208
- package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -993
- package/.claude/agents/v3/ddd-domain-expert.md +220 -220
- package/.claude/agents/v3/injection-analyst.md +236 -236
- package/.claude/agents/v3/memory-specialist.md +995 -995
- package/.claude/agents/v3/performance-engineer.md +1233 -1233
- package/.claude/agents/v3/pii-detector.md +151 -151
- package/.claude/agents/v3/reasoningbank-learner.md +213 -213
- package/.claude/agents/v3/security-architect-aidefence.md +410 -410
- package/.claude/agents/v3/security-architect.md +867 -867
- package/.claude/agents/v3/security-auditor.md +771 -771
- package/.claude/agents/v3/sparc-orchestrator.md +182 -182
- package/.claude/agents/v3/swarm-memory-manager.md +157 -157
- package/.claude/agents/v3/v3-integration-architect.md +205 -205
- package/.claude/commands/agents/README.md +50 -50
- package/.claude/commands/agents/agent-capabilities.md +140 -140
- package/.claude/commands/agents/agent-coordination.md +28 -28
- package/.claude/commands/agents/agent-spawning.md +28 -28
- package/.claude/commands/agents/agent-types.md +216 -216
- package/.claude/commands/agents/health.md +139 -139
- package/.claude/commands/agents/list.md +100 -100
- package/.claude/commands/agents/logs.md +130 -130
- package/.claude/commands/agents/metrics.md +122 -122
- package/.claude/commands/agents/pool.md +127 -127
- package/.claude/commands/agents/spawn.md +140 -140
- package/.claude/commands/agents/status.md +115 -115
- package/.claude/commands/agents/stop.md +102 -102
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +53 -53
- package/.claude/commands/analysis/README.md +9 -9
- package/.claude/commands/analysis/bottleneck-detect.md +162 -162
- package/.claude/commands/analysis/performance-bottlenecks.md +58 -58
- package/.claude/commands/analysis/performance-report.md +25 -25
- package/.claude/commands/analysis/token-efficiency.md +44 -44
- package/.claude/commands/analysis/token-usage.md +25 -25
- package/.claude/commands/automation/README.md +9 -9
- package/.claude/commands/automation/auto-agent.md +122 -122
- package/.claude/commands/automation/self-healing.md +105 -105
- package/.claude/commands/automation/session-memory.md +89 -89
- package/.claude/commands/automation/smart-agents.md +72 -72
- package/.claude/commands/automation/smart-spawn.md +25 -25
- package/.claude/commands/automation/workflow-select.md +25 -25
- package/.claude/commands/claude-flow-help.md +103 -103
- package/.claude/commands/claude-flow-memory.md +107 -107
- package/.claude/commands/claude-flow-swarm.md +205 -205
- package/.claude/commands/coordination/README.md +9 -9
- package/.claude/commands/coordination/agent-spawn.md +25 -25
- package/.claude/commands/coordination/init.md +44 -44
- package/.claude/commands/coordination/orchestrate.md +43 -43
- package/.claude/commands/coordination/spawn.md +45 -45
- package/.claude/commands/coordination/swarm-init.md +85 -85
- package/.claude/commands/coordination/task-orchestrate.md +25 -25
- package/.claude/commands/flow-nexus/app-store.md +123 -123
- package/.claude/commands/flow-nexus/challenges.md +119 -119
- package/.claude/commands/flow-nexus/login-registration.md +64 -64
- package/.claude/commands/flow-nexus/neural-network.md +133 -133
- package/.claude/commands/flow-nexus/payments.md +115 -115
- package/.claude/commands/flow-nexus/sandbox.md +82 -82
- package/.claude/commands/flow-nexus/swarm.md +86 -86
- package/.claude/commands/flow-nexus/user-tools.md +151 -151
- package/.claude/commands/flow-nexus/workflow.md +114 -114
- package/.claude/commands/github/README.md +11 -11
- package/.claude/commands/github/code-review-swarm.md +513 -513
- package/.claude/commands/github/code-review.md +25 -25
- package/.claude/commands/github/github-modes.md +146 -146
- package/.claude/commands/github/github-swarm.md +121 -121
- package/.claude/commands/github/issue-tracker.md +291 -291
- package/.claude/commands/github/issue-triage.md +25 -25
- package/.claude/commands/github/multi-repo-swarm.md +518 -518
- package/.claude/commands/github/pr-enhance.md +26 -26
- package/.claude/commands/github/pr-manager.md +169 -169
- package/.claude/commands/github/project-board-sync.md +470 -470
- package/.claude/commands/github/release-manager.md +337 -337
- package/.claude/commands/github/release-swarm.md +543 -543
- package/.claude/commands/github/repo-analyze.md +25 -25
- package/.claude/commands/github/repo-architect.md +366 -366
- package/.claude/commands/github/swarm-issue.md +481 -481
- package/.claude/commands/github/swarm-pr.md +284 -284
- package/.claude/commands/github/sync-coordinator.md +300 -300
- package/.claude/commands/github/workflow-automation.md +441 -441
- package/.claude/commands/hive-mind/README.md +17 -17
- package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -8
- package/.claude/commands/hive-mind/hive-mind-init.md +18 -18
- package/.claude/commands/hive-mind/hive-mind-memory.md +8 -8
- package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -8
- package/.claude/commands/hive-mind/hive-mind-resume.md +8 -8
- package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -8
- package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -21
- package/.claude/commands/hive-mind/hive-mind-status.md +8 -8
- package/.claude/commands/hive-mind/hive-mind-stop.md +8 -8
- package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -8
- package/.claude/commands/hive-mind/hive-mind.md +27 -27
- package/.claude/commands/hooks/README.md +11 -11
- package/.claude/commands/hooks/overview.md +57 -57
- package/.claude/commands/hooks/post-edit.md +117 -117
- package/.claude/commands/hooks/post-task.md +112 -112
- package/.claude/commands/hooks/pre-edit.md +113 -113
- package/.claude/commands/hooks/pre-task.md +111 -111
- package/.claude/commands/hooks/session-end.md +118 -118
- package/.claude/commands/hooks/setup.md +102 -102
- package/.claude/commands/memory/README.md +9 -9
- package/.claude/commands/memory/memory-persist.md +25 -25
- package/.claude/commands/memory/memory-search.md +25 -25
- package/.claude/commands/memory/memory-usage.md +25 -25
- package/.claude/commands/memory/neural.md +47 -47
- package/.claude/commands/monitoring/README.md +9 -9
- package/.claude/commands/monitoring/agent-metrics.md +25 -25
- package/.claude/commands/monitoring/agents.md +44 -44
- package/.claude/commands/monitoring/real-time-view.md +25 -25
- package/.claude/commands/monitoring/status.md +46 -46
- package/.claude/commands/monitoring/swarm-monitor.md +25 -25
- package/.claude/commands/optimization/README.md +9 -9
- package/.claude/commands/optimization/auto-topology.md +61 -61
- package/.claude/commands/optimization/cache-manage.md +25 -25
- package/.claude/commands/optimization/parallel-execute.md +25 -25
- package/.claude/commands/optimization/parallel-execution.md +49 -49
- package/.claude/commands/optimization/topology-optimize.md +25 -25
- package/.claude/commands/pair/README.md +260 -260
- package/.claude/commands/pair/commands.md +545 -545
- package/.claude/commands/pair/config.md +509 -509
- package/.claude/commands/pair/examples.md +511 -511
- package/.claude/commands/pair/modes.md +347 -347
- package/.claude/commands/pair/session.md +406 -406
- package/.claude/commands/pair/start.md +208 -208
- package/.claude/commands/sparc/analyzer.md +51 -51
- package/.claude/commands/sparc/architect.md +53 -53
- package/.claude/commands/sparc/ask.md +97 -97
- package/.claude/commands/sparc/batch-executor.md +54 -54
- package/.claude/commands/sparc/code.md +89 -89
- package/.claude/commands/sparc/coder.md +54 -54
- package/.claude/commands/sparc/debug.md +83 -83
- package/.claude/commands/sparc/debugger.md +54 -54
- package/.claude/commands/sparc/designer.md +53 -53
- package/.claude/commands/sparc/devops.md +109 -109
- package/.claude/commands/sparc/docs-writer.md +80 -80
- package/.claude/commands/sparc/documenter.md +54 -54
- package/.claude/commands/sparc/innovator.md +54 -54
- package/.claude/commands/sparc/integration.md +83 -83
- package/.claude/commands/sparc/mcp.md +117 -117
- package/.claude/commands/sparc/memory-manager.md +54 -54
- package/.claude/commands/sparc/optimizer.md +54 -54
- package/.claude/commands/sparc/orchestrator.md +131 -131
- package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -83
- package/.claude/commands/sparc/refinement-optimization-mode.md +83 -83
- package/.claude/commands/sparc/researcher.md +54 -54
- package/.claude/commands/sparc/reviewer.md +54 -54
- package/.claude/commands/sparc/security-review.md +80 -80
- package/.claude/commands/sparc/sparc-modes.md +174 -174
- package/.claude/commands/sparc/sparc.md +111 -111
- package/.claude/commands/sparc/spec-pseudocode.md +80 -80
- package/.claude/commands/sparc/supabase-admin.md +348 -348
- package/.claude/commands/sparc/swarm-coordinator.md +54 -54
- package/.claude/commands/sparc/tdd.md +54 -54
- package/.claude/commands/sparc/tester.md +54 -54
- package/.claude/commands/sparc/tutorial.md +79 -79
- package/.claude/commands/sparc/workflow-manager.md +54 -54
- package/.claude/commands/sparc.md +166 -166
- package/.claude/commands/stream-chain/pipeline.md +120 -120
- package/.claude/commands/stream-chain/run.md +69 -69
- package/.claude/commands/swarm/README.md +15 -15
- package/.claude/commands/swarm/analysis.md +95 -95
- package/.claude/commands/swarm/development.md +96 -96
- package/.claude/commands/swarm/examples.md +168 -168
- package/.claude/commands/swarm/maintenance.md +102 -102
- package/.claude/commands/swarm/optimization.md +117 -117
- package/.claude/commands/swarm/research.md +136 -136
- package/.claude/commands/swarm/swarm-analysis.md +8 -8
- package/.claude/commands/swarm/swarm-background.md +8 -8
- package/.claude/commands/swarm/swarm-init.md +19 -19
- package/.claude/commands/swarm/swarm-modes.md +8 -8
- package/.claude/commands/swarm/swarm-monitor.md +8 -8
- package/.claude/commands/swarm/swarm-spawn.md +19 -19
- package/.claude/commands/swarm/swarm-status.md +8 -8
- package/.claude/commands/swarm/swarm-strategies.md +8 -8
- package/.claude/commands/swarm/swarm.md +87 -87
- package/.claude/commands/swarm/testing.md +131 -131
- package/.claude/commands/training/README.md +9 -9
- package/.claude/commands/training/model-update.md +25 -25
- package/.claude/commands/training/neural-patterns.md +107 -107
- package/.claude/commands/training/neural-train.md +75 -75
- package/.claude/commands/training/pattern-learn.md +25 -25
- package/.claude/commands/training/specialization.md +62 -62
- package/.claude/commands/truth/start.md +142 -142
- package/.claude/commands/verify/check.md +49 -49
- package/.claude/commands/verify/start.md +127 -127
- package/.claude/commands/workflows/README.md +9 -9
- package/.claude/commands/workflows/development.md +77 -77
- package/.claude/commands/workflows/research.md +62 -62
- package/.claude/commands/workflows/workflow-create.md +25 -25
- package/.claude/commands/workflows/workflow-execute.md +25 -25
- package/.claude/commands/workflows/workflow-export.md +25 -25
- package/.claude/helpers/README.md +96 -96
- package/.claude/helpers/adr-compliance.sh +186 -186
- package/.claude/helpers/auto-commit.sh +178 -178
- package/.claude/helpers/auto-memory-hook.mjs +368 -368
- package/.claude/helpers/checkpoint-manager.sh +251 -251
- package/.claude/helpers/daemon-manager.sh +252 -252
- package/.claude/helpers/ddd-tracker.sh +144 -144
- package/.claude/helpers/github-safe.js +121 -121
- package/.claude/helpers/github-setup.sh +28 -28
- package/.claude/helpers/guidance-hook.sh +13 -13
- package/.claude/helpers/guidance-hooks.sh +102 -102
- package/.claude/helpers/health-monitor.sh +108 -108
- package/.claude/helpers/hook-handler.cjs +278 -278
- package/.claude/helpers/intelligence.cjs +1031 -1031
- package/.claude/helpers/learning-hooks.sh +329 -329
- package/.claude/helpers/learning-optimizer.sh +127 -127
- package/.claude/helpers/learning-service.mjs +1144 -1144
- package/.claude/helpers/memory.js +83 -83
- package/.claude/helpers/metrics-db.mjs +488 -488
- package/.claude/helpers/pattern-consolidator.sh +86 -86
- package/.claude/helpers/perf-worker.sh +160 -160
- package/.claude/helpers/post-commit +16 -16
- package/.claude/helpers/pre-commit +26 -26
- package/.claude/helpers/quick-start.sh +19 -19
- package/.claude/helpers/router.js +66 -66
- package/.claude/helpers/security-scanner.sh +127 -127
- package/.claude/helpers/session.js +135 -135
- package/.claude/helpers/setup-mcp.sh +18 -18
- package/.claude/helpers/standard-checkpoint-hooks.sh +189 -189
- package/.claude/helpers/statusline-hook.sh +21 -21
- package/.claude/helpers/statusline.cjs +575 -575
- package/.claude/helpers/statusline.js +321 -321
- package/.claude/helpers/swarm-comms.sh +353 -353
- package/.claude/helpers/swarm-hooks.sh +761 -761
- package/.claude/helpers/swarm-monitor.sh +210 -210
- package/.claude/helpers/sync-v3-metrics.sh +245 -245
- package/.claude/helpers/update-v3-progress.sh +165 -165
- package/.claude/helpers/v3-quick-status.sh +57 -57
- package/.claude/helpers/v3.sh +110 -110
- package/.claude/helpers/validate-v3-config.sh +215 -215
- package/.claude/helpers/worker-manager.sh +170 -170
- package/.claude/settings.json +182 -182
- package/.claude/skills/agentdb-advanced/SKILL.md +550 -550
- package/.claude/skills/agentdb-learning/SKILL.md +545 -545
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -339
- package/.claude/skills/agentdb-optimization/SKILL.md +509 -509
- package/.claude/skills/agentdb-vector-search/SKILL.md +339 -339
- package/.claude/skills/agentic-jujutsu/SKILL.md +645 -645
- package/.claude/skills/aidefence-scan.md +151 -151
- package/.claude/skills/aidefence.yaml +297 -297
- package/.claude/skills/browser/SKILL.md +204 -204
- package/.claude/skills/flow-nexus-neural/SKILL.md +738 -738
- package/.claude/skills/flow-nexus-platform/SKILL.md +1157 -1157
- package/.claude/skills/flow-nexus-swarm/SKILL.md +610 -610
- package/.claude/skills/github-code-review/SKILL.md +1140 -1140
- package/.claude/skills/github-multi-repo/SKILL.md +874 -874
- package/.claude/skills/github-project-management/SKILL.md +1290 -1277
- package/.claude/skills/github-release-management/SKILL.md +1081 -1081
- package/.claude/skills/github-workflow-automation/SKILL.md +1065 -1065
- package/.claude/skills/hive-mind-advanced/SKILL.md +712 -712
- package/.claude/skills/hooks-automation/SKILL.md +1201 -1201
- package/.claude/skills/pair-programming/SKILL.md +1202 -1202
- package/.claude/skills/performance-analysis/SKILL.md +563 -563
- package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -446
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -201
- package/.claude/skills/secure-review.md +181 -181
- package/.claude/skills/skill-builder/SKILL.md +910 -910
- package/.claude/skills/sparc-methodology/SKILL.md +1115 -1115
- package/.claude/skills/stream-chain/SKILL.md +563 -563
- package/.claude/skills/swarm-advanced/SKILL.md +973 -973
- package/.claude/skills/swarm-orchestration/SKILL.md +179 -179
- package/.claude/skills/v3-cli-modernization/SKILL.md +871 -871
- package/.claude/skills/v3-core-implementation/SKILL.md +796 -796
- package/.claude/skills/v3-ddd-architecture/SKILL.md +441 -441
- package/.claude/skills/v3-integration-deep/SKILL.md +240 -240
- package/.claude/skills/v3-mcp-optimization/SKILL.md +776 -776
- package/.claude/skills/v3-memory-unification/SKILL.md +173 -173
- package/.claude/skills/v3-performance-optimization/SKILL.md +389 -389
- package/.claude/skills/v3-security-overhaul/SKILL.md +81 -81
- package/.claude/skills/v3-swarm-coordination/SKILL.md +339 -339
- package/.claude/skills/verification-quality/SKILL.md +649 -649
- package/.claude/skills/worker-benchmarks/skill.md +135 -135
- package/.claude/skills/worker-integration/skill.md +154 -154
- package/README.md +393 -391
- package/bin/cli.js +220 -220
- package/bin/mcp-server.js +224 -224
- package/bin/preinstall.cjs +2 -2
- package/dist/src/commands/agent-wasm.js +2 -2
- package/dist/src/commands/agent-wasm.js.map +1 -1
- package/dist/src/commands/completions.js +409 -409
- package/dist/src/commands/daemon.d.ts.map +1 -1
- package/dist/src/commands/daemon.js +19 -3
- package/dist/src/commands/daemon.js.map +1 -1
- package/dist/src/commands/doctor.d.ts.map +1 -1
- package/dist/src/commands/doctor.js +105 -23
- package/dist/src/commands/doctor.js.map +1 -1
- package/dist/src/commands/embeddings.js +26 -26
- package/dist/src/commands/hive-mind.d.ts.map +1 -1
- package/dist/src/commands/hive-mind.js +122 -104
- package/dist/src/commands/hive-mind.js.map +1 -1
- package/dist/src/commands/hooks.d.ts.map +1 -1
- package/dist/src/commands/hooks.js +34 -21
- package/dist/src/commands/hooks.js.map +1 -1
- package/dist/src/commands/memory.d.ts.map +1 -1
- package/dist/src/commands/memory.js +68 -0
- package/dist/src/commands/memory.js.map +1 -1
- package/dist/src/commands/ruvector/backup.js +23 -23
- package/dist/src/commands/ruvector/benchmark.js +31 -31
- package/dist/src/commands/ruvector/import.js +14 -14
- package/dist/src/commands/ruvector/init.js +115 -115
- package/dist/src/commands/ruvector/migrate.js +99 -99
- package/dist/src/commands/ruvector/optimize.js +51 -51
- package/dist/src/commands/ruvector/setup.js +624 -624
- package/dist/src/commands/ruvector/status.js +38 -38
- package/dist/src/index.d.ts +5 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +59 -18
- package/dist/src/index.js.map +1 -1
- package/dist/src/init/claudemd-generator.js +226 -226
- package/dist/src/init/executor.d.ts.map +1 -1
- package/dist/src/init/executor.js +511 -453
- package/dist/src/init/executor.js.map +1 -1
- package/dist/src/init/helpers-generator.js +645 -645
- package/dist/src/init/settings-generator.d.ts.map +1 -1
- package/dist/src/init/settings-generator.js +11 -5
- package/dist/src/init/settings-generator.js.map +1 -1
- package/dist/src/init/statusline-generator.js +858 -858
- package/dist/src/init/types.d.ts +7 -0
- package/dist/src/init/types.d.ts.map +1 -1
- package/dist/src/init/types.js.map +1 -1
- package/dist/src/mcp-tools/agentdb-tools.d.ts +3 -0
- package/dist/src/mcp-tools/agentdb-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/agentdb-tools.js +108 -0
- package/dist/src/mcp-tools/agentdb-tools.js.map +1 -1
- package/dist/src/mcp-tools/hooks-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/hooks-tools.js +4 -2
- package/dist/src/mcp-tools/hooks-tools.js.map +1 -1
- package/dist/src/mcp-tools/memory-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/memory-tools.js +19 -0
- package/dist/src/mcp-tools/memory-tools.js.map +1 -1
- package/dist/src/mcp-tools/neural-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/neural-tools.js +14 -1
- package/dist/src/mcp-tools/neural-tools.js.map +1 -1
- package/dist/src/mcp-tools/security-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/security-tools.js +28 -3
- package/dist/src/mcp-tools/security-tools.js.map +1 -1
- package/dist/src/mcp-tools/swarm-tools.d.ts.map +1 -1
- package/dist/src/mcp-tools/swarm-tools.js +72 -3
- package/dist/src/mcp-tools/swarm-tools.js.map +1 -1
- package/dist/src/mcp-tools/wasm-agent-tools.js +1 -1
- package/dist/src/mcp-tools/wasm-agent-tools.js.map +1 -1
- package/dist/src/memory/intelligence.d.ts.map +1 -1
- package/dist/src/memory/intelligence.js +28 -3
- package/dist/src/memory/intelligence.js.map +1 -1
- package/dist/src/memory/memory-bridge.d.ts +69 -0
- package/dist/src/memory/memory-bridge.d.ts.map +1 -1
- package/dist/src/memory/memory-bridge.js +319 -66
- package/dist/src/memory/memory-bridge.js.map +1 -1
- package/dist/src/memory/memory-initializer.d.ts +5 -0
- package/dist/src/memory/memory-initializer.d.ts.map +1 -1
- package/dist/src/memory/memory-initializer.js +369 -363
- package/dist/src/memory/memory-initializer.js.map +1 -1
- package/dist/src/memory/neural-package-bridge.d.ts +48 -0
- package/dist/src/memory/neural-package-bridge.d.ts.map +1 -0
- package/dist/src/memory/neural-package-bridge.js +87 -0
- package/dist/src/memory/neural-package-bridge.js.map +1 -0
- package/dist/src/memory/rabitq-index.js +5 -5
- package/dist/src/memory/sona-optimizer.d.ts.map +1 -1
- package/dist/src/memory/sona-optimizer.js +1 -0
- package/dist/src/memory/sona-optimizer.js.map +1 -1
- package/dist/src/parser.d.ts +9 -0
- package/dist/src/parser.d.ts.map +1 -1
- package/dist/src/parser.js +11 -0
- package/dist/src/parser.js.map +1 -1
- package/dist/src/runtime/headless.js +28 -28
- package/dist/src/ruvector/agent-wasm.d.ts.map +1 -1
- package/dist/src/ruvector/agent-wasm.js +4 -1
- package/dist/src/ruvector/agent-wasm.js.map +1 -1
- package/dist/src/ruvector/index.d.ts +0 -2
- package/dist/src/ruvector/index.d.ts.map +1 -1
- package/dist/src/ruvector/index.js +8 -2
- package/dist/src/ruvector/index.js.map +1 -1
- package/dist/src/ruvector/model-router.d.ts +22 -1
- package/dist/src/ruvector/model-router.d.ts.map +1 -1
- package/dist/src/ruvector/model-router.js +125 -5
- package/dist/src/ruvector/model-router.js.map +1 -1
- package/dist/src/services/headless-worker-executor.js +84 -84
- package/dist/src/transfer/deploy-seraphine.js +23 -23
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +5 -4
- package/scripts/deploy-ipfs-node.sh +153 -153
- package/scripts/postinstall.cjs +153 -153
- package/scripts/publish-registry.ts +345 -345
- package/scripts/publish.sh +57 -57
- package/scripts/setup-ipfs-registry.md +366 -366
- package/dist/src/services/event-stream.d.ts.map +0 -1
- package/dist/src/services/event-stream.js.map +0 -1
- package/dist/src/services/loop-worker-runner.d.ts.map +0 -1
- package/dist/src/services/loop-worker-runner.js.map +0 -1
- package/dist/src/services/runtime-capabilities.d.ts.map +0 -1
- package/dist/src/services/runtime-capabilities.js.map +0 -1
|
@@ -31,295 +31,295 @@ async function getBridge() {
|
|
|
31
31
|
* Enhanced schema with pattern confidence, temporal decay, versioning
|
|
32
32
|
* Vector embeddings enabled for semantic search
|
|
33
33
|
*/
|
|
34
|
-
export const MEMORY_SCHEMA_V3 = `
|
|
35
|
-
-- RuFlo V3 Memory Database
|
|
36
|
-
-- Version: 3.0.0
|
|
37
|
-
-- Features: Pattern learning, vector embeddings, temporal decay, migration tracking
|
|
38
|
-
|
|
39
|
-
PRAGMA journal_mode = WAL;
|
|
40
|
-
PRAGMA synchronous = NORMAL;
|
|
41
|
-
PRAGMA foreign_keys = ON;
|
|
42
|
-
|
|
43
|
-
-- ============================================
|
|
44
|
-
-- CORE MEMORY TABLES
|
|
45
|
-
-- ============================================
|
|
46
|
-
|
|
47
|
-
-- Memory entries (main storage)
|
|
48
|
-
CREATE TABLE IF NOT EXISTS memory_entries (
|
|
49
|
-
id TEXT PRIMARY KEY,
|
|
50
|
-
key TEXT NOT NULL,
|
|
51
|
-
namespace TEXT DEFAULT 'default',
|
|
52
|
-
content TEXT NOT NULL,
|
|
53
|
-
type TEXT DEFAULT 'semantic' CHECK(type IN ('semantic', 'episodic', 'procedural', 'working', 'pattern')),
|
|
54
|
-
|
|
55
|
-
-- Vector embedding for semantic search (stored as JSON array)
|
|
56
|
-
embedding TEXT,
|
|
57
|
-
embedding_model TEXT DEFAULT 'local',
|
|
58
|
-
embedding_dimensions INTEGER,
|
|
59
|
-
|
|
60
|
-
-- Metadata
|
|
61
|
-
tags TEXT, -- JSON array
|
|
62
|
-
metadata TEXT, -- JSON object
|
|
63
|
-
owner_id TEXT,
|
|
64
|
-
|
|
65
|
-
-- Timestamps
|
|
66
|
-
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
67
|
-
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
68
|
-
expires_at INTEGER,
|
|
69
|
-
last_accessed_at INTEGER,
|
|
70
|
-
|
|
71
|
-
-- Access tracking for hot/cold detection
|
|
72
|
-
access_count INTEGER DEFAULT 0,
|
|
73
|
-
|
|
74
|
-
-- Status
|
|
75
|
-
status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deleted')),
|
|
76
|
-
|
|
77
|
-
UNIQUE(namespace, key)
|
|
78
|
-
);
|
|
79
|
-
|
|
80
|
-
-- Indexes for memory entries
|
|
81
|
-
CREATE INDEX IF NOT EXISTS idx_memory_namespace ON memory_entries(namespace);
|
|
82
|
-
CREATE INDEX IF NOT EXISTS idx_memory_key ON memory_entries(key);
|
|
83
|
-
CREATE INDEX IF NOT EXISTS idx_memory_type ON memory_entries(type);
|
|
84
|
-
CREATE INDEX IF NOT EXISTS idx_memory_status ON memory_entries(status);
|
|
85
|
-
CREATE INDEX IF NOT EXISTS idx_memory_created ON memory_entries(created_at);
|
|
86
|
-
CREATE INDEX IF NOT EXISTS idx_memory_accessed ON memory_entries(last_accessed_at);
|
|
87
|
-
CREATE INDEX IF NOT EXISTS idx_memory_owner ON memory_entries(owner_id);
|
|
88
|
-
|
|
89
|
-
-- ============================================
|
|
90
|
-
-- PATTERN LEARNING TABLES
|
|
91
|
-
-- ============================================
|
|
92
|
-
|
|
93
|
-
-- Learned patterns with confidence scoring and versioning
|
|
94
|
-
CREATE TABLE IF NOT EXISTS patterns (
|
|
95
|
-
id TEXT PRIMARY KEY,
|
|
96
|
-
|
|
97
|
-
-- Pattern identification
|
|
98
|
-
name TEXT NOT NULL,
|
|
99
|
-
pattern_type TEXT NOT NULL CHECK(pattern_type IN (
|
|
100
|
-
'task-routing', 'error-recovery', 'optimization', 'learning',
|
|
101
|
-
'coordination', 'prediction', 'code-pattern', 'workflow'
|
|
102
|
-
)),
|
|
103
|
-
|
|
104
|
-
-- Pattern definition
|
|
105
|
-
condition TEXT NOT NULL, -- Regex or semantic match
|
|
106
|
-
action TEXT NOT NULL, -- What to do when pattern matches
|
|
107
|
-
description TEXT,
|
|
108
|
-
|
|
109
|
-
-- Confidence scoring (0.0 - 1.0)
|
|
110
|
-
confidence REAL DEFAULT 0.5,
|
|
111
|
-
success_count INTEGER DEFAULT 0,
|
|
112
|
-
failure_count INTEGER DEFAULT 0,
|
|
113
|
-
|
|
114
|
-
-- Temporal decay
|
|
115
|
-
decay_rate REAL DEFAULT 0.01, -- How fast confidence decays
|
|
116
|
-
half_life_days INTEGER DEFAULT 30, -- Days until confidence halves without use
|
|
117
|
-
|
|
118
|
-
-- Vector embedding for semantic pattern matching
|
|
119
|
-
embedding TEXT,
|
|
120
|
-
embedding_dimensions INTEGER,
|
|
121
|
-
|
|
122
|
-
-- Versioning
|
|
123
|
-
version INTEGER DEFAULT 1,
|
|
124
|
-
parent_id TEXT REFERENCES patterns(id),
|
|
125
|
-
|
|
126
|
-
-- Metadata
|
|
127
|
-
tags TEXT, -- JSON array
|
|
128
|
-
metadata TEXT, -- JSON object
|
|
129
|
-
source TEXT, -- Where the pattern was learned from
|
|
130
|
-
|
|
131
|
-
-- Timestamps
|
|
132
|
-
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
133
|
-
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
134
|
-
last_matched_at INTEGER,
|
|
135
|
-
last_success_at INTEGER,
|
|
136
|
-
last_failure_at INTEGER,
|
|
137
|
-
|
|
138
|
-
-- Status
|
|
139
|
-
status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deprecated', 'experimental'))
|
|
140
|
-
);
|
|
141
|
-
|
|
142
|
-
-- Indexes for patterns
|
|
143
|
-
CREATE INDEX IF NOT EXISTS idx_patterns_type ON patterns(pattern_type);
|
|
144
|
-
CREATE INDEX IF NOT EXISTS idx_patterns_confidence ON patterns(confidence DESC);
|
|
145
|
-
CREATE INDEX IF NOT EXISTS idx_patterns_status ON patterns(status);
|
|
146
|
-
CREATE INDEX IF NOT EXISTS idx_patterns_last_matched ON patterns(last_matched_at);
|
|
147
|
-
|
|
148
|
-
-- Pattern evolution history (for versioning)
|
|
149
|
-
CREATE TABLE IF NOT EXISTS pattern_history (
|
|
150
|
-
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
151
|
-
pattern_id TEXT NOT NULL REFERENCES patterns(id),
|
|
152
|
-
version INTEGER NOT NULL,
|
|
153
|
-
|
|
154
|
-
-- Snapshot of pattern state
|
|
155
|
-
confidence REAL,
|
|
156
|
-
success_count INTEGER,
|
|
157
|
-
failure_count INTEGER,
|
|
158
|
-
condition TEXT,
|
|
159
|
-
action TEXT,
|
|
160
|
-
|
|
161
|
-
-- What changed
|
|
162
|
-
change_type TEXT CHECK(change_type IN ('created', 'updated', 'success', 'failure', 'decay', 'merged', 'split')),
|
|
163
|
-
change_reason TEXT,
|
|
164
|
-
|
|
165
|
-
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
|
|
166
|
-
);
|
|
167
|
-
|
|
168
|
-
CREATE INDEX IF NOT EXISTS idx_pattern_history_pattern ON pattern_history(pattern_id);
|
|
169
|
-
|
|
170
|
-
-- ============================================
|
|
171
|
-
-- LEARNING & TRAJECTORY TABLES
|
|
172
|
-
-- ============================================
|
|
173
|
-
|
|
174
|
-
-- Learning trajectories (SONA integration)
|
|
175
|
-
CREATE TABLE IF NOT EXISTS trajectories (
|
|
176
|
-
id TEXT PRIMARY KEY,
|
|
177
|
-
session_id TEXT,
|
|
178
|
-
|
|
179
|
-
-- Trajectory state
|
|
180
|
-
status TEXT DEFAULT 'active' CHECK(status IN ('active', 'completed', 'failed', 'abandoned')),
|
|
181
|
-
verdict TEXT CHECK(verdict IN ('success', 'failure', 'partial', NULL)),
|
|
182
|
-
|
|
183
|
-
-- Context
|
|
184
|
-
task TEXT,
|
|
185
|
-
context TEXT, -- JSON object
|
|
186
|
-
|
|
187
|
-
-- Metrics
|
|
188
|
-
total_steps INTEGER DEFAULT 0,
|
|
189
|
-
total_reward REAL DEFAULT 0,
|
|
190
|
-
|
|
191
|
-
-- Timestamps
|
|
192
|
-
started_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
193
|
-
ended_at INTEGER,
|
|
194
|
-
|
|
195
|
-
-- Reference to extracted pattern (if any)
|
|
196
|
-
extracted_pattern_id TEXT REFERENCES patterns(id)
|
|
197
|
-
);
|
|
198
|
-
|
|
199
|
-
-- Trajectory steps
|
|
200
|
-
CREATE TABLE IF NOT EXISTS trajectory_steps (
|
|
201
|
-
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
202
|
-
trajectory_id TEXT NOT NULL REFERENCES trajectories(id),
|
|
203
|
-
step_number INTEGER NOT NULL,
|
|
204
|
-
|
|
205
|
-
-- Step data
|
|
206
|
-
action TEXT NOT NULL,
|
|
207
|
-
observation TEXT,
|
|
208
|
-
reward REAL DEFAULT 0,
|
|
209
|
-
|
|
210
|
-
-- Metadata
|
|
211
|
-
metadata TEXT, -- JSON object
|
|
212
|
-
|
|
213
|
-
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
|
|
214
|
-
);
|
|
215
|
-
|
|
216
|
-
CREATE INDEX IF NOT EXISTS idx_steps_trajectory ON trajectory_steps(trajectory_id);
|
|
217
|
-
|
|
218
|
-
-- ============================================
|
|
219
|
-
-- MIGRATION STATE TRACKING
|
|
220
|
-
-- ============================================
|
|
221
|
-
|
|
222
|
-
-- Migration state (for resume capability)
|
|
223
|
-
CREATE TABLE IF NOT EXISTS migration_state (
|
|
224
|
-
id TEXT PRIMARY KEY,
|
|
225
|
-
migration_type TEXT NOT NULL, -- 'v2-to-v3', 'pattern', 'memory', etc.
|
|
226
|
-
|
|
227
|
-
-- Progress tracking
|
|
228
|
-
status TEXT DEFAULT 'pending' CHECK(status IN ('pending', 'in_progress', 'completed', 'failed', 'rolled_back')),
|
|
229
|
-
total_items INTEGER DEFAULT 0,
|
|
230
|
-
processed_items INTEGER DEFAULT 0,
|
|
231
|
-
failed_items INTEGER DEFAULT 0,
|
|
232
|
-
skipped_items INTEGER DEFAULT 0,
|
|
233
|
-
|
|
234
|
-
-- Current position (for resume)
|
|
235
|
-
current_batch INTEGER DEFAULT 0,
|
|
236
|
-
last_processed_id TEXT,
|
|
237
|
-
|
|
238
|
-
-- Source/destination info
|
|
239
|
-
source_path TEXT,
|
|
240
|
-
source_type TEXT,
|
|
241
|
-
destination_path TEXT,
|
|
242
|
-
|
|
243
|
-
-- Backup info
|
|
244
|
-
backup_path TEXT,
|
|
245
|
-
backup_created_at INTEGER,
|
|
246
|
-
|
|
247
|
-
-- Error tracking
|
|
248
|
-
last_error TEXT,
|
|
249
|
-
errors TEXT, -- JSON array of errors
|
|
250
|
-
|
|
251
|
-
-- Timestamps
|
|
252
|
-
started_at INTEGER,
|
|
253
|
-
completed_at INTEGER,
|
|
254
|
-
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
255
|
-
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
|
|
256
|
-
);
|
|
257
|
-
|
|
258
|
-
-- ============================================
|
|
259
|
-
-- SESSION MANAGEMENT
|
|
260
|
-
-- ============================================
|
|
261
|
-
|
|
262
|
-
-- Sessions for context persistence
|
|
263
|
-
CREATE TABLE IF NOT EXISTS sessions (
|
|
264
|
-
id TEXT PRIMARY KEY,
|
|
265
|
-
|
|
266
|
-
-- Session state
|
|
267
|
-
state TEXT NOT NULL, -- JSON object with full session state
|
|
268
|
-
status TEXT DEFAULT 'active' CHECK(status IN ('active', 'paused', 'completed', 'expired')),
|
|
269
|
-
|
|
270
|
-
-- Context
|
|
271
|
-
project_path TEXT,
|
|
272
|
-
branch TEXT,
|
|
273
|
-
|
|
274
|
-
-- Metrics
|
|
275
|
-
tasks_completed INTEGER DEFAULT 0,
|
|
276
|
-
patterns_learned INTEGER DEFAULT 0,
|
|
277
|
-
|
|
278
|
-
-- Timestamps
|
|
279
|
-
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
280
|
-
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
281
|
-
expires_at INTEGER
|
|
282
|
-
);
|
|
283
|
-
|
|
284
|
-
-- ============================================
|
|
285
|
-
-- VECTOR INDEX METADATA (for HNSW)
|
|
286
|
-
-- ============================================
|
|
287
|
-
|
|
288
|
-
-- Track HNSW index state
|
|
289
|
-
CREATE TABLE IF NOT EXISTS vector_indexes (
|
|
290
|
-
id TEXT PRIMARY KEY,
|
|
291
|
-
name TEXT NOT NULL UNIQUE,
|
|
292
|
-
|
|
293
|
-
-- Index configuration
|
|
294
|
-
dimensions INTEGER NOT NULL,
|
|
295
|
-
metric TEXT DEFAULT 'cosine' CHECK(metric IN ('cosine', 'euclidean', 'dot')),
|
|
296
|
-
|
|
297
|
-
-- HNSW parameters
|
|
298
|
-
hnsw_m INTEGER DEFAULT 16,
|
|
299
|
-
hnsw_ef_construction INTEGER DEFAULT 200,
|
|
300
|
-
hnsw_ef_search INTEGER DEFAULT 100,
|
|
301
|
-
|
|
302
|
-
-- Quantization
|
|
303
|
-
quantization_type TEXT CHECK(quantization_type IN ('none', 'scalar', 'product')),
|
|
304
|
-
quantization_bits INTEGER DEFAULT 8,
|
|
305
|
-
|
|
306
|
-
-- Statistics
|
|
307
|
-
total_vectors INTEGER DEFAULT 0,
|
|
308
|
-
last_rebuild_at INTEGER,
|
|
309
|
-
|
|
310
|
-
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
311
|
-
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
|
|
312
|
-
);
|
|
313
|
-
|
|
314
|
-
-- ============================================
|
|
315
|
-
-- SYSTEM METADATA
|
|
316
|
-
-- ============================================
|
|
317
|
-
|
|
318
|
-
CREATE TABLE IF NOT EXISTS metadata (
|
|
319
|
-
key TEXT PRIMARY KEY,
|
|
320
|
-
value TEXT NOT NULL,
|
|
321
|
-
updated_at INTEGER DEFAULT (strftime('%s', 'now') * 1000)
|
|
322
|
-
);
|
|
34
|
+
export const MEMORY_SCHEMA_V3 = `
|
|
35
|
+
-- RuFlo V3 Memory Database
|
|
36
|
+
-- Version: 3.0.0
|
|
37
|
+
-- Features: Pattern learning, vector embeddings, temporal decay, migration tracking
|
|
38
|
+
|
|
39
|
+
PRAGMA journal_mode = WAL;
|
|
40
|
+
PRAGMA synchronous = NORMAL;
|
|
41
|
+
PRAGMA foreign_keys = ON;
|
|
42
|
+
|
|
43
|
+
-- ============================================
|
|
44
|
+
-- CORE MEMORY TABLES
|
|
45
|
+
-- ============================================
|
|
46
|
+
|
|
47
|
+
-- Memory entries (main storage)
|
|
48
|
+
CREATE TABLE IF NOT EXISTS memory_entries (
|
|
49
|
+
id TEXT PRIMARY KEY,
|
|
50
|
+
key TEXT NOT NULL,
|
|
51
|
+
namespace TEXT DEFAULT 'default',
|
|
52
|
+
content TEXT NOT NULL,
|
|
53
|
+
type TEXT DEFAULT 'semantic' CHECK(type IN ('semantic', 'episodic', 'procedural', 'working', 'pattern')),
|
|
54
|
+
|
|
55
|
+
-- Vector embedding for semantic search (stored as JSON array)
|
|
56
|
+
embedding TEXT,
|
|
57
|
+
embedding_model TEXT DEFAULT 'local',
|
|
58
|
+
embedding_dimensions INTEGER,
|
|
59
|
+
|
|
60
|
+
-- Metadata
|
|
61
|
+
tags TEXT, -- JSON array
|
|
62
|
+
metadata TEXT, -- JSON object
|
|
63
|
+
owner_id TEXT,
|
|
64
|
+
|
|
65
|
+
-- Timestamps
|
|
66
|
+
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
67
|
+
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
68
|
+
expires_at INTEGER,
|
|
69
|
+
last_accessed_at INTEGER,
|
|
70
|
+
|
|
71
|
+
-- Access tracking for hot/cold detection
|
|
72
|
+
access_count INTEGER DEFAULT 0,
|
|
73
|
+
|
|
74
|
+
-- Status
|
|
75
|
+
status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deleted')),
|
|
76
|
+
|
|
77
|
+
UNIQUE(namespace, key)
|
|
78
|
+
);
|
|
79
|
+
|
|
80
|
+
-- Indexes for memory entries
|
|
81
|
+
CREATE INDEX IF NOT EXISTS idx_memory_namespace ON memory_entries(namespace);
|
|
82
|
+
CREATE INDEX IF NOT EXISTS idx_memory_key ON memory_entries(key);
|
|
83
|
+
CREATE INDEX IF NOT EXISTS idx_memory_type ON memory_entries(type);
|
|
84
|
+
CREATE INDEX IF NOT EXISTS idx_memory_status ON memory_entries(status);
|
|
85
|
+
CREATE INDEX IF NOT EXISTS idx_memory_created ON memory_entries(created_at);
|
|
86
|
+
CREATE INDEX IF NOT EXISTS idx_memory_accessed ON memory_entries(last_accessed_at);
|
|
87
|
+
CREATE INDEX IF NOT EXISTS idx_memory_owner ON memory_entries(owner_id);
|
|
88
|
+
|
|
89
|
+
-- ============================================
|
|
90
|
+
-- PATTERN LEARNING TABLES
|
|
91
|
+
-- ============================================
|
|
92
|
+
|
|
93
|
+
-- Learned patterns with confidence scoring and versioning
|
|
94
|
+
CREATE TABLE IF NOT EXISTS patterns (
|
|
95
|
+
id TEXT PRIMARY KEY,
|
|
96
|
+
|
|
97
|
+
-- Pattern identification
|
|
98
|
+
name TEXT NOT NULL,
|
|
99
|
+
pattern_type TEXT NOT NULL CHECK(pattern_type IN (
|
|
100
|
+
'task-routing', 'error-recovery', 'optimization', 'learning',
|
|
101
|
+
'coordination', 'prediction', 'code-pattern', 'workflow'
|
|
102
|
+
)),
|
|
103
|
+
|
|
104
|
+
-- Pattern definition
|
|
105
|
+
condition TEXT NOT NULL, -- Regex or semantic match
|
|
106
|
+
action TEXT NOT NULL, -- What to do when pattern matches
|
|
107
|
+
description TEXT,
|
|
108
|
+
|
|
109
|
+
-- Confidence scoring (0.0 - 1.0)
|
|
110
|
+
confidence REAL DEFAULT 0.5,
|
|
111
|
+
success_count INTEGER DEFAULT 0,
|
|
112
|
+
failure_count INTEGER DEFAULT 0,
|
|
113
|
+
|
|
114
|
+
-- Temporal decay
|
|
115
|
+
decay_rate REAL DEFAULT 0.01, -- How fast confidence decays
|
|
116
|
+
half_life_days INTEGER DEFAULT 30, -- Days until confidence halves without use
|
|
117
|
+
|
|
118
|
+
-- Vector embedding for semantic pattern matching
|
|
119
|
+
embedding TEXT,
|
|
120
|
+
embedding_dimensions INTEGER,
|
|
121
|
+
|
|
122
|
+
-- Versioning
|
|
123
|
+
version INTEGER DEFAULT 1,
|
|
124
|
+
parent_id TEXT REFERENCES patterns(id),
|
|
125
|
+
|
|
126
|
+
-- Metadata
|
|
127
|
+
tags TEXT, -- JSON array
|
|
128
|
+
metadata TEXT, -- JSON object
|
|
129
|
+
source TEXT, -- Where the pattern was learned from
|
|
130
|
+
|
|
131
|
+
-- Timestamps
|
|
132
|
+
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
133
|
+
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
134
|
+
last_matched_at INTEGER,
|
|
135
|
+
last_success_at INTEGER,
|
|
136
|
+
last_failure_at INTEGER,
|
|
137
|
+
|
|
138
|
+
-- Status
|
|
139
|
+
status TEXT DEFAULT 'active' CHECK(status IN ('active', 'archived', 'deprecated', 'experimental'))
|
|
140
|
+
);
|
|
141
|
+
|
|
142
|
+
-- Indexes for patterns
|
|
143
|
+
CREATE INDEX IF NOT EXISTS idx_patterns_type ON patterns(pattern_type);
|
|
144
|
+
CREATE INDEX IF NOT EXISTS idx_patterns_confidence ON patterns(confidence DESC);
|
|
145
|
+
CREATE INDEX IF NOT EXISTS idx_patterns_status ON patterns(status);
|
|
146
|
+
CREATE INDEX IF NOT EXISTS idx_patterns_last_matched ON patterns(last_matched_at);
|
|
147
|
+
|
|
148
|
+
-- Pattern evolution history (for versioning)
|
|
149
|
+
CREATE TABLE IF NOT EXISTS pattern_history (
|
|
150
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
151
|
+
pattern_id TEXT NOT NULL REFERENCES patterns(id),
|
|
152
|
+
version INTEGER NOT NULL,
|
|
153
|
+
|
|
154
|
+
-- Snapshot of pattern state
|
|
155
|
+
confidence REAL,
|
|
156
|
+
success_count INTEGER,
|
|
157
|
+
failure_count INTEGER,
|
|
158
|
+
condition TEXT,
|
|
159
|
+
action TEXT,
|
|
160
|
+
|
|
161
|
+
-- What changed
|
|
162
|
+
change_type TEXT CHECK(change_type IN ('created', 'updated', 'success', 'failure', 'decay', 'merged', 'split')),
|
|
163
|
+
change_reason TEXT,
|
|
164
|
+
|
|
165
|
+
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
|
|
166
|
+
);
|
|
167
|
+
|
|
168
|
+
CREATE INDEX IF NOT EXISTS idx_pattern_history_pattern ON pattern_history(pattern_id);
|
|
169
|
+
|
|
170
|
+
-- ============================================
|
|
171
|
+
-- LEARNING & TRAJECTORY TABLES
|
|
172
|
+
-- ============================================
|
|
173
|
+
|
|
174
|
+
-- Learning trajectories (SONA integration)
|
|
175
|
+
CREATE TABLE IF NOT EXISTS trajectories (
|
|
176
|
+
id TEXT PRIMARY KEY,
|
|
177
|
+
session_id TEXT,
|
|
178
|
+
|
|
179
|
+
-- Trajectory state
|
|
180
|
+
status TEXT DEFAULT 'active' CHECK(status IN ('active', 'completed', 'failed', 'abandoned')),
|
|
181
|
+
verdict TEXT CHECK(verdict IN ('success', 'failure', 'partial', NULL)),
|
|
182
|
+
|
|
183
|
+
-- Context
|
|
184
|
+
task TEXT,
|
|
185
|
+
context TEXT, -- JSON object
|
|
186
|
+
|
|
187
|
+
-- Metrics
|
|
188
|
+
total_steps INTEGER DEFAULT 0,
|
|
189
|
+
total_reward REAL DEFAULT 0,
|
|
190
|
+
|
|
191
|
+
-- Timestamps
|
|
192
|
+
started_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
193
|
+
ended_at INTEGER,
|
|
194
|
+
|
|
195
|
+
-- Reference to extracted pattern (if any)
|
|
196
|
+
extracted_pattern_id TEXT REFERENCES patterns(id)
|
|
197
|
+
);
|
|
198
|
+
|
|
199
|
+
-- Trajectory steps
|
|
200
|
+
CREATE TABLE IF NOT EXISTS trajectory_steps (
|
|
201
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
202
|
+
trajectory_id TEXT NOT NULL REFERENCES trajectories(id),
|
|
203
|
+
step_number INTEGER NOT NULL,
|
|
204
|
+
|
|
205
|
+
-- Step data
|
|
206
|
+
action TEXT NOT NULL,
|
|
207
|
+
observation TEXT,
|
|
208
|
+
reward REAL DEFAULT 0,
|
|
209
|
+
|
|
210
|
+
-- Metadata
|
|
211
|
+
metadata TEXT, -- JSON object
|
|
212
|
+
|
|
213
|
+
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
|
|
214
|
+
);
|
|
215
|
+
|
|
216
|
+
CREATE INDEX IF NOT EXISTS idx_steps_trajectory ON trajectory_steps(trajectory_id);
|
|
217
|
+
|
|
218
|
+
-- ============================================
|
|
219
|
+
-- MIGRATION STATE TRACKING
|
|
220
|
+
-- ============================================
|
|
221
|
+
|
|
222
|
+
-- Migration state (for resume capability)
|
|
223
|
+
CREATE TABLE IF NOT EXISTS migration_state (
|
|
224
|
+
id TEXT PRIMARY KEY,
|
|
225
|
+
migration_type TEXT NOT NULL, -- 'v2-to-v3', 'pattern', 'memory', etc.
|
|
226
|
+
|
|
227
|
+
-- Progress tracking
|
|
228
|
+
status TEXT DEFAULT 'pending' CHECK(status IN ('pending', 'in_progress', 'completed', 'failed', 'rolled_back')),
|
|
229
|
+
total_items INTEGER DEFAULT 0,
|
|
230
|
+
processed_items INTEGER DEFAULT 0,
|
|
231
|
+
failed_items INTEGER DEFAULT 0,
|
|
232
|
+
skipped_items INTEGER DEFAULT 0,
|
|
233
|
+
|
|
234
|
+
-- Current position (for resume)
|
|
235
|
+
current_batch INTEGER DEFAULT 0,
|
|
236
|
+
last_processed_id TEXT,
|
|
237
|
+
|
|
238
|
+
-- Source/destination info
|
|
239
|
+
source_path TEXT,
|
|
240
|
+
source_type TEXT,
|
|
241
|
+
destination_path TEXT,
|
|
242
|
+
|
|
243
|
+
-- Backup info
|
|
244
|
+
backup_path TEXT,
|
|
245
|
+
backup_created_at INTEGER,
|
|
246
|
+
|
|
247
|
+
-- Error tracking
|
|
248
|
+
last_error TEXT,
|
|
249
|
+
errors TEXT, -- JSON array of errors
|
|
250
|
+
|
|
251
|
+
-- Timestamps
|
|
252
|
+
started_at INTEGER,
|
|
253
|
+
completed_at INTEGER,
|
|
254
|
+
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
255
|
+
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
|
|
256
|
+
);
|
|
257
|
+
|
|
258
|
+
-- ============================================
|
|
259
|
+
-- SESSION MANAGEMENT
|
|
260
|
+
-- ============================================
|
|
261
|
+
|
|
262
|
+
-- Sessions for context persistence
|
|
263
|
+
CREATE TABLE IF NOT EXISTS sessions (
|
|
264
|
+
id TEXT PRIMARY KEY,
|
|
265
|
+
|
|
266
|
+
-- Session state
|
|
267
|
+
state TEXT NOT NULL, -- JSON object with full session state
|
|
268
|
+
status TEXT DEFAULT 'active' CHECK(status IN ('active', 'paused', 'completed', 'expired')),
|
|
269
|
+
|
|
270
|
+
-- Context
|
|
271
|
+
project_path TEXT,
|
|
272
|
+
branch TEXT,
|
|
273
|
+
|
|
274
|
+
-- Metrics
|
|
275
|
+
tasks_completed INTEGER DEFAULT 0,
|
|
276
|
+
patterns_learned INTEGER DEFAULT 0,
|
|
277
|
+
|
|
278
|
+
-- Timestamps
|
|
279
|
+
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
280
|
+
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
281
|
+
expires_at INTEGER
|
|
282
|
+
);
|
|
283
|
+
|
|
284
|
+
-- ============================================
|
|
285
|
+
-- VECTOR INDEX METADATA (for HNSW)
|
|
286
|
+
-- ============================================
|
|
287
|
+
|
|
288
|
+
-- Track HNSW index state
|
|
289
|
+
CREATE TABLE IF NOT EXISTS vector_indexes (
|
|
290
|
+
id TEXT PRIMARY KEY,
|
|
291
|
+
name TEXT NOT NULL UNIQUE,
|
|
292
|
+
|
|
293
|
+
-- Index configuration
|
|
294
|
+
dimensions INTEGER NOT NULL,
|
|
295
|
+
metric TEXT DEFAULT 'cosine' CHECK(metric IN ('cosine', 'euclidean', 'dot')),
|
|
296
|
+
|
|
297
|
+
-- HNSW parameters
|
|
298
|
+
hnsw_m INTEGER DEFAULT 16,
|
|
299
|
+
hnsw_ef_construction INTEGER DEFAULT 200,
|
|
300
|
+
hnsw_ef_search INTEGER DEFAULT 100,
|
|
301
|
+
|
|
302
|
+
-- Quantization
|
|
303
|
+
quantization_type TEXT CHECK(quantization_type IN ('none', 'scalar', 'product')),
|
|
304
|
+
quantization_bits INTEGER DEFAULT 8,
|
|
305
|
+
|
|
306
|
+
-- Statistics
|
|
307
|
+
total_vectors INTEGER DEFAULT 0,
|
|
308
|
+
last_rebuild_at INTEGER,
|
|
309
|
+
|
|
310
|
+
created_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000),
|
|
311
|
+
updated_at INTEGER NOT NULL DEFAULT (strftime('%s', 'now') * 1000)
|
|
312
|
+
);
|
|
313
|
+
|
|
314
|
+
-- ============================================
|
|
315
|
+
-- SYSTEM METADATA
|
|
316
|
+
-- ============================================
|
|
317
|
+
|
|
318
|
+
CREATE TABLE IF NOT EXISTS metadata (
|
|
319
|
+
key TEXT PRIMARY KEY,
|
|
320
|
+
value TEXT NOT NULL,
|
|
321
|
+
updated_at INTEGER DEFAULT (strftime('%s', 'now') * 1000)
|
|
322
|
+
);
|
|
323
323
|
`;
|
|
324
324
|
let hnswIndex = null;
|
|
325
325
|
let hnswInitializing = false;
|
|
@@ -407,11 +407,11 @@ export async function getHNSWIndex(options) {
|
|
|
407
407
|
const fileBuffer = readFileMaybeEncrypted(dbPath, null);
|
|
408
408
|
const sqlDb = new SQL.Database(fileBuffer);
|
|
409
409
|
// Load all entries with embeddings
|
|
410
|
-
const result = sqlDb.exec(`
|
|
411
|
-
SELECT id, key, namespace, content, embedding
|
|
412
|
-
FROM memory_entries
|
|
413
|
-
WHERE status = 'active' AND embedding IS NOT NULL
|
|
414
|
-
LIMIT 10000
|
|
410
|
+
const result = sqlDb.exec(`
|
|
411
|
+
SELECT id, key, namespace, content, embedding
|
|
412
|
+
FROM memory_entries
|
|
413
|
+
WHERE status = 'active' AND embedding IS NOT NULL
|
|
414
|
+
LIMIT 10000
|
|
415
415
|
`);
|
|
416
416
|
if (result[0]?.values) {
|
|
417
417
|
for (const row of result[0].values) {
|
|
@@ -800,21 +800,21 @@ export function flashAttentionSearch(query, vectors, options = {}) {
|
|
|
800
800
|
* Initial metadata to insert after schema creation
|
|
801
801
|
*/
|
|
802
802
|
export function getInitialMetadata(backend) {
|
|
803
|
-
return `
|
|
804
|
-
INSERT OR REPLACE INTO metadata (key, value) VALUES
|
|
805
|
-
('schema_version', '3.0.0'),
|
|
806
|
-
('backend', '${backend}'),
|
|
807
|
-
('created_at', '${new Date().toISOString()}'),
|
|
808
|
-
('sql_js', 'true'),
|
|
809
|
-
('vector_embeddings', 'enabled'),
|
|
810
|
-
('pattern_learning', 'enabled'),
|
|
811
|
-
('temporal_decay', 'enabled'),
|
|
812
|
-
('hnsw_indexing', 'enabled');
|
|
813
|
-
|
|
814
|
-
-- Create default vector index configuration
|
|
815
|
-
INSERT OR IGNORE INTO vector_indexes (id, name, dimensions) VALUES
|
|
816
|
-
('default', 'default', 768),
|
|
817
|
-
('patterns', 'patterns', 768);
|
|
803
|
+
return `
|
|
804
|
+
INSERT OR REPLACE INTO metadata (key, value) VALUES
|
|
805
|
+
('schema_version', '3.0.0'),
|
|
806
|
+
('backend', '${backend}'),
|
|
807
|
+
('created_at', '${new Date().toISOString()}'),
|
|
808
|
+
('sql_js', 'true'),
|
|
809
|
+
('vector_embeddings', 'enabled'),
|
|
810
|
+
('pattern_learning', 'enabled'),
|
|
811
|
+
('temporal_decay', 'enabled'),
|
|
812
|
+
('hnsw_indexing', 'enabled');
|
|
813
|
+
|
|
814
|
+
-- Create default vector index configuration
|
|
815
|
+
INSERT OR IGNORE INTO vector_indexes (id, name, dimensions) VALUES
|
|
816
|
+
('default', 'default', 768),
|
|
817
|
+
('patterns', 'patterns', 768);
|
|
818
818
|
`;
|
|
819
819
|
}
|
|
820
820
|
/**
|
|
@@ -990,9 +990,16 @@ export async function initializeMemoryDatabase(options) {
|
|
|
990
990
|
}
|
|
991
991
|
}
|
|
992
992
|
// Check existing database
|
|
993
|
+
// #1791.6 — Idempotent re-init: if the database already exists and the
|
|
994
|
+
// caller did not pass --force, treat it as a successful no-op instead of
|
|
995
|
+
// an error. Callers (CLI, MCP tools, embeddings) can branch on
|
|
996
|
+
// `alreadyExists` if they want a different message; previous behavior
|
|
997
|
+
// surfaced an `[ERROR]` and a "Initialization failed" spinner even when
|
|
998
|
+
// the existing DB was perfectly healthy.
|
|
993
999
|
if (fs.existsSync(dbPath) && !force) {
|
|
994
1000
|
return {
|
|
995
|
-
success:
|
|
1001
|
+
success: true,
|
|
1002
|
+
alreadyExists: true,
|
|
996
1003
|
backend,
|
|
997
1004
|
dbPath,
|
|
998
1005
|
schemaVersion: '3.0.0',
|
|
@@ -1004,8 +1011,7 @@ export async function initializeMemoryDatabase(options) {
|
|
|
1004
1011
|
temporalDecay: false,
|
|
1005
1012
|
hnswIndexing: false,
|
|
1006
1013
|
migrationTracking: false
|
|
1007
|
-
}
|
|
1008
|
-
error: 'Database already exists. Use --force to reinitialize.'
|
|
1014
|
+
}
|
|
1009
1015
|
};
|
|
1010
1016
|
}
|
|
1011
1017
|
// Try to use sql.js (WASM SQLite)
|
|
@@ -1214,14 +1220,14 @@ export async function applyTemporalDecay(dbPath) {
|
|
|
1214
1220
|
const db = new SQL.Database(fileBuffer);
|
|
1215
1221
|
// Apply decay: confidence *= exp(-decay_rate * days_since_last_use)
|
|
1216
1222
|
const now = Date.now();
|
|
1217
|
-
const decayQuery = `
|
|
1218
|
-
UPDATE patterns
|
|
1219
|
-
SET
|
|
1220
|
-
confidence = confidence * (1.0 - decay_rate * ((? - COALESCE(last_matched_at, created_at)) / 86400000.0)),
|
|
1221
|
-
updated_at = ?
|
|
1222
|
-
WHERE status = 'active'
|
|
1223
|
-
AND confidence > 0.1
|
|
1224
|
-
AND (? - COALESCE(last_matched_at, created_at)) > 86400000
|
|
1223
|
+
const decayQuery = `
|
|
1224
|
+
UPDATE patterns
|
|
1225
|
+
SET
|
|
1226
|
+
confidence = confidence * (1.0 - decay_rate * ((? - COALESCE(last_matched_at, created_at)) / 86400000.0)),
|
|
1227
|
+
updated_at = ?
|
|
1228
|
+
WHERE status = 'active'
|
|
1229
|
+
AND confidence > 0.1
|
|
1230
|
+
AND (? - COALESCE(last_matched_at, created_at)) > 86400000
|
|
1225
1231
|
`;
|
|
1226
1232
|
db.run(decayQuery, [now, now, now]);
|
|
1227
1233
|
const changes = db.getRowsModified();
|
|
@@ -1567,9 +1573,9 @@ export async function verifyMemoryInit(dbPath, options) {
|
|
|
1567
1573
|
const testKey = 'verification_test';
|
|
1568
1574
|
const testValue = 'This is a verification test entry for memory initialization';
|
|
1569
1575
|
try {
|
|
1570
|
-
db.run(`
|
|
1571
|
-
INSERT INTO memory_entries (id, key, namespace, content, type, created_at, updated_at)
|
|
1572
|
-
VALUES (?, ?, 'test', ?, 'semantic', ?, ?)
|
|
1576
|
+
db.run(`
|
|
1577
|
+
INSERT INTO memory_entries (id, key, namespace, content, type, created_at, updated_at)
|
|
1578
|
+
VALUES (?, ?, 'test', ?, 'semantic', ?, ?)
|
|
1573
1579
|
`, [testId, testKey, testValue, Date.now(), Date.now()]);
|
|
1574
1580
|
tests.push({
|
|
1575
1581
|
name: 'Write entry',
|
|
@@ -1611,10 +1617,10 @@ export async function verifyMemoryInit(dbPath, options) {
|
|
|
1611
1617
|
try {
|
|
1612
1618
|
const { embedding, dimensions, model } = await generateEmbedding(testValue);
|
|
1613
1619
|
const embeddingJson = JSON.stringify(embedding);
|
|
1614
|
-
db.run(`
|
|
1615
|
-
UPDATE memory_entries
|
|
1616
|
-
SET embedding = ?, embedding_dimensions = ?, embedding_model = ?
|
|
1617
|
-
WHERE id = ?
|
|
1620
|
+
db.run(`
|
|
1621
|
+
UPDATE memory_entries
|
|
1622
|
+
SET embedding = ?, embedding_dimensions = ?, embedding_model = ?
|
|
1623
|
+
WHERE id = ?
|
|
1618
1624
|
`, [embeddingJson, dimensions, model, testId]);
|
|
1619
1625
|
tests.push({
|
|
1620
1626
|
name: 'Generate embedding',
|
|
@@ -1635,9 +1641,9 @@ export async function verifyMemoryInit(dbPath, options) {
|
|
|
1635
1641
|
const patternStart = Date.now();
|
|
1636
1642
|
try {
|
|
1637
1643
|
const patternId = `pattern_${Date.now()}`;
|
|
1638
|
-
db.run(`
|
|
1639
|
-
INSERT INTO patterns (id, name, pattern_type, condition, action, confidence, created_at, updated_at)
|
|
1640
|
-
VALUES (?, 'test-pattern', 'task-routing', 'test condition', 'test action', 0.5, ?, ?)
|
|
1644
|
+
db.run(`
|
|
1645
|
+
INSERT INTO patterns (id, name, pattern_type, condition, action, confidence, created_at, updated_at)
|
|
1646
|
+
VALUES (?, 'test-pattern', 'task-routing', 'test condition', 'test action', 0.5, ?, ?)
|
|
1641
1647
|
`, [patternId, Date.now(), Date.now()]);
|
|
1642
1648
|
tests.push({
|
|
1643
1649
|
name: 'Pattern storage',
|
|
@@ -1757,15 +1763,15 @@ export async function storeEntry(options) {
|
|
|
1757
1763
|
}
|
|
1758
1764
|
// Insert or update entry (upsert mode uses REPLACE)
|
|
1759
1765
|
const insertSql = upsert
|
|
1760
|
-
? `INSERT OR REPLACE INTO memory_entries (
|
|
1761
|
-
id, key, namespace, content, type,
|
|
1762
|
-
embedding, embedding_dimensions, embedding_model,
|
|
1763
|
-
tags, metadata, created_at, updated_at, expires_at, status
|
|
1766
|
+
? `INSERT OR REPLACE INTO memory_entries (
|
|
1767
|
+
id, key, namespace, content, type,
|
|
1768
|
+
embedding, embedding_dimensions, embedding_model,
|
|
1769
|
+
tags, metadata, created_at, updated_at, expires_at, status
|
|
1764
1770
|
) VALUES (?, ?, ?, ?, 'semantic', ?, ?, ?, ?, ?, ?, ?, ?, 'active')`
|
|
1765
|
-
: `INSERT INTO memory_entries (
|
|
1766
|
-
id, key, namespace, content, type,
|
|
1767
|
-
embedding, embedding_dimensions, embedding_model,
|
|
1768
|
-
tags, metadata, created_at, updated_at, expires_at, status
|
|
1771
|
+
: `INSERT INTO memory_entries (
|
|
1772
|
+
id, key, namespace, content, type,
|
|
1773
|
+
embedding, embedding_dimensions, embedding_model,
|
|
1774
|
+
tags, metadata, created_at, updated_at, expires_at, status
|
|
1769
1775
|
) VALUES (?, ?, ?, ?, 'semantic', ?, ?, ?, ?, ?, ?, ?, ?, 'active')`;
|
|
1770
1776
|
db.run(insertSql, [
|
|
1771
1777
|
id,
|
|
@@ -2093,13 +2099,13 @@ export async function getEntry(options) {
|
|
|
2093
2099
|
const fileBuffer = readFileMaybeEncrypted(dbPath, null);
|
|
2094
2100
|
const db = new SQL.Database(fileBuffer);
|
|
2095
2101
|
// Find entry by key
|
|
2096
|
-
const getStmt = db.prepare(`
|
|
2097
|
-
SELECT id, key, namespace, content, embedding, access_count, created_at, updated_at, tags
|
|
2098
|
-
FROM memory_entries
|
|
2099
|
-
WHERE status = 'active'
|
|
2100
|
-
AND key = ?
|
|
2101
|
-
AND namespace = ?
|
|
2102
|
-
LIMIT 1
|
|
2102
|
+
const getStmt = db.prepare(`
|
|
2103
|
+
SELECT id, key, namespace, content, embedding, access_count, created_at, updated_at, tags
|
|
2104
|
+
FROM memory_entries
|
|
2105
|
+
WHERE status = 'active'
|
|
2106
|
+
AND key = ?
|
|
2107
|
+
AND namespace = ?
|
|
2108
|
+
LIMIT 1
|
|
2103
2109
|
`);
|
|
2104
2110
|
getStmt.bind([key, namespace]);
|
|
2105
2111
|
const getRows = [];
|
|
@@ -2114,10 +2120,10 @@ export async function getEntry(options) {
|
|
|
2114
2120
|
}
|
|
2115
2121
|
const [id, entryKey, ns, content, embedding, accessCount, createdAt, updatedAt, tagsJson] = result[0].values[0];
|
|
2116
2122
|
// Update access count
|
|
2117
|
-
db.run(`
|
|
2118
|
-
UPDATE memory_entries
|
|
2119
|
-
SET access_count = access_count + 1, last_accessed_at = strftime('%s', 'now') * 1000
|
|
2120
|
-
WHERE id = ?
|
|
2123
|
+
db.run(`
|
|
2124
|
+
UPDATE memory_entries
|
|
2125
|
+
SET access_count = access_count + 1, last_accessed_at = strftime('%s', 'now') * 1000
|
|
2126
|
+
WHERE id = ?
|
|
2121
2127
|
`, [String(id)]);
|
|
2122
2128
|
// Save updated database
|
|
2123
2129
|
const data = db.export();
|
|
@@ -2204,12 +2210,12 @@ export async function deleteEntry(options) {
|
|
|
2204
2210
|
const fileBuffer = readFileMaybeEncrypted(dbPath, null);
|
|
2205
2211
|
const db = new SQL.Database(fileBuffer);
|
|
2206
2212
|
// Check if entry exists first
|
|
2207
|
-
const checkStmt = db.prepare(`
|
|
2208
|
-
SELECT id FROM memory_entries
|
|
2209
|
-
WHERE status = 'active'
|
|
2210
|
-
AND key = ?
|
|
2211
|
-
AND namespace = ?
|
|
2212
|
-
LIMIT 1
|
|
2213
|
+
const checkStmt = db.prepare(`
|
|
2214
|
+
SELECT id FROM memory_entries
|
|
2215
|
+
WHERE status = 'active'
|
|
2216
|
+
AND key = ?
|
|
2217
|
+
AND namespace = ?
|
|
2218
|
+
LIMIT 1
|
|
2213
2219
|
`);
|
|
2214
2220
|
checkStmt.bind([key, namespace]);
|
|
2215
2221
|
const checkRows = [];
|
|
@@ -2236,14 +2242,14 @@ export async function deleteEntry(options) {
|
|
|
2236
2242
|
const entryId = String(checkResult[0].values[0][0]);
|
|
2237
2243
|
// Delete the entry (soft delete by setting status to 'deleted')
|
|
2238
2244
|
// Also null out the embedding to clean up vector data from SQLite
|
|
2239
|
-
db.run(`
|
|
2240
|
-
UPDATE memory_entries
|
|
2241
|
-
SET status = 'deleted',
|
|
2242
|
-
embedding = NULL,
|
|
2243
|
-
updated_at = strftime('%s', 'now') * 1000
|
|
2244
|
-
WHERE key = ?
|
|
2245
|
-
AND namespace = ?
|
|
2246
|
-
AND status = 'active'
|
|
2245
|
+
db.run(`
|
|
2246
|
+
UPDATE memory_entries
|
|
2247
|
+
SET status = 'deleted',
|
|
2248
|
+
embedding = NULL,
|
|
2249
|
+
updated_at = strftime('%s', 'now') * 1000
|
|
2250
|
+
WHERE key = ?
|
|
2251
|
+
AND namespace = ?
|
|
2252
|
+
AND status = 'active'
|
|
2247
2253
|
`, [key, namespace]);
|
|
2248
2254
|
// Get remaining count
|
|
2249
2255
|
const countResult = db.exec(`SELECT COUNT(*) FROM memory_entries WHERE status = 'active'`);
|