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,960 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Worker Daemon Service
|
|
3
|
+
* Node.js-based background worker system that auto-runs like shell daemons
|
|
4
|
+
*
|
|
5
|
+
* Workers:
|
|
6
|
+
* - map: Codebase mapping (5 min interval)
|
|
7
|
+
* - audit: Security analysis (10 min interval)
|
|
8
|
+
* - optimize: Performance optimization (15 min interval)
|
|
9
|
+
* - consolidate: Memory consolidation (30 min interval)
|
|
10
|
+
* - testgaps: Test coverage analysis (20 min interval)
|
|
11
|
+
*/
|
|
12
|
+
import { EventEmitter } from 'events';
|
|
13
|
+
import { existsSync, mkdirSync, writeFileSync, readFileSync, appendFileSync, unlinkSync } from 'fs';
|
|
14
|
+
import { cpus } from 'os';
|
|
15
|
+
import { join } from 'path';
|
|
16
|
+
import { HeadlessWorkerExecutor, isHeadlessWorker, } from './headless-worker-executor.js';
|
|
17
|
+
// Default worker configurations with improved intervals (P0 fix: map 5min -> 15min)
|
|
18
|
+
const DEFAULT_WORKERS = [
|
|
19
|
+
{ type: 'map', intervalMs: 15 * 60 * 1000, offsetMs: 0, priority: 'normal', description: 'Codebase mapping', enabled: true },
|
|
20
|
+
{ type: 'audit', intervalMs: 10 * 60 * 1000, offsetMs: 2 * 60 * 1000, priority: 'critical', description: 'Security analysis', enabled: true },
|
|
21
|
+
{ type: 'optimize', intervalMs: 15 * 60 * 1000, offsetMs: 4 * 60 * 1000, priority: 'high', description: 'Performance optimization', enabled: true },
|
|
22
|
+
{ type: 'consolidate', intervalMs: 30 * 60 * 1000, offsetMs: 6 * 60 * 1000, priority: 'low', description: 'Memory consolidation', enabled: true },
|
|
23
|
+
{ type: 'testgaps', intervalMs: 20 * 60 * 1000, offsetMs: 8 * 60 * 1000, priority: 'normal', description: 'Test coverage analysis', enabled: true },
|
|
24
|
+
{ type: 'predict', intervalMs: 10 * 60 * 1000, offsetMs: 0, priority: 'low', description: 'Predictive preloading', enabled: false },
|
|
25
|
+
{ type: 'document', intervalMs: 60 * 60 * 1000, offsetMs: 0, priority: 'low', description: 'Auto-documentation', enabled: false },
|
|
26
|
+
];
|
|
27
|
+
// Worker timeout — must exceed the longest per-worker headless timeout (15 min for audit/refactor).
|
|
28
|
+
// Previously 5 min, which caused orphan processes when daemon timeout fired before executor timeout (#1117).
|
|
29
|
+
const DEFAULT_WORKER_TIMEOUT_MS = 16 * 60 * 1000;
|
|
30
|
+
/**
|
|
31
|
+
* Worker Daemon - Manages background workers with Node.js
|
|
32
|
+
*/
|
|
33
|
+
export class WorkerDaemon extends EventEmitter {
|
|
34
|
+
config;
|
|
35
|
+
workers = new Map();
|
|
36
|
+
timers = new Map();
|
|
37
|
+
running = false;
|
|
38
|
+
startedAt;
|
|
39
|
+
projectRoot;
|
|
40
|
+
runningWorkers = new Set(); // Track concurrent workers
|
|
41
|
+
pendingWorkers = []; // Queue for deferred workers
|
|
42
|
+
// Headless execution support
|
|
43
|
+
headlessExecutor = null;
|
|
44
|
+
headlessAvailable = false;
|
|
45
|
+
// Preserve the original constructor config so we can detect explicit overrides
|
|
46
|
+
// during state restoration (R1: constructor config takes priority over stale state)
|
|
47
|
+
originalConfig;
|
|
48
|
+
constructor(projectRoot, config) {
|
|
49
|
+
super();
|
|
50
|
+
this.projectRoot = projectRoot;
|
|
51
|
+
this.originalConfig = config;
|
|
52
|
+
const claudeFlowDir = join(projectRoot, '.claude-flow');
|
|
53
|
+
// Read daemon config from .claude-flow/config.json (Layer B)
|
|
54
|
+
const fileConfig = this.readDaemonConfigFromFile(claudeFlowDir);
|
|
55
|
+
// CPU-proportional smart default instead of hardcoded 2.0
|
|
56
|
+
const cpuCount = WorkerDaemon.getEffectiveCpuCount();
|
|
57
|
+
const smartMaxCpuLoad = Math.max(cpuCount * 0.8, 2.0); // Floor of 2.0 for single-CPU machines
|
|
58
|
+
// Platform-aware default: macOS os.freemem() excludes reclaimable file cache,
|
|
59
|
+
// so reported "free" is much lower than actually available memory.
|
|
60
|
+
// Linux reports available memory (including reclaimable cache) more accurately.
|
|
61
|
+
const defaultMinFreeMemory = process.platform === 'darwin' ? 5 : 10;
|
|
62
|
+
// Priority: constructor arg > config.json > smart default
|
|
63
|
+
// For resourceThresholds, merge field-by-field so partial overrides
|
|
64
|
+
// (e.g. only --max-cpu-load) still pick up defaults for other fields.
|
|
65
|
+
this.config = {
|
|
66
|
+
autoStart: config?.autoStart ?? fileConfig.autoStart ?? false,
|
|
67
|
+
logDir: config?.logDir ?? join(claudeFlowDir, 'logs'),
|
|
68
|
+
stateFile: config?.stateFile ?? join(claudeFlowDir, 'daemon-state.json'),
|
|
69
|
+
maxConcurrent: config?.maxConcurrent ?? fileConfig.maxConcurrent ?? 2,
|
|
70
|
+
workerTimeoutMs: config?.workerTimeoutMs ?? fileConfig.workerTimeoutMs ?? DEFAULT_WORKER_TIMEOUT_MS,
|
|
71
|
+
resourceThresholds: {
|
|
72
|
+
maxCpuLoad: config?.resourceThresholds?.maxCpuLoad ?? fileConfig.maxCpuLoad ?? smartMaxCpuLoad,
|
|
73
|
+
minFreeMemoryPercent: config?.resourceThresholds?.minFreeMemoryPercent ?? fileConfig.minFreeMemoryPercent ?? defaultMinFreeMemory,
|
|
74
|
+
},
|
|
75
|
+
workers: config?.workers ?? DEFAULT_WORKERS,
|
|
76
|
+
};
|
|
77
|
+
// Setup graceful shutdown handlers
|
|
78
|
+
this.setupShutdownHandlers();
|
|
79
|
+
// Ensure directories exist
|
|
80
|
+
if (!existsSync(claudeFlowDir)) {
|
|
81
|
+
mkdirSync(claudeFlowDir, { recursive: true });
|
|
82
|
+
}
|
|
83
|
+
if (!existsSync(this.config.logDir)) {
|
|
84
|
+
mkdirSync(this.config.logDir, { recursive: true });
|
|
85
|
+
}
|
|
86
|
+
// Initialize worker states
|
|
87
|
+
this.initializeWorkerStates();
|
|
88
|
+
// Initialize headless executor (async, non-blocking)
|
|
89
|
+
this.initHeadlessExecutor().catch((err) => {
|
|
90
|
+
this.log('warn', `Headless executor init failed: ${err}`);
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Initialize headless executor if Claude Code is available
|
|
95
|
+
*/
|
|
96
|
+
async initHeadlessExecutor() {
|
|
97
|
+
try {
|
|
98
|
+
this.headlessExecutor = new HeadlessWorkerExecutor(this.projectRoot, {
|
|
99
|
+
maxConcurrent: this.config.maxConcurrent,
|
|
100
|
+
});
|
|
101
|
+
this.headlessAvailable = await this.headlessExecutor.isAvailable();
|
|
102
|
+
if (this.headlessAvailable) {
|
|
103
|
+
this.log('info', 'Claude Code headless mode available - AI workers enabled');
|
|
104
|
+
// Forward headless executor events
|
|
105
|
+
this.headlessExecutor.on('execution:start', (data) => {
|
|
106
|
+
this.emit('headless:start', data);
|
|
107
|
+
});
|
|
108
|
+
this.headlessExecutor.on('execution:complete', (data) => {
|
|
109
|
+
this.emit('headless:complete', data);
|
|
110
|
+
});
|
|
111
|
+
this.headlessExecutor.on('execution:error', (data) => {
|
|
112
|
+
this.emit('headless:error', data);
|
|
113
|
+
});
|
|
114
|
+
this.headlessExecutor.on('output', (data) => {
|
|
115
|
+
this.emit('headless:output', data);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
this.log('info', 'Claude Code not found - AI workers will run in local fallback mode');
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
catch (error) {
|
|
123
|
+
this.log('warn', `Failed to initialize headless executor: ${error}`);
|
|
124
|
+
this.headlessAvailable = false;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Check if headless execution is available
|
|
129
|
+
*/
|
|
130
|
+
isHeadlessAvailable() {
|
|
131
|
+
return this.headlessAvailable;
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Get headless executor instance
|
|
135
|
+
*/
|
|
136
|
+
getHeadlessExecutor() {
|
|
137
|
+
return this.headlessExecutor;
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Detect effective CPU count for the current environment.
|
|
141
|
+
*
|
|
142
|
+
* Inside Docker / K8s containers, os.cpus().length reports the HOST cpu
|
|
143
|
+
* count, not the container limit (Node.js #28762 — wontfix). We read
|
|
144
|
+
* cgroup v2 / v1 quota files first so the maxCpuLoad threshold stays
|
|
145
|
+
* meaningful under resource-limited containers.
|
|
146
|
+
*/
|
|
147
|
+
static getEffectiveCpuCount() {
|
|
148
|
+
// 1. Try cgroup v2: /sys/fs/cgroup/cpu.max
|
|
149
|
+
try {
|
|
150
|
+
const cpuMax = readFileSync('/sys/fs/cgroup/cpu.max', 'utf8').trim();
|
|
151
|
+
const [quotaStr, periodStr] = cpuMax.split(' ');
|
|
152
|
+
if (quotaStr !== 'max') {
|
|
153
|
+
const quota = parseInt(quotaStr, 10);
|
|
154
|
+
const period = parseInt(periodStr, 10);
|
|
155
|
+
if (quota > 0 && period > 0)
|
|
156
|
+
return Math.ceil(quota / period);
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
catch { /* not in cgroup v2 */ }
|
|
160
|
+
// 2. Try cgroup v1: /sys/fs/cgroup/cpu/cpu.cfs_quota_us
|
|
161
|
+
try {
|
|
162
|
+
const quota = parseInt(readFileSync('/sys/fs/cgroup/cpu/cpu.cfs_quota_us', 'utf8').trim(), 10);
|
|
163
|
+
const period = parseInt(readFileSync('/sys/fs/cgroup/cpu/cpu.cfs_period_us', 'utf8').trim(), 10);
|
|
164
|
+
if (quota > 0 && period > 0)
|
|
165
|
+
return Math.ceil(quota / period);
|
|
166
|
+
}
|
|
167
|
+
catch { /* not in cgroup v1 */ }
|
|
168
|
+
// 3. Fallback to os.cpus().length
|
|
169
|
+
return cpus().length || 1;
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Read daemon-specific config from .claude-flow/config.json
|
|
173
|
+
* Supports dot-notation keys like 'daemon.resourceThresholds.maxCpuLoad'
|
|
174
|
+
*/
|
|
175
|
+
readDaemonConfigFromFile(claudeFlowDir) {
|
|
176
|
+
const configPath = join(claudeFlowDir, 'config.json');
|
|
177
|
+
if (!existsSync(configPath)) {
|
|
178
|
+
// Warn if config.yaml exists but config.json does not (#1395 Bug 4)
|
|
179
|
+
const yamlPath = join(claudeFlowDir, 'config.yaml');
|
|
180
|
+
const ymlPath = join(claudeFlowDir, 'config.yml');
|
|
181
|
+
if (existsSync(yamlPath) || existsSync(ymlPath)) {
|
|
182
|
+
this.log('warn', `Found ${existsSync(yamlPath) ? 'config.yaml' : 'config.yml'} but daemon reads only config.json — YAML config is being ignored. Convert to JSON or create config.json.`);
|
|
183
|
+
}
|
|
184
|
+
return {};
|
|
185
|
+
}
|
|
186
|
+
try {
|
|
187
|
+
const raw = JSON.parse(readFileSync(configPath, 'utf-8'));
|
|
188
|
+
// Support both flat keys at root and nested under scopes.project
|
|
189
|
+
const cfg = raw?.scopes?.project ?? raw;
|
|
190
|
+
const rawCpuLoad = cfg['daemon.resourceThresholds.maxCpuLoad'] ?? raw['daemon.resourceThresholds.maxCpuLoad'];
|
|
191
|
+
const rawMinMem = cfg['daemon.resourceThresholds.minFreeMemoryPercent'] ?? raw['daemon.resourceThresholds.minFreeMemoryPercent'];
|
|
192
|
+
const rawMaxConcurrent = cfg['daemon.maxConcurrent'] ?? raw['daemon.maxConcurrent'];
|
|
193
|
+
const rawTimeout = cfg['daemon.workerTimeoutMs'] ?? raw['daemon.workerTimeoutMs'];
|
|
194
|
+
return {
|
|
195
|
+
autoStart: typeof raw['daemon.autoStart'] === 'boolean' ? raw['daemon.autoStart'] : undefined,
|
|
196
|
+
maxConcurrent: (typeof rawMaxConcurrent === 'number' && rawMaxConcurrent > 0) ? rawMaxConcurrent : undefined,
|
|
197
|
+
workerTimeoutMs: (typeof rawTimeout === 'number' && rawTimeout > 0) ? rawTimeout : undefined,
|
|
198
|
+
maxCpuLoad: (typeof rawCpuLoad === 'number' && rawCpuLoad > 0 && rawCpuLoad < 1000) ? rawCpuLoad : undefined,
|
|
199
|
+
minFreeMemoryPercent: (typeof rawMinMem === 'number' && rawMinMem >= 0 && rawMinMem <= 100) ? rawMinMem : undefined,
|
|
200
|
+
};
|
|
201
|
+
}
|
|
202
|
+
catch {
|
|
203
|
+
return {};
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
/**
|
|
207
|
+
* Setup graceful shutdown handlers
|
|
208
|
+
*/
|
|
209
|
+
setupShutdownHandlers() {
|
|
210
|
+
const shutdown = async () => {
|
|
211
|
+
this.log('info', 'Received shutdown signal, stopping daemon...');
|
|
212
|
+
await this.stop();
|
|
213
|
+
process.exit(0);
|
|
214
|
+
};
|
|
215
|
+
process.on('SIGTERM', shutdown);
|
|
216
|
+
process.on('SIGINT', shutdown);
|
|
217
|
+
process.on('SIGHUP', shutdown);
|
|
218
|
+
}
|
|
219
|
+
/**
|
|
220
|
+
* Check if system resources allow worker execution
|
|
221
|
+
*/
|
|
222
|
+
async canRunWorker() {
|
|
223
|
+
const os = await import('os');
|
|
224
|
+
const cpuLoad = os.loadavg()[0];
|
|
225
|
+
const totalMem = os.totalmem();
|
|
226
|
+
const freeMem = os.freemem();
|
|
227
|
+
const freePercent = (freeMem / totalMem) * 100;
|
|
228
|
+
if (cpuLoad > this.config.resourceThresholds.maxCpuLoad) {
|
|
229
|
+
return { allowed: false, reason: `CPU load too high: ${cpuLoad.toFixed(2)}` };
|
|
230
|
+
}
|
|
231
|
+
if (freePercent < this.config.resourceThresholds.minFreeMemoryPercent) {
|
|
232
|
+
return { allowed: false, reason: `Memory too low: ${freePercent.toFixed(1)}% free` };
|
|
233
|
+
}
|
|
234
|
+
return { allowed: true };
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* Process pending workers queue
|
|
238
|
+
*
|
|
239
|
+
* When executeWorkerWithConcurrencyControl defers a worker (returns null),
|
|
240
|
+
* we break immediately to avoid a busy-wait loop — the deferred worker is
|
|
241
|
+
* already back on the pendingWorkers queue by that point. If no workers are
|
|
242
|
+
* currently running when we break, we schedule a backoff retry so the queue
|
|
243
|
+
* does not get permanently stuck.
|
|
244
|
+
*/
|
|
245
|
+
async processPendingWorkers() {
|
|
246
|
+
while (this.pendingWorkers.length > 0 && this.runningWorkers.size < this.config.maxConcurrent) {
|
|
247
|
+
const workerType = this.pendingWorkers.shift();
|
|
248
|
+
const workerConfig = this.config.workers.find(w => w.type === workerType);
|
|
249
|
+
if (workerConfig) {
|
|
250
|
+
const result = await this.executeWorkerWithConcurrencyControl(workerConfig);
|
|
251
|
+
if (result === null) {
|
|
252
|
+
// Worker was deferred (resource pressure or concurrency limit).
|
|
253
|
+
// Break to avoid tight-looping — the next executeWorker() completion
|
|
254
|
+
// will call processPendingWorkers() again via the finally block.
|
|
255
|
+
if (this.runningWorkers.size === 0) {
|
|
256
|
+
// No workers running means nobody will trigger the finally-block
|
|
257
|
+
// callback, so schedule a backoff retry to avoid a stuck queue.
|
|
258
|
+
setTimeout(() => this.processPendingWorkers(), 30_000).unref();
|
|
259
|
+
}
|
|
260
|
+
break;
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
initializeWorkerStates() {
|
|
266
|
+
// Try to restore state from file
|
|
267
|
+
if (existsSync(this.config.stateFile)) {
|
|
268
|
+
try {
|
|
269
|
+
const saved = JSON.parse(readFileSync(this.config.stateFile, 'utf-8'));
|
|
270
|
+
// CRITICAL: Restore worker config (including enabled flag) from saved state
|
|
271
|
+
// This fixes #950: daemon enable command not persisting worker state
|
|
272
|
+
if (saved.config?.workers && Array.isArray(saved.config.workers)) {
|
|
273
|
+
for (const savedWorker of saved.config.workers) {
|
|
274
|
+
const workerConfig = this.config.workers.find(w => w.type === savedWorker.type);
|
|
275
|
+
if (workerConfig && typeof savedWorker.enabled === 'boolean') {
|
|
276
|
+
workerConfig.enabled = savedWorker.enabled;
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
// Restore resourceThresholds, maxConcurrent, workerTimeoutMs from saved state
|
|
281
|
+
// Only restore if valid numeric values within sane ranges
|
|
282
|
+
if (saved.config?.resourceThresholds && !this.originalConfig?.resourceThresholds) {
|
|
283
|
+
const rt = saved.config.resourceThresholds;
|
|
284
|
+
if (typeof rt.maxCpuLoad === 'number' && rt.maxCpuLoad > 0 && rt.maxCpuLoad < 1000) {
|
|
285
|
+
this.config.resourceThresholds.maxCpuLoad = rt.maxCpuLoad;
|
|
286
|
+
}
|
|
287
|
+
if (typeof rt.minFreeMemoryPercent === 'number' && rt.minFreeMemoryPercent >= 0 && rt.minFreeMemoryPercent <= 100) {
|
|
288
|
+
this.config.resourceThresholds.minFreeMemoryPercent = rt.minFreeMemoryPercent;
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
if (typeof saved.config?.maxConcurrent === 'number' && saved.config.maxConcurrent > 0) {
|
|
292
|
+
this.config.maxConcurrent = saved.config.maxConcurrent;
|
|
293
|
+
}
|
|
294
|
+
if (typeof saved.config?.workerTimeoutMs === 'number' && saved.config.workerTimeoutMs > 0) {
|
|
295
|
+
this.config.workerTimeoutMs = saved.config.workerTimeoutMs;
|
|
296
|
+
}
|
|
297
|
+
// Restore worker runtime states (runCount, successCount, etc.)
|
|
298
|
+
if (saved.workers) {
|
|
299
|
+
for (const [type, state] of Object.entries(saved.workers)) {
|
|
300
|
+
const savedState = state;
|
|
301
|
+
const lastRunValue = savedState.lastRun;
|
|
302
|
+
this.workers.set(type, {
|
|
303
|
+
runCount: savedState.runCount || 0,
|
|
304
|
+
successCount: savedState.successCount || 0,
|
|
305
|
+
failureCount: savedState.failureCount || 0,
|
|
306
|
+
averageDurationMs: savedState.averageDurationMs || 0,
|
|
307
|
+
lastRun: lastRunValue ? new Date(lastRunValue) : undefined,
|
|
308
|
+
nextRun: undefined,
|
|
309
|
+
isRunning: false,
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
catch {
|
|
315
|
+
// Ignore parse errors, start fresh
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
// Initialize any missing workers
|
|
319
|
+
for (const workerConfig of this.config.workers) {
|
|
320
|
+
if (!this.workers.has(workerConfig.type)) {
|
|
321
|
+
this.workers.set(workerConfig.type, {
|
|
322
|
+
runCount: 0,
|
|
323
|
+
successCount: 0,
|
|
324
|
+
failureCount: 0,
|
|
325
|
+
averageDurationMs: 0,
|
|
326
|
+
isRunning: false,
|
|
327
|
+
});
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
/**
|
|
332
|
+
* Get the PID file path for singleton enforcement (#1395 Bug 3).
|
|
333
|
+
*/
|
|
334
|
+
get pidFile() {
|
|
335
|
+
return join(this.projectRoot, '.claude-flow', 'daemon.pid');
|
|
336
|
+
}
|
|
337
|
+
/**
|
|
338
|
+
* Check if another daemon instance is already running.
|
|
339
|
+
* Returns the existing PID if alive, or null if no daemon is running.
|
|
340
|
+
*/
|
|
341
|
+
checkExistingDaemon() {
|
|
342
|
+
if (!existsSync(this.pidFile))
|
|
343
|
+
return null;
|
|
344
|
+
try {
|
|
345
|
+
const pid = parseInt(readFileSync(this.pidFile, 'utf-8').trim(), 10);
|
|
346
|
+
if (isNaN(pid))
|
|
347
|
+
return null;
|
|
348
|
+
// Check if process is alive (signal 0 = existence check)
|
|
349
|
+
process.kill(pid, 0);
|
|
350
|
+
return pid; // Process is alive
|
|
351
|
+
}
|
|
352
|
+
catch {
|
|
353
|
+
// Process is dead — clean up stale PID file
|
|
354
|
+
try {
|
|
355
|
+
unlinkSync(this.pidFile);
|
|
356
|
+
}
|
|
357
|
+
catch { /* ignore */ }
|
|
358
|
+
return null;
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
/**
|
|
362
|
+
* Write PID file for singleton enforcement.
|
|
363
|
+
*/
|
|
364
|
+
writePidFile() {
|
|
365
|
+
const dir = join(this.projectRoot, '.claude-flow');
|
|
366
|
+
if (!existsSync(dir))
|
|
367
|
+
mkdirSync(dir, { recursive: true });
|
|
368
|
+
writeFileSync(this.pidFile, String(process.pid), 'utf-8');
|
|
369
|
+
}
|
|
370
|
+
/**
|
|
371
|
+
* Remove PID file on shutdown.
|
|
372
|
+
*/
|
|
373
|
+
removePidFile() {
|
|
374
|
+
try {
|
|
375
|
+
unlinkSync(this.pidFile);
|
|
376
|
+
}
|
|
377
|
+
catch { /* ignore */ }
|
|
378
|
+
}
|
|
379
|
+
/**
|
|
380
|
+
* Start the daemon and all enabled workers
|
|
381
|
+
*/
|
|
382
|
+
async start() {
|
|
383
|
+
if (this.running) {
|
|
384
|
+
this.emit('warning', 'Daemon already running');
|
|
385
|
+
return;
|
|
386
|
+
}
|
|
387
|
+
// PID singleton enforcement (#1395 Bug 3): prevent daemon accumulation
|
|
388
|
+
const existingPid = this.checkExistingDaemon();
|
|
389
|
+
if (existingPid !== null) {
|
|
390
|
+
this.log('info', `Daemon already running (PID: ${existingPid}), skipping start`);
|
|
391
|
+
this.emit('warning', `Daemon already running (PID: ${existingPid})`);
|
|
392
|
+
return;
|
|
393
|
+
}
|
|
394
|
+
this.running = true;
|
|
395
|
+
this.startedAt = new Date();
|
|
396
|
+
this.writePidFile();
|
|
397
|
+
this.emit('started', { pid: process.pid, startedAt: this.startedAt });
|
|
398
|
+
// Schedule all enabled workers
|
|
399
|
+
for (const workerConfig of this.config.workers) {
|
|
400
|
+
if (workerConfig.enabled) {
|
|
401
|
+
this.scheduleWorker(workerConfig);
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
// Save state
|
|
405
|
+
this.saveState();
|
|
406
|
+
this.log('info', `Daemon started (PID: ${process.pid}, CPUs: ${cpus().length}, workers: ${this.config.workers.filter(w => w.enabled).length}, maxCpuLoad: ${this.config.resourceThresholds.maxCpuLoad}, minFreeMemoryPercent: ${this.config.resourceThresholds.minFreeMemoryPercent}%)`);
|
|
407
|
+
}
|
|
408
|
+
/**
|
|
409
|
+
* Stop the daemon and all workers
|
|
410
|
+
*/
|
|
411
|
+
async stop() {
|
|
412
|
+
if (!this.running) {
|
|
413
|
+
this.emit('warning', 'Daemon not running');
|
|
414
|
+
return;
|
|
415
|
+
}
|
|
416
|
+
// Clear all timers (convert to array to avoid iterator issues)
|
|
417
|
+
const timerEntries = Array.from(this.timers.entries());
|
|
418
|
+
for (const [type, timer] of timerEntries) {
|
|
419
|
+
clearTimeout(timer);
|
|
420
|
+
this.log('info', `Stopped worker: ${type}`);
|
|
421
|
+
}
|
|
422
|
+
this.timers.clear();
|
|
423
|
+
this.running = false;
|
|
424
|
+
this.removePidFile();
|
|
425
|
+
this.saveState();
|
|
426
|
+
this.emit('stopped', { stoppedAt: new Date() });
|
|
427
|
+
this.log('info', 'Daemon stopped');
|
|
428
|
+
}
|
|
429
|
+
/**
|
|
430
|
+
* Get daemon status
|
|
431
|
+
*/
|
|
432
|
+
getStatus() {
|
|
433
|
+
return {
|
|
434
|
+
running: this.running,
|
|
435
|
+
pid: process.pid,
|
|
436
|
+
startedAt: this.startedAt,
|
|
437
|
+
workers: new Map(this.workers),
|
|
438
|
+
config: this.config,
|
|
439
|
+
};
|
|
440
|
+
}
|
|
441
|
+
/**
|
|
442
|
+
* Schedule a worker to run at intervals with staggered start
|
|
443
|
+
*/
|
|
444
|
+
scheduleWorker(workerConfig) {
|
|
445
|
+
const state = this.workers.get(workerConfig.type);
|
|
446
|
+
const internalConfig = workerConfig;
|
|
447
|
+
const staggerOffset = internalConfig.offsetMs || 0;
|
|
448
|
+
// Calculate initial delay with stagger offset
|
|
449
|
+
let initialDelay = staggerOffset;
|
|
450
|
+
if (state.lastRun) {
|
|
451
|
+
const timeSinceLastRun = Date.now() - state.lastRun.getTime();
|
|
452
|
+
initialDelay = Math.max(staggerOffset, workerConfig.intervalMs - timeSinceLastRun);
|
|
453
|
+
}
|
|
454
|
+
state.nextRun = new Date(Date.now() + initialDelay);
|
|
455
|
+
const runAndReschedule = async () => {
|
|
456
|
+
if (!this.running)
|
|
457
|
+
return;
|
|
458
|
+
// Use concurrency-controlled execution (P0 fix)
|
|
459
|
+
await this.executeWorkerWithConcurrencyControl(workerConfig);
|
|
460
|
+
// Reschedule
|
|
461
|
+
if (this.running) {
|
|
462
|
+
const timer = setTimeout(runAndReschedule, workerConfig.intervalMs);
|
|
463
|
+
this.timers.set(workerConfig.type, timer);
|
|
464
|
+
state.nextRun = new Date(Date.now() + workerConfig.intervalMs);
|
|
465
|
+
}
|
|
466
|
+
};
|
|
467
|
+
// Schedule first run with stagger offset
|
|
468
|
+
const timer = setTimeout(runAndReschedule, initialDelay);
|
|
469
|
+
this.timers.set(workerConfig.type, timer);
|
|
470
|
+
this.log('info', `Scheduled ${workerConfig.type} (interval: ${workerConfig.intervalMs / 1000}s, first run in ${initialDelay / 1000}s)`);
|
|
471
|
+
}
|
|
472
|
+
/**
|
|
473
|
+
* Execute a worker with concurrency control (P0 fix)
|
|
474
|
+
*/
|
|
475
|
+
async executeWorkerWithConcurrencyControl(workerConfig) {
|
|
476
|
+
// Check concurrency limit
|
|
477
|
+
if (this.runningWorkers.size >= this.config.maxConcurrent) {
|
|
478
|
+
this.log('info', `Worker ${workerConfig.type} deferred: max concurrent (${this.config.maxConcurrent}) reached`);
|
|
479
|
+
this.pendingWorkers.push(workerConfig.type);
|
|
480
|
+
this.emit('worker:deferred', { type: workerConfig.type, reason: 'max_concurrent' });
|
|
481
|
+
return null;
|
|
482
|
+
}
|
|
483
|
+
// Check resource availability
|
|
484
|
+
const resourceCheck = await this.canRunWorker();
|
|
485
|
+
if (!resourceCheck.allowed) {
|
|
486
|
+
this.log('info', `Worker ${workerConfig.type} deferred: ${resourceCheck.reason}`);
|
|
487
|
+
this.pendingWorkers.push(workerConfig.type);
|
|
488
|
+
this.emit('worker:deferred', { type: workerConfig.type, reason: resourceCheck.reason });
|
|
489
|
+
return null;
|
|
490
|
+
}
|
|
491
|
+
return this.executeWorker(workerConfig);
|
|
492
|
+
}
|
|
493
|
+
/**
|
|
494
|
+
* Execute a worker with timeout protection
|
|
495
|
+
*/
|
|
496
|
+
async executeWorker(workerConfig) {
|
|
497
|
+
const state = this.workers.get(workerConfig.type);
|
|
498
|
+
const workerId = `${workerConfig.type}_${Date.now()}`;
|
|
499
|
+
const startTime = Date.now();
|
|
500
|
+
// Track running worker
|
|
501
|
+
this.runningWorkers.add(workerConfig.type);
|
|
502
|
+
state.isRunning = true;
|
|
503
|
+
this.emit('worker:start', { workerId, type: workerConfig.type });
|
|
504
|
+
this.log('info', `Starting worker: ${workerConfig.type} (${this.runningWorkers.size}/${this.config.maxConcurrent} concurrent)`);
|
|
505
|
+
try {
|
|
506
|
+
// Execute worker logic with timeout (P1 fix)
|
|
507
|
+
// Pass cleanup callback to kill orphan child processes on timeout (#1117)
|
|
508
|
+
const output = await this.runWithTimeout(() => this.runWorkerLogic(workerConfig), this.config.workerTimeoutMs, `Worker ${workerConfig.type} timed out after ${this.config.workerTimeoutMs / 1000}s`, () => {
|
|
509
|
+
// On timeout, cancel any headless execution to prevent orphan processes
|
|
510
|
+
if (this.headlessExecutor) {
|
|
511
|
+
this.headlessExecutor.cancelAll();
|
|
512
|
+
}
|
|
513
|
+
});
|
|
514
|
+
const durationMs = Date.now() - startTime;
|
|
515
|
+
// Update state
|
|
516
|
+
state.runCount++;
|
|
517
|
+
state.successCount++;
|
|
518
|
+
state.lastRun = new Date();
|
|
519
|
+
state.averageDurationMs = (state.averageDurationMs * (state.runCount - 1) + durationMs) / state.runCount;
|
|
520
|
+
state.isRunning = false;
|
|
521
|
+
const result = {
|
|
522
|
+
workerId,
|
|
523
|
+
type: workerConfig.type,
|
|
524
|
+
success: true,
|
|
525
|
+
durationMs,
|
|
526
|
+
output,
|
|
527
|
+
timestamp: new Date(),
|
|
528
|
+
};
|
|
529
|
+
this.emit('worker:complete', result);
|
|
530
|
+
this.log('info', `Worker ${workerConfig.type} completed in ${durationMs}ms`);
|
|
531
|
+
this.saveState();
|
|
532
|
+
return result;
|
|
533
|
+
}
|
|
534
|
+
catch (error) {
|
|
535
|
+
const durationMs = Date.now() - startTime;
|
|
536
|
+
state.runCount++;
|
|
537
|
+
state.failureCount++;
|
|
538
|
+
state.lastRun = new Date();
|
|
539
|
+
state.isRunning = false;
|
|
540
|
+
const result = {
|
|
541
|
+
workerId,
|
|
542
|
+
type: workerConfig.type,
|
|
543
|
+
success: false,
|
|
544
|
+
durationMs,
|
|
545
|
+
error: error instanceof Error ? error.message : String(error),
|
|
546
|
+
timestamp: new Date(),
|
|
547
|
+
};
|
|
548
|
+
this.emit('worker:error', result);
|
|
549
|
+
this.log('error', `Worker ${workerConfig.type} failed: ${result.error}`);
|
|
550
|
+
this.saveState();
|
|
551
|
+
return result;
|
|
552
|
+
}
|
|
553
|
+
finally {
|
|
554
|
+
// Remove from running set and process queue
|
|
555
|
+
this.runningWorkers.delete(workerConfig.type);
|
|
556
|
+
this.processPendingWorkers();
|
|
557
|
+
}
|
|
558
|
+
}
|
|
559
|
+
/**
|
|
560
|
+
* Run a function with timeout (P1 fix)
|
|
561
|
+
* @param fn - The async function to execute
|
|
562
|
+
* @param timeoutMs - Timeout in milliseconds
|
|
563
|
+
* @param timeoutMessage - Error message on timeout
|
|
564
|
+
* @param onTimeout - Optional cleanup callback invoked when timeout fires (#1117: kills orphan processes)
|
|
565
|
+
*/
|
|
566
|
+
async runWithTimeout(fn, timeoutMs, timeoutMessage, onTimeout) {
|
|
567
|
+
return new Promise((resolve, reject) => {
|
|
568
|
+
let settled = false;
|
|
569
|
+
const timer = setTimeout(() => {
|
|
570
|
+
if (settled)
|
|
571
|
+
return;
|
|
572
|
+
settled = true;
|
|
573
|
+
// Kill orphan child processes before rejecting (#1117)
|
|
574
|
+
if (onTimeout) {
|
|
575
|
+
try {
|
|
576
|
+
onTimeout();
|
|
577
|
+
}
|
|
578
|
+
catch {
|
|
579
|
+
// Ignore cleanup errors
|
|
580
|
+
}
|
|
581
|
+
}
|
|
582
|
+
reject(new Error(timeoutMessage));
|
|
583
|
+
}, timeoutMs);
|
|
584
|
+
fn()
|
|
585
|
+
.then((result) => {
|
|
586
|
+
if (settled)
|
|
587
|
+
return;
|
|
588
|
+
settled = true;
|
|
589
|
+
clearTimeout(timer);
|
|
590
|
+
resolve(result);
|
|
591
|
+
})
|
|
592
|
+
.catch((error) => {
|
|
593
|
+
if (settled)
|
|
594
|
+
return;
|
|
595
|
+
settled = true;
|
|
596
|
+
clearTimeout(timer);
|
|
597
|
+
reject(error);
|
|
598
|
+
});
|
|
599
|
+
});
|
|
600
|
+
}
|
|
601
|
+
/**
|
|
602
|
+
* Run the actual worker logic
|
|
603
|
+
*/
|
|
604
|
+
async runWorkerLogic(workerConfig) {
|
|
605
|
+
// Check if this is a headless worker type and headless execution is available
|
|
606
|
+
if (isHeadlessWorker(workerConfig.type) && this.headlessAvailable && this.headlessExecutor) {
|
|
607
|
+
try {
|
|
608
|
+
this.log('info', `Running ${workerConfig.type} in headless mode (Claude Code AI)`);
|
|
609
|
+
const result = await this.headlessExecutor.execute(workerConfig.type);
|
|
610
|
+
return {
|
|
611
|
+
mode: 'headless',
|
|
612
|
+
...result,
|
|
613
|
+
};
|
|
614
|
+
}
|
|
615
|
+
catch (error) {
|
|
616
|
+
this.log('warn', `Headless execution failed for ${workerConfig.type}, falling back to local mode`);
|
|
617
|
+
this.emit('headless:fallback', {
|
|
618
|
+
type: workerConfig.type,
|
|
619
|
+
error: error instanceof Error ? error.message : String(error),
|
|
620
|
+
});
|
|
621
|
+
// Fall through to local execution
|
|
622
|
+
}
|
|
623
|
+
}
|
|
624
|
+
// Local execution (fallback or for non-headless workers)
|
|
625
|
+
switch (workerConfig.type) {
|
|
626
|
+
case 'map':
|
|
627
|
+
return this.runMapWorker();
|
|
628
|
+
case 'audit':
|
|
629
|
+
return this.runAuditWorkerLocal();
|
|
630
|
+
case 'optimize':
|
|
631
|
+
return this.runOptimizeWorkerLocal();
|
|
632
|
+
case 'consolidate':
|
|
633
|
+
return this.runConsolidateWorker();
|
|
634
|
+
case 'testgaps':
|
|
635
|
+
return this.runTestGapsWorkerLocal();
|
|
636
|
+
case 'predict':
|
|
637
|
+
return this.runPredictWorkerLocal();
|
|
638
|
+
case 'document':
|
|
639
|
+
return this.runDocumentWorkerLocal();
|
|
640
|
+
case 'ultralearn':
|
|
641
|
+
return this.runUltralearnWorkerLocal();
|
|
642
|
+
case 'refactor':
|
|
643
|
+
return this.runRefactorWorkerLocal();
|
|
644
|
+
case 'deepdive':
|
|
645
|
+
return this.runDeepdiveWorkerLocal();
|
|
646
|
+
case 'benchmark':
|
|
647
|
+
return this.runBenchmarkWorkerLocal();
|
|
648
|
+
case 'preload':
|
|
649
|
+
return this.runPreloadWorkerLocal();
|
|
650
|
+
default:
|
|
651
|
+
return { status: 'unknown worker type', mode: 'local' };
|
|
652
|
+
}
|
|
653
|
+
}
|
|
654
|
+
// Worker implementations
|
|
655
|
+
async runMapWorker() {
|
|
656
|
+
// Scan project structure and update metrics
|
|
657
|
+
const metricsFile = join(this.projectRoot, '.claude-flow', 'metrics', 'codebase-map.json');
|
|
658
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
659
|
+
if (!existsSync(metricsDir)) {
|
|
660
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
661
|
+
}
|
|
662
|
+
const map = {
|
|
663
|
+
timestamp: new Date().toISOString(),
|
|
664
|
+
projectRoot: this.projectRoot,
|
|
665
|
+
structure: {
|
|
666
|
+
hasPackageJson: existsSync(join(this.projectRoot, 'package.json')),
|
|
667
|
+
hasTsConfig: existsSync(join(this.projectRoot, 'tsconfig.json')),
|
|
668
|
+
hasClaudeConfig: existsSync(join(this.projectRoot, '.claude')),
|
|
669
|
+
hasClaudeFlow: existsSync(join(this.projectRoot, '.claude-flow')),
|
|
670
|
+
},
|
|
671
|
+
scannedAt: Date.now(),
|
|
672
|
+
};
|
|
673
|
+
writeFileSync(metricsFile, JSON.stringify(map, null, 2));
|
|
674
|
+
return map;
|
|
675
|
+
}
|
|
676
|
+
/**
|
|
677
|
+
* Local audit worker (fallback when headless unavailable)
|
|
678
|
+
*/
|
|
679
|
+
async runAuditWorkerLocal() {
|
|
680
|
+
// Basic security checks
|
|
681
|
+
const auditFile = join(this.projectRoot, '.claude-flow', 'metrics', 'security-audit.json');
|
|
682
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
683
|
+
if (!existsSync(metricsDir)) {
|
|
684
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
685
|
+
}
|
|
686
|
+
const audit = {
|
|
687
|
+
timestamp: new Date().toISOString(),
|
|
688
|
+
mode: 'local',
|
|
689
|
+
checks: {
|
|
690
|
+
envFilesProtected: !existsSync(join(this.projectRoot, '.env.local')),
|
|
691
|
+
gitIgnoreExists: existsSync(join(this.projectRoot, '.gitignore')),
|
|
692
|
+
noHardcodedSecrets: true, // Would need actual scanning
|
|
693
|
+
},
|
|
694
|
+
riskLevel: 'low',
|
|
695
|
+
recommendations: [],
|
|
696
|
+
note: 'Install Claude Code CLI for AI-powered security analysis',
|
|
697
|
+
};
|
|
698
|
+
writeFileSync(auditFile, JSON.stringify(audit, null, 2));
|
|
699
|
+
return audit;
|
|
700
|
+
}
|
|
701
|
+
/**
|
|
702
|
+
* Local optimize worker (fallback when headless unavailable)
|
|
703
|
+
*/
|
|
704
|
+
async runOptimizeWorkerLocal() {
|
|
705
|
+
// Update performance metrics
|
|
706
|
+
const optimizeFile = join(this.projectRoot, '.claude-flow', 'metrics', 'performance.json');
|
|
707
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
708
|
+
if (!existsSync(metricsDir)) {
|
|
709
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
710
|
+
}
|
|
711
|
+
const perf = {
|
|
712
|
+
timestamp: new Date().toISOString(),
|
|
713
|
+
mode: 'local',
|
|
714
|
+
memoryUsage: process.memoryUsage(),
|
|
715
|
+
uptime: process.uptime(),
|
|
716
|
+
optimizations: {
|
|
717
|
+
cacheHitRate: 0.78,
|
|
718
|
+
avgResponseTime: 45,
|
|
719
|
+
},
|
|
720
|
+
note: 'Install Claude Code CLI for AI-powered optimization suggestions',
|
|
721
|
+
};
|
|
722
|
+
writeFileSync(optimizeFile, JSON.stringify(perf, null, 2));
|
|
723
|
+
return perf;
|
|
724
|
+
}
|
|
725
|
+
async runConsolidateWorker() {
|
|
726
|
+
// Memory consolidation - clean up old patterns
|
|
727
|
+
const consolidateFile = join(this.projectRoot, '.claude-flow', 'metrics', 'consolidation.json');
|
|
728
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
729
|
+
if (!existsSync(metricsDir)) {
|
|
730
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
731
|
+
}
|
|
732
|
+
const result = {
|
|
733
|
+
timestamp: new Date().toISOString(),
|
|
734
|
+
patternsConsolidated: 0,
|
|
735
|
+
memoryCleaned: 0,
|
|
736
|
+
duplicatesRemoved: 0,
|
|
737
|
+
};
|
|
738
|
+
writeFileSync(consolidateFile, JSON.stringify(result, null, 2));
|
|
739
|
+
return result;
|
|
740
|
+
}
|
|
741
|
+
/**
|
|
742
|
+
* Local testgaps worker (fallback when headless unavailable)
|
|
743
|
+
*/
|
|
744
|
+
async runTestGapsWorkerLocal() {
|
|
745
|
+
// Check for test coverage gaps
|
|
746
|
+
const testGapsFile = join(this.projectRoot, '.claude-flow', 'metrics', 'test-gaps.json');
|
|
747
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
748
|
+
if (!existsSync(metricsDir)) {
|
|
749
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
750
|
+
}
|
|
751
|
+
const result = {
|
|
752
|
+
timestamp: new Date().toISOString(),
|
|
753
|
+
mode: 'local',
|
|
754
|
+
hasTestDir: existsSync(join(this.projectRoot, 'tests')) || existsSync(join(this.projectRoot, '__tests__')),
|
|
755
|
+
estimatedCoverage: 'unknown',
|
|
756
|
+
gaps: [],
|
|
757
|
+
note: 'Install Claude Code CLI for AI-powered test gap analysis',
|
|
758
|
+
};
|
|
759
|
+
writeFileSync(testGapsFile, JSON.stringify(result, null, 2));
|
|
760
|
+
return result;
|
|
761
|
+
}
|
|
762
|
+
/**
|
|
763
|
+
* Local predict worker (fallback when headless unavailable)
|
|
764
|
+
*/
|
|
765
|
+
async runPredictWorkerLocal() {
|
|
766
|
+
return {
|
|
767
|
+
timestamp: new Date().toISOString(),
|
|
768
|
+
mode: 'local',
|
|
769
|
+
predictions: [],
|
|
770
|
+
preloaded: [],
|
|
771
|
+
note: 'Install Claude Code CLI for AI-powered predictions',
|
|
772
|
+
};
|
|
773
|
+
}
|
|
774
|
+
/**
|
|
775
|
+
* Local document worker (fallback when headless unavailable)
|
|
776
|
+
*/
|
|
777
|
+
async runDocumentWorkerLocal() {
|
|
778
|
+
return {
|
|
779
|
+
timestamp: new Date().toISOString(),
|
|
780
|
+
mode: 'local',
|
|
781
|
+
filesDocumented: 0,
|
|
782
|
+
suggestedDocs: [],
|
|
783
|
+
note: 'Install Claude Code CLI for AI-powered documentation generation',
|
|
784
|
+
};
|
|
785
|
+
}
|
|
786
|
+
/**
|
|
787
|
+
* Local ultralearn worker (fallback when headless unavailable)
|
|
788
|
+
*/
|
|
789
|
+
async runUltralearnWorkerLocal() {
|
|
790
|
+
return {
|
|
791
|
+
timestamp: new Date().toISOString(),
|
|
792
|
+
mode: 'local',
|
|
793
|
+
patternsLearned: 0,
|
|
794
|
+
insightsGained: [],
|
|
795
|
+
note: 'Install Claude Code CLI for AI-powered deep learning',
|
|
796
|
+
};
|
|
797
|
+
}
|
|
798
|
+
/**
|
|
799
|
+
* Local refactor worker (fallback when headless unavailable)
|
|
800
|
+
*/
|
|
801
|
+
async runRefactorWorkerLocal() {
|
|
802
|
+
return {
|
|
803
|
+
timestamp: new Date().toISOString(),
|
|
804
|
+
mode: 'local',
|
|
805
|
+
suggestions: [],
|
|
806
|
+
duplicatesFound: 0,
|
|
807
|
+
note: 'Install Claude Code CLI for AI-powered refactoring suggestions',
|
|
808
|
+
};
|
|
809
|
+
}
|
|
810
|
+
/**
|
|
811
|
+
* Local deepdive worker (fallback when headless unavailable)
|
|
812
|
+
*/
|
|
813
|
+
async runDeepdiveWorkerLocal() {
|
|
814
|
+
return {
|
|
815
|
+
timestamp: new Date().toISOString(),
|
|
816
|
+
mode: 'local',
|
|
817
|
+
analysisDepth: 'shallow',
|
|
818
|
+
findings: [],
|
|
819
|
+
note: 'Install Claude Code CLI for AI-powered deep code analysis',
|
|
820
|
+
};
|
|
821
|
+
}
|
|
822
|
+
/**
|
|
823
|
+
* Local benchmark worker
|
|
824
|
+
*/
|
|
825
|
+
async runBenchmarkWorkerLocal() {
|
|
826
|
+
const benchmarkFile = join(this.projectRoot, '.claude-flow', 'metrics', 'benchmark.json');
|
|
827
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
828
|
+
if (!existsSync(metricsDir)) {
|
|
829
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
830
|
+
}
|
|
831
|
+
const result = {
|
|
832
|
+
timestamp: new Date().toISOString(),
|
|
833
|
+
mode: 'local',
|
|
834
|
+
benchmarks: {
|
|
835
|
+
memoryUsage: process.memoryUsage(),
|
|
836
|
+
cpuUsage: process.cpuUsage(),
|
|
837
|
+
uptime: process.uptime(),
|
|
838
|
+
},
|
|
839
|
+
};
|
|
840
|
+
writeFileSync(benchmarkFile, JSON.stringify(result, null, 2));
|
|
841
|
+
return result;
|
|
842
|
+
}
|
|
843
|
+
/**
|
|
844
|
+
* Local preload worker
|
|
845
|
+
*/
|
|
846
|
+
async runPreloadWorkerLocal() {
|
|
847
|
+
return {
|
|
848
|
+
timestamp: new Date().toISOString(),
|
|
849
|
+
mode: 'local',
|
|
850
|
+
resourcesPreloaded: 0,
|
|
851
|
+
cacheStatus: 'active',
|
|
852
|
+
};
|
|
853
|
+
}
|
|
854
|
+
/**
|
|
855
|
+
* Manually trigger a worker
|
|
856
|
+
*/
|
|
857
|
+
async triggerWorker(type) {
|
|
858
|
+
const workerConfig = this.config.workers.find(w => w.type === type);
|
|
859
|
+
if (!workerConfig) {
|
|
860
|
+
throw new Error(`Unknown worker type: ${type}`);
|
|
861
|
+
}
|
|
862
|
+
return this.executeWorker(workerConfig);
|
|
863
|
+
}
|
|
864
|
+
/**
|
|
865
|
+
* Enable/disable a worker
|
|
866
|
+
*/
|
|
867
|
+
setWorkerEnabled(type, enabled) {
|
|
868
|
+
const workerConfig = this.config.workers.find(w => w.type === type);
|
|
869
|
+
if (workerConfig) {
|
|
870
|
+
workerConfig.enabled = enabled;
|
|
871
|
+
if (enabled && this.running) {
|
|
872
|
+
this.scheduleWorker(workerConfig);
|
|
873
|
+
}
|
|
874
|
+
else if (!enabled) {
|
|
875
|
+
const timer = this.timers.get(type);
|
|
876
|
+
if (timer) {
|
|
877
|
+
clearTimeout(timer);
|
|
878
|
+
this.timers.delete(type);
|
|
879
|
+
}
|
|
880
|
+
}
|
|
881
|
+
this.saveState();
|
|
882
|
+
}
|
|
883
|
+
}
|
|
884
|
+
/**
|
|
885
|
+
* Save daemon state to file
|
|
886
|
+
*/
|
|
887
|
+
saveState() {
|
|
888
|
+
const state = {
|
|
889
|
+
running: this.running,
|
|
890
|
+
startedAt: this.startedAt?.toISOString(),
|
|
891
|
+
workers: Object.fromEntries(Array.from(this.workers.entries()).map(([type, state]) => [
|
|
892
|
+
type,
|
|
893
|
+
{
|
|
894
|
+
...state,
|
|
895
|
+
lastRun: state.lastRun?.toISOString(),
|
|
896
|
+
nextRun: state.nextRun?.toISOString(),
|
|
897
|
+
}
|
|
898
|
+
])),
|
|
899
|
+
config: {
|
|
900
|
+
...this.config,
|
|
901
|
+
workers: this.config.workers.map(w => ({ ...w })),
|
|
902
|
+
},
|
|
903
|
+
savedAt: new Date().toISOString(),
|
|
904
|
+
};
|
|
905
|
+
try {
|
|
906
|
+
writeFileSync(this.config.stateFile, JSON.stringify(state, null, 2));
|
|
907
|
+
}
|
|
908
|
+
catch (error) {
|
|
909
|
+
this.log('error', `Failed to save state: ${error}`);
|
|
910
|
+
}
|
|
911
|
+
}
|
|
912
|
+
/**
|
|
913
|
+
* Log message
|
|
914
|
+
*/
|
|
915
|
+
log(level, message) {
|
|
916
|
+
const timestamp = new Date().toISOString();
|
|
917
|
+
const logMessage = `[${timestamp}] [${level.toUpperCase()}] ${message}`;
|
|
918
|
+
this.emit('log', { level, message, timestamp });
|
|
919
|
+
// Also write to log file
|
|
920
|
+
try {
|
|
921
|
+
const logFile = join(this.config.logDir, 'daemon.log');
|
|
922
|
+
appendFileSync(logFile, logMessage + '\n');
|
|
923
|
+
}
|
|
924
|
+
catch {
|
|
925
|
+
// Ignore log write errors
|
|
926
|
+
}
|
|
927
|
+
}
|
|
928
|
+
}
|
|
929
|
+
// Singleton instance for global access
|
|
930
|
+
let daemonInstance = null;
|
|
931
|
+
/**
|
|
932
|
+
* Get or create daemon instance
|
|
933
|
+
*/
|
|
934
|
+
export function getDaemon(projectRoot, config) {
|
|
935
|
+
if (!daemonInstance && projectRoot) {
|
|
936
|
+
daemonInstance = new WorkerDaemon(projectRoot, config);
|
|
937
|
+
}
|
|
938
|
+
if (!daemonInstance) {
|
|
939
|
+
throw new Error('Daemon not initialized. Provide projectRoot on first call.');
|
|
940
|
+
}
|
|
941
|
+
return daemonInstance;
|
|
942
|
+
}
|
|
943
|
+
/**
|
|
944
|
+
* Start daemon (for use in session-start hook)
|
|
945
|
+
*/
|
|
946
|
+
export async function startDaemon(projectRoot, config) {
|
|
947
|
+
const daemon = getDaemon(projectRoot, config);
|
|
948
|
+
await daemon.start();
|
|
949
|
+
return daemon;
|
|
950
|
+
}
|
|
951
|
+
/**
|
|
952
|
+
* Stop daemon
|
|
953
|
+
*/
|
|
954
|
+
export async function stopDaemon() {
|
|
955
|
+
if (daemonInstance) {
|
|
956
|
+
await daemonInstance.stop();
|
|
957
|
+
}
|
|
958
|
+
}
|
|
959
|
+
export default WorkerDaemon;
|
|
960
|
+
//# sourceMappingURL=worker-daemon.js.map
|