@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
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@claude-flow/cli",
|
|
3
|
-
"version": "3.7.0-alpha.
|
|
3
|
+
"version": "3.7.0-alpha.10",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "Ruflo CLI - Enterprise AI agent orchestration with 60+ specialized agents, swarm coordination, MCP server, self-learning hooks, and vector memory for Claude Code",
|
|
6
6
|
"main": "dist/src/index.js",
|
|
@@ -97,6 +97,7 @@
|
|
|
97
97
|
"dependencies": {
|
|
98
98
|
"@claude-flow/cli-core": "^3.7.0-alpha.5",
|
|
99
99
|
"@claude-flow/mcp": "^3.0.0-alpha.8",
|
|
100
|
+
"@claude-flow/neural": "^3.0.0-alpha.8",
|
|
100
101
|
"@claude-flow/shared": "^3.0.0-alpha.7",
|
|
101
102
|
"@noble/ed25519": "^2.1.0",
|
|
102
103
|
"@ruvector/rabitq-wasm": "^0.1.0",
|
|
@@ -107,7 +108,7 @@
|
|
|
107
108
|
"@claude-flow/codex": "^3.0.0-alpha.8",
|
|
108
109
|
"@claude-flow/embeddings": "^3.0.0-alpha.12",
|
|
109
110
|
"@claude-flow/guidance": "^3.0.0-alpha.1",
|
|
110
|
-
"@claude-flow/memory": "
|
|
111
|
+
"@claude-flow/memory": "workspace:3.0.0-alpha.14",
|
|
111
112
|
"@claude-flow/plugin-gastown-bridge": "^0.1.3",
|
|
112
113
|
"@claude-flow/security": "^3.0.0-alpha.1",
|
|
113
114
|
"@ruvector/attention": "^0.1.32",
|
|
@@ -117,8 +118,8 @@
|
|
|
117
118
|
"@ruvector/router": "^0.1.30",
|
|
118
119
|
"@ruvector/ruvllm-wasm": "^2.0.2",
|
|
119
120
|
"@ruvector/rvagent-wasm": "^0.1.0",
|
|
120
|
-
"@ruvector/sona": "^0.1.
|
|
121
|
-
"agentdb": "^3.0.0-alpha.
|
|
121
|
+
"@ruvector/sona": "^0.1.6",
|
|
122
|
+
"agentdb": "^3.0.0-alpha.13",
|
|
122
123
|
"agentic-flow": "^3.0.0-alpha.1"
|
|
123
124
|
},
|
|
124
125
|
"publishConfig": {
|
|
@@ -1,153 +1,153 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
#
|
|
3
|
-
# Deploy IPFS Node to Google Cloud
|
|
4
|
-
# Provides free IPFS pinning for your users
|
|
5
|
-
#
|
|
6
|
-
# Usage:
|
|
7
|
-
# ./deploy-ipfs-node.sh [PROJECT_ID] [ZONE]
|
|
8
|
-
#
|
|
9
|
-
# Example:
|
|
10
|
-
# ./deploy-ipfs-node.sh my-project us-central1-a
|
|
11
|
-
#
|
|
12
|
-
|
|
13
|
-
set -e
|
|
14
|
-
|
|
15
|
-
PROJECT_ID="${1:-$(gcloud config get-value project)}"
|
|
16
|
-
ZONE="${2:-us-central1-a}"
|
|
17
|
-
INSTANCE_NAME="ipfs-node"
|
|
18
|
-
MACHINE_TYPE="e2-medium" # $25/month, use e2-small for $8/month
|
|
19
|
-
DISK_SIZE="100GB"
|
|
20
|
-
|
|
21
|
-
echo "╔══════════════════════════════════════════════════════════════╗"
|
|
22
|
-
echo "║ IPFS Node Deployment for Claude Flow ║"
|
|
23
|
-
echo "╚══════════════════════════════════════════════════════════════╝"
|
|
24
|
-
echo ""
|
|
25
|
-
echo "Project: $PROJECT_ID"
|
|
26
|
-
echo "Zone: $ZONE"
|
|
27
|
-
echo "Machine: $MACHINE_TYPE"
|
|
28
|
-
echo "Disk: $DISK_SIZE"
|
|
29
|
-
echo ""
|
|
30
|
-
|
|
31
|
-
# Create firewall rules
|
|
32
|
-
echo "▶ Creating firewall rules..."
|
|
33
|
-
gcloud compute firewall-rules create ipfs-swarm \
|
|
34
|
-
--project="$PROJECT_ID" \
|
|
35
|
-
--allow=tcp:4001,udp:4001 \
|
|
36
|
-
--target-tags=ipfs-node \
|
|
37
|
-
--description="IPFS swarm connections" \
|
|
38
|
-
2>/dev/null || echo " (firewall rule already exists)"
|
|
39
|
-
|
|
40
|
-
gcloud compute firewall-rules create ipfs-api \
|
|
41
|
-
--project="$PROJECT_ID" \
|
|
42
|
-
--allow=tcp:5001 \
|
|
43
|
-
--target-tags=ipfs-node \
|
|
44
|
-
--source-ranges="0.0.0.0/0" \
|
|
45
|
-
--description="IPFS API (consider restricting)" \
|
|
46
|
-
2>/dev/null || echo " (firewall rule already exists)"
|
|
47
|
-
|
|
48
|
-
gcloud compute firewall-rules create ipfs-gateway \
|
|
49
|
-
--project="$PROJECT_ID" \
|
|
50
|
-
--allow=tcp:8080 \
|
|
51
|
-
--target-tags=ipfs-node \
|
|
52
|
-
--description="IPFS Gateway" \
|
|
53
|
-
2>/dev/null || echo " (firewall rule already exists)"
|
|
54
|
-
|
|
55
|
-
# Create startup script
|
|
56
|
-
STARTUP_SCRIPT='#!/bin/bash
|
|
57
|
-
set -e
|
|
58
|
-
|
|
59
|
-
# Install IPFS
|
|
60
|
-
echo "Installing IPFS..."
|
|
61
|
-
wget -q https://dist.ipfs.tech/kubo/v0.24.0/kubo_v0.24.0_linux-amd64.tar.gz
|
|
62
|
-
tar xzf kubo_v0.24.0_linux-amd64.tar.gz
|
|
63
|
-
cd kubo && sudo bash install.sh
|
|
64
|
-
cd .. && rm -rf kubo kubo_v0.24.0_linux-amd64.tar.gz
|
|
65
|
-
|
|
66
|
-
# Create ipfs user
|
|
67
|
-
sudo useradd -m -s /bin/bash ipfs || true
|
|
68
|
-
|
|
69
|
-
# Initialize IPFS
|
|
70
|
-
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs init --profile=server
|
|
71
|
-
|
|
72
|
-
# Configure IPFS for server use
|
|
73
|
-
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config Addresses.API /ip4/0.0.0.0/tcp/5001
|
|
74
|
-
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config Addresses.Gateway /ip4/0.0.0.0/tcp/8080
|
|
75
|
-
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config --json API.HTTPHeaders.Access-Control-Allow-Origin "[\"*\"]"
|
|
76
|
-
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config --json API.HTTPHeaders.Access-Control-Allow-Methods "[\"PUT\", \"POST\", \"GET\"]"
|
|
77
|
-
|
|
78
|
-
# Set storage limits (adjust as needed)
|
|
79
|
-
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config Datastore.StorageMax 80GB
|
|
80
|
-
|
|
81
|
-
# Create systemd service
|
|
82
|
-
cat > /etc/systemd/system/ipfs.service << EOF
|
|
83
|
-
[Unit]
|
|
84
|
-
Description=IPFS Daemon
|
|
85
|
-
After=network.target
|
|
86
|
-
|
|
87
|
-
[Service]
|
|
88
|
-
Type=simple
|
|
89
|
-
User=ipfs
|
|
90
|
-
Environment=IPFS_PATH=/home/ipfs/.ipfs
|
|
91
|
-
ExecStart=/usr/local/bin/ipfs daemon --migrate=true
|
|
92
|
-
Restart=on-failure
|
|
93
|
-
RestartSec=10
|
|
94
|
-
|
|
95
|
-
[Install]
|
|
96
|
-
WantedBy=multi-user.target
|
|
97
|
-
EOF
|
|
98
|
-
|
|
99
|
-
# Start IPFS
|
|
100
|
-
systemctl daemon-reload
|
|
101
|
-
systemctl enable ipfs
|
|
102
|
-
systemctl start ipfs
|
|
103
|
-
|
|
104
|
-
echo "IPFS node started successfully!"
|
|
105
|
-
'
|
|
106
|
-
|
|
107
|
-
# Create instance
|
|
108
|
-
echo "▶ Creating VM instance..."
|
|
109
|
-
gcloud compute instances create "$INSTANCE_NAME" \
|
|
110
|
-
--project="$PROJECT_ID" \
|
|
111
|
-
--zone="$ZONE" \
|
|
112
|
-
--machine-type="$MACHINE_TYPE" \
|
|
113
|
-
--image-family=ubuntu-2204-lts \
|
|
114
|
-
--image-project=ubuntu-os-cloud \
|
|
115
|
-
--boot-disk-size="$DISK_SIZE" \
|
|
116
|
-
--boot-disk-type=pd-ssd \
|
|
117
|
-
--tags=ipfs-node \
|
|
118
|
-
--metadata=startup-script="$STARTUP_SCRIPT"
|
|
119
|
-
|
|
120
|
-
# Get external IP
|
|
121
|
-
echo ""
|
|
122
|
-
echo "▶ Waiting for instance to start..."
|
|
123
|
-
sleep 30
|
|
124
|
-
|
|
125
|
-
EXTERNAL_IP=$(gcloud compute instances describe "$INSTANCE_NAME" \
|
|
126
|
-
--project="$PROJECT_ID" \
|
|
127
|
-
--zone="$ZONE" \
|
|
128
|
-
--format='get(networkInterfaces[0].accessConfigs[0].natIP)')
|
|
129
|
-
|
|
130
|
-
echo ""
|
|
131
|
-
echo "═══════════════════════════════════════════════════════════════"
|
|
132
|
-
echo " DEPLOYMENT COMPLETE"
|
|
133
|
-
echo "═══════════════════════════════════════════════════════════════"
|
|
134
|
-
echo ""
|
|
135
|
-
echo " IPFS Node IP: $EXTERNAL_IP"
|
|
136
|
-
echo ""
|
|
137
|
-
echo " Endpoints:"
|
|
138
|
-
echo " API: http://$EXTERNAL_IP:5001"
|
|
139
|
-
echo " Gateway: http://$EXTERNAL_IP:8080"
|
|
140
|
-
echo " Swarm: /ip4/$EXTERNAL_IP/tcp/4001"
|
|
141
|
-
echo ""
|
|
142
|
-
echo " Test commands:"
|
|
143
|
-
echo " curl http://$EXTERNAL_IP:5001/api/v0/id"
|
|
144
|
-
echo " curl http://$EXTERNAL_IP:8080/ipfs/QmYwAPJzv5CZsnA625s3Xf2nemtYgPpHdWEz79ojWnPbdG/readme"
|
|
145
|
-
echo ""
|
|
146
|
-
echo " Configure Claude Flow CLI:"
|
|
147
|
-
echo " export IPFS_API_URL=http://$EXTERNAL_IP:5001"
|
|
148
|
-
echo ""
|
|
149
|
-
echo " SSH into node:"
|
|
150
|
-
echo " gcloud compute ssh $INSTANCE_NAME --zone=$ZONE"
|
|
151
|
-
echo ""
|
|
152
|
-
echo " Monthly cost estimate: ~\$25-54 depending on usage"
|
|
153
|
-
echo ""
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
#
|
|
3
|
+
# Deploy IPFS Node to Google Cloud
|
|
4
|
+
# Provides free IPFS pinning for your users
|
|
5
|
+
#
|
|
6
|
+
# Usage:
|
|
7
|
+
# ./deploy-ipfs-node.sh [PROJECT_ID] [ZONE]
|
|
8
|
+
#
|
|
9
|
+
# Example:
|
|
10
|
+
# ./deploy-ipfs-node.sh my-project us-central1-a
|
|
11
|
+
#
|
|
12
|
+
|
|
13
|
+
set -e
|
|
14
|
+
|
|
15
|
+
PROJECT_ID="${1:-$(gcloud config get-value project)}"
|
|
16
|
+
ZONE="${2:-us-central1-a}"
|
|
17
|
+
INSTANCE_NAME="ipfs-node"
|
|
18
|
+
MACHINE_TYPE="e2-medium" # $25/month, use e2-small for $8/month
|
|
19
|
+
DISK_SIZE="100GB"
|
|
20
|
+
|
|
21
|
+
echo "╔══════════════════════════════════════════════════════════════╗"
|
|
22
|
+
echo "║ IPFS Node Deployment for Claude Flow ║"
|
|
23
|
+
echo "╚══════════════════════════════════════════════════════════════╝"
|
|
24
|
+
echo ""
|
|
25
|
+
echo "Project: $PROJECT_ID"
|
|
26
|
+
echo "Zone: $ZONE"
|
|
27
|
+
echo "Machine: $MACHINE_TYPE"
|
|
28
|
+
echo "Disk: $DISK_SIZE"
|
|
29
|
+
echo ""
|
|
30
|
+
|
|
31
|
+
# Create firewall rules
|
|
32
|
+
echo "▶ Creating firewall rules..."
|
|
33
|
+
gcloud compute firewall-rules create ipfs-swarm \
|
|
34
|
+
--project="$PROJECT_ID" \
|
|
35
|
+
--allow=tcp:4001,udp:4001 \
|
|
36
|
+
--target-tags=ipfs-node \
|
|
37
|
+
--description="IPFS swarm connections" \
|
|
38
|
+
2>/dev/null || echo " (firewall rule already exists)"
|
|
39
|
+
|
|
40
|
+
gcloud compute firewall-rules create ipfs-api \
|
|
41
|
+
--project="$PROJECT_ID" \
|
|
42
|
+
--allow=tcp:5001 \
|
|
43
|
+
--target-tags=ipfs-node \
|
|
44
|
+
--source-ranges="0.0.0.0/0" \
|
|
45
|
+
--description="IPFS API (consider restricting)" \
|
|
46
|
+
2>/dev/null || echo " (firewall rule already exists)"
|
|
47
|
+
|
|
48
|
+
gcloud compute firewall-rules create ipfs-gateway \
|
|
49
|
+
--project="$PROJECT_ID" \
|
|
50
|
+
--allow=tcp:8080 \
|
|
51
|
+
--target-tags=ipfs-node \
|
|
52
|
+
--description="IPFS Gateway" \
|
|
53
|
+
2>/dev/null || echo " (firewall rule already exists)"
|
|
54
|
+
|
|
55
|
+
# Create startup script
|
|
56
|
+
STARTUP_SCRIPT='#!/bin/bash
|
|
57
|
+
set -e
|
|
58
|
+
|
|
59
|
+
# Install IPFS
|
|
60
|
+
echo "Installing IPFS..."
|
|
61
|
+
wget -q https://dist.ipfs.tech/kubo/v0.24.0/kubo_v0.24.0_linux-amd64.tar.gz
|
|
62
|
+
tar xzf kubo_v0.24.0_linux-amd64.tar.gz
|
|
63
|
+
cd kubo && sudo bash install.sh
|
|
64
|
+
cd .. && rm -rf kubo kubo_v0.24.0_linux-amd64.tar.gz
|
|
65
|
+
|
|
66
|
+
# Create ipfs user
|
|
67
|
+
sudo useradd -m -s /bin/bash ipfs || true
|
|
68
|
+
|
|
69
|
+
# Initialize IPFS
|
|
70
|
+
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs init --profile=server
|
|
71
|
+
|
|
72
|
+
# Configure IPFS for server use
|
|
73
|
+
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config Addresses.API /ip4/0.0.0.0/tcp/5001
|
|
74
|
+
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config Addresses.Gateway /ip4/0.0.0.0/tcp/8080
|
|
75
|
+
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config --json API.HTTPHeaders.Access-Control-Allow-Origin "[\"*\"]"
|
|
76
|
+
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config --json API.HTTPHeaders.Access-Control-Allow-Methods "[\"PUT\", \"POST\", \"GET\"]"
|
|
77
|
+
|
|
78
|
+
# Set storage limits (adjust as needed)
|
|
79
|
+
sudo -u ipfs IPFS_PATH=/home/ipfs/.ipfs ipfs config Datastore.StorageMax 80GB
|
|
80
|
+
|
|
81
|
+
# Create systemd service
|
|
82
|
+
cat > /etc/systemd/system/ipfs.service << EOF
|
|
83
|
+
[Unit]
|
|
84
|
+
Description=IPFS Daemon
|
|
85
|
+
After=network.target
|
|
86
|
+
|
|
87
|
+
[Service]
|
|
88
|
+
Type=simple
|
|
89
|
+
User=ipfs
|
|
90
|
+
Environment=IPFS_PATH=/home/ipfs/.ipfs
|
|
91
|
+
ExecStart=/usr/local/bin/ipfs daemon --migrate=true
|
|
92
|
+
Restart=on-failure
|
|
93
|
+
RestartSec=10
|
|
94
|
+
|
|
95
|
+
[Install]
|
|
96
|
+
WantedBy=multi-user.target
|
|
97
|
+
EOF
|
|
98
|
+
|
|
99
|
+
# Start IPFS
|
|
100
|
+
systemctl daemon-reload
|
|
101
|
+
systemctl enable ipfs
|
|
102
|
+
systemctl start ipfs
|
|
103
|
+
|
|
104
|
+
echo "IPFS node started successfully!"
|
|
105
|
+
'
|
|
106
|
+
|
|
107
|
+
# Create instance
|
|
108
|
+
echo "▶ Creating VM instance..."
|
|
109
|
+
gcloud compute instances create "$INSTANCE_NAME" \
|
|
110
|
+
--project="$PROJECT_ID" \
|
|
111
|
+
--zone="$ZONE" \
|
|
112
|
+
--machine-type="$MACHINE_TYPE" \
|
|
113
|
+
--image-family=ubuntu-2204-lts \
|
|
114
|
+
--image-project=ubuntu-os-cloud \
|
|
115
|
+
--boot-disk-size="$DISK_SIZE" \
|
|
116
|
+
--boot-disk-type=pd-ssd \
|
|
117
|
+
--tags=ipfs-node \
|
|
118
|
+
--metadata=startup-script="$STARTUP_SCRIPT"
|
|
119
|
+
|
|
120
|
+
# Get external IP
|
|
121
|
+
echo ""
|
|
122
|
+
echo "▶ Waiting for instance to start..."
|
|
123
|
+
sleep 30
|
|
124
|
+
|
|
125
|
+
EXTERNAL_IP=$(gcloud compute instances describe "$INSTANCE_NAME" \
|
|
126
|
+
--project="$PROJECT_ID" \
|
|
127
|
+
--zone="$ZONE" \
|
|
128
|
+
--format='get(networkInterfaces[0].accessConfigs[0].natIP)')
|
|
129
|
+
|
|
130
|
+
echo ""
|
|
131
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
132
|
+
echo " DEPLOYMENT COMPLETE"
|
|
133
|
+
echo "═══════════════════════════════════════════════════════════════"
|
|
134
|
+
echo ""
|
|
135
|
+
echo " IPFS Node IP: $EXTERNAL_IP"
|
|
136
|
+
echo ""
|
|
137
|
+
echo " Endpoints:"
|
|
138
|
+
echo " API: http://$EXTERNAL_IP:5001"
|
|
139
|
+
echo " Gateway: http://$EXTERNAL_IP:8080"
|
|
140
|
+
echo " Swarm: /ip4/$EXTERNAL_IP/tcp/4001"
|
|
141
|
+
echo ""
|
|
142
|
+
echo " Test commands:"
|
|
143
|
+
echo " curl http://$EXTERNAL_IP:5001/api/v0/id"
|
|
144
|
+
echo " curl http://$EXTERNAL_IP:8080/ipfs/QmYwAPJzv5CZsnA625s3Xf2nemtYgPpHdWEz79ojWnPbdG/readme"
|
|
145
|
+
echo ""
|
|
146
|
+
echo " Configure Claude Flow CLI:"
|
|
147
|
+
echo " export IPFS_API_URL=http://$EXTERNAL_IP:5001"
|
|
148
|
+
echo ""
|
|
149
|
+
echo " SSH into node:"
|
|
150
|
+
echo " gcloud compute ssh $INSTANCE_NAME --zone=$ZONE"
|
|
151
|
+
echo ""
|
|
152
|
+
echo " Monthly cost estimate: ~\$25-54 depending on usage"
|
|
153
|
+
echo ""
|
package/scripts/postinstall.cjs
CHANGED
|
@@ -1,153 +1,153 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
/**
|
|
3
|
-
* @claude-flow/cli postinstall — agentdb compatibility patches.
|
|
4
|
-
*
|
|
5
|
-
* Two patches applied to the user's installed agentdb tree:
|
|
6
|
-
*
|
|
7
|
-
* 1. Sibling directory copy (#1721 fix): agentic-flow's runtime patch
|
|
8
|
-
* expects agentdb's controllers + utils + core + services + types
|
|
9
|
-
* at `dist/<name>/` (legacy v1.x layout). agentdb v3 ships at
|
|
10
|
-
* `dist/src/<name>/`. Copy each `dist/src/<name>/` subdir to
|
|
11
|
-
* `dist/<name>/` so the legacy import paths resolve. Skip dirs that
|
|
12
|
-
* already exist so this is idempotent.
|
|
13
|
-
*
|
|
14
|
-
* 2. Exports-field augmentation (ADR-095 G7): six controller files
|
|
15
|
-
* exist in agentdb's dist but are not declared in its package.json
|
|
16
|
-
* `exports` field — `AttestationLog`, `MutationGuard`,
|
|
17
|
-
* `GuardedVectorBackend`, `GNNService`, `RVFOptimizer`,
|
|
18
|
-
* `GraphAdapter`. Without these declared, Node's strict exports
|
|
19
|
-
* enforcement blocks subpath imports even when the file is on disk.
|
|
20
|
-
* We add the missing entries (only if the file actually exists)
|
|
21
|
-
* so consumers can reach them via `agentdb/controllers/...`.
|
|
22
|
-
*
|
|
23
|
-
* Both patches are best-effort — failure to apply does not break
|
|
24
|
-
* install (try/catch wraps each phase). Re-running is safe.
|
|
25
|
-
*/
|
|
26
|
-
|
|
27
|
-
'use strict';
|
|
28
|
-
|
|
29
|
-
const fs = require('node:fs');
|
|
30
|
-
const path = require('node:path');
|
|
31
|
-
|
|
32
|
-
function findAgentdbBase() {
|
|
33
|
-
try {
|
|
34
|
-
const r = require.resolve('agentdb');
|
|
35
|
-
if (r.includes('dist/src')) return path.join(path.dirname(r), '..', '..');
|
|
36
|
-
if (r.includes('dist')) return path.join(path.dirname(r), '..');
|
|
37
|
-
return path.dirname(r);
|
|
38
|
-
} catch { return null; }
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Find every agentdb installation reachable in the install's node_modules
|
|
43
|
-
* tree. Necessary because pnpm/npm hoisting can place multiple copies of
|
|
44
|
-
* agentdb (different versions) at different levels. Only patching the
|
|
45
|
-
* resolved one leaves consumer code that imports through a different
|
|
46
|
-
* resolution path with stale exports.
|
|
47
|
-
*
|
|
48
|
-
* Strategy: walk up from the postinstall script's directory, collect any
|
|
49
|
-
* `node_modules/agentdb` we find along the way + the .pnpm cached copies
|
|
50
|
-
* directly under the same node_modules/.pnpm/ root.
|
|
51
|
-
*/
|
|
52
|
-
function findAllAgentdbBases() {
|
|
53
|
-
const found = new Set();
|
|
54
|
-
let dir = __dirname;
|
|
55
|
-
for (let i = 0; i < 12; i++) {
|
|
56
|
-
const candidate = path.join(dir, 'node_modules', 'agentdb');
|
|
57
|
-
if (fs.existsSync(path.join(candidate, 'package.json'))) {
|
|
58
|
-
try { found.add(fs.realpathSync(candidate)); } catch { found.add(candidate); }
|
|
59
|
-
}
|
|
60
|
-
// Also check for .pnpm cache adjacent to this node_modules
|
|
61
|
-
const pnpmDir = path.join(dir, 'node_modules', '.pnpm');
|
|
62
|
-
if (fs.existsSync(pnpmDir)) {
|
|
63
|
-
try {
|
|
64
|
-
for (const e of fs.readdirSync(pnpmDir)) {
|
|
65
|
-
if (e.startsWith('agentdb@')) {
|
|
66
|
-
const adb = path.join(pnpmDir, e, 'node_modules', 'agentdb');
|
|
67
|
-
if (fs.existsSync(path.join(adb, 'package.json'))) {
|
|
68
|
-
try { found.add(fs.realpathSync(adb)); } catch { found.add(adb); }
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
} catch { /* ignore */ }
|
|
73
|
-
}
|
|
74
|
-
const parent = path.dirname(dir);
|
|
75
|
-
if (parent === dir) break;
|
|
76
|
-
dir = parent;
|
|
77
|
-
}
|
|
78
|
-
return Array.from(found);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
function copySiblings(base) {
|
|
82
|
-
const srcDist = path.join(base, 'dist', 'src');
|
|
83
|
-
if (!fs.existsSync(srcDist)) return;
|
|
84
|
-
for (const entry of fs.readdirSync(srcDist)) {
|
|
85
|
-
const src = path.join(srcDist, entry);
|
|
86
|
-
const target = path.join(base, 'dist', entry);
|
|
87
|
-
try {
|
|
88
|
-
if (fs.statSync(src).isDirectory() && !fs.existsSync(target)) {
|
|
89
|
-
fs.cpSync(src, target, { recursive: true });
|
|
90
|
-
}
|
|
91
|
-
} catch { /* best-effort */ }
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
function augmentExports(base) {
|
|
96
|
-
const pkgPath = path.join(base, 'package.json');
|
|
97
|
-
if (!fs.existsSync(pkgPath)) return;
|
|
98
|
-
let pkg;
|
|
99
|
-
try { pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8')); }
|
|
100
|
-
catch { return; }
|
|
101
|
-
if (!pkg.exports || typeof pkg.exports !== 'object') return;
|
|
102
|
-
|
|
103
|
-
// Subpath → relative file path (only added if both: (a) file exists, (b) export not already declared)
|
|
104
|
-
const additions = {
|
|
105
|
-
'./controllers/AttestationLog': './dist/src/security/AttestationLog.js',
|
|
106
|
-
'./controllers/MutationGuard': './dist/src/security/MutationGuard.js',
|
|
107
|
-
'./controllers/GuardedVectorBackend': './dist/src/backends/ruvector/GuardedVectorBackend.js',
|
|
108
|
-
// GNNService and RVFOptimizer live outside dist/src/controllers/ in
|
|
109
|
-
// current agentdb. Map to the actual paths so the export points at a
|
|
110
|
-
// real file. Future agentdb versions may move them — the file-exists
|
|
111
|
-
// guard below will skip cleanly if these paths drift.
|
|
112
|
-
'./controllers/GNNService': './dist/src/services/GNNService.js',
|
|
113
|
-
'./controllers/RVFOptimizer': './dist/src/optimizations/RVFOptimizer.js',
|
|
114
|
-
// GraphAdapter location varies; try the graph-node backend path. If
|
|
115
|
-
// missing, the file-exists guard skips it without error.
|
|
116
|
-
'./controllers/GraphAdapter': './dist/src/backends/graph-node/GraphAdapter.js',
|
|
117
|
-
// Also expose the security index so consumers can import the security namespace.
|
|
118
|
-
'./security/controllers': './dist/src/security/index.js',
|
|
119
|
-
};
|
|
120
|
-
|
|
121
|
-
let changed = false;
|
|
122
|
-
for (const [subpath, target] of Object.entries(additions)) {
|
|
123
|
-
if (pkg.exports[subpath]) continue;
|
|
124
|
-
const abs = path.join(base, target);
|
|
125
|
-
if (!fs.existsSync(abs)) continue;
|
|
126
|
-
pkg.exports[subpath] = target;
|
|
127
|
-
changed = true;
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
if (changed) {
|
|
131
|
-
try {
|
|
132
|
-
fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + '\n', 'utf-8');
|
|
133
|
-
} catch { /* best-effort */ }
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
function main() {
|
|
138
|
-
// Patch every reachable agentdb instance, not just the first resolution
|
|
139
|
-
// result. pnpm/npm hoisting can leave multiple agentdb copies in the
|
|
140
|
-
// install tree, and consumers may import through any of them.
|
|
141
|
-
const bases = findAllAgentdbBases();
|
|
142
|
-
if (bases.length === 0) {
|
|
143
|
-
// Fall back to the single-base path so we still attempt something
|
|
144
|
-
// when the directory walk didn't find anything (e.g. unusual installs).
|
|
145
|
-
const base = findAgentdbBase();
|
|
146
|
-
if (base) bases.push(base);
|
|
147
|
-
}
|
|
148
|
-
for (const base of bases) {
|
|
149
|
-
try { copySiblings(base); } catch { /* phase 1 best-effort */ }
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
main();
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* @claude-flow/cli postinstall — agentdb compatibility patches.
|
|
4
|
+
*
|
|
5
|
+
* Two patches applied to the user's installed agentdb tree:
|
|
6
|
+
*
|
|
7
|
+
* 1. Sibling directory copy (#1721 fix): agentic-flow's runtime patch
|
|
8
|
+
* expects agentdb's controllers + utils + core + services + types
|
|
9
|
+
* at `dist/<name>/` (legacy v1.x layout). agentdb v3 ships at
|
|
10
|
+
* `dist/src/<name>/`. Copy each `dist/src/<name>/` subdir to
|
|
11
|
+
* `dist/<name>/` so the legacy import paths resolve. Skip dirs that
|
|
12
|
+
* already exist so this is idempotent.
|
|
13
|
+
*
|
|
14
|
+
* 2. Exports-field augmentation (ADR-095 G7): six controller files
|
|
15
|
+
* exist in agentdb's dist but are not declared in its package.json
|
|
16
|
+
* `exports` field — `AttestationLog`, `MutationGuard`,
|
|
17
|
+
* `GuardedVectorBackend`, `GNNService`, `RVFOptimizer`,
|
|
18
|
+
* `GraphAdapter`. Without these declared, Node's strict exports
|
|
19
|
+
* enforcement blocks subpath imports even when the file is on disk.
|
|
20
|
+
* We add the missing entries (only if the file actually exists)
|
|
21
|
+
* so consumers can reach them via `agentdb/controllers/...`.
|
|
22
|
+
*
|
|
23
|
+
* Both patches are best-effort — failure to apply does not break
|
|
24
|
+
* install (try/catch wraps each phase). Re-running is safe.
|
|
25
|
+
*/
|
|
26
|
+
|
|
27
|
+
'use strict';
|
|
28
|
+
|
|
29
|
+
const fs = require('node:fs');
|
|
30
|
+
const path = require('node:path');
|
|
31
|
+
|
|
32
|
+
function findAgentdbBase() {
|
|
33
|
+
try {
|
|
34
|
+
const r = require.resolve('agentdb');
|
|
35
|
+
if (r.includes('dist/src')) return path.join(path.dirname(r), '..', '..');
|
|
36
|
+
if (r.includes('dist')) return path.join(path.dirname(r), '..');
|
|
37
|
+
return path.dirname(r);
|
|
38
|
+
} catch { return null; }
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Find every agentdb installation reachable in the install's node_modules
|
|
43
|
+
* tree. Necessary because pnpm/npm hoisting can place multiple copies of
|
|
44
|
+
* agentdb (different versions) at different levels. Only patching the
|
|
45
|
+
* resolved one leaves consumer code that imports through a different
|
|
46
|
+
* resolution path with stale exports.
|
|
47
|
+
*
|
|
48
|
+
* Strategy: walk up from the postinstall script's directory, collect any
|
|
49
|
+
* `node_modules/agentdb` we find along the way + the .pnpm cached copies
|
|
50
|
+
* directly under the same node_modules/.pnpm/ root.
|
|
51
|
+
*/
|
|
52
|
+
function findAllAgentdbBases() {
|
|
53
|
+
const found = new Set();
|
|
54
|
+
let dir = __dirname;
|
|
55
|
+
for (let i = 0; i < 12; i++) {
|
|
56
|
+
const candidate = path.join(dir, 'node_modules', 'agentdb');
|
|
57
|
+
if (fs.existsSync(path.join(candidate, 'package.json'))) {
|
|
58
|
+
try { found.add(fs.realpathSync(candidate)); } catch { found.add(candidate); }
|
|
59
|
+
}
|
|
60
|
+
// Also check for .pnpm cache adjacent to this node_modules
|
|
61
|
+
const pnpmDir = path.join(dir, 'node_modules', '.pnpm');
|
|
62
|
+
if (fs.existsSync(pnpmDir)) {
|
|
63
|
+
try {
|
|
64
|
+
for (const e of fs.readdirSync(pnpmDir)) {
|
|
65
|
+
if (e.startsWith('agentdb@')) {
|
|
66
|
+
const adb = path.join(pnpmDir, e, 'node_modules', 'agentdb');
|
|
67
|
+
if (fs.existsSync(path.join(adb, 'package.json'))) {
|
|
68
|
+
try { found.add(fs.realpathSync(adb)); } catch { found.add(adb); }
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
} catch { /* ignore */ }
|
|
73
|
+
}
|
|
74
|
+
const parent = path.dirname(dir);
|
|
75
|
+
if (parent === dir) break;
|
|
76
|
+
dir = parent;
|
|
77
|
+
}
|
|
78
|
+
return Array.from(found);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
function copySiblings(base) {
|
|
82
|
+
const srcDist = path.join(base, 'dist', 'src');
|
|
83
|
+
if (!fs.existsSync(srcDist)) return;
|
|
84
|
+
for (const entry of fs.readdirSync(srcDist)) {
|
|
85
|
+
const src = path.join(srcDist, entry);
|
|
86
|
+
const target = path.join(base, 'dist', entry);
|
|
87
|
+
try {
|
|
88
|
+
if (fs.statSync(src).isDirectory() && !fs.existsSync(target)) {
|
|
89
|
+
fs.cpSync(src, target, { recursive: true });
|
|
90
|
+
}
|
|
91
|
+
} catch { /* best-effort */ }
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
function augmentExports(base) {
|
|
96
|
+
const pkgPath = path.join(base, 'package.json');
|
|
97
|
+
if (!fs.existsSync(pkgPath)) return;
|
|
98
|
+
let pkg;
|
|
99
|
+
try { pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf-8')); }
|
|
100
|
+
catch { return; }
|
|
101
|
+
if (!pkg.exports || typeof pkg.exports !== 'object') return;
|
|
102
|
+
|
|
103
|
+
// Subpath → relative file path (only added if both: (a) file exists, (b) export not already declared)
|
|
104
|
+
const additions = {
|
|
105
|
+
'./controllers/AttestationLog': './dist/src/security/AttestationLog.js',
|
|
106
|
+
'./controllers/MutationGuard': './dist/src/security/MutationGuard.js',
|
|
107
|
+
'./controllers/GuardedVectorBackend': './dist/src/backends/ruvector/GuardedVectorBackend.js',
|
|
108
|
+
// GNNService and RVFOptimizer live outside dist/src/controllers/ in
|
|
109
|
+
// current agentdb. Map to the actual paths so the export points at a
|
|
110
|
+
// real file. Future agentdb versions may move them — the file-exists
|
|
111
|
+
// guard below will skip cleanly if these paths drift.
|
|
112
|
+
'./controllers/GNNService': './dist/src/services/GNNService.js',
|
|
113
|
+
'./controllers/RVFOptimizer': './dist/src/optimizations/RVFOptimizer.js',
|
|
114
|
+
// GraphAdapter location varies; try the graph-node backend path. If
|
|
115
|
+
// missing, the file-exists guard skips it without error.
|
|
116
|
+
'./controllers/GraphAdapter': './dist/src/backends/graph-node/GraphAdapter.js',
|
|
117
|
+
// Also expose the security index so consumers can import the security namespace.
|
|
118
|
+
'./security/controllers': './dist/src/security/index.js',
|
|
119
|
+
};
|
|
120
|
+
|
|
121
|
+
let changed = false;
|
|
122
|
+
for (const [subpath, target] of Object.entries(additions)) {
|
|
123
|
+
if (pkg.exports[subpath]) continue;
|
|
124
|
+
const abs = path.join(base, target);
|
|
125
|
+
if (!fs.existsSync(abs)) continue;
|
|
126
|
+
pkg.exports[subpath] = target;
|
|
127
|
+
changed = true;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
if (changed) {
|
|
131
|
+
try {
|
|
132
|
+
fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + '\n', 'utf-8');
|
|
133
|
+
} catch { /* best-effort */ }
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
function main() {
|
|
138
|
+
// Patch every reachable agentdb instance, not just the first resolution
|
|
139
|
+
// result. pnpm/npm hoisting can leave multiple agentdb copies in the
|
|
140
|
+
// install tree, and consumers may import through any of them.
|
|
141
|
+
const bases = findAllAgentdbBases();
|
|
142
|
+
if (bases.length === 0) {
|
|
143
|
+
// Fall back to the single-base path so we still attempt something
|
|
144
|
+
// when the directory walk didn't find anything (e.g. unusual installs).
|
|
145
|
+
const base = findAgentdbBase();
|
|
146
|
+
if (base) bases.push(base);
|
|
147
|
+
}
|
|
148
|
+
for (const base of bases) {
|
|
149
|
+
try { copySiblings(base); } catch { /* phase 1 best-effort */ }
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
main();
|