@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
|
@@ -1,144 +1,144 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# Claude Flow V3 - DDD Progress Tracker Worker
|
|
3
|
-
# Tracks Domain-Driven Design implementation progress
|
|
4
|
-
|
|
5
|
-
set -euo pipefail
|
|
6
|
-
|
|
7
|
-
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
8
|
-
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
|
9
|
-
METRICS_DIR="$PROJECT_ROOT/.claude-flow/metrics"
|
|
10
|
-
DDD_FILE="$METRICS_DIR/ddd-progress.json"
|
|
11
|
-
V3_PROGRESS="$METRICS_DIR/v3-progress.json"
|
|
12
|
-
LAST_RUN_FILE="$METRICS_DIR/.ddd-last-run"
|
|
13
|
-
|
|
14
|
-
mkdir -p "$METRICS_DIR"
|
|
15
|
-
|
|
16
|
-
# V3 Target Domains
|
|
17
|
-
DOMAINS=("agent-lifecycle" "task-execution" "memory-management" "coordination" "shared-kernel")
|
|
18
|
-
|
|
19
|
-
should_run() {
|
|
20
|
-
if [ ! -f "$LAST_RUN_FILE" ]; then return 0; fi
|
|
21
|
-
local last_run=$(cat "$LAST_RUN_FILE" 2>/dev/null || echo "0")
|
|
22
|
-
local now=$(date +%s)
|
|
23
|
-
[ $((now - last_run)) -ge 600 ] # 10 minutes
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
check_domain() {
|
|
27
|
-
local domain="$1"
|
|
28
|
-
local domain_path="$PROJECT_ROOT/v3/@claude-flow/$domain"
|
|
29
|
-
local alt_path="$PROJECT_ROOT/src/domains/$domain"
|
|
30
|
-
|
|
31
|
-
local score=0
|
|
32
|
-
local max_score=100
|
|
33
|
-
|
|
34
|
-
# Check if domain directory exists (20 points)
|
|
35
|
-
if [ -d "$domain_path" ] || [ -d "$alt_path" ]; then
|
|
36
|
-
score=$((score + 20))
|
|
37
|
-
local path="${domain_path:-$alt_path}"
|
|
38
|
-
[ -d "$domain_path" ] && path="$domain_path" || path="$alt_path"
|
|
39
|
-
|
|
40
|
-
# Check for domain layer (15 points)
|
|
41
|
-
[ -d "$path/domain" ] || [ -d "$path/src/domain" ] && score=$((score + 15))
|
|
42
|
-
|
|
43
|
-
# Check for application layer (15 points)
|
|
44
|
-
[ -d "$path/application" ] || [ -d "$path/src/application" ] && score=$((score + 15))
|
|
45
|
-
|
|
46
|
-
# Check for infrastructure layer (15 points)
|
|
47
|
-
[ -d "$path/infrastructure" ] || [ -d "$path/src/infrastructure" ] && score=$((score + 15))
|
|
48
|
-
|
|
49
|
-
# Check for API/interface layer (10 points)
|
|
50
|
-
[ -d "$path/api" ] || [ -d "$path/src/api" ] && score=$((score + 10))
|
|
51
|
-
|
|
52
|
-
# Check for tests (15 points)
|
|
53
|
-
local test_count=$(find "$path" -name "*.test.ts" -o -name "*.spec.ts" 2>/dev/null | wc -l)
|
|
54
|
-
[ "$test_count" -gt 0 ] && score=$((score + 15))
|
|
55
|
-
|
|
56
|
-
# Check for index/exports (10 points)
|
|
57
|
-
[ -f "$path/index.ts" ] || [ -f "$path/src/index.ts" ] && score=$((score + 10))
|
|
58
|
-
fi
|
|
59
|
-
|
|
60
|
-
echo "$score"
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
count_entities() {
|
|
64
|
-
local type="$1"
|
|
65
|
-
local pattern="$2"
|
|
66
|
-
|
|
67
|
-
find "$PROJECT_ROOT/v3" "$PROJECT_ROOT/src" -name "*.ts" 2>/dev/null | \
|
|
68
|
-
xargs grep -l "$pattern" 2>/dev/null | \
|
|
69
|
-
grep -v node_modules | grep -v ".test." | wc -l || echo "0"
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
track_ddd() {
|
|
73
|
-
echo "[$(date +%H:%M:%S)] Tracking DDD progress..."
|
|
74
|
-
|
|
75
|
-
local total_score=0
|
|
76
|
-
local domain_scores=""
|
|
77
|
-
local completed_domains=0
|
|
78
|
-
|
|
79
|
-
for domain in "${DOMAINS[@]}"; do
|
|
80
|
-
local score=$(check_domain "$domain")
|
|
81
|
-
total_score=$((total_score + score))
|
|
82
|
-
domain_scores="$domain_scores\"$domain\": $score, "
|
|
83
|
-
|
|
84
|
-
[ "$score" -ge 50 ] && completed_domains=$((completed_domains + 1))
|
|
85
|
-
done
|
|
86
|
-
|
|
87
|
-
# Calculate overall progress
|
|
88
|
-
local max_total=$((${#DOMAINS[@]} * 100))
|
|
89
|
-
local progress=$((total_score * 100 / max_total))
|
|
90
|
-
|
|
91
|
-
# Count DDD artifacts
|
|
92
|
-
local entities=$(count_entities "entities" "class.*Entity\|interface.*Entity")
|
|
93
|
-
local value_objects=$(count_entities "value-objects" "class.*VO\|ValueObject")
|
|
94
|
-
local aggregates=$(count_entities "aggregates" "class.*Aggregate\|AggregateRoot")
|
|
95
|
-
local repositories=$(count_entities "repositories" "interface.*Repository\|Repository")
|
|
96
|
-
local services=$(count_entities "services" "class.*Service\|Service")
|
|
97
|
-
local events=$(count_entities "events" "class.*Event\|DomainEvent")
|
|
98
|
-
|
|
99
|
-
# Write DDD metrics
|
|
100
|
-
cat > "$DDD_FILE" << EOF
|
|
101
|
-
{
|
|
102
|
-
"timestamp": "$(date -Iseconds)",
|
|
103
|
-
"progress": $progress,
|
|
104
|
-
"domains": {
|
|
105
|
-
${domain_scores%,*}
|
|
106
|
-
},
|
|
107
|
-
"completed": $completed_domains,
|
|
108
|
-
"total": ${#DOMAINS[@]},
|
|
109
|
-
"artifacts": {
|
|
110
|
-
"entities": $entities,
|
|
111
|
-
"valueObjects": $value_objects,
|
|
112
|
-
"aggregates": $aggregates,
|
|
113
|
-
"repositories": $repositories,
|
|
114
|
-
"services": $services,
|
|
115
|
-
"domainEvents": $events
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
EOF
|
|
119
|
-
|
|
120
|
-
# Update v3-progress.json
|
|
121
|
-
if [ -f "$V3_PROGRESS" ] && command -v jq &>/dev/null; then
|
|
122
|
-
jq --argjson progress "$progress" --argjson completed "$completed_domains" \
|
|
123
|
-
'.ddd.progress = $progress | .domains.completed = $completed' \
|
|
124
|
-
"$V3_PROGRESS" > "$V3_PROGRESS.tmp" && mv "$V3_PROGRESS.tmp" "$V3_PROGRESS"
|
|
125
|
-
fi
|
|
126
|
-
|
|
127
|
-
echo "[$(date +%H:%M:%S)] ✓ DDD: ${progress}% | Domains: $completed_domains/${#DOMAINS[@]} | Entities: $entities | Services: $services"
|
|
128
|
-
|
|
129
|
-
date +%s > "$LAST_RUN_FILE"
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
case "${1:-check}" in
|
|
133
|
-
"run"|"track") track_ddd ;;
|
|
134
|
-
"check") should_run && track_ddd || echo "[$(date +%H:%M:%S)] Skipping (throttled)" ;;
|
|
135
|
-
"force") rm -f "$LAST_RUN_FILE"; track_ddd ;;
|
|
136
|
-
"status")
|
|
137
|
-
if [ -f "$DDD_FILE" ]; then
|
|
138
|
-
jq -r '"Progress: \(.progress)% | Domains: \(.completed)/\(.total) | Entities: \(.artifacts.entities) | Services: \(.artifacts.services)"' "$DDD_FILE"
|
|
139
|
-
else
|
|
140
|
-
echo "No DDD data available"
|
|
141
|
-
fi
|
|
142
|
-
;;
|
|
143
|
-
*) echo "Usage: $0 [run|check|force|status]" ;;
|
|
144
|
-
esac
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Claude Flow V3 - DDD Progress Tracker Worker
|
|
3
|
+
# Tracks Domain-Driven Design implementation progress
|
|
4
|
+
|
|
5
|
+
set -euo pipefail
|
|
6
|
+
|
|
7
|
+
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
8
|
+
PROJECT_ROOT="$(cd "$SCRIPT_DIR/../.." && pwd)"
|
|
9
|
+
METRICS_DIR="$PROJECT_ROOT/.claude-flow/metrics"
|
|
10
|
+
DDD_FILE="$METRICS_DIR/ddd-progress.json"
|
|
11
|
+
V3_PROGRESS="$METRICS_DIR/v3-progress.json"
|
|
12
|
+
LAST_RUN_FILE="$METRICS_DIR/.ddd-last-run"
|
|
13
|
+
|
|
14
|
+
mkdir -p "$METRICS_DIR"
|
|
15
|
+
|
|
16
|
+
# V3 Target Domains
|
|
17
|
+
DOMAINS=("agent-lifecycle" "task-execution" "memory-management" "coordination" "shared-kernel")
|
|
18
|
+
|
|
19
|
+
should_run() {
|
|
20
|
+
if [ ! -f "$LAST_RUN_FILE" ]; then return 0; fi
|
|
21
|
+
local last_run=$(cat "$LAST_RUN_FILE" 2>/dev/null || echo "0")
|
|
22
|
+
local now=$(date +%s)
|
|
23
|
+
[ $((now - last_run)) -ge 600 ] # 10 minutes
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
check_domain() {
|
|
27
|
+
local domain="$1"
|
|
28
|
+
local domain_path="$PROJECT_ROOT/v3/@claude-flow/$domain"
|
|
29
|
+
local alt_path="$PROJECT_ROOT/src/domains/$domain"
|
|
30
|
+
|
|
31
|
+
local score=0
|
|
32
|
+
local max_score=100
|
|
33
|
+
|
|
34
|
+
# Check if domain directory exists (20 points)
|
|
35
|
+
if [ -d "$domain_path" ] || [ -d "$alt_path" ]; then
|
|
36
|
+
score=$((score + 20))
|
|
37
|
+
local path="${domain_path:-$alt_path}"
|
|
38
|
+
[ -d "$domain_path" ] && path="$domain_path" || path="$alt_path"
|
|
39
|
+
|
|
40
|
+
# Check for domain layer (15 points)
|
|
41
|
+
[ -d "$path/domain" ] || [ -d "$path/src/domain" ] && score=$((score + 15))
|
|
42
|
+
|
|
43
|
+
# Check for application layer (15 points)
|
|
44
|
+
[ -d "$path/application" ] || [ -d "$path/src/application" ] && score=$((score + 15))
|
|
45
|
+
|
|
46
|
+
# Check for infrastructure layer (15 points)
|
|
47
|
+
[ -d "$path/infrastructure" ] || [ -d "$path/src/infrastructure" ] && score=$((score + 15))
|
|
48
|
+
|
|
49
|
+
# Check for API/interface layer (10 points)
|
|
50
|
+
[ -d "$path/api" ] || [ -d "$path/src/api" ] && score=$((score + 10))
|
|
51
|
+
|
|
52
|
+
# Check for tests (15 points)
|
|
53
|
+
local test_count=$(find "$path" -name "*.test.ts" -o -name "*.spec.ts" 2>/dev/null | wc -l)
|
|
54
|
+
[ "$test_count" -gt 0 ] && score=$((score + 15))
|
|
55
|
+
|
|
56
|
+
# Check for index/exports (10 points)
|
|
57
|
+
[ -f "$path/index.ts" ] || [ -f "$path/src/index.ts" ] && score=$((score + 10))
|
|
58
|
+
fi
|
|
59
|
+
|
|
60
|
+
echo "$score"
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
count_entities() {
|
|
64
|
+
local type="$1"
|
|
65
|
+
local pattern="$2"
|
|
66
|
+
|
|
67
|
+
find "$PROJECT_ROOT/v3" "$PROJECT_ROOT/src" -name "*.ts" 2>/dev/null | \
|
|
68
|
+
xargs grep -l "$pattern" 2>/dev/null | \
|
|
69
|
+
grep -v node_modules | grep -v ".test." | wc -l || echo "0"
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
track_ddd() {
|
|
73
|
+
echo "[$(date +%H:%M:%S)] Tracking DDD progress..."
|
|
74
|
+
|
|
75
|
+
local total_score=0
|
|
76
|
+
local domain_scores=""
|
|
77
|
+
local completed_domains=0
|
|
78
|
+
|
|
79
|
+
for domain in "${DOMAINS[@]}"; do
|
|
80
|
+
local score=$(check_domain "$domain")
|
|
81
|
+
total_score=$((total_score + score))
|
|
82
|
+
domain_scores="$domain_scores\"$domain\": $score, "
|
|
83
|
+
|
|
84
|
+
[ "$score" -ge 50 ] && completed_domains=$((completed_domains + 1))
|
|
85
|
+
done
|
|
86
|
+
|
|
87
|
+
# Calculate overall progress
|
|
88
|
+
local max_total=$((${#DOMAINS[@]} * 100))
|
|
89
|
+
local progress=$((total_score * 100 / max_total))
|
|
90
|
+
|
|
91
|
+
# Count DDD artifacts
|
|
92
|
+
local entities=$(count_entities "entities" "class.*Entity\|interface.*Entity")
|
|
93
|
+
local value_objects=$(count_entities "value-objects" "class.*VO\|ValueObject")
|
|
94
|
+
local aggregates=$(count_entities "aggregates" "class.*Aggregate\|AggregateRoot")
|
|
95
|
+
local repositories=$(count_entities "repositories" "interface.*Repository\|Repository")
|
|
96
|
+
local services=$(count_entities "services" "class.*Service\|Service")
|
|
97
|
+
local events=$(count_entities "events" "class.*Event\|DomainEvent")
|
|
98
|
+
|
|
99
|
+
# Write DDD metrics
|
|
100
|
+
cat > "$DDD_FILE" << EOF
|
|
101
|
+
{
|
|
102
|
+
"timestamp": "$(date -Iseconds)",
|
|
103
|
+
"progress": $progress,
|
|
104
|
+
"domains": {
|
|
105
|
+
${domain_scores%,*}
|
|
106
|
+
},
|
|
107
|
+
"completed": $completed_domains,
|
|
108
|
+
"total": ${#DOMAINS[@]},
|
|
109
|
+
"artifacts": {
|
|
110
|
+
"entities": $entities,
|
|
111
|
+
"valueObjects": $value_objects,
|
|
112
|
+
"aggregates": $aggregates,
|
|
113
|
+
"repositories": $repositories,
|
|
114
|
+
"services": $services,
|
|
115
|
+
"domainEvents": $events
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
EOF
|
|
119
|
+
|
|
120
|
+
# Update v3-progress.json
|
|
121
|
+
if [ -f "$V3_PROGRESS" ] && command -v jq &>/dev/null; then
|
|
122
|
+
jq --argjson progress "$progress" --argjson completed "$completed_domains" \
|
|
123
|
+
'.ddd.progress = $progress | .domains.completed = $completed' \
|
|
124
|
+
"$V3_PROGRESS" > "$V3_PROGRESS.tmp" && mv "$V3_PROGRESS.tmp" "$V3_PROGRESS"
|
|
125
|
+
fi
|
|
126
|
+
|
|
127
|
+
echo "[$(date +%H:%M:%S)] ✓ DDD: ${progress}% | Domains: $completed_domains/${#DOMAINS[@]} | Entities: $entities | Services: $services"
|
|
128
|
+
|
|
129
|
+
date +%s > "$LAST_RUN_FILE"
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
case "${1:-check}" in
|
|
133
|
+
"run"|"track") track_ddd ;;
|
|
134
|
+
"check") should_run && track_ddd || echo "[$(date +%H:%M:%S)] Skipping (throttled)" ;;
|
|
135
|
+
"force") rm -f "$LAST_RUN_FILE"; track_ddd ;;
|
|
136
|
+
"status")
|
|
137
|
+
if [ -f "$DDD_FILE" ]; then
|
|
138
|
+
jq -r '"Progress: \(.progress)% | Domains: \(.completed)/\(.total) | Entities: \(.artifacts.entities) | Services: \(.artifacts.services)"' "$DDD_FILE"
|
|
139
|
+
else
|
|
140
|
+
echo "No DDD data available"
|
|
141
|
+
fi
|
|
142
|
+
;;
|
|
143
|
+
*) echo "Usage: $0 [run|check|force|status]" ;;
|
|
144
|
+
esac
|
|
@@ -1,121 +1,121 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Safe GitHub CLI Helper
|
|
5
|
-
*
|
|
6
|
-
* Prevents two classes of issue when calling `gh`:
|
|
7
|
-
* 1. Timeout / shell-quoting bugs when issue/PR bodies contain backticks,
|
|
8
|
-
* `$(...)`, or other special characters — bodies go through a temp file
|
|
9
|
-
* via `--body-file` instead of being inlined in the command line.
|
|
10
|
-
* 2. Command injection (audit_1776853149979 finding) — args were
|
|
11
|
-
* previously concatenated into a shell string and passed to
|
|
12
|
-
* `execSync`, so a caller passing `; rm -rf …` would have it
|
|
13
|
-
* executed by /bin/sh. Now uses `execFileSync('gh', argArray)`
|
|
14
|
-
* which goes through execve directly with no shell interpretation.
|
|
15
|
-
*
|
|
16
|
-
* Usage:
|
|
17
|
-
* ./github-safe.js issue comment 123 "Message with `backticks`"
|
|
18
|
-
* ./github-safe.js pr create --title "Title" --body "Complex body"
|
|
19
|
-
*/
|
|
20
|
-
|
|
21
|
-
import { execFileSync } from 'child_process';
|
|
22
|
-
import { writeFileSync, unlinkSync } from 'fs';
|
|
23
|
-
import { tmpdir } from 'os';
|
|
24
|
-
import { join } from 'path';
|
|
25
|
-
import { randomBytes } from 'crypto';
|
|
26
|
-
|
|
27
|
-
const args = process.argv.slice(2);
|
|
28
|
-
|
|
29
|
-
if (args.length < 2) {
|
|
30
|
-
console.log(`
|
|
31
|
-
Safe GitHub CLI Helper
|
|
32
|
-
|
|
33
|
-
Usage:
|
|
34
|
-
./github-safe.js issue comment <number> <body>
|
|
35
|
-
./github-safe.js pr comment <number> <body>
|
|
36
|
-
./github-safe.js issue create --title <title> --body <body>
|
|
37
|
-
./github-safe.js pr create --title <title> --body <body>
|
|
38
|
-
|
|
39
|
-
Bodies with backticks, command substitution, and other special shell
|
|
40
|
-
characters are routed through a tempfile via --body-file. All gh args
|
|
41
|
-
are passed via execFileSync (no shell interpretation).
|
|
42
|
-
`);
|
|
43
|
-
process.exit(1);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
// Whitelist of gh top-level commands we forward. Restricting this is
|
|
47
|
-
// defense-in-depth even though execFileSync would already block shell
|
|
48
|
-
// metacharacters in args.
|
|
49
|
-
const ALLOWED_COMMANDS = new Set(['issue', 'pr', 'repo', 'api', 'workflow', 'run', 'release', 'auth', 'gist']);
|
|
50
|
-
|
|
51
|
-
const [command, subcommand, ...restArgs] = args;
|
|
52
|
-
|
|
53
|
-
if (!ALLOWED_COMMANDS.has(command)) {
|
|
54
|
-
console.error(`Refusing to forward unknown gh command: ${command}`);
|
|
55
|
-
console.error(`Allowed: ${Array.from(ALLOWED_COMMANDS).join(', ')}`);
|
|
56
|
-
process.exit(1);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
// Build the final argv that gets passed to execFileSync.
|
|
60
|
-
// IMPORTANT: never join into a shell string. Each element is one argv slot.
|
|
61
|
-
function runGh(argv) {
|
|
62
|
-
try {
|
|
63
|
-
execFileSync('gh', argv, {
|
|
64
|
-
stdio: 'inherit',
|
|
65
|
-
timeout: 30000,
|
|
66
|
-
// shell:false is the default — kept explicit so a future refactor
|
|
67
|
-
// doesn't accidentally turn it on.
|
|
68
|
-
shell: false,
|
|
69
|
-
});
|
|
70
|
-
} catch (error) {
|
|
71
|
-
console.error('Error:', error?.message ?? String(error));
|
|
72
|
-
process.exit(1);
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
// Handle commands that take body content
|
|
77
|
-
if ((command === 'issue' || command === 'pr') &&
|
|
78
|
-
(subcommand === 'comment' || subcommand === 'create')) {
|
|
79
|
-
|
|
80
|
-
let bodyIndex = -1;
|
|
81
|
-
let body = '';
|
|
82
|
-
|
|
83
|
-
if (subcommand === 'comment' && restArgs.length >= 2) {
|
|
84
|
-
// Positional: github-safe.js issue comment 123 "body"
|
|
85
|
-
body = restArgs[1];
|
|
86
|
-
bodyIndex = 1;
|
|
87
|
-
} else {
|
|
88
|
-
bodyIndex = restArgs.indexOf('--body');
|
|
89
|
-
if (bodyIndex !== -1 && bodyIndex < restArgs.length - 1) {
|
|
90
|
-
body = restArgs[bodyIndex + 1];
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
if (body) {
|
|
95
|
-
const tmpFile = join(tmpdir(), `gh-body-${randomBytes(8).toString('hex')}.tmp`);
|
|
96
|
-
try {
|
|
97
|
-
writeFileSync(tmpFile, body, 'utf8');
|
|
98
|
-
|
|
99
|
-
// Build the gh argv with --body-file instead of --body / inline body
|
|
100
|
-
const finalArgs = [command, subcommand, ...restArgs];
|
|
101
|
-
const offset = 2; // command + subcommand
|
|
102
|
-
if (subcommand === 'comment' && bodyIndex === 1) {
|
|
103
|
-
finalArgs[offset + 1] = '--body-file';
|
|
104
|
-
finalArgs.push(tmpFile);
|
|
105
|
-
} else if (bodyIndex !== -1) {
|
|
106
|
-
finalArgs[offset + bodyIndex] = '--body-file';
|
|
107
|
-
finalArgs[offset + bodyIndex + 1] = tmpFile;
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
runGh(finalArgs);
|
|
111
|
-
} finally {
|
|
112
|
-
try { unlinkSync(tmpFile); } catch { /* ignore cleanup errors */ }
|
|
113
|
-
}
|
|
114
|
-
} else {
|
|
115
|
-
// No body — forward all args as-is (still via execFileSync)
|
|
116
|
-
runGh(args);
|
|
117
|
-
}
|
|
118
|
-
} else {
|
|
119
|
-
// Other gh subcommands — forward as-is
|
|
120
|
-
runGh(args);
|
|
121
|
-
}
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Safe GitHub CLI Helper
|
|
5
|
+
*
|
|
6
|
+
* Prevents two classes of issue when calling `gh`:
|
|
7
|
+
* 1. Timeout / shell-quoting bugs when issue/PR bodies contain backticks,
|
|
8
|
+
* `$(...)`, or other special characters — bodies go through a temp file
|
|
9
|
+
* via `--body-file` instead of being inlined in the command line.
|
|
10
|
+
* 2. Command injection (audit_1776853149979 finding) — args were
|
|
11
|
+
* previously concatenated into a shell string and passed to
|
|
12
|
+
* `execSync`, so a caller passing `; rm -rf …` would have it
|
|
13
|
+
* executed by /bin/sh. Now uses `execFileSync('gh', argArray)`
|
|
14
|
+
* which goes through execve directly with no shell interpretation.
|
|
15
|
+
*
|
|
16
|
+
* Usage:
|
|
17
|
+
* ./github-safe.js issue comment 123 "Message with `backticks`"
|
|
18
|
+
* ./github-safe.js pr create --title "Title" --body "Complex body"
|
|
19
|
+
*/
|
|
20
|
+
|
|
21
|
+
import { execFileSync } from 'child_process';
|
|
22
|
+
import { writeFileSync, unlinkSync } from 'fs';
|
|
23
|
+
import { tmpdir } from 'os';
|
|
24
|
+
import { join } from 'path';
|
|
25
|
+
import { randomBytes } from 'crypto';
|
|
26
|
+
|
|
27
|
+
const args = process.argv.slice(2);
|
|
28
|
+
|
|
29
|
+
if (args.length < 2) {
|
|
30
|
+
console.log(`
|
|
31
|
+
Safe GitHub CLI Helper
|
|
32
|
+
|
|
33
|
+
Usage:
|
|
34
|
+
./github-safe.js issue comment <number> <body>
|
|
35
|
+
./github-safe.js pr comment <number> <body>
|
|
36
|
+
./github-safe.js issue create --title <title> --body <body>
|
|
37
|
+
./github-safe.js pr create --title <title> --body <body>
|
|
38
|
+
|
|
39
|
+
Bodies with backticks, command substitution, and other special shell
|
|
40
|
+
characters are routed through a tempfile via --body-file. All gh args
|
|
41
|
+
are passed via execFileSync (no shell interpretation).
|
|
42
|
+
`);
|
|
43
|
+
process.exit(1);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
// Whitelist of gh top-level commands we forward. Restricting this is
|
|
47
|
+
// defense-in-depth even though execFileSync would already block shell
|
|
48
|
+
// metacharacters in args.
|
|
49
|
+
const ALLOWED_COMMANDS = new Set(['issue', 'pr', 'repo', 'api', 'workflow', 'run', 'release', 'auth', 'gist']);
|
|
50
|
+
|
|
51
|
+
const [command, subcommand, ...restArgs] = args;
|
|
52
|
+
|
|
53
|
+
if (!ALLOWED_COMMANDS.has(command)) {
|
|
54
|
+
console.error(`Refusing to forward unknown gh command: ${command}`);
|
|
55
|
+
console.error(`Allowed: ${Array.from(ALLOWED_COMMANDS).join(', ')}`);
|
|
56
|
+
process.exit(1);
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
// Build the final argv that gets passed to execFileSync.
|
|
60
|
+
// IMPORTANT: never join into a shell string. Each element is one argv slot.
|
|
61
|
+
function runGh(argv) {
|
|
62
|
+
try {
|
|
63
|
+
execFileSync('gh', argv, {
|
|
64
|
+
stdio: 'inherit',
|
|
65
|
+
timeout: 30000,
|
|
66
|
+
// shell:false is the default — kept explicit so a future refactor
|
|
67
|
+
// doesn't accidentally turn it on.
|
|
68
|
+
shell: false,
|
|
69
|
+
});
|
|
70
|
+
} catch (error) {
|
|
71
|
+
console.error('Error:', error?.message ?? String(error));
|
|
72
|
+
process.exit(1);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// Handle commands that take body content
|
|
77
|
+
if ((command === 'issue' || command === 'pr') &&
|
|
78
|
+
(subcommand === 'comment' || subcommand === 'create')) {
|
|
79
|
+
|
|
80
|
+
let bodyIndex = -1;
|
|
81
|
+
let body = '';
|
|
82
|
+
|
|
83
|
+
if (subcommand === 'comment' && restArgs.length >= 2) {
|
|
84
|
+
// Positional: github-safe.js issue comment 123 "body"
|
|
85
|
+
body = restArgs[1];
|
|
86
|
+
bodyIndex = 1;
|
|
87
|
+
} else {
|
|
88
|
+
bodyIndex = restArgs.indexOf('--body');
|
|
89
|
+
if (bodyIndex !== -1 && bodyIndex < restArgs.length - 1) {
|
|
90
|
+
body = restArgs[bodyIndex + 1];
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
if (body) {
|
|
95
|
+
const tmpFile = join(tmpdir(), `gh-body-${randomBytes(8).toString('hex')}.tmp`);
|
|
96
|
+
try {
|
|
97
|
+
writeFileSync(tmpFile, body, 'utf8');
|
|
98
|
+
|
|
99
|
+
// Build the gh argv with --body-file instead of --body / inline body
|
|
100
|
+
const finalArgs = [command, subcommand, ...restArgs];
|
|
101
|
+
const offset = 2; // command + subcommand
|
|
102
|
+
if (subcommand === 'comment' && bodyIndex === 1) {
|
|
103
|
+
finalArgs[offset + 1] = '--body-file';
|
|
104
|
+
finalArgs.push(tmpFile);
|
|
105
|
+
} else if (bodyIndex !== -1) {
|
|
106
|
+
finalArgs[offset + bodyIndex] = '--body-file';
|
|
107
|
+
finalArgs[offset + bodyIndex + 1] = tmpFile;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
runGh(finalArgs);
|
|
111
|
+
} finally {
|
|
112
|
+
try { unlinkSync(tmpFile); } catch { /* ignore cleanup errors */ }
|
|
113
|
+
}
|
|
114
|
+
} else {
|
|
115
|
+
// No body — forward all args as-is (still via execFileSync)
|
|
116
|
+
runGh(args);
|
|
117
|
+
}
|
|
118
|
+
} else {
|
|
119
|
+
// Other gh subcommands — forward as-is
|
|
120
|
+
runGh(args);
|
|
121
|
+
}
|
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# Setup GitHub integration for Claude Flow
|
|
3
|
-
|
|
4
|
-
echo "🔗 Setting up GitHub integration..."
|
|
5
|
-
|
|
6
|
-
# Check for gh CLI
|
|
7
|
-
if ! command -v gh &> /dev/null; then
|
|
8
|
-
echo "⚠️ GitHub CLI (gh) not found"
|
|
9
|
-
echo "Install from: https://cli.github.com/"
|
|
10
|
-
echo "Continuing without GitHub features..."
|
|
11
|
-
else
|
|
12
|
-
echo "✅ GitHub CLI found"
|
|
13
|
-
|
|
14
|
-
# Check auth status
|
|
15
|
-
if gh auth status &> /dev/null; then
|
|
16
|
-
echo "✅ GitHub authentication active"
|
|
17
|
-
else
|
|
18
|
-
echo "⚠️ Not authenticated with GitHub"
|
|
19
|
-
echo "Run: gh auth login"
|
|
20
|
-
fi
|
|
21
|
-
fi
|
|
22
|
-
|
|
23
|
-
echo ""
|
|
24
|
-
echo "📦 GitHub swarm commands available:"
|
|
25
|
-
echo " - npx claude-flow github swarm"
|
|
26
|
-
echo " - npx claude-flow repo analyze"
|
|
27
|
-
echo " - npx claude-flow pr enhance"
|
|
28
|
-
echo " - npx claude-flow issue triage"
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Setup GitHub integration for Claude Flow
|
|
3
|
+
|
|
4
|
+
echo "🔗 Setting up GitHub integration..."
|
|
5
|
+
|
|
6
|
+
# Check for gh CLI
|
|
7
|
+
if ! command -v gh &> /dev/null; then
|
|
8
|
+
echo "⚠️ GitHub CLI (gh) not found"
|
|
9
|
+
echo "Install from: https://cli.github.com/"
|
|
10
|
+
echo "Continuing without GitHub features..."
|
|
11
|
+
else
|
|
12
|
+
echo "✅ GitHub CLI found"
|
|
13
|
+
|
|
14
|
+
# Check auth status
|
|
15
|
+
if gh auth status &> /dev/null; then
|
|
16
|
+
echo "✅ GitHub authentication active"
|
|
17
|
+
else
|
|
18
|
+
echo "⚠️ Not authenticated with GitHub"
|
|
19
|
+
echo "Run: gh auth login"
|
|
20
|
+
fi
|
|
21
|
+
fi
|
|
22
|
+
|
|
23
|
+
echo ""
|
|
24
|
+
echo "📦 GitHub swarm commands available:"
|
|
25
|
+
echo " - npx claude-flow github swarm"
|
|
26
|
+
echo " - npx claude-flow repo analyze"
|
|
27
|
+
echo " - npx claude-flow pr enhance"
|
|
28
|
+
echo " - npx claude-flow issue triage"
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# Capture hook guidance for Claude visibility
|
|
3
|
-
GUIDANCE_FILE=".claude-flow/last-guidance.txt"
|
|
4
|
-
mkdir -p .claude-flow
|
|
5
|
-
|
|
6
|
-
case "$1" in
|
|
7
|
-
"route")
|
|
8
|
-
npx agentic-flow@alpha hooks route "$2" 2>&1 | tee "$GUIDANCE_FILE"
|
|
9
|
-
;;
|
|
10
|
-
"pre-edit")
|
|
11
|
-
npx agentic-flow@alpha hooks pre-edit "$2" 2>&1 | tee "$GUIDANCE_FILE"
|
|
12
|
-
;;
|
|
13
|
-
esac
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
# Capture hook guidance for Claude visibility
|
|
3
|
+
GUIDANCE_FILE=".claude-flow/last-guidance.txt"
|
|
4
|
+
mkdir -p .claude-flow
|
|
5
|
+
|
|
6
|
+
case "$1" in
|
|
7
|
+
"route")
|
|
8
|
+
npx agentic-flow@alpha hooks route "$2" 2>&1 | tee "$GUIDANCE_FILE"
|
|
9
|
+
;;
|
|
10
|
+
"pre-edit")
|
|
11
|
+
npx agentic-flow@alpha hooks pre-edit "$2" 2>&1 | tee "$GUIDANCE_FILE"
|
|
12
|
+
;;
|
|
13
|
+
esac
|