odd-flow 1.0.0
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/MIGRATION_SUMMARY.md +222 -0
- package/.claude/agents/analysis/analyze-code-quality.md +58 -0
- package/.claude/agents/analysis/code-analyzer.md +189 -0
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +58 -0
- package/.claude/agents/architecture/system-design/arch-system-design.md +36 -0
- package/.claude/agents/base-template-generator.md +41 -0
- package/.claude/agents/consensus/byzantine-coordinator.md +43 -0
- package/.claude/agents/consensus/crdt-synchronizer.md +977 -0
- package/.claude/agents/consensus/gossip-coordinator.md +43 -0
- package/.claude/agents/consensus/performance-benchmarker.md +831 -0
- package/.claude/agents/consensus/quorum-manager.md +803 -0
- package/.claude/agents/consensus/raft-manager.md +43 -0
- package/.claude/agents/consensus/security-manager.md +602 -0
- package/.claude/agents/core/coder.md +244 -0
- package/.claude/agents/core/planner.md +152 -0
- package/.claude/agents/core/researcher.md +174 -0
- package/.claude/agents/core/reviewer.md +309 -0
- package/.claude/agents/core/tester.md +300 -0
- package/.claude/agents/custom/test-long-runner.md +43 -0
- package/.claude/agents/data/ml/data-ml-model.md +76 -0
- package/.claude/agents/database-specialist.md +9 -0
- package/.claude/agents/development/backend/dev-backend-api.md +29 -0
- package/.claude/agents/development/dev-backend-api.md +178 -0
- package/.claude/agents/devops/ci-cd/ops-cicd-github.md +52 -0
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +63 -0
- package/.claude/agents/dual-mode/codex-coordinator.md +201 -0
- package/.claude/agents/dual-mode/codex-worker.md +183 -0
- package/.claude/agents/dual-mode/dual-orchestrator.md +253 -0
- package/.claude/agents/flow-nexus/app-store.md +88 -0
- package/.claude/agents/flow-nexus/authentication.md +69 -0
- package/.claude/agents/flow-nexus/challenges.md +81 -0
- package/.claude/agents/flow-nexus/neural-network.md +88 -0
- package/.claude/agents/flow-nexus/payments.md +83 -0
- package/.claude/agents/flow-nexus/sandbox.md +76 -0
- package/.claude/agents/flow-nexus/swarm.md +76 -0
- package/.claude/agents/flow-nexus/user-tools.md +96 -0
- package/.claude/agents/flow-nexus/workflow.md +84 -0
- package/.claude/agents/github/code-review-swarm.md +521 -0
- package/.claude/agents/github/github-modes.md +154 -0
- package/.claude/agents/github/issue-tracker.md +299 -0
- package/.claude/agents/github/multi-repo-swarm.md +525 -0
- package/.claude/agents/github/pr-manager.md +163 -0
- package/.claude/agents/github/project-board-sync.md +478 -0
- package/.claude/agents/github/release-manager.md +336 -0
- package/.claude/agents/github/release-swarm.md +551 -0
- package/.claude/agents/github/repo-architect.md +365 -0
- package/.claude/agents/github/swarm-issue.md +548 -0
- package/.claude/agents/github/swarm-pr.md +399 -0
- package/.claude/agents/github/sync-coordinator.md +423 -0
- package/.claude/agents/github/workflow-automation.md +605 -0
- package/.claude/agents/goal/agent.md +817 -0
- package/.claude/agents/goal/code-goal-planner.md +445 -0
- package/.claude/agents/goal/goal-planner.md +168 -0
- package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +129 -0
- package/.claude/agents/hive-mind/queen-coordinator.md +202 -0
- package/.claude/agents/hive-mind/scout-explorer.md +241 -0
- package/.claude/agents/hive-mind/swarm-memory-manager.md +192 -0
- package/.claude/agents/hive-mind/worker-specialist.md +216 -0
- package/.claude/agents/neural/safla-neural.md +74 -0
- package/.claude/agents/optimization/benchmark-suite.md +663 -0
- package/.claude/agents/optimization/load-balancer.md +429 -0
- package/.claude/agents/optimization/performance-monitor.md +670 -0
- package/.claude/agents/optimization/resource-allocator.md +672 -0
- package/.claude/agents/optimization/topology-optimizer.md +806 -0
- package/.claude/agents/payments/agentic-payments.md +126 -0
- package/.claude/agents/project-coordinator.md +8 -0
- package/.claude/agents/python-specialist.md +9 -0
- package/.claude/agents/reasoning/agent.md +817 -0
- package/.claude/agents/reasoning/goal-planner.md +73 -0
- package/.claude/agents/security-auditor.md +9 -0
- package/.claude/agents/sona/sona-learning-optimizer.md +65 -0
- package/.claude/agents/sparc/architecture.md +453 -0
- package/.claude/agents/sparc/pseudocode.md +299 -0
- package/.claude/agents/sparc/refinement.md +504 -0
- package/.claude/agents/sparc/specification.md +258 -0
- package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +88 -0
- package/.claude/agents/sublinear/consensus-coordinator.md +338 -0
- package/.claude/agents/sublinear/matrix-optimizer.md +185 -0
- package/.claude/agents/sublinear/pagerank-analyzer.md +299 -0
- package/.claude/agents/sublinear/performance-optimizer.md +368 -0
- package/.claude/agents/sublinear/trading-predictor.md +246 -0
- package/.claude/agents/swarm/adaptive-coordinator.md +364 -0
- package/.claude/agents/swarm/hierarchical-coordinator.md +300 -0
- package/.claude/agents/swarm/mesh-coordinator.md +363 -0
- package/.claude/agents/templates/automation-smart-agent.md +185 -0
- package/.claude/agents/templates/coordinator-swarm-init.md +83 -0
- package/.claude/agents/templates/github-pr-manager.md +155 -0
- package/.claude/agents/templates/implementer-sparc-coder.md +231 -0
- package/.claude/agents/templates/memory-coordinator.md +163 -0
- package/.claude/agents/templates/migration-plan.md +724 -0
- package/.claude/agents/templates/orchestrator-task.md +120 -0
- package/.claude/agents/templates/performance-analyzer.md +179 -0
- package/.claude/agents/templates/sparc-coordinator.md +163 -0
- package/.claude/agents/testing/production-validator.md +373 -0
- package/.claude/agents/testing/tdd-london-swarm.md +222 -0
- package/.claude/agents/testing/unit/tdd-london-swarm.md +222 -0
- package/.claude/agents/testing/validation/production-validator.md +373 -0
- package/.claude/agents/typescript-specialist.md +9 -0
- package/.claude/agents/v3/database-specialist.md +9 -0
- package/.claude/agents/v3/project-coordinator.md +8 -0
- package/.claude/agents/v3/python-specialist.md +9 -0
- package/.claude/agents/v3/test-architect.md +9 -0
- package/.claude/agents/v3/typescript-specialist.md +9 -0
- package/.claude/agents/v3/v3-integration-architect.md +312 -0
- package/.claude/agents/v3/v3-memory-specialist.md +281 -0
- package/.claude/agents/v3/v3-performance-engineer.md +363 -0
- package/.claude/agents/v3/v3-queen-coordinator.md +63 -0
- package/.claude/agents/v3/v3-security-architect.md +140 -0
- package/.claude/checkpoints/1767754460.json +8 -0
- package/.claude/commands/agents/README.md +10 -0
- package/.claude/commands/agents/agent-capabilities.md +21 -0
- package/.claude/commands/agents/agent-coordination.md +28 -0
- package/.claude/commands/agents/agent-spawning.md +28 -0
- package/.claude/commands/agents/agent-types.md +26 -0
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
- package/.claude/commands/analysis/README.md +9 -0
- package/.claude/commands/analysis/bottleneck-detect.md +162 -0
- package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
- package/.claude/commands/analysis/performance-report.md +25 -0
- package/.claude/commands/analysis/token-efficiency.md +45 -0
- package/.claude/commands/analysis/token-usage.md +25 -0
- package/.claude/commands/automation/README.md +9 -0
- package/.claude/commands/automation/auto-agent.md +122 -0
- package/.claude/commands/automation/self-healing.md +106 -0
- package/.claude/commands/automation/session-memory.md +90 -0
- package/.claude/commands/automation/smart-agents.md +73 -0
- package/.claude/commands/automation/smart-spawn.md +25 -0
- package/.claude/commands/automation/workflow-select.md +25 -0
- package/.claude/commands/claude-flow-help.md +103 -0
- package/.claude/commands/claude-flow-memory.md +107 -0
- package/.claude/commands/claude-flow-swarm.md +205 -0
- package/.claude/commands/coordination/README.md +9 -0
- package/.claude/commands/coordination/agent-spawn.md +25 -0
- package/.claude/commands/coordination/init.md +44 -0
- package/.claude/commands/coordination/orchestrate.md +43 -0
- package/.claude/commands/coordination/spawn.md +45 -0
- package/.claude/commands/coordination/swarm-init.md +85 -0
- package/.claude/commands/coordination/task-orchestrate.md +25 -0
- package/.claude/commands/flow-nexus/app-store.md +124 -0
- package/.claude/commands/flow-nexus/challenges.md +120 -0
- package/.claude/commands/flow-nexus/login-registration.md +65 -0
- package/.claude/commands/flow-nexus/neural-network.md +134 -0
- package/.claude/commands/flow-nexus/payments.md +116 -0
- package/.claude/commands/flow-nexus/sandbox.md +83 -0
- package/.claude/commands/flow-nexus/swarm.md +87 -0
- package/.claude/commands/flow-nexus/user-tools.md +152 -0
- package/.claude/commands/flow-nexus/workflow.md +115 -0
- package/.claude/commands/github/README.md +11 -0
- package/.claude/commands/github/code-review-swarm.md +514 -0
- package/.claude/commands/github/code-review.md +25 -0
- package/.claude/commands/github/github-modes.md +147 -0
- package/.claude/commands/github/github-swarm.md +121 -0
- package/.claude/commands/github/issue-tracker.md +292 -0
- package/.claude/commands/github/issue-triage.md +25 -0
- package/.claude/commands/github/multi-repo-swarm.md +519 -0
- package/.claude/commands/github/pr-enhance.md +26 -0
- package/.claude/commands/github/pr-manager.md +170 -0
- package/.claude/commands/github/project-board-sync.md +471 -0
- package/.claude/commands/github/release-manager.md +338 -0
- package/.claude/commands/github/release-swarm.md +544 -0
- package/.claude/commands/github/repo-analyze.md +25 -0
- package/.claude/commands/github/repo-architect.md +367 -0
- package/.claude/commands/github/swarm-issue.md +482 -0
- package/.claude/commands/github/swarm-pr.md +285 -0
- package/.claude/commands/github/sync-coordinator.md +301 -0
- package/.claude/commands/github/workflow-automation.md +442 -0
- package/.claude/commands/hive-mind/README.md +17 -0
- package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-init.md +18 -0
- package/.claude/commands/hive-mind/hive-mind-memory.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-resume.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -0
- package/.claude/commands/hive-mind/hive-mind-status.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-stop.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -0
- package/.claude/commands/hive-mind/hive-mind.md +27 -0
- package/.claude/commands/hooks/README.md +11 -0
- package/.claude/commands/hooks/overview.md +58 -0
- package/.claude/commands/hooks/post-edit.md +117 -0
- package/.claude/commands/hooks/post-task.md +112 -0
- package/.claude/commands/hooks/pre-edit.md +113 -0
- package/.claude/commands/hooks/pre-task.md +111 -0
- package/.claude/commands/hooks/session-end.md +118 -0
- package/.claude/commands/hooks/setup.md +103 -0
- package/.claude/commands/memory/README.md +9 -0
- package/.claude/commands/memory/memory-persist.md +25 -0
- package/.claude/commands/memory/memory-search.md +25 -0
- package/.claude/commands/memory/memory-usage.md +25 -0
- package/.claude/commands/memory/neural.md +47 -0
- package/.claude/commands/monitoring/README.md +9 -0
- package/.claude/commands/monitoring/agent-metrics.md +25 -0
- package/.claude/commands/monitoring/agents.md +44 -0
- package/.claude/commands/monitoring/real-time-view.md +25 -0
- package/.claude/commands/monitoring/status.md +46 -0
- package/.claude/commands/monitoring/swarm-monitor.md +25 -0
- package/.claude/commands/optimization/README.md +9 -0
- package/.claude/commands/optimization/auto-topology.md +62 -0
- package/.claude/commands/optimization/cache-manage.md +25 -0
- package/.claude/commands/optimization/parallel-execute.md +25 -0
- package/.claude/commands/optimization/parallel-execution.md +50 -0
- package/.claude/commands/optimization/topology-optimize.md +25 -0
- package/.claude/commands/pair/README.md +261 -0
- package/.claude/commands/pair/commands.md +546 -0
- package/.claude/commands/pair/config.md +510 -0
- package/.claude/commands/pair/examples.md +512 -0
- package/.claude/commands/pair/modes.md +348 -0
- package/.claude/commands/pair/session.md +407 -0
- package/.claude/commands/pair/start.md +209 -0
- package/.claude/commands/sparc/analyzer.md +52 -0
- package/.claude/commands/sparc/architect.md +53 -0
- package/.claude/commands/sparc/ask.md +97 -0
- package/.claude/commands/sparc/batch-executor.md +54 -0
- package/.claude/commands/sparc/code.md +89 -0
- package/.claude/commands/sparc/coder.md +54 -0
- package/.claude/commands/sparc/debug.md +83 -0
- package/.claude/commands/sparc/debugger.md +54 -0
- package/.claude/commands/sparc/designer.md +53 -0
- package/.claude/commands/sparc/devops.md +109 -0
- package/.claude/commands/sparc/docs-writer.md +80 -0
- package/.claude/commands/sparc/documenter.md +54 -0
- package/.claude/commands/sparc/innovator.md +54 -0
- package/.claude/commands/sparc/integration.md +83 -0
- package/.claude/commands/sparc/mcp.md +117 -0
- package/.claude/commands/sparc/memory-manager.md +54 -0
- package/.claude/commands/sparc/optimizer.md +54 -0
- package/.claude/commands/sparc/orchestrator.md +132 -0
- package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -0
- package/.claude/commands/sparc/refinement-optimization-mode.md +83 -0
- package/.claude/commands/sparc/researcher.md +54 -0
- package/.claude/commands/sparc/reviewer.md +54 -0
- package/.claude/commands/sparc/security-review.md +80 -0
- package/.claude/commands/sparc/sparc-modes.md +174 -0
- package/.claude/commands/sparc/sparc.md +111 -0
- package/.claude/commands/sparc/spec-pseudocode.md +80 -0
- package/.claude/commands/sparc/supabase-admin.md +348 -0
- package/.claude/commands/sparc/swarm-coordinator.md +54 -0
- package/.claude/commands/sparc/tdd.md +54 -0
- package/.claude/commands/sparc/tester.md +54 -0
- package/.claude/commands/sparc/tutorial.md +79 -0
- package/.claude/commands/sparc/workflow-manager.md +54 -0
- package/.claude/commands/sparc.md +166 -0
- package/.claude/commands/stream-chain/pipeline.md +121 -0
- package/.claude/commands/stream-chain/run.md +70 -0
- package/.claude/commands/swarm/README.md +15 -0
- package/.claude/commands/swarm/analysis.md +95 -0
- package/.claude/commands/swarm/development.md +96 -0
- package/.claude/commands/swarm/examples.md +168 -0
- package/.claude/commands/swarm/maintenance.md +102 -0
- package/.claude/commands/swarm/optimization.md +117 -0
- package/.claude/commands/swarm/research.md +136 -0
- package/.claude/commands/swarm/swarm-analysis.md +8 -0
- package/.claude/commands/swarm/swarm-background.md +8 -0
- package/.claude/commands/swarm/swarm-init.md +19 -0
- package/.claude/commands/swarm/swarm-modes.md +8 -0
- package/.claude/commands/swarm/swarm-monitor.md +8 -0
- package/.claude/commands/swarm/swarm-spawn.md +19 -0
- package/.claude/commands/swarm/swarm-status.md +8 -0
- package/.claude/commands/swarm/swarm-strategies.md +8 -0
- package/.claude/commands/swarm/swarm.md +27 -0
- package/.claude/commands/swarm/testing.md +131 -0
- package/.claude/commands/training/README.md +9 -0
- package/.claude/commands/training/model-update.md +25 -0
- package/.claude/commands/training/neural-patterns.md +74 -0
- package/.claude/commands/training/neural-train.md +25 -0
- package/.claude/commands/training/pattern-learn.md +25 -0
- package/.claude/commands/training/specialization.md +63 -0
- package/.claude/commands/truth/start.md +143 -0
- package/.claude/commands/verify/check.md +50 -0
- package/.claude/commands/verify/start.md +128 -0
- package/.claude/commands/workflows/README.md +9 -0
- package/.claude/commands/workflows/development.md +78 -0
- package/.claude/commands/workflows/research.md +63 -0
- package/.claude/commands/workflows/workflow-create.md +25 -0
- package/.claude/commands/workflows/workflow-execute.md +25 -0
- package/.claude/commands/workflows/workflow-export.md +25 -0
- package/.claude/config/v3-dependency-optimization.json +266 -0
- package/.claude/config/v3-performance-targets.json +251 -0
- package/.claude/helpers/README.md +97 -0
- package/.claude/helpers/adr-compliance.sh +186 -0
- package/.claude/helpers/aggressive-microcompact.mjs +36 -0
- package/.claude/helpers/auto-commit.sh +178 -0
- package/.claude/helpers/auto-memory-hook.mjs +369 -0
- package/.claude/helpers/checkpoint-manager.sh +251 -0
- package/.claude/helpers/context-persistence-hook.mjs +1979 -0
- package/.claude/helpers/daemon-manager.sh +252 -0
- package/.claude/helpers/ddd-tracker.sh +144 -0
- package/.claude/helpers/github-safe.js +106 -0
- package/.claude/helpers/github-setup.sh +28 -0
- package/.claude/helpers/guidance-hook.sh +13 -0
- package/.claude/helpers/guidance-hooks.sh +102 -0
- package/.claude/helpers/health-monitor.sh +108 -0
- package/.claude/helpers/hook-handler.cjs +234 -0
- package/.claude/helpers/intelligence.cjs +207 -0
- package/.claude/helpers/learning-hooks.sh +329 -0
- package/.claude/helpers/learning-optimizer.sh +127 -0
- package/.claude/helpers/learning-service.mjs +1144 -0
- package/.claude/helpers/memory.cjs +84 -0
- package/.claude/helpers/metrics-db.mjs +488 -0
- package/.claude/helpers/pattern-consolidator.sh +86 -0
- package/.claude/helpers/perf-worker.sh +160 -0
- package/.claude/helpers/quick-start.sh +19 -0
- package/.claude/helpers/router.cjs +62 -0
- package/.claude/helpers/security-scanner.sh +127 -0
- package/.claude/helpers/session.cjs +125 -0
- package/.claude/helpers/setup-mcp.sh +18 -0
- package/.claude/helpers/standard-checkpoint-hooks.sh +189 -0
- package/.claude/helpers/statusline.cjs +770 -0
- package/.claude/helpers/swarm-comms.sh +353 -0
- package/.claude/helpers/swarm-hooks.sh +761 -0
- package/.claude/helpers/swarm-monitor.sh +211 -0
- package/.claude/helpers/sync-v3-metrics.sh +245 -0
- package/.claude/helpers/update-v3-progress.sh +166 -0
- package/.claude/helpers/v3-quick-status.sh +58 -0
- package/.claude/helpers/v3.sh +111 -0
- package/.claude/helpers/validate-v3-config.sh +216 -0
- package/.claude/helpers/worker-manager.sh +170 -0
- package/.claude/mcp.json +13 -0
- package/.claude/settings copy.json +526 -0
- package/.claude/settings.json +305 -0
- package/.claude/skills/agentdb-advanced/SKILL.md +550 -0
- package/.claude/skills/agentdb-learning/SKILL.md +545 -0
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -0
- package/.claude/skills/agentdb-optimization/SKILL.md +509 -0
- package/.claude/skills/agentdb-vector-search/SKILL.md +339 -0
- package/.claude/skills/agentic-jujutsu/SKILL.md +645 -0
- package/.claude/skills/dual-mode/README.md +71 -0
- package/.claude/skills/dual-mode/dual-collect.md +103 -0
- package/.claude/skills/dual-mode/dual-coordinate.md +85 -0
- package/.claude/skills/dual-mode/dual-spawn.md +81 -0
- package/.claude/skills/flow-nexus-neural/SKILL.md +727 -0
- package/.claude/skills/flow-nexus-platform/SKILL.md +1154 -0
- package/.claude/skills/flow-nexus-swarm/SKILL.md +604 -0
- package/.claude/skills/github-code-review/SKILL.md +1125 -0
- package/.claude/skills/github-multi-repo/SKILL.md +862 -0
- package/.claude/skills/github-project-management/SKILL.md +1250 -0
- package/.claude/skills/github-release-management/SKILL.md +1064 -0
- package/.claude/skills/github-workflow-automation/SKILL.md +1047 -0
- package/.claude/skills/hive-mind-advanced/SKILL.md +709 -0
- package/.claude/skills/hooks-automation/SKILL.md +1201 -0
- package/.claude/skills/pair-programming/SKILL.md +1202 -0
- package/.claude/skills/performance-analysis/SKILL.md +560 -0
- package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -0
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
- package/.claude/skills/skill-builder/SKILL.md +910 -0
- package/.claude/skills/sparc-methodology/SKILL.md +1106 -0
- package/.claude/skills/stream-chain/SKILL.md +560 -0
- package/.claude/skills/swarm-advanced/SKILL.md +970 -0
- package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
- package/.claude/skills/v3-cli-modernization/SKILL.md +872 -0
- package/.claude/skills/v3-core-implementation/SKILL.md +797 -0
- package/.claude/skills/v3-ddd-architecture/SKILL.md +442 -0
- package/.claude/skills/v3-integration-deep/SKILL.md +241 -0
- package/.claude/skills/v3-mcp-optimization/SKILL.md +777 -0
- package/.claude/skills/v3-memory-unification/SKILL.md +174 -0
- package/.claude/skills/v3-performance-optimization/SKILL.md +390 -0
- package/.claude/skills/v3-security-overhaul/SKILL.md +82 -0
- package/.claude/skills/v3-swarm-coordination/SKILL.md +340 -0
- package/.claude/skills/verification-quality/SKILL.md +647 -0
- package/.claude/skills/worker-benchmarks/SKILL.md +129 -0
- package/.claude/skills/worker-integration/SKILL.md +147 -0
- package/.claude/statusline-command.sh +176 -0
- package/.claude/statusline.mjs +109 -0
- package/.claude/statusline.sh +431 -0
- package/.claude-plugin/README.md +720 -0
- package/.claude-plugin/docs/INSTALLATION.md +261 -0
- package/.claude-plugin/docs/PLUGIN_SUMMARY.md +361 -0
- package/.claude-plugin/docs/QUICKSTART.md +361 -0
- package/.claude-plugin/docs/STRUCTURE.md +128 -0
- package/.claude-plugin/hooks/hooks.json +74 -0
- package/.claude-plugin/marketplace.json +96 -0
- package/.claude-plugin/plugin.json +71 -0
- package/.claude-plugin/scripts/install.sh +234 -0
- package/.claude-plugin/scripts/uninstall.sh +36 -0
- package/.claude-plugin/scripts/verify.sh +108 -0
- package/LICENSE +21 -0
- package/README.md +7541 -0
- package/bin/cli.js +11 -0
- package/bin/npx-repair.js +7 -0
- package/bin/npx-safe-launch.js +9 -0
- package/package.json +84 -0
- package/v3/@claude-flow/cli/README.md +192 -0
- package/v3/@claude-flow/cli/bin/cli.js +156 -0
- package/v3/@claude-flow/cli/bin/mcp-server.js +189 -0
- package/v3/@claude-flow/cli/bin/preinstall.cjs +2 -0
- package/v3/@claude-flow/cli/dist/src/appliance/gguf-engine.d.ts +91 -0
- package/v3/@claude-flow/cli/dist/src/appliance/gguf-engine.js +425 -0
- package/v3/@claude-flow/cli/dist/src/appliance/ruvllm-bridge.d.ts +102 -0
- package/v3/@claude-flow/cli/dist/src/appliance/ruvllm-bridge.js +292 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-builder.d.ts +44 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-builder.js +329 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-distribution.d.ts +97 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-distribution.js +370 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-format.d.ts +111 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-format.js +393 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-runner.d.ts +69 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-runner.js +237 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-signing.d.ts +123 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-signing.js +347 -0
- package/v3/@claude-flow/cli/dist/src/autopilot-state.d.ts +77 -0
- package/v3/@claude-flow/cli/dist/src/autopilot-state.js +279 -0
- package/v3/@claude-flow/cli/dist/src/benchmarks/pretrain/index.d.ts +58 -0
- package/v3/@claude-flow/cli/dist/src/benchmarks/pretrain/index.js +404 -0
- package/v3/@claude-flow/cli/dist/src/commands/agent-wasm.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/commands/agent-wasm.js +333 -0
- package/v3/@claude-flow/cli/dist/src/commands/agent.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/agent.js +927 -0
- package/v3/@claude-flow/cli/dist/src/commands/analyze.d.ts +17 -0
- package/v3/@claude-flow/cli/dist/src/commands/analyze.js +1821 -0
- package/v3/@claude-flow/cli/dist/src/commands/appliance-advanced.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/commands/appliance-advanced.js +215 -0
- package/v3/@claude-flow/cli/dist/src/commands/appliance.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/appliance.js +406 -0
- package/v3/@claude-flow/cli/dist/src/commands/autopilot.d.ts +15 -0
- package/v3/@claude-flow/cli/dist/src/commands/autopilot.js +362 -0
- package/v3/@claude-flow/cli/dist/src/commands/benchmark.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/benchmark.js +459 -0
- package/v3/@claude-flow/cli/dist/src/commands/claims.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/claims.js +621 -0
- package/v3/@claude-flow/cli/dist/src/commands/cleanup.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/cleanup.js +216 -0
- package/v3/@claude-flow/cli/dist/src/commands/completions.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/completions.js +537 -0
- package/v3/@claude-flow/cli/dist/src/commands/config.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/config.js +356 -0
- package/v3/@claude-flow/cli/dist/src/commands/daemon.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/daemon.js +669 -0
- package/v3/@claude-flow/cli/dist/src/commands/deployment.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/deployment.js +669 -0
- package/v3/@claude-flow/cli/dist/src/commands/doctor.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/doctor.js +617 -0
- package/v3/@claude-flow/cli/dist/src/commands/embeddings.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/commands/embeddings.js +1573 -0
- package/v3/@claude-flow/cli/dist/src/commands/guidance.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/guidance.js +560 -0
- package/v3/@claude-flow/cli/dist/src/commands/hive-mind.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/hive-mind.js +1237 -0
- package/v3/@claude-flow/cli/dist/src/commands/hooks.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/hooks.js +4441 -0
- package/v3/@claude-flow/cli/dist/src/commands/index.d.ts +117 -0
- package/v3/@claude-flow/cli/dist/src/commands/index.js +384 -0
- package/v3/@claude-flow/cli/dist/src/commands/init.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/init.js +969 -0
- package/v3/@claude-flow/cli/dist/src/commands/issues.d.ts +21 -0
- package/v3/@claude-flow/cli/dist/src/commands/issues.js +567 -0
- package/v3/@claude-flow/cli/dist/src/commands/mcp.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/mcp.js +718 -0
- package/v3/@claude-flow/cli/dist/src/commands/memory.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/memory.js +1299 -0
- package/v3/@claude-flow/cli/dist/src/commands/migrate.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/migrate.js +742 -0
- package/v3/@claude-flow/cli/dist/src/commands/neural.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/neural.js +1451 -0
- package/v3/@claude-flow/cli/dist/src/commands/performance.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/performance.js +576 -0
- package/v3/@claude-flow/cli/dist/src/commands/plugins.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/commands/plugins.js +817 -0
- package/v3/@claude-flow/cli/dist/src/commands/process.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/process.js +641 -0
- package/v3/@claude-flow/cli/dist/src/commands/progress.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/progress.js +259 -0
- package/v3/@claude-flow/cli/dist/src/commands/providers.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/providers.js +355 -0
- package/v3/@claude-flow/cli/dist/src/commands/route.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/commands/route.js +811 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.js +746 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.js +480 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.js +347 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.d.ts +27 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.js +127 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.js +431 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.js +481 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.js +503 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.js +763 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.js +456 -0
- package/v3/@claude-flow/cli/dist/src/commands/security.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/security.js +614 -0
- package/v3/@claude-flow/cli/dist/src/commands/session.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/session.js +750 -0
- package/v3/@claude-flow/cli/dist/src/commands/start.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/start.js +418 -0
- package/v3/@claude-flow/cli/dist/src/commands/status.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/status.js +591 -0
- package/v3/@claude-flow/cli/dist/src/commands/swarm.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/swarm.js +802 -0
- package/v3/@claude-flow/cli/dist/src/commands/task.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/task.js +671 -0
- package/v3/@claude-flow/cli/dist/src/commands/transfer-store.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/commands/transfer-store.js +428 -0
- package/v3/@claude-flow/cli/dist/src/commands/update.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/update.js +276 -0
- package/v3/@claude-flow/cli/dist/src/commands/workflow.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/workflow.js +617 -0
- package/v3/@claude-flow/cli/dist/src/config-adapter.d.ts +15 -0
- package/v3/@claude-flow/cli/dist/src/config-adapter.js +186 -0
- package/v3/@claude-flow/cli/dist/src/index.d.ts +74 -0
- package/v3/@claude-flow/cli/dist/src/index.js +469 -0
- package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.d.ts +68 -0
- package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.js +264 -0
- package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts +25 -0
- package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.js +486 -0
- package/v3/@claude-flow/cli/dist/src/init/executor.d.ts +41 -0
- package/v3/@claude-flow/cli/dist/src/init/executor.js +1776 -0
- package/v3/@claude-flow/cli/dist/src/init/helpers-generator.d.ts +60 -0
- package/v3/@claude-flow/cli/dist/src/init/helpers-generator.js +1181 -0
- package/v3/@claude-flow/cli/dist/src/init/index.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/init/index.js +15 -0
- package/v3/@claude-flow/cli/dist/src/init/mcp-generator.d.ts +26 -0
- package/v3/@claude-flow/cli/dist/src/init/mcp-generator.js +101 -0
- package/v3/@claude-flow/cli/dist/src/init/settings-generator.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/init/settings-generator.js +392 -0
- package/v3/@claude-flow/cli/dist/src/init/statusline-generator.d.ts +28 -0
- package/v3/@claude-flow/cli/dist/src/init/statusline-generator.js +833 -0
- package/v3/@claude-flow/cli/dist/src/init/types.d.ts +295 -0
- package/v3/@claude-flow/cli/dist/src/init/types.js +263 -0
- package/v3/@claude-flow/cli/dist/src/mcp-client.d.ts +92 -0
- package/v3/@claude-flow/cli/dist/src/mcp-client.js +227 -0
- package/v3/@claude-flow/cli/dist/src/mcp-server.d.ts +163 -0
- package/v3/@claude-flow/cli/dist/src/mcp-server.js +654 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.js +550 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agentdb-tools.d.ts +30 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agentdb-tools.js +557 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.js +317 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/claims-tools.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/claims-tools.js +732 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.js +357 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/coordination-tools.js +665 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/embeddings-tools.js +782 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.js +811 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.d.ts +44 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js +3120 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/index.d.ts +22 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/index.js +21 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.js +512 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/neural-tools.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/neural-tools.js +461 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/performance-tools.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/performance-tools.js +534 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.js +348 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.js +404 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.js +315 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.js +288 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/system-tools.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/system-tools.js +408 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.js +405 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/types.d.ts +31 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/types.js +7 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.js +572 -0
- package/v3/@claude-flow/cli/dist/src/memory/ewc-consolidation.d.ts +295 -0
- package/v3/@claude-flow/cli/dist/src/memory/ewc-consolidation.js +601 -0
- package/v3/@claude-flow/cli/dist/src/memory/intelligence.d.ts +338 -0
- package/v3/@claude-flow/cli/dist/src/memory/intelligence.js +1023 -0
- package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.d.ts +407 -0
- package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.js +1499 -0
- package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.d.ts +412 -0
- package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.js +2222 -0
- package/v3/@claude-flow/cli/dist/src/memory/sona-optimizer.d.ts +227 -0
- package/v3/@claude-flow/cli/dist/src/memory/sona-optimizer.js +633 -0
- package/v3/@claude-flow/cli/dist/src/output.d.ts +133 -0
- package/v3/@claude-flow/cli/dist/src/output.js +514 -0
- package/v3/@claude-flow/cli/dist/src/parser.d.ts +51 -0
- package/v3/@claude-flow/cli/dist/src/parser.js +425 -0
- package/v3/@claude-flow/cli/dist/src/plugins/manager.d.ts +133 -0
- package/v3/@claude-flow/cli/dist/src/plugins/manager.js +400 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/discovery.d.ts +88 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/discovery.js +1147 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/index.d.ts +76 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/index.js +141 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/search.d.ts +46 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/search.js +230 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/types.d.ts +274 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/types.js +7 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/demo-plugin-store.js +126 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/standalone-test.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/standalone-test.js +188 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/test-plugin-store.js +206 -0
- package/v3/@claude-flow/cli/dist/src/production/circuit-breaker.d.ts +101 -0
- package/v3/@claude-flow/cli/dist/src/production/circuit-breaker.js +241 -0
- package/v3/@claude-flow/cli/dist/src/production/error-handler.d.ts +92 -0
- package/v3/@claude-flow/cli/dist/src/production/error-handler.js +299 -0
- package/v3/@claude-flow/cli/dist/src/production/index.d.ts +23 -0
- package/v3/@claude-flow/cli/dist/src/production/index.js +18 -0
- package/v3/@claude-flow/cli/dist/src/production/monitoring.d.ts +161 -0
- package/v3/@claude-flow/cli/dist/src/production/monitoring.js +356 -0
- package/v3/@claude-flow/cli/dist/src/production/rate-limiter.d.ts +80 -0
- package/v3/@claude-flow/cli/dist/src/production/rate-limiter.js +201 -0
- package/v3/@claude-flow/cli/dist/src/production/retry.d.ts +48 -0
- package/v3/@claude-flow/cli/dist/src/production/retry.js +179 -0
- package/v3/@claude-flow/cli/dist/src/prompt.d.ts +44 -0
- package/v3/@claude-flow/cli/dist/src/prompt.js +501 -0
- package/v3/@claude-flow/cli/dist/src/runtime/headless.d.ts +60 -0
- package/v3/@claude-flow/cli/dist/src/runtime/headless.js +284 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/agent-wasm.d.ts +182 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/agent-wasm.js +316 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.d.ts +67 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.js +277 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.d.ts +160 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.js +529 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.d.ts +33 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.js +157 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.d.ts +175 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.js +698 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/enhanced-model-router.js +513 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/flash-attention.d.ts +193 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/flash-attention.js +641 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.d.ts +187 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.js +929 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/index.d.ts +40 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/index.js +76 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/lora-adapter.d.ts +218 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/lora-adapter.js +455 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/model-router.d.ts +220 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/model-router.js +488 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/moe-router.d.ts +206 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/moe-router.js +626 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.d.ts +211 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.js +681 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/ruvllm-wasm.d.ts +179 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/ruvllm-wasm.js +363 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/semantic-router.d.ts +77 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/semantic-router.js +178 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.d.ts +67 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.js +241 -0
- package/v3/@claude-flow/cli/dist/src/services/agentic-flow-bridge.d.ts +50 -0
- package/v3/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +95 -0
- package/v3/@claude-flow/cli/dist/src/services/claim-service.d.ts +204 -0
- package/v3/@claude-flow/cli/dist/src/services/claim-service.js +818 -0
- package/v3/@claude-flow/cli/dist/src/services/config-file-manager.d.ts +37 -0
- package/v3/@claude-flow/cli/dist/src/services/config-file-manager.js +224 -0
- package/v3/@claude-flow/cli/dist/src/services/container-worker-pool.d.ts +197 -0
- package/v3/@claude-flow/cli/dist/src/services/container-worker-pool.js +583 -0
- package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.d.ts +304 -0
- package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.js +1024 -0
- package/v3/@claude-flow/cli/dist/src/services/index.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/services/index.js +11 -0
- package/v3/@claude-flow/cli/dist/src/services/registry-api.d.ts +58 -0
- package/v3/@claude-flow/cli/dist/src/services/registry-api.js +146 -0
- package/v3/@claude-flow/cli/dist/src/services/ruvector-training.d.ts +220 -0
- package/v3/@claude-flow/cli/dist/src/services/ruvector-training.js +686 -0
- package/v3/@claude-flow/cli/dist/src/services/worker-daemon.d.ts +245 -0
- package/v3/@claude-flow/cli/dist/src/services/worker-daemon.js +960 -0
- package/v3/@claude-flow/cli/dist/src/services/worker-queue.d.ts +194 -0
- package/v3/@claude-flow/cli/dist/src/services/worker-queue.js +513 -0
- package/v3/@claude-flow/cli/dist/src/suggest.d.ts +51 -0
- package/v3/@claude-flow/cli/dist/src/suggest.js +198 -0
- package/v3/@claude-flow/cli/dist/src/transfer/anonymization/index.d.ts +25 -0
- package/v3/@claude-flow/cli/dist/src/transfer/anonymization/index.js +175 -0
- package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.js +205 -0
- package/v3/@claude-flow/cli/dist/src/transfer/export.d.ts +25 -0
- package/v3/@claude-flow/cli/dist/src/transfer/export.js +113 -0
- package/v3/@claude-flow/cli/dist/src/transfer/index.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/transfer/index.js +31 -0
- package/v3/@claude-flow/cli/dist/src/transfer/ipfs/client.d.ts +109 -0
- package/v3/@claude-flow/cli/dist/src/transfer/ipfs/client.js +307 -0
- package/v3/@claude-flow/cli/dist/src/transfer/ipfs/upload.d.ts +95 -0
- package/v3/@claude-flow/cli/dist/src/transfer/ipfs/upload.js +411 -0
- package/v3/@claude-flow/cli/dist/src/transfer/models/seraphine.d.ts +72 -0
- package/v3/@claude-flow/cli/dist/src/transfer/models/seraphine.js +373 -0
- package/v3/@claude-flow/cli/dist/src/transfer/serialization/cfp.d.ts +49 -0
- package/v3/@claude-flow/cli/dist/src/transfer/serialization/cfp.js +183 -0
- package/v3/@claude-flow/cli/dist/src/transfer/storage/gcs.d.ts +82 -0
- package/v3/@claude-flow/cli/dist/src/transfer/storage/gcs.js +272 -0
- package/v3/@claude-flow/cli/dist/src/transfer/storage/index.d.ts +6 -0
- package/v3/@claude-flow/cli/dist/src/transfer/storage/index.js +6 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/discovery.d.ts +84 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/discovery.js +382 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/download.d.ts +70 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/download.js +334 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/index.d.ts +84 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/index.js +153 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/publish.d.ts +76 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/publish.js +294 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/registry.d.ts +58 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/registry.js +285 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/search.d.ts +54 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/search.js +232 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/tests/standalone-test.js +190 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/types.d.ts +193 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/types.js +6 -0
- package/v3/@claude-flow/cli/dist/src/transfer/test-seraphine.d.ts +6 -0
- package/v3/@claude-flow/cli/dist/src/transfer/test-seraphine.js +105 -0
- package/v3/@claude-flow/cli/dist/src/transfer/tests/test-store.d.ts +7 -0
- package/v3/@claude-flow/cli/dist/src/transfer/tests/test-store.js +214 -0
- package/v3/@claude-flow/cli/dist/src/transfer/types.d.ts +245 -0
- package/v3/@claude-flow/cli/dist/src/transfer/types.js +6 -0
- package/v3/@claude-flow/cli/dist/src/types.d.ts +198 -0
- package/v3/@claude-flow/cli/dist/src/types.js +38 -0
- package/v3/@claude-flow/cli/dist/src/update/checker.d.ts +34 -0
- package/v3/@claude-flow/cli/dist/src/update/checker.js +190 -0
- package/v3/@claude-flow/cli/dist/src/update/executor.d.ts +32 -0
- package/v3/@claude-flow/cli/dist/src/update/executor.js +181 -0
- package/v3/@claude-flow/cli/dist/src/update/index.d.ts +33 -0
- package/v3/@claude-flow/cli/dist/src/update/index.js +64 -0
- package/v3/@claude-flow/cli/dist/src/update/rate-limiter.d.ts +20 -0
- package/v3/@claude-flow/cli/dist/src/update/rate-limiter.js +96 -0
- package/v3/@claude-flow/cli/dist/src/update/validator.d.ts +17 -0
- package/v3/@claude-flow/cli/dist/src/update/validator.js +123 -0
- package/v3/@claude-flow/cli/dist/src/utils/path-validation.d.ts +20 -0
- package/v3/@claude-flow/cli/dist/src/utils/path-validation.js +80 -0
- package/v3/@claude-flow/cli/package.json +75 -0
- package/v3/@claude-flow/shared/README.md +323 -0
- package/v3/@claude-flow/shared/package.json +42 -0
- package/v3/README.md +493 -0
|
@@ -0,0 +1,669 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* V3 CLI Daemon Command
|
|
3
|
+
* Manages background worker daemon (Node.js-based, similar to shell helpers)
|
|
4
|
+
*/
|
|
5
|
+
import { output } from '../output.js';
|
|
6
|
+
import { getDaemon, startDaemon, stopDaemon } from '../services/worker-daemon.js';
|
|
7
|
+
import { spawn } from 'child_process';
|
|
8
|
+
import { fileURLToPath } from 'url';
|
|
9
|
+
import { dirname, join, resolve } from 'path';
|
|
10
|
+
import * as fs from 'fs';
|
|
11
|
+
// Start daemon subcommand
|
|
12
|
+
const startCommand = {
|
|
13
|
+
name: 'start',
|
|
14
|
+
description: 'Start the worker daemon with all enabled background workers',
|
|
15
|
+
options: [
|
|
16
|
+
{ name: 'workers', short: 'w', type: 'string', description: 'Comma-separated list of workers to enable (default: map,audit,optimize,consolidate,testgaps)' },
|
|
17
|
+
{ name: 'quiet', short: 'Q', type: 'boolean', description: 'Suppress output' },
|
|
18
|
+
{ name: 'background', short: 'b', type: 'boolean', description: 'Run daemon in background (detached process)', default: true },
|
|
19
|
+
{ name: 'foreground', short: 'f', type: 'boolean', description: 'Run daemon in foreground (blocks terminal)' },
|
|
20
|
+
{ name: 'headless', type: 'boolean', description: 'Enable headless worker execution (E2B sandbox)' },
|
|
21
|
+
{ name: 'sandbox', type: 'string', description: 'Default sandbox mode for headless workers', choices: ['strict', 'permissive', 'disabled'] },
|
|
22
|
+
{ name: 'max-cpu-load', type: 'string', description: 'Override maxCpuLoad resource threshold (e.g. 4.0)' },
|
|
23
|
+
{ name: 'min-free-memory', type: 'string', description: 'Override minFreeMemoryPercent resource threshold (e.g. 15)' },
|
|
24
|
+
],
|
|
25
|
+
examples: [
|
|
26
|
+
{ command: 'claude-flow daemon start', description: 'Start daemon in background (default)' },
|
|
27
|
+
{ command: 'claude-flow daemon start --foreground', description: 'Start in foreground (blocks terminal)' },
|
|
28
|
+
{ command: 'claude-flow daemon start -w map,audit,optimize', description: 'Start with specific workers' },
|
|
29
|
+
{ command: 'claude-flow daemon start --headless --sandbox strict', description: 'Start with headless workers in strict sandbox' },
|
|
30
|
+
],
|
|
31
|
+
action: async (ctx) => {
|
|
32
|
+
const quiet = ctx.flags.quiet;
|
|
33
|
+
const foreground = ctx.flags.foreground;
|
|
34
|
+
const projectRoot = process.cwd();
|
|
35
|
+
const isDaemonProcess = process.env.CLAUDE_FLOW_DAEMON === '1';
|
|
36
|
+
// Parse resource threshold overrides from CLI flags
|
|
37
|
+
const config = {};
|
|
38
|
+
const rawMaxCpu = ctx.flags['max-cpu-load'];
|
|
39
|
+
const rawMinMem = ctx.flags['min-free-memory'];
|
|
40
|
+
// Strict numeric pattern to prevent command injection when forwarding to subprocess (S1)
|
|
41
|
+
const NUMERIC_RE = /^\d+(\.\d+)?$/;
|
|
42
|
+
const sanitize = (s) => s.replace(/[\x00-\x1f\x7f-\x9f]/g, '');
|
|
43
|
+
if (rawMaxCpu || rawMinMem) {
|
|
44
|
+
const thresholds = {};
|
|
45
|
+
if (rawMaxCpu) {
|
|
46
|
+
const val = parseFloat(rawMaxCpu);
|
|
47
|
+
if (NUMERIC_RE.test(rawMaxCpu) && isFinite(val) && val > 0 && val <= 1000) {
|
|
48
|
+
thresholds.maxCpuLoad = val;
|
|
49
|
+
}
|
|
50
|
+
else if (!quiet) {
|
|
51
|
+
output.printWarning(`Ignoring invalid --max-cpu-load value: ${sanitize(rawMaxCpu)}`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
if (rawMinMem) {
|
|
55
|
+
const val = parseFloat(rawMinMem);
|
|
56
|
+
if (NUMERIC_RE.test(rawMinMem) && isFinite(val) && val >= 0 && val <= 100) {
|
|
57
|
+
thresholds.minFreeMemoryPercent = val;
|
|
58
|
+
}
|
|
59
|
+
else if (!quiet) {
|
|
60
|
+
output.printWarning(`Ignoring invalid --min-free-memory value: ${sanitize(rawMinMem)}`);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
if (thresholds.maxCpuLoad !== undefined || thresholds.minFreeMemoryPercent !== undefined) {
|
|
64
|
+
config.resourceThresholds = thresholds;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
// Check if background daemon already running (skip if we ARE the daemon process)
|
|
68
|
+
if (!isDaemonProcess) {
|
|
69
|
+
const bgPid = getBackgroundDaemonPid(projectRoot);
|
|
70
|
+
if (bgPid && isProcessRunning(bgPid)) {
|
|
71
|
+
if (!quiet) {
|
|
72
|
+
output.printWarning(`Daemon already running in background (PID: ${bgPid})`);
|
|
73
|
+
}
|
|
74
|
+
return { success: true };
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
// Background mode (default): fork a detached process
|
|
78
|
+
if (!foreground) {
|
|
79
|
+
return startBackgroundDaemon(projectRoot, quiet, rawMaxCpu, rawMinMem);
|
|
80
|
+
}
|
|
81
|
+
// Foreground mode: run in current process (blocks terminal)
|
|
82
|
+
try {
|
|
83
|
+
const stateDir = join(projectRoot, '.claude-flow');
|
|
84
|
+
const pidFile = join(stateDir, 'daemon.pid');
|
|
85
|
+
// Ensure state directory exists
|
|
86
|
+
if (!fs.existsSync(stateDir)) {
|
|
87
|
+
fs.mkdirSync(stateDir, { recursive: true });
|
|
88
|
+
}
|
|
89
|
+
// NOTE: Do NOT write PID file here — startDaemon() writes it internally.
|
|
90
|
+
// Writing it before startDaemon() causes checkExistingDaemon() to detect
|
|
91
|
+
// our own PID and return early, leaving no workers scheduled (#1478 Bug 1).
|
|
92
|
+
// Clean up PID file on exit
|
|
93
|
+
const cleanup = () => {
|
|
94
|
+
try {
|
|
95
|
+
if (fs.existsSync(pidFile)) {
|
|
96
|
+
fs.unlinkSync(pidFile);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
catch { /* ignore */ }
|
|
100
|
+
};
|
|
101
|
+
process.on('exit', cleanup);
|
|
102
|
+
process.on('SIGINT', () => { cleanup(); process.exit(0); });
|
|
103
|
+
process.on('SIGTERM', () => { cleanup(); process.exit(0); });
|
|
104
|
+
// Ignore SIGHUP on macOS/Linux — prevents daemon death when terminal closes (#1283)
|
|
105
|
+
if (process.platform !== 'win32') {
|
|
106
|
+
process.on('SIGHUP', () => { });
|
|
107
|
+
}
|
|
108
|
+
if (!quiet) {
|
|
109
|
+
const spinner = output.createSpinner({ text: 'Starting worker daemon...', spinner: 'dots' });
|
|
110
|
+
spinner.start();
|
|
111
|
+
const daemon = await startDaemon(projectRoot, config);
|
|
112
|
+
const status = daemon.getStatus();
|
|
113
|
+
spinner.succeed('Worker daemon started (foreground mode)');
|
|
114
|
+
output.writeln();
|
|
115
|
+
output.printBox([
|
|
116
|
+
`PID: ${status.pid}`,
|
|
117
|
+
`Started: ${status.startedAt?.toISOString()}`,
|
|
118
|
+
`Workers: ${status.config.workers.filter(w => w.enabled).length} enabled`,
|
|
119
|
+
`Max Concurrent: ${status.config.maxConcurrent}`,
|
|
120
|
+
`Max CPU Load: ${status.config.resourceThresholds.maxCpuLoad}`,
|
|
121
|
+
`Min Free Memory: ${status.config.resourceThresholds.minFreeMemoryPercent}%`,
|
|
122
|
+
].join('\n'), 'Daemon Status');
|
|
123
|
+
output.writeln();
|
|
124
|
+
output.writeln(output.bold('Scheduled Workers'));
|
|
125
|
+
output.printTable({
|
|
126
|
+
columns: [
|
|
127
|
+
{ key: 'type', header: 'Worker', width: 15 },
|
|
128
|
+
{ key: 'interval', header: 'Interval', width: 12 },
|
|
129
|
+
{ key: 'priority', header: 'Priority', width: 10 },
|
|
130
|
+
{ key: 'description', header: 'Description', width: 30 },
|
|
131
|
+
],
|
|
132
|
+
data: status.config.workers
|
|
133
|
+
.filter(w => w.enabled)
|
|
134
|
+
.map(w => ({
|
|
135
|
+
type: output.highlight(w.type),
|
|
136
|
+
interval: `${Math.round(w.intervalMs / 60000)}min`,
|
|
137
|
+
priority: w.priority === 'critical' ? output.error(w.priority) :
|
|
138
|
+
w.priority === 'high' ? output.warning(w.priority) :
|
|
139
|
+
output.dim(w.priority),
|
|
140
|
+
description: w.description,
|
|
141
|
+
})),
|
|
142
|
+
});
|
|
143
|
+
output.writeln();
|
|
144
|
+
output.writeln(output.dim('Press Ctrl+C to stop daemon'));
|
|
145
|
+
// Listen for worker events
|
|
146
|
+
daemon.on('worker:start', ({ type }) => {
|
|
147
|
+
output.writeln(output.dim(`[daemon] Worker starting: ${type}`));
|
|
148
|
+
});
|
|
149
|
+
daemon.on('worker:complete', ({ type, durationMs }) => {
|
|
150
|
+
output.writeln(output.success(`[daemon] Worker completed: ${type} (${durationMs}ms)`));
|
|
151
|
+
});
|
|
152
|
+
daemon.on('worker:error', ({ type, error }) => {
|
|
153
|
+
output.writeln(output.error(`[daemon] Worker failed: ${type} - ${error}`));
|
|
154
|
+
});
|
|
155
|
+
// Keep process alive — setInterval creates a ref'd handle that prevents
|
|
156
|
+
// Node.js from exiting even when startDaemon's timers are unref'd (#1478 Bug 2).
|
|
157
|
+
setInterval(() => { }, 60_000);
|
|
158
|
+
await new Promise(() => { }); // Never resolves - daemon runs until killed
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
await startDaemon(projectRoot, config);
|
|
162
|
+
setInterval(() => { }, 60_000); // Keep alive with ref'd handle (#1478)
|
|
163
|
+
await new Promise(() => { }); // Keep alive
|
|
164
|
+
}
|
|
165
|
+
return { success: true };
|
|
166
|
+
}
|
|
167
|
+
catch (error) {
|
|
168
|
+
output.printError(`Failed to start daemon: ${error instanceof Error ? error.message : String(error)}`);
|
|
169
|
+
return { success: false, exitCode: 1 };
|
|
170
|
+
}
|
|
171
|
+
},
|
|
172
|
+
};
|
|
173
|
+
/**
|
|
174
|
+
* Validate path for security - prevents path traversal and injection
|
|
175
|
+
*/
|
|
176
|
+
function validatePath(path, label) {
|
|
177
|
+
// Must be absolute after resolution
|
|
178
|
+
const resolved = resolve(path);
|
|
179
|
+
// Check for null bytes (injection attack)
|
|
180
|
+
if (path.includes('\0')) {
|
|
181
|
+
throw new Error(`${label} contains null bytes`);
|
|
182
|
+
}
|
|
183
|
+
// Check for shell metacharacters in path components
|
|
184
|
+
if (/[;&|`$<>]/.test(path)) {
|
|
185
|
+
throw new Error(`${label} contains shell metacharacters`);
|
|
186
|
+
}
|
|
187
|
+
// Prevent path traversal outside expected directories
|
|
188
|
+
if (!resolved.includes('.claude-flow') && !resolved.includes('bin')) {
|
|
189
|
+
// Allow only paths within project structure
|
|
190
|
+
const cwd = process.cwd();
|
|
191
|
+
if (!resolved.startsWith(cwd)) {
|
|
192
|
+
throw new Error(`${label} escapes project directory`);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* Start daemon as a detached background process
|
|
198
|
+
*/
|
|
199
|
+
async function startBackgroundDaemon(projectRoot, quiet, maxCpuLoad, minFreeMemory) {
|
|
200
|
+
// Validate and resolve project root
|
|
201
|
+
const resolvedRoot = resolve(projectRoot);
|
|
202
|
+
validatePath(resolvedRoot, 'Project root');
|
|
203
|
+
const stateDir = join(resolvedRoot, '.claude-flow');
|
|
204
|
+
const pidFile = join(stateDir, 'daemon.pid');
|
|
205
|
+
const logFile = join(stateDir, 'daemon.log');
|
|
206
|
+
// Validate all paths
|
|
207
|
+
validatePath(stateDir, 'State directory');
|
|
208
|
+
validatePath(pidFile, 'PID file');
|
|
209
|
+
validatePath(logFile, 'Log file');
|
|
210
|
+
// Ensure state directory exists
|
|
211
|
+
if (!fs.existsSync(stateDir)) {
|
|
212
|
+
fs.mkdirSync(stateDir, { recursive: true });
|
|
213
|
+
}
|
|
214
|
+
// Get path to CLI (from dist/src/commands/daemon.js -> bin/cli.js)
|
|
215
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
216
|
+
const __dirname = dirname(__filename);
|
|
217
|
+
// dist/src/commands -> dist/src -> dist -> package root -> bin/cli.js
|
|
218
|
+
const cliPath = resolve(join(__dirname, '..', '..', '..', 'bin', 'cli.js'));
|
|
219
|
+
validatePath(cliPath, 'CLI path');
|
|
220
|
+
// Verify CLI path exists
|
|
221
|
+
if (!fs.existsSync(cliPath)) {
|
|
222
|
+
output.printError(`CLI not found at: ${cliPath}`);
|
|
223
|
+
return { success: false, exitCode: 1 };
|
|
224
|
+
}
|
|
225
|
+
// Platform-aware spawn flags
|
|
226
|
+
const isWin = process.platform === 'win32';
|
|
227
|
+
const spawnOpts = {
|
|
228
|
+
cwd: resolvedRoot,
|
|
229
|
+
detached: !isWin, // detached is POSIX-only; Windows uses windowsHide
|
|
230
|
+
// Use 'ignore' for all stdio — passing fs.openSync() FDs causes the child to
|
|
231
|
+
// die on Windows when the parent exits and closes the FDs (#1478 Bug 3).
|
|
232
|
+
// The daemon writes its own logs via appendFileSync to .claude-flow/logs/.
|
|
233
|
+
stdio: ['ignore', 'ignore', 'ignore'],
|
|
234
|
+
env: {
|
|
235
|
+
...process.env,
|
|
236
|
+
CLAUDE_FLOW_DAEMON: '1',
|
|
237
|
+
// Prevent macOS SIGHUP kill when terminal closes
|
|
238
|
+
...(process.platform === 'darwin' ? { NOHUP: '1' } : {}),
|
|
239
|
+
},
|
|
240
|
+
...(isWin ? { shell: true, windowsHide: true } : {}),
|
|
241
|
+
};
|
|
242
|
+
// Use spawn with explicit arguments instead of shell string interpolation
|
|
243
|
+
// This prevents command injection via paths
|
|
244
|
+
const spawnArgs = [
|
|
245
|
+
cliPath,
|
|
246
|
+
'daemon', 'start', '--foreground', '--quiet',
|
|
247
|
+
];
|
|
248
|
+
// Forward resource threshold flags to the foreground child process
|
|
249
|
+
// Validate with strict numeric pattern to prevent shell injection on Windows (S1)
|
|
250
|
+
const SPAWN_NUMERIC_RE = /^\d+(\.\d+)?$/;
|
|
251
|
+
if (maxCpuLoad && SPAWN_NUMERIC_RE.test(maxCpuLoad)) {
|
|
252
|
+
spawnArgs.push('--max-cpu-load', maxCpuLoad);
|
|
253
|
+
}
|
|
254
|
+
if (minFreeMemory && SPAWN_NUMERIC_RE.test(minFreeMemory)) {
|
|
255
|
+
spawnArgs.push('--min-free-memory', minFreeMemory);
|
|
256
|
+
}
|
|
257
|
+
const child = spawn(process.execPath, spawnArgs, spawnOpts);
|
|
258
|
+
// Get PID from spawned process directly (no shell echo needed)
|
|
259
|
+
const pid = child.pid;
|
|
260
|
+
if (!pid || pid <= 0) {
|
|
261
|
+
output.printError('Failed to get daemon PID');
|
|
262
|
+
return { success: false, exitCode: 1 };
|
|
263
|
+
}
|
|
264
|
+
// Unref BEFORE writing PID file — prevents race where parent exits
|
|
265
|
+
// but child hasn't fully detached yet (fixes macOS daemon death #1283)
|
|
266
|
+
child.unref();
|
|
267
|
+
// Longer delay to let the child process start and write its own PID file.
|
|
268
|
+
// 100ms was too short on Windows; the child's checkExistingDaemon() would
|
|
269
|
+
// find the parent-written PID and return early (#1478 Bug 1).
|
|
270
|
+
await new Promise(resolve => setTimeout(resolve, 500));
|
|
271
|
+
// Write PID file only if the child hasn't already written its own.
|
|
272
|
+
// The foreground child calls writePidFile() internally, but on some platforms
|
|
273
|
+
// it may not have started yet, so we write as a fallback.
|
|
274
|
+
if (!fs.existsSync(pidFile)) {
|
|
275
|
+
fs.writeFileSync(pidFile, String(pid));
|
|
276
|
+
}
|
|
277
|
+
if (!quiet) {
|
|
278
|
+
output.printSuccess(`Daemon started in background (PID: ${pid})`);
|
|
279
|
+
output.printInfo(`Logs: ${logFile}`);
|
|
280
|
+
output.printInfo(`Stop with: claude-flow daemon stop`);
|
|
281
|
+
}
|
|
282
|
+
return { success: true };
|
|
283
|
+
}
|
|
284
|
+
// Stop daemon subcommand
|
|
285
|
+
const stopCommand = {
|
|
286
|
+
name: 'stop',
|
|
287
|
+
description: 'Stop the worker daemon and all background workers',
|
|
288
|
+
options: [
|
|
289
|
+
{ name: 'quiet', short: 'Q', type: 'boolean', description: 'Suppress output' },
|
|
290
|
+
],
|
|
291
|
+
examples: [
|
|
292
|
+
{ command: 'claude-flow daemon stop', description: 'Stop the daemon' },
|
|
293
|
+
],
|
|
294
|
+
action: async (ctx) => {
|
|
295
|
+
const quiet = ctx.flags.quiet;
|
|
296
|
+
const projectRoot = process.cwd();
|
|
297
|
+
try {
|
|
298
|
+
if (!quiet) {
|
|
299
|
+
const spinner = output.createSpinner({ text: 'Stopping worker daemon...', spinner: 'dots' });
|
|
300
|
+
spinner.start();
|
|
301
|
+
// Try to stop in-process daemon first
|
|
302
|
+
await stopDaemon();
|
|
303
|
+
// Also kill any background daemon by PID
|
|
304
|
+
const killed = await killBackgroundDaemon(projectRoot);
|
|
305
|
+
spinner.succeed(killed ? 'Worker daemon stopped' : 'Worker daemon was not running');
|
|
306
|
+
}
|
|
307
|
+
else {
|
|
308
|
+
await stopDaemon();
|
|
309
|
+
await killBackgroundDaemon(projectRoot);
|
|
310
|
+
}
|
|
311
|
+
return { success: true };
|
|
312
|
+
}
|
|
313
|
+
catch (error) {
|
|
314
|
+
output.printError(`Failed to stop daemon: ${error instanceof Error ? error.message : String(error)}`);
|
|
315
|
+
return { success: false, exitCode: 1 };
|
|
316
|
+
}
|
|
317
|
+
},
|
|
318
|
+
};
|
|
319
|
+
/**
|
|
320
|
+
* Kill background daemon process using PID file
|
|
321
|
+
*/
|
|
322
|
+
async function killBackgroundDaemon(projectRoot) {
|
|
323
|
+
const pidFile = join(projectRoot, '.claude-flow', 'daemon.pid');
|
|
324
|
+
if (!fs.existsSync(pidFile)) {
|
|
325
|
+
return false;
|
|
326
|
+
}
|
|
327
|
+
try {
|
|
328
|
+
const pid = parseInt(fs.readFileSync(pidFile, 'utf-8').trim(), 10);
|
|
329
|
+
if (isNaN(pid)) {
|
|
330
|
+
fs.unlinkSync(pidFile);
|
|
331
|
+
return false;
|
|
332
|
+
}
|
|
333
|
+
// Check if process is running
|
|
334
|
+
try {
|
|
335
|
+
process.kill(pid, 0); // Signal 0 = check if alive
|
|
336
|
+
}
|
|
337
|
+
catch {
|
|
338
|
+
// Process not running, clean up stale PID file
|
|
339
|
+
fs.unlinkSync(pidFile);
|
|
340
|
+
return false;
|
|
341
|
+
}
|
|
342
|
+
// Kill the process
|
|
343
|
+
process.kill(pid, 'SIGTERM');
|
|
344
|
+
// Wait a moment then force kill if needed
|
|
345
|
+
await new Promise(resolve => setTimeout(resolve, 1000));
|
|
346
|
+
try {
|
|
347
|
+
process.kill(pid, 0);
|
|
348
|
+
// Still alive, force kill
|
|
349
|
+
process.kill(pid, 'SIGKILL');
|
|
350
|
+
}
|
|
351
|
+
catch {
|
|
352
|
+
// Process terminated
|
|
353
|
+
}
|
|
354
|
+
// Clean up PID file
|
|
355
|
+
if (fs.existsSync(pidFile)) {
|
|
356
|
+
fs.unlinkSync(pidFile);
|
|
357
|
+
}
|
|
358
|
+
return true;
|
|
359
|
+
}
|
|
360
|
+
catch (error) {
|
|
361
|
+
// Clean up PID file on any error
|
|
362
|
+
if (fs.existsSync(pidFile)) {
|
|
363
|
+
fs.unlinkSync(pidFile);
|
|
364
|
+
}
|
|
365
|
+
return false;
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
/**
|
|
369
|
+
* Get PID of background daemon from PID file
|
|
370
|
+
*/
|
|
371
|
+
function getBackgroundDaemonPid(projectRoot) {
|
|
372
|
+
const pidFile = join(projectRoot, '.claude-flow', 'daemon.pid');
|
|
373
|
+
if (!fs.existsSync(pidFile)) {
|
|
374
|
+
return null;
|
|
375
|
+
}
|
|
376
|
+
try {
|
|
377
|
+
const pid = parseInt(fs.readFileSync(pidFile, 'utf-8').trim(), 10);
|
|
378
|
+
return isNaN(pid) ? null : pid;
|
|
379
|
+
}
|
|
380
|
+
catch {
|
|
381
|
+
return null;
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
/**
|
|
385
|
+
* Check if a process is running
|
|
386
|
+
*/
|
|
387
|
+
function isProcessRunning(pid) {
|
|
388
|
+
try {
|
|
389
|
+
process.kill(pid, 0); // Signal 0 = check if alive
|
|
390
|
+
return true;
|
|
391
|
+
}
|
|
392
|
+
catch {
|
|
393
|
+
return false;
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
// Status subcommand
|
|
397
|
+
const statusCommand = {
|
|
398
|
+
name: 'status',
|
|
399
|
+
description: 'Show daemon and worker status',
|
|
400
|
+
options: [
|
|
401
|
+
{ name: 'verbose', short: 'v', type: 'boolean', description: 'Show detailed worker statistics' },
|
|
402
|
+
{ name: 'show-modes', type: 'boolean', description: 'Show worker execution modes (local/headless) and sandbox settings' },
|
|
403
|
+
],
|
|
404
|
+
examples: [
|
|
405
|
+
{ command: 'claude-flow daemon status', description: 'Show daemon status' },
|
|
406
|
+
{ command: 'claude-flow daemon status -v', description: 'Show detailed status' },
|
|
407
|
+
{ command: 'claude-flow daemon status --show-modes', description: 'Show worker execution modes' },
|
|
408
|
+
],
|
|
409
|
+
action: async (ctx) => {
|
|
410
|
+
const verbose = ctx.flags.verbose;
|
|
411
|
+
const showModes = ctx.flags['show-modes'];
|
|
412
|
+
const projectRoot = process.cwd();
|
|
413
|
+
try {
|
|
414
|
+
const daemon = getDaemon(projectRoot);
|
|
415
|
+
const status = daemon.getStatus();
|
|
416
|
+
// Also check for background daemon
|
|
417
|
+
const bgPid = getBackgroundDaemonPid(projectRoot);
|
|
418
|
+
const bgRunning = bgPid ? isProcessRunning(bgPid) : false;
|
|
419
|
+
const isRunning = status.running || bgRunning;
|
|
420
|
+
const displayPid = bgPid || status.pid;
|
|
421
|
+
output.writeln();
|
|
422
|
+
// Daemon status box
|
|
423
|
+
const statusIcon = isRunning ? output.success('●') : output.error('○');
|
|
424
|
+
const statusText = isRunning ? output.success('RUNNING') : output.error('STOPPED');
|
|
425
|
+
const mode = bgRunning ? output.dim(' (background)') : status.running ? output.dim(' (foreground)') : '';
|
|
426
|
+
output.printBox([
|
|
427
|
+
`Status: ${statusIcon} ${statusText}${mode}`,
|
|
428
|
+
`PID: ${displayPid}`,
|
|
429
|
+
status.startedAt ? `Started: ${status.startedAt.toISOString()}` : '',
|
|
430
|
+
`Workers Enabled: ${status.config.workers.filter(w => w.enabled).length}`,
|
|
431
|
+
`Max Concurrent: ${status.config.maxConcurrent}`,
|
|
432
|
+
`Max CPU Load: ${status.config.resourceThresholds.maxCpuLoad}`,
|
|
433
|
+
`Min Free Memory: ${status.config.resourceThresholds.minFreeMemoryPercent}%`,
|
|
434
|
+
].filter(Boolean).join('\n'), 'Odd Flow Daemon');
|
|
435
|
+
output.writeln();
|
|
436
|
+
output.writeln(output.bold('Worker Status'));
|
|
437
|
+
const workerData = status.config.workers.map(w => {
|
|
438
|
+
const state = status.workers.get(w.type);
|
|
439
|
+
// Check for headless mode from worker config or state
|
|
440
|
+
const isHeadless = w.headless || state?.headless || false;
|
|
441
|
+
const sandboxMode = w.sandbox || state?.sandbox || null;
|
|
442
|
+
return {
|
|
443
|
+
type: w.enabled ? output.highlight(w.type) : output.dim(w.type),
|
|
444
|
+
enabled: w.enabled ? output.success('✓') : output.dim('○'),
|
|
445
|
+
status: state?.isRunning ? output.warning('running') :
|
|
446
|
+
w.enabled ? output.success('idle') : output.dim('disabled'),
|
|
447
|
+
runs: state?.runCount ?? 0,
|
|
448
|
+
success: state ? `${Math.round((state.successCount / Math.max(state.runCount, 1)) * 100)}%` : '-',
|
|
449
|
+
lastRun: state?.lastRun ? formatTimeAgo(state.lastRun) : output.dim('never'),
|
|
450
|
+
nextRun: state?.nextRun && w.enabled ? formatTimeUntil(state.nextRun) : output.dim('-'),
|
|
451
|
+
mode: isHeadless ? output.highlight('headless') : output.dim('local'),
|
|
452
|
+
sandbox: isHeadless ? (sandboxMode || 'strict') : output.dim('-'),
|
|
453
|
+
};
|
|
454
|
+
});
|
|
455
|
+
// Build columns based on --show-modes flag
|
|
456
|
+
const baseColumns = [
|
|
457
|
+
{ key: 'type', header: 'Worker', width: 12 },
|
|
458
|
+
{ key: 'enabled', header: 'On', width: 4 },
|
|
459
|
+
{ key: 'status', header: 'Status', width: 10 },
|
|
460
|
+
{ key: 'runs', header: 'Runs', width: 6 },
|
|
461
|
+
{ key: 'success', header: 'Success', width: 8 },
|
|
462
|
+
{ key: 'lastRun', header: 'Last Run', width: 12 },
|
|
463
|
+
{ key: 'nextRun', header: 'Next Run', width: 12 },
|
|
464
|
+
];
|
|
465
|
+
const modeColumns = showModes ? [
|
|
466
|
+
{ key: 'mode', header: 'Mode', width: 10 },
|
|
467
|
+
{ key: 'sandbox', header: 'Sandbox', width: 12 },
|
|
468
|
+
] : [];
|
|
469
|
+
output.printTable({
|
|
470
|
+
columns: [...baseColumns, ...modeColumns],
|
|
471
|
+
data: workerData,
|
|
472
|
+
});
|
|
473
|
+
if (verbose) {
|
|
474
|
+
output.writeln();
|
|
475
|
+
output.writeln(output.bold('Worker Configuration'));
|
|
476
|
+
output.printTable({
|
|
477
|
+
columns: [
|
|
478
|
+
{ key: 'type', header: 'Worker', width: 12 },
|
|
479
|
+
{ key: 'interval', header: 'Interval', width: 10 },
|
|
480
|
+
{ key: 'priority', header: 'Priority', width: 10 },
|
|
481
|
+
{ key: 'avgDuration', header: 'Avg Duration', width: 12 },
|
|
482
|
+
{ key: 'description', header: 'Description', width: 30 },
|
|
483
|
+
],
|
|
484
|
+
data: status.config.workers.map(w => {
|
|
485
|
+
const state = status.workers.get(w.type);
|
|
486
|
+
return {
|
|
487
|
+
type: w.type,
|
|
488
|
+
interval: `${Math.round(w.intervalMs / 60000)}min`,
|
|
489
|
+
priority: w.priority,
|
|
490
|
+
avgDuration: state?.averageDurationMs ? `${Math.round(state.averageDurationMs)}ms` : '-',
|
|
491
|
+
description: w.description,
|
|
492
|
+
};
|
|
493
|
+
}),
|
|
494
|
+
});
|
|
495
|
+
}
|
|
496
|
+
return { success: true, data: status };
|
|
497
|
+
}
|
|
498
|
+
catch (error) {
|
|
499
|
+
// Daemon not initialized
|
|
500
|
+
output.writeln();
|
|
501
|
+
output.printBox([
|
|
502
|
+
`Status: ${output.error('○')} ${output.error('NOT INITIALIZED')}`,
|
|
503
|
+
'',
|
|
504
|
+
'Run "claude-flow daemon start" to start the daemon',
|
|
505
|
+
].join('\n'), 'Odd Flow Daemon');
|
|
506
|
+
return { success: true };
|
|
507
|
+
}
|
|
508
|
+
},
|
|
509
|
+
};
|
|
510
|
+
// Trigger subcommand - manually run a worker
|
|
511
|
+
const triggerCommand = {
|
|
512
|
+
name: 'trigger',
|
|
513
|
+
description: 'Manually trigger a specific worker',
|
|
514
|
+
options: [
|
|
515
|
+
{ name: 'worker', short: 'w', type: 'string', description: 'Worker type to trigger', required: true },
|
|
516
|
+
{ name: 'headless', type: 'boolean', description: 'Run triggered worker in headless mode (E2B sandbox)' },
|
|
517
|
+
],
|
|
518
|
+
examples: [
|
|
519
|
+
{ command: 'claude-flow daemon trigger -w map', description: 'Trigger the map worker' },
|
|
520
|
+
{ command: 'claude-flow daemon trigger -w audit', description: 'Trigger security audit' },
|
|
521
|
+
{ command: 'claude-flow daemon trigger -w audit --headless', description: 'Trigger audit in headless sandbox' },
|
|
522
|
+
],
|
|
523
|
+
action: async (ctx) => {
|
|
524
|
+
const workerType = ctx.flags.worker;
|
|
525
|
+
if (!workerType) {
|
|
526
|
+
output.printError('Worker type is required. Use --worker or -w flag.');
|
|
527
|
+
output.writeln();
|
|
528
|
+
output.writeln('Available workers: map, audit, optimize, consolidate, testgaps, predict, document, ultralearn, refactor, benchmark, deepdive, preload');
|
|
529
|
+
return { success: false, exitCode: 1 };
|
|
530
|
+
}
|
|
531
|
+
try {
|
|
532
|
+
const daemon = getDaemon(process.cwd());
|
|
533
|
+
const spinner = output.createSpinner({ text: `Running ${workerType} worker...`, spinner: 'dots' });
|
|
534
|
+
spinner.start();
|
|
535
|
+
const result = await daemon.triggerWorker(workerType);
|
|
536
|
+
if (result.success) {
|
|
537
|
+
spinner.succeed(`Worker ${workerType} completed in ${result.durationMs}ms`);
|
|
538
|
+
if (result.output) {
|
|
539
|
+
output.writeln();
|
|
540
|
+
output.writeln(output.bold('Output'));
|
|
541
|
+
output.printJson(result.output);
|
|
542
|
+
}
|
|
543
|
+
}
|
|
544
|
+
else {
|
|
545
|
+
spinner.fail(`Worker ${workerType} failed: ${result.error}`);
|
|
546
|
+
}
|
|
547
|
+
return { success: result.success, data: result };
|
|
548
|
+
}
|
|
549
|
+
catch (error) {
|
|
550
|
+
output.printError(`Failed to trigger worker: ${error instanceof Error ? error.message : String(error)}`);
|
|
551
|
+
return { success: false, exitCode: 1 };
|
|
552
|
+
}
|
|
553
|
+
},
|
|
554
|
+
};
|
|
555
|
+
// Enable/disable worker subcommand
|
|
556
|
+
const enableCommand = {
|
|
557
|
+
name: 'enable',
|
|
558
|
+
description: 'Enable or disable a specific worker',
|
|
559
|
+
options: [
|
|
560
|
+
{ name: 'worker', short: 'w', type: 'string', description: 'Worker type', required: true },
|
|
561
|
+
{ name: 'disable', short: 'd', type: 'boolean', description: 'Disable instead of enable' },
|
|
562
|
+
],
|
|
563
|
+
examples: [
|
|
564
|
+
{ command: 'claude-flow daemon enable -w predict', description: 'Enable predict worker' },
|
|
565
|
+
{ command: 'claude-flow daemon enable -w document --disable', description: 'Disable document worker' },
|
|
566
|
+
],
|
|
567
|
+
action: async (ctx) => {
|
|
568
|
+
const workerType = ctx.flags.worker;
|
|
569
|
+
const disable = ctx.flags.disable;
|
|
570
|
+
if (!workerType) {
|
|
571
|
+
output.printError('Worker type is required. Use --worker or -w flag.');
|
|
572
|
+
return { success: false, exitCode: 1 };
|
|
573
|
+
}
|
|
574
|
+
try {
|
|
575
|
+
const daemon = getDaemon(process.cwd());
|
|
576
|
+
daemon.setWorkerEnabled(workerType, !disable);
|
|
577
|
+
output.printSuccess(`Worker ${workerType} ${disable ? 'disabled' : 'enabled'}`);
|
|
578
|
+
return { success: true };
|
|
579
|
+
}
|
|
580
|
+
catch (error) {
|
|
581
|
+
output.printError(`Failed to ${disable ? 'disable' : 'enable'} worker: ${error instanceof Error ? error.message : String(error)}`);
|
|
582
|
+
return { success: false, exitCode: 1 };
|
|
583
|
+
}
|
|
584
|
+
},
|
|
585
|
+
};
|
|
586
|
+
// Helper functions for time formatting
|
|
587
|
+
function formatTimeAgo(date) {
|
|
588
|
+
const seconds = Math.floor((Date.now() - date.getTime()) / 1000);
|
|
589
|
+
if (seconds < 60)
|
|
590
|
+
return `${seconds}s ago`;
|
|
591
|
+
if (seconds < 3600)
|
|
592
|
+
return `${Math.floor(seconds / 60)}m ago`;
|
|
593
|
+
if (seconds < 86400)
|
|
594
|
+
return `${Math.floor(seconds / 3600)}h ago`;
|
|
595
|
+
return `${Math.floor(seconds / 86400)}d ago`;
|
|
596
|
+
}
|
|
597
|
+
function formatTimeUntil(date) {
|
|
598
|
+
const seconds = Math.floor((date.getTime() - Date.now()) / 1000);
|
|
599
|
+
if (seconds < 0)
|
|
600
|
+
return 'now';
|
|
601
|
+
if (seconds < 60)
|
|
602
|
+
return `in ${seconds}s`;
|
|
603
|
+
if (seconds < 3600)
|
|
604
|
+
return `in ${Math.floor(seconds / 60)}m`;
|
|
605
|
+
if (seconds < 86400)
|
|
606
|
+
return `in ${Math.floor(seconds / 3600)}h`;
|
|
607
|
+
return `in ${Math.floor(seconds / 86400)}d`;
|
|
608
|
+
}
|
|
609
|
+
// Main daemon command
|
|
610
|
+
export const daemonCommand = {
|
|
611
|
+
name: 'daemon',
|
|
612
|
+
description: 'Manage background worker daemon (Node.js-based, auto-runs like shell helpers)',
|
|
613
|
+
subcommands: [
|
|
614
|
+
startCommand,
|
|
615
|
+
stopCommand,
|
|
616
|
+
statusCommand,
|
|
617
|
+
triggerCommand,
|
|
618
|
+
enableCommand,
|
|
619
|
+
],
|
|
620
|
+
options: [],
|
|
621
|
+
examples: [
|
|
622
|
+
{ command: 'claude-flow daemon start', description: 'Start the daemon' },
|
|
623
|
+
{ command: 'claude-flow daemon start --headless', description: 'Start with headless workers (E2B sandbox)' },
|
|
624
|
+
{ command: 'claude-flow daemon status', description: 'Check daemon status' },
|
|
625
|
+
{ command: 'claude-flow daemon stop', description: 'Stop the daemon' },
|
|
626
|
+
{ command: 'claude-flow daemon trigger -w audit', description: 'Run security audit' },
|
|
627
|
+
],
|
|
628
|
+
action: async () => {
|
|
629
|
+
output.writeln();
|
|
630
|
+
output.writeln(output.bold('Odd Flow Daemon - Background Task Management'));
|
|
631
|
+
output.writeln();
|
|
632
|
+
output.writeln('Node.js-based background worker system that auto-runs like shell daemons.');
|
|
633
|
+
output.writeln('Manages 12 specialized workers for continuous optimization and monitoring.');
|
|
634
|
+
output.writeln();
|
|
635
|
+
output.writeln(output.bold('Headless Mode'));
|
|
636
|
+
output.writeln('Workers can run in headless mode using E2B sandboxes for isolated execution.');
|
|
637
|
+
output.writeln('Use --headless flag with start/trigger commands. Sandbox modes: strict, permissive, disabled.');
|
|
638
|
+
output.writeln();
|
|
639
|
+
output.writeln(output.bold('Available Workers'));
|
|
640
|
+
output.printList([
|
|
641
|
+
`${output.highlight('map')} - Codebase mapping (5 min interval)`,
|
|
642
|
+
`${output.highlight('audit')} - Security analysis (10 min interval)`,
|
|
643
|
+
`${output.highlight('optimize')} - Performance optimization (15 min interval)`,
|
|
644
|
+
`${output.highlight('consolidate')} - Memory consolidation (30 min interval)`,
|
|
645
|
+
`${output.highlight('testgaps')} - Test coverage analysis (20 min interval)`,
|
|
646
|
+
`${output.highlight('predict')} - Predictive preloading (2 min, disabled by default)`,
|
|
647
|
+
`${output.highlight('document')} - Auto-documentation (60 min, disabled by default)`,
|
|
648
|
+
`${output.highlight('ultralearn')} - Deep knowledge acquisition (manual trigger)`,
|
|
649
|
+
`${output.highlight('refactor')} - Code refactoring suggestions (manual trigger)`,
|
|
650
|
+
`${output.highlight('benchmark')} - Performance benchmarking (manual trigger)`,
|
|
651
|
+
`${output.highlight('deepdive')} - Deep code analysis (manual trigger)`,
|
|
652
|
+
`${output.highlight('preload')} - Resource preloading (manual trigger)`,
|
|
653
|
+
]);
|
|
654
|
+
output.writeln();
|
|
655
|
+
output.writeln(output.bold('Subcommands'));
|
|
656
|
+
output.printList([
|
|
657
|
+
`${output.highlight('start')} - Start the daemon`,
|
|
658
|
+
`${output.highlight('stop')} - Stop the daemon`,
|
|
659
|
+
`${output.highlight('status')} - Show daemon status`,
|
|
660
|
+
`${output.highlight('trigger')} - Manually run a worker`,
|
|
661
|
+
`${output.highlight('enable')} - Enable/disable a worker`,
|
|
662
|
+
]);
|
|
663
|
+
output.writeln();
|
|
664
|
+
output.writeln('Run "claude-flow daemon <subcommand> --help" for details');
|
|
665
|
+
return { success: true };
|
|
666
|
+
},
|
|
667
|
+
};
|
|
668
|
+
export default daemonCommand;
|
|
669
|
+
//# sourceMappingURL=daemon.js.map
|