@sparkleideas/cli 3.1.0-alpha.19 → 3.1.0-alpha.21
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/dist/src/appliance/gguf-engine.d.ts +91 -0
- package/dist/src/appliance/gguf-engine.d.ts.map +1 -0
- package/dist/src/appliance/gguf-engine.js +425 -0
- package/dist/src/appliance/gguf-engine.js.map +1 -0
- package/dist/src/appliance/ruvllm-bridge.d.ts +102 -0
- package/dist/src/appliance/ruvllm-bridge.d.ts.map +1 -0
- package/dist/src/appliance/ruvllm-bridge.js +292 -0
- package/dist/src/appliance/ruvllm-bridge.js.map +1 -0
- package/dist/src/appliance/rvfa-builder.d.ts +44 -0
- package/dist/src/appliance/rvfa-builder.d.ts.map +1 -0
- package/dist/src/appliance/rvfa-builder.js +329 -0
- package/dist/src/appliance/rvfa-builder.js.map +1 -0
- package/dist/src/appliance/rvfa-distribution.d.ts +97 -0
- package/dist/src/appliance/rvfa-distribution.d.ts.map +1 -0
- package/dist/src/appliance/rvfa-distribution.js +370 -0
- package/dist/src/appliance/rvfa-distribution.js.map +1 -0
- package/dist/src/appliance/rvfa-format.d.ts +111 -0
- package/dist/src/appliance/rvfa-format.d.ts.map +1 -0
- package/dist/src/appliance/rvfa-format.js +393 -0
- package/dist/src/appliance/rvfa-format.js.map +1 -0
- package/dist/src/appliance/rvfa-runner.d.ts +69 -0
- package/dist/src/appliance/rvfa-runner.d.ts.map +1 -0
- package/dist/src/appliance/rvfa-runner.js +237 -0
- package/dist/src/appliance/rvfa-runner.js.map +1 -0
- package/dist/src/appliance/rvfa-signing.d.ts +123 -0
- package/dist/src/appliance/rvfa-signing.d.ts.map +1 -0
- package/dist/src/appliance/rvfa-signing.js +347 -0
- package/dist/src/appliance/rvfa-signing.js.map +1 -0
- package/dist/src/benchmarks/pretrain/index.d.ts +58 -0
- package/dist/src/benchmarks/pretrain/index.d.ts.map +1 -0
- package/dist/src/benchmarks/pretrain/index.js +404 -0
- package/dist/src/benchmarks/pretrain/index.js.map +1 -0
- package/dist/src/commands/agent.d.ts +8 -0
- package/dist/src/commands/agent.d.ts.map +1 -0
- package/dist/src/commands/agent.js +819 -0
- package/dist/src/commands/agent.js.map +1 -0
- package/dist/src/commands/analyze.d.ts +19 -0
- package/dist/src/commands/analyze.d.ts.map +1 -0
- package/dist/src/commands/analyze.js +1823 -0
- package/dist/src/commands/analyze.js.map +1 -0
- package/dist/src/commands/appliance-advanced.d.ts +9 -0
- package/dist/src/commands/appliance-advanced.d.ts.map +1 -0
- package/dist/src/commands/appliance-advanced.js +215 -0
- package/dist/src/commands/appliance-advanced.js.map +1 -0
- package/dist/src/commands/appliance.d.ts +8 -0
- package/dist/src/commands/appliance.d.ts.map +1 -0
- package/dist/src/commands/appliance.js +406 -0
- package/dist/src/commands/appliance.js.map +1 -0
- package/dist/src/commands/benchmark.d.ts +10 -0
- package/dist/src/commands/benchmark.d.ts.map +1 -0
- package/dist/src/commands/benchmark.js +459 -0
- package/dist/src/commands/benchmark.js.map +1 -0
- package/dist/src/commands/categories.d.ts +75 -0
- package/dist/src/commands/categories.d.ts.map +1 -0
- package/dist/src/commands/categories.js +178 -0
- package/dist/src/commands/categories.js.map +1 -0
- package/dist/src/commands/claims.d.ts +10 -0
- package/dist/src/commands/claims.d.ts.map +1 -0
- package/dist/src/commands/claims.js +373 -0
- package/dist/src/commands/claims.js.map +1 -0
- package/dist/src/commands/completions.d.ts +10 -0
- package/dist/src/commands/completions.d.ts.map +1 -0
- package/dist/src/commands/completions.js +539 -0
- package/dist/src/commands/completions.js.map +1 -0
- package/dist/src/commands/config.d.ts +8 -0
- package/dist/src/commands/config.d.ts.map +1 -0
- package/dist/src/commands/config.js +406 -0
- package/dist/src/commands/config.js.map +1 -0
- package/dist/src/commands/daemon.d.ts +8 -0
- package/dist/src/commands/daemon.d.ts.map +1 -0
- package/dist/src/commands/daemon.js +609 -0
- package/dist/src/commands/daemon.js.map +1 -0
- package/dist/src/commands/deployment.d.ts +10 -0
- package/dist/src/commands/deployment.d.ts.map +1 -0
- package/dist/src/commands/deployment.js +289 -0
- package/dist/src/commands/deployment.js.map +1 -0
- package/dist/src/commands/doctor.d.ts +10 -0
- package/dist/src/commands/doctor.d.ts.map +1 -0
- package/dist/src/commands/doctor.js +602 -0
- package/dist/src/commands/doctor.js.map +1 -0
- package/dist/src/commands/embeddings.d.ts +18 -0
- package/dist/src/commands/embeddings.d.ts.map +1 -0
- package/dist/src/commands/embeddings.js +1576 -0
- package/dist/src/commands/embeddings.js.map +1 -0
- package/dist/src/commands/guidance.d.ts +8 -0
- package/dist/src/commands/guidance.d.ts.map +1 -0
- package/dist/src/commands/guidance.js +560 -0
- package/dist/src/commands/guidance.js.map +1 -0
- package/dist/src/commands/hive-mind.d.ts +11 -0
- package/dist/src/commands/hive-mind.d.ts.map +1 -0
- package/dist/src/commands/hive-mind.js +1230 -0
- package/dist/src/commands/hive-mind.js.map +1 -0
- package/dist/src/commands/hooks.d.ts +8 -0
- package/dist/src/commands/hooks.d.ts.map +1 -0
- package/dist/src/commands/hooks.js +3759 -0
- package/dist/src/commands/hooks.js.map +1 -0
- package/dist/src/commands/index.d.ts +113 -0
- package/dist/src/commands/index.d.ts.map +1 -0
- package/dist/src/commands/index.js +368 -0
- package/dist/src/commands/index.js.map +1 -0
- package/dist/src/commands/init.d.ts +8 -0
- package/dist/src/commands/init.d.ts.map +1 -0
- package/dist/src/commands/init.js +965 -0
- package/dist/src/commands/init.js.map +1 -0
- package/dist/src/commands/issues.d.ts +21 -0
- package/dist/src/commands/issues.d.ts.map +1 -0
- package/dist/src/commands/issues.js +567 -0
- package/dist/src/commands/issues.js.map +1 -0
- package/dist/src/commands/mcp.d.ts +11 -0
- package/dist/src/commands/mcp.d.ts.map +1 -0
- package/dist/src/commands/mcp.js +715 -0
- package/dist/src/commands/mcp.js.map +1 -0
- package/dist/src/commands/memory.d.ts +8 -0
- package/dist/src/commands/memory.d.ts.map +1 -0
- package/dist/src/commands/memory.js +1292 -0
- package/dist/src/commands/memory.js.map +1 -0
- package/dist/src/commands/migrate.d.ts +8 -0
- package/dist/src/commands/migrate.d.ts.map +1 -0
- package/dist/src/commands/migrate.js +410 -0
- package/dist/src/commands/migrate.js.map +1 -0
- package/dist/src/commands/neural.d.ts +10 -0
- package/dist/src/commands/neural.d.ts.map +1 -0
- package/dist/src/commands/neural.js +1448 -0
- package/dist/src/commands/neural.js.map +1 -0
- package/dist/src/commands/performance.d.ts +10 -0
- package/dist/src/commands/performance.d.ts.map +1 -0
- package/dist/src/commands/performance.js +579 -0
- package/dist/src/commands/performance.js.map +1 -0
- package/dist/src/commands/plugins.d.ts +11 -0
- package/dist/src/commands/plugins.d.ts.map +1 -0
- package/dist/src/commands/plugins.js +820 -0
- package/dist/src/commands/plugins.js.map +1 -0
- package/dist/src/commands/process.d.ts +10 -0
- package/dist/src/commands/process.d.ts.map +1 -0
- package/dist/src/commands/process.js +641 -0
- package/dist/src/commands/process.js.map +1 -0
- package/dist/src/commands/progress.d.ts +11 -0
- package/dist/src/commands/progress.d.ts.map +1 -0
- package/dist/src/commands/progress.js +259 -0
- package/dist/src/commands/progress.js.map +1 -0
- package/dist/src/commands/providers.d.ts +10 -0
- package/dist/src/commands/providers.d.ts.map +1 -0
- package/dist/src/commands/providers.js +232 -0
- package/dist/src/commands/providers.js.map +1 -0
- package/dist/src/commands/route.d.ts +16 -0
- package/dist/src/commands/route.d.ts.map +1 -0
- package/dist/src/commands/route.js +813 -0
- package/dist/src/commands/route.js.map +1 -0
- package/dist/src/commands/ruvector/backup.d.ts +11 -0
- package/dist/src/commands/ruvector/backup.d.ts.map +1 -0
- package/dist/src/commands/ruvector/backup.js +746 -0
- package/dist/src/commands/ruvector/backup.js.map +1 -0
- package/dist/src/commands/ruvector/benchmark.d.ts +11 -0
- package/dist/src/commands/ruvector/benchmark.d.ts.map +1 -0
- package/dist/src/commands/ruvector/benchmark.js +480 -0
- package/dist/src/commands/ruvector/benchmark.js.map +1 -0
- package/dist/src/commands/ruvector/import.d.ts +18 -0
- package/dist/src/commands/ruvector/import.d.ts.map +1 -0
- package/dist/src/commands/ruvector/import.js +349 -0
- package/dist/src/commands/ruvector/import.js.map +1 -0
- package/dist/src/commands/ruvector/index.d.ts +29 -0
- package/dist/src/commands/ruvector/index.d.ts.map +1 -0
- package/dist/src/commands/ruvector/index.js +129 -0
- package/dist/src/commands/ruvector/index.js.map +1 -0
- package/dist/src/commands/ruvector/init.d.ts +11 -0
- package/dist/src/commands/ruvector/init.d.ts.map +1 -0
- package/dist/src/commands/ruvector/init.js +431 -0
- package/dist/src/commands/ruvector/init.js.map +1 -0
- package/dist/src/commands/ruvector/migrate.d.ts +11 -0
- package/dist/src/commands/ruvector/migrate.d.ts.map +1 -0
- package/dist/src/commands/ruvector/migrate.js +481 -0
- package/dist/src/commands/ruvector/migrate.js.map +1 -0
- package/dist/src/commands/ruvector/optimize.d.ts +11 -0
- package/dist/src/commands/ruvector/optimize.d.ts.map +1 -0
- package/dist/src/commands/ruvector/optimize.js +503 -0
- package/dist/src/commands/ruvector/optimize.js.map +1 -0
- package/dist/src/commands/ruvector/setup.d.ts +18 -0
- package/dist/src/commands/ruvector/setup.d.ts.map +1 -0
- package/dist/src/commands/ruvector/setup.js +765 -0
- package/dist/src/commands/ruvector/setup.js.map +1 -0
- package/dist/src/commands/ruvector/status.d.ts +11 -0
- package/dist/src/commands/ruvector/status.d.ts.map +1 -0
- package/dist/src/commands/ruvector/status.js +456 -0
- package/dist/src/commands/ruvector/status.js.map +1 -0
- package/dist/src/commands/security.d.ts +10 -0
- package/dist/src/commands/security.d.ts.map +1 -0
- package/dist/src/commands/security.js +575 -0
- package/dist/src/commands/security.js.map +1 -0
- package/dist/src/commands/session.d.ts +8 -0
- package/dist/src/commands/session.d.ts.map +1 -0
- package/dist/src/commands/session.js +750 -0
- package/dist/src/commands/session.js.map +1 -0
- package/dist/src/commands/start.d.ts +8 -0
- package/dist/src/commands/start.d.ts.map +1 -0
- package/dist/src/commands/start.js +418 -0
- package/dist/src/commands/start.js.map +1 -0
- package/dist/src/commands/status.d.ts +8 -0
- package/dist/src/commands/status.d.ts.map +1 -0
- package/dist/src/commands/status.js +591 -0
- package/dist/src/commands/status.js.map +1 -0
- package/dist/src/commands/swarm.d.ts +8 -0
- package/dist/src/commands/swarm.d.ts.map +1 -0
- package/dist/src/commands/swarm.js +748 -0
- package/dist/src/commands/swarm.js.map +1 -0
- package/dist/src/commands/task.d.ts +8 -0
- package/dist/src/commands/task.d.ts.map +1 -0
- package/dist/src/commands/task.js +671 -0
- package/dist/src/commands/task.js.map +1 -0
- package/dist/src/commands/transfer-store.d.ts +13 -0
- package/dist/src/commands/transfer-store.d.ts.map +1 -0
- package/dist/src/commands/transfer-store.js +428 -0
- package/dist/src/commands/transfer-store.js.map +1 -0
- package/dist/src/commands/update.d.ts +8 -0
- package/dist/src/commands/update.d.ts.map +1 -0
- package/dist/src/commands/update.js +276 -0
- package/dist/src/commands/update.js.map +1 -0
- package/dist/src/commands/workflow.d.ts +8 -0
- package/dist/src/commands/workflow.d.ts.map +1 -0
- package/dist/src/commands/workflow.js +617 -0
- package/dist/src/commands/workflow.js.map +1 -0
- package/dist/src/config-adapter.d.ts +15 -0
- package/dist/src/config-adapter.d.ts.map +1 -0
- package/dist/src/config-adapter.js +186 -0
- package/dist/src/config-adapter.js.map +1 -0
- package/dist/src/index.d.ts +76 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +470 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/infrastructure/in-memory-repositories.d.ts +68 -0
- package/dist/src/infrastructure/in-memory-repositories.d.ts.map +1 -0
- package/dist/src/infrastructure/in-memory-repositories.js +264 -0
- package/dist/src/infrastructure/in-memory-repositories.js.map +1 -0
- package/dist/src/init/claudemd-generator.d.ts +25 -0
- package/dist/src/init/claudemd-generator.d.ts.map +1 -0
- package/dist/src/init/claudemd-generator.js +486 -0
- package/dist/src/init/claudemd-generator.js.map +1 -0
- package/dist/src/init/executor.d.ts +41 -0
- package/dist/src/init/executor.d.ts.map +1 -0
- package/dist/src/init/executor.js +1741 -0
- package/dist/src/init/executor.js.map +1 -0
- package/dist/src/init/helpers-generator.d.ts +60 -0
- package/dist/src/init/helpers-generator.d.ts.map +1 -0
- package/dist/src/init/helpers-generator.js +1166 -0
- package/dist/src/init/helpers-generator.js.map +1 -0
- package/dist/src/init/index.d.ts +13 -0
- package/dist/src/init/index.d.ts.map +1 -0
- package/dist/src/init/index.js +15 -0
- package/dist/src/init/index.js.map +1 -0
- package/dist/src/init/mcp-generator.d.ts +26 -0
- package/dist/src/init/mcp-generator.d.ts.map +1 -0
- package/dist/src/init/mcp-generator.js +116 -0
- package/dist/src/init/mcp-generator.js.map +1 -0
- package/dist/src/init/settings-generator.d.ts +14 -0
- package/dist/src/init/settings-generator.d.ts.map +1 -0
- package/dist/src/init/settings-generator.js +399 -0
- package/dist/src/init/settings-generator.js.map +1 -0
- package/dist/src/init/statusline-generator.d.ts +28 -0
- package/dist/src/init/statusline-generator.d.ts.map +1 -0
- package/dist/src/init/statusline-generator.js +817 -0
- package/dist/src/init/statusline-generator.js.map +1 -0
- package/dist/src/init/types.d.ts +287 -0
- package/dist/src/init/types.d.ts.map +1 -0
- package/dist/src/init/types.js +259 -0
- package/dist/src/init/types.js.map +1 -0
- package/dist/src/mcp-client.d.ts +92 -0
- package/dist/src/mcp-client.d.ts.map +1 -0
- package/dist/src/mcp-client.js +237 -0
- package/dist/src/mcp-client.js.map +1 -0
- package/dist/src/mcp-server.d.ts +161 -0
- package/dist/src/mcp-server.d.ts.map +1 -0
- package/dist/src/mcp-server.js +627 -0
- package/dist/src/mcp-server.js.map +1 -0
- package/dist/src/mcp-tools/agent-tools.d.ts +9 -0
- package/dist/src/mcp-tools/agent-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/agent-tools.js +549 -0
- package/dist/src/mcp-tools/agent-tools.js.map +1 -0
- package/dist/src/mcp-tools/agentdb-tools.d.ts +30 -0
- package/dist/src/mcp-tools/agentdb-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/agentdb-tools.js +557 -0
- package/dist/src/mcp-tools/agentdb-tools.js.map +1 -0
- package/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
- package/dist/src/mcp-tools/analyze-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/analyze-tools.js +317 -0
- package/dist/src/mcp-tools/analyze-tools.js.map +1 -0
- package/dist/src/mcp-tools/auto-install.d.ts +83 -0
- package/dist/src/mcp-tools/auto-install.d.ts.map +1 -0
- package/dist/src/mcp-tools/auto-install.js +131 -0
- package/dist/src/mcp-tools/auto-install.js.map +1 -0
- package/dist/src/mcp-tools/browser-tools.d.ts +13 -0
- package/dist/src/mcp-tools/browser-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/browser-tools.js +550 -0
- package/dist/src/mcp-tools/browser-tools.js.map +1 -0
- package/dist/src/mcp-tools/claims-tools.d.ts +12 -0
- package/dist/src/mcp-tools/claims-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/claims-tools.js +732 -0
- package/dist/src/mcp-tools/claims-tools.js.map +1 -0
- package/dist/src/mcp-tools/config-tools.d.ts +8 -0
- package/dist/src/mcp-tools/config-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/config-tools.js +343 -0
- package/dist/src/mcp-tools/config-tools.js.map +1 -0
- package/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
- package/dist/src/mcp-tools/coordination-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/coordination-tools.js +486 -0
- package/dist/src/mcp-tools/coordination-tools.js.map +1 -0
- package/dist/src/mcp-tools/daa-tools.d.ts +13 -0
- package/dist/src/mcp-tools/daa-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/daa-tools.js +426 -0
- package/dist/src/mcp-tools/daa-tools.js.map +1 -0
- package/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
- package/dist/src/mcp-tools/embeddings-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/embeddings-tools.js +782 -0
- package/dist/src/mcp-tools/embeddings-tools.js.map +1 -0
- package/dist/src/mcp-tools/github-tools.d.ts +13 -0
- package/dist/src/mcp-tools/github-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/github-tools.js +373 -0
- package/dist/src/mcp-tools/github-tools.js.map +1 -0
- package/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
- package/dist/src/mcp-tools/hive-mind-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/hive-mind-tools.js +583 -0
- package/dist/src/mcp-tools/hive-mind-tools.js.map +1 -0
- package/dist/src/mcp-tools/hooks-tools.d.ts +44 -0
- package/dist/src/mcp-tools/hooks-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/hooks-tools.js +2969 -0
- package/dist/src/mcp-tools/hooks-tools.js.map +1 -0
- package/dist/src/mcp-tools/index.d.ts +23 -0
- package/dist/src/mcp-tools/index.d.ts.map +1 -0
- package/dist/src/mcp-tools/index.js +22 -0
- package/dist/src/mcp-tools/index.js.map +1 -0
- package/dist/src/mcp-tools/memory-tools.d.ts +14 -0
- package/dist/src/mcp-tools/memory-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/memory-tools.js +499 -0
- package/dist/src/mcp-tools/memory-tools.js.map +1 -0
- package/dist/src/mcp-tools/neural-tools.d.ts +16 -0
- package/dist/src/mcp-tools/neural-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/neural-tools.js +461 -0
- package/dist/src/mcp-tools/neural-tools.js.map +1 -0
- package/dist/src/mcp-tools/performance-tools.d.ts +16 -0
- package/dist/src/mcp-tools/performance-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/performance-tools.js +534 -0
- package/dist/src/mcp-tools/performance-tools.js.map +1 -0
- package/dist/src/mcp-tools/progress-tools.d.ts +14 -0
- package/dist/src/mcp-tools/progress-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/progress-tools.js +348 -0
- package/dist/src/mcp-tools/progress-tools.js.map +1 -0
- package/dist/src/mcp-tools/security-tools.d.ts +18 -0
- package/dist/src/mcp-tools/security-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/security-tools.js +434 -0
- package/dist/src/mcp-tools/security-tools.js.map +1 -0
- package/dist/src/mcp-tools/session-tools.d.ts +8 -0
- package/dist/src/mcp-tools/session-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/session-tools.js +315 -0
- package/dist/src/mcp-tools/session-tools.js.map +1 -0
- package/dist/src/mcp-tools/swarm-tools.d.ts +8 -0
- package/dist/src/mcp-tools/swarm-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/swarm-tools.js +102 -0
- package/dist/src/mcp-tools/swarm-tools.js.map +1 -0
- package/dist/src/mcp-tools/system-tools.d.ts +13 -0
- package/dist/src/mcp-tools/system-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/system-tools.js +417 -0
- package/dist/src/mcp-tools/system-tools.js.map +1 -0
- package/dist/src/mcp-tools/task-tools.d.ts +8 -0
- package/dist/src/mcp-tools/task-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/task-tools.js +338 -0
- package/dist/src/mcp-tools/task-tools.js.map +1 -0
- package/dist/src/mcp-tools/terminal-tools.d.ts +13 -0
- package/dist/src/mcp-tools/terminal-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/terminal-tools.js +246 -0
- package/dist/src/mcp-tools/terminal-tools.js.map +1 -0
- package/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
- package/dist/src/mcp-tools/transfer-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/transfer-tools.js +396 -0
- package/dist/src/mcp-tools/transfer-tools.js.map +1 -0
- package/dist/src/mcp-tools/types.d.ts +31 -0
- package/dist/src/mcp-tools/types.d.ts.map +1 -0
- package/dist/src/mcp-tools/types.js +7 -0
- package/dist/src/mcp-tools/types.js.map +1 -0
- package/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
- package/dist/src/mcp-tools/workflow-tools.d.ts.map +1 -0
- package/dist/src/mcp-tools/workflow-tools.js +572 -0
- package/dist/src/mcp-tools/workflow-tools.js.map +1 -0
- package/dist/src/memory/ewc-consolidation.d.ts +271 -0
- package/dist/src/memory/ewc-consolidation.d.ts.map +1 -0
- package/dist/src/memory/ewc-consolidation.js +542 -0
- package/dist/src/memory/ewc-consolidation.js.map +1 -0
- package/dist/src/memory/intelligence.d.ts +285 -0
- package/dist/src/memory/intelligence.d.ts.map +1 -0
- package/dist/src/memory/intelligence.js +794 -0
- package/dist/src/memory/intelligence.js.map +1 -0
- package/dist/src/memory/memory-bridge.d.ts +407 -0
- package/dist/src/memory/memory-bridge.d.ts.map +1 -0
- package/dist/src/memory/memory-bridge.js +1494 -0
- package/dist/src/memory/memory-bridge.js.map +1 -0
- package/dist/src/memory/memory-initializer.d.ts +405 -0
- package/dist/src/memory/memory-initializer.d.ts.map +1 -0
- package/dist/src/memory/memory-initializer.js +2105 -0
- package/dist/src/memory/memory-initializer.js.map +1 -0
- package/dist/src/memory/sona-optimizer.d.ts +227 -0
- package/dist/src/memory/sona-optimizer.d.ts.map +1 -0
- package/dist/src/memory/sona-optimizer.js +633 -0
- package/dist/src/memory/sona-optimizer.js.map +1 -0
- package/dist/src/output.d.ts +133 -0
- package/dist/src/output.d.ts.map +1 -0
- package/dist/src/output.js +514 -0
- package/dist/src/output.js.map +1 -0
- package/dist/src/parser.d.ts +41 -0
- package/dist/src/parser.d.ts.map +1 -0
- package/dist/src/parser.js +377 -0
- package/dist/src/parser.js.map +1 -0
- package/dist/src/plugins/manager.d.ts +133 -0
- package/dist/src/plugins/manager.d.ts.map +1 -0
- package/dist/src/plugins/manager.js +400 -0
- package/dist/src/plugins/manager.js.map +1 -0
- package/dist/src/plugins/store/discovery.d.ts +88 -0
- package/dist/src/plugins/store/discovery.d.ts.map +1 -0
- package/dist/src/plugins/store/discovery.js +1147 -0
- package/dist/src/plugins/store/discovery.js.map +1 -0
- package/dist/src/plugins/store/index.d.ts +76 -0
- package/dist/src/plugins/store/index.d.ts.map +1 -0
- package/dist/src/plugins/store/index.js +141 -0
- package/dist/src/plugins/store/index.js.map +1 -0
- package/dist/src/plugins/store/search.d.ts +46 -0
- package/dist/src/plugins/store/search.d.ts.map +1 -0
- package/dist/src/plugins/store/search.js +230 -0
- package/dist/src/plugins/store/search.js.map +1 -0
- package/dist/src/plugins/store/types.d.ts +274 -0
- package/dist/src/plugins/store/types.d.ts.map +1 -0
- package/dist/src/plugins/store/types.js +7 -0
- package/dist/src/plugins/store/types.js.map +1 -0
- package/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
- package/dist/src/plugins/tests/demo-plugin-store.d.ts.map +1 -0
- package/dist/src/plugins/tests/demo-plugin-store.js +126 -0
- package/dist/src/plugins/tests/demo-plugin-store.js.map +1 -0
- package/dist/src/plugins/tests/standalone-test.d.ts +12 -0
- package/dist/src/plugins/tests/standalone-test.d.ts.map +1 -0
- package/dist/src/plugins/tests/standalone-test.js +188 -0
- package/dist/src/plugins/tests/standalone-test.js.map +1 -0
- package/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
- package/dist/src/plugins/tests/test-plugin-store.d.ts.map +1 -0
- package/dist/src/plugins/tests/test-plugin-store.js +206 -0
- package/dist/src/plugins/tests/test-plugin-store.js.map +1 -0
- package/dist/src/production/circuit-breaker.d.ts +101 -0
- package/dist/src/production/circuit-breaker.d.ts.map +1 -0
- package/dist/src/production/circuit-breaker.js +241 -0
- package/dist/src/production/circuit-breaker.js.map +1 -0
- package/dist/src/production/error-handler.d.ts +92 -0
- package/dist/src/production/error-handler.d.ts.map +1 -0
- package/dist/src/production/error-handler.js +299 -0
- package/dist/src/production/error-handler.js.map +1 -0
- package/dist/src/production/index.d.ts +23 -0
- package/dist/src/production/index.d.ts.map +1 -0
- package/dist/src/production/index.js +18 -0
- package/dist/src/production/index.js.map +1 -0
- package/dist/src/production/monitoring.d.ts +161 -0
- package/dist/src/production/monitoring.d.ts.map +1 -0
- package/dist/src/production/monitoring.js +356 -0
- package/dist/src/production/monitoring.js.map +1 -0
- package/dist/src/production/rate-limiter.d.ts +80 -0
- package/dist/src/production/rate-limiter.d.ts.map +1 -0
- package/dist/src/production/rate-limiter.js +201 -0
- package/dist/src/production/rate-limiter.js.map +1 -0
- package/dist/src/production/retry.d.ts +48 -0
- package/dist/src/production/retry.d.ts.map +1 -0
- package/dist/src/production/retry.js +179 -0
- package/dist/src/production/retry.js.map +1 -0
- package/dist/src/prompt.d.ts +44 -0
- package/dist/src/prompt.d.ts.map +1 -0
- package/dist/src/prompt.js +501 -0
- package/dist/src/prompt.js.map +1 -0
- package/dist/src/runtime/headless.d.ts +60 -0
- package/dist/src/runtime/headless.d.ts.map +1 -0
- package/dist/src/runtime/headless.js +284 -0
- package/dist/src/runtime/headless.js.map +1 -0
- package/dist/src/ruvector/ast-analyzer.d.ts +67 -0
- package/dist/src/ruvector/ast-analyzer.d.ts.map +1 -0
- package/dist/src/ruvector/ast-analyzer.js +277 -0
- package/dist/src/ruvector/ast-analyzer.js.map +1 -0
- package/dist/src/ruvector/coverage-router.d.ts +160 -0
- package/dist/src/ruvector/coverage-router.d.ts.map +1 -0
- package/dist/src/ruvector/coverage-router.js +529 -0
- package/dist/src/ruvector/coverage-router.js.map +1 -0
- package/dist/src/ruvector/coverage-tools.d.ts +33 -0
- package/dist/src/ruvector/coverage-tools.d.ts.map +1 -0
- package/dist/src/ruvector/coverage-tools.js +157 -0
- package/dist/src/ruvector/coverage-tools.js.map +1 -0
- package/dist/src/ruvector/diff-classifier.d.ts +175 -0
- package/dist/src/ruvector/diff-classifier.d.ts.map +1 -0
- package/dist/src/ruvector/diff-classifier.js +698 -0
- package/dist/src/ruvector/diff-classifier.js.map +1 -0
- package/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
- package/dist/src/ruvector/enhanced-model-router.d.ts.map +1 -0
- package/dist/src/ruvector/enhanced-model-router.js +529 -0
- package/dist/src/ruvector/enhanced-model-router.js.map +1 -0
- package/dist/src/ruvector/flash-attention.d.ts +195 -0
- package/dist/src/ruvector/flash-attention.d.ts.map +1 -0
- package/dist/src/ruvector/flash-attention.js +643 -0
- package/dist/src/ruvector/flash-attention.js.map +1 -0
- package/dist/src/ruvector/graph-analyzer.d.ts +187 -0
- package/dist/src/ruvector/graph-analyzer.d.ts.map +1 -0
- package/dist/src/ruvector/graph-analyzer.js +929 -0
- package/dist/src/ruvector/graph-analyzer.js.map +1 -0
- package/dist/src/ruvector/index.d.ts +34 -0
- package/dist/src/ruvector/index.d.ts.map +1 -0
- package/dist/src/ruvector/index.js +60 -0
- package/dist/src/ruvector/index.js.map +1 -0
- package/dist/src/ruvector/lora-adapter.d.ts +218 -0
- package/dist/src/ruvector/lora-adapter.d.ts.map +1 -0
- package/dist/src/ruvector/lora-adapter.js +455 -0
- package/dist/src/ruvector/lora-adapter.js.map +1 -0
- package/dist/src/ruvector/model-router.d.ts +220 -0
- package/dist/src/ruvector/model-router.d.ts.map +1 -0
- package/dist/src/ruvector/model-router.js +488 -0
- package/dist/src/ruvector/model-router.js.map +1 -0
- package/dist/src/ruvector/moe-router.d.ts +206 -0
- package/dist/src/ruvector/moe-router.d.ts.map +1 -0
- package/dist/src/ruvector/moe-router.js +626 -0
- package/dist/src/ruvector/moe-router.js.map +1 -0
- package/dist/src/ruvector/q-learning-router.d.ts +211 -0
- package/dist/src/ruvector/q-learning-router.d.ts.map +1 -0
- package/dist/src/ruvector/q-learning-router.js +681 -0
- package/dist/src/ruvector/q-learning-router.js.map +1 -0
- package/dist/src/ruvector/semantic-router.d.ts +77 -0
- package/dist/src/ruvector/semantic-router.d.ts.map +1 -0
- package/dist/src/ruvector/semantic-router.js +178 -0
- package/dist/src/ruvector/semantic-router.js.map +1 -0
- package/dist/src/ruvector/vector-db.d.ts +69 -0
- package/dist/src/ruvector/vector-db.d.ts.map +1 -0
- package/dist/src/ruvector/vector-db.js +243 -0
- package/dist/src/ruvector/vector-db.js.map +1 -0
- package/dist/src/services/agentic-flow-bridge.d.ts +50 -0
- package/dist/src/services/agentic-flow-bridge.d.ts.map +1 -0
- package/dist/src/services/agentic-flow-bridge.js +95 -0
- package/dist/src/services/agentic-flow-bridge.js.map +1 -0
- package/dist/src/services/claim-service.d.ts +204 -0
- package/dist/src/services/claim-service.d.ts.map +1 -0
- package/dist/src/services/claim-service.js +818 -0
- package/dist/src/services/claim-service.js.map +1 -0
- package/dist/src/services/container-worker-pool.d.ts +197 -0
- package/dist/src/services/container-worker-pool.d.ts.map +1 -0
- package/dist/src/services/container-worker-pool.js +583 -0
- package/dist/src/services/container-worker-pool.js.map +1 -0
- package/dist/src/services/headless-worker-executor.d.ts +304 -0
- package/dist/src/services/headless-worker-executor.d.ts.map +1 -0
- package/dist/src/services/headless-worker-executor.js +999 -0
- package/dist/src/services/headless-worker-executor.js.map +1 -0
- package/dist/src/services/index.d.ts +13 -0
- package/dist/src/services/index.d.ts.map +1 -0
- package/dist/src/services/index.js +11 -0
- package/dist/src/services/index.js.map +1 -0
- package/dist/src/services/registry-api.d.ts +58 -0
- package/dist/src/services/registry-api.d.ts.map +1 -0
- package/dist/src/services/registry-api.js +146 -0
- package/dist/src/services/registry-api.js.map +1 -0
- package/dist/src/services/ruvector-training.d.ts +214 -0
- package/dist/src/services/ruvector-training.d.ts.map +1 -0
- package/dist/src/services/ruvector-training.js +497 -0
- package/dist/src/services/ruvector-training.js.map +1 -0
- package/dist/src/services/worker-daemon.d.ts +203 -0
- package/dist/src/services/worker-daemon.d.ts.map +1 -0
- package/dist/src/services/worker-daemon.js +756 -0
- package/dist/src/services/worker-daemon.js.map +1 -0
- package/dist/src/services/worker-queue.d.ts +194 -0
- package/dist/src/services/worker-queue.d.ts.map +1 -0
- package/dist/src/services/worker-queue.js +513 -0
- package/dist/src/services/worker-queue.js.map +1 -0
- package/dist/src/suggest.d.ts +53 -0
- package/dist/src/suggest.d.ts.map +1 -0
- package/dist/src/suggest.js +200 -0
- package/dist/src/suggest.js.map +1 -0
- package/dist/src/tests/ruvector-integration-benchmark.d.ts +6 -0
- package/dist/src/tests/ruvector-integration-benchmark.d.ts.map +1 -0
- package/dist/src/tests/ruvector-integration-benchmark.js +385 -0
- package/dist/src/tests/ruvector-integration-benchmark.js.map +1 -0
- package/dist/src/transfer/anonymization/index.d.ts +25 -0
- package/dist/src/transfer/anonymization/index.d.ts.map +1 -0
- package/dist/src/transfer/anonymization/index.js +175 -0
- package/dist/src/transfer/anonymization/index.js.map +1 -0
- package/dist/src/transfer/deploy-seraphine.d.ts +13 -0
- package/dist/src/transfer/deploy-seraphine.d.ts.map +1 -0
- package/dist/src/transfer/deploy-seraphine.js +205 -0
- package/dist/src/transfer/deploy-seraphine.js.map +1 -0
- package/dist/src/transfer/export.d.ts +25 -0
- package/dist/src/transfer/export.d.ts.map +1 -0
- package/dist/src/transfer/export.js +113 -0
- package/dist/src/transfer/export.js.map +1 -0
- package/dist/src/transfer/index.d.ts +12 -0
- package/dist/src/transfer/index.d.ts.map +1 -0
- package/dist/src/transfer/index.js +31 -0
- package/dist/src/transfer/index.js.map +1 -0
- package/dist/src/transfer/ipfs/client.d.ts +109 -0
- package/dist/src/transfer/ipfs/client.d.ts.map +1 -0
- package/dist/src/transfer/ipfs/client.js +307 -0
- package/dist/src/transfer/ipfs/client.js.map +1 -0
- package/dist/src/transfer/ipfs/upload.d.ts +95 -0
- package/dist/src/transfer/ipfs/upload.d.ts.map +1 -0
- package/dist/src/transfer/ipfs/upload.js +411 -0
- package/dist/src/transfer/ipfs/upload.js.map +1 -0
- package/dist/src/transfer/models/seraphine.d.ts +72 -0
- package/dist/src/transfer/models/seraphine.d.ts.map +1 -0
- package/dist/src/transfer/models/seraphine.js +373 -0
- package/dist/src/transfer/models/seraphine.js.map +1 -0
- package/dist/src/transfer/serialization/cfp.d.ts +49 -0
- package/dist/src/transfer/serialization/cfp.d.ts.map +1 -0
- package/dist/src/transfer/serialization/cfp.js +183 -0
- package/dist/src/transfer/serialization/cfp.js.map +1 -0
- package/dist/src/transfer/storage/gcs.d.ts +82 -0
- package/dist/src/transfer/storage/gcs.d.ts.map +1 -0
- package/dist/src/transfer/storage/gcs.js +256 -0
- package/dist/src/transfer/storage/gcs.js.map +1 -0
- package/dist/src/transfer/storage/index.d.ts +6 -0
- package/dist/src/transfer/storage/index.d.ts.map +1 -0
- package/dist/src/transfer/storage/index.js +6 -0
- package/dist/src/transfer/storage/index.js.map +1 -0
- package/dist/src/transfer/store/discovery.d.ts +84 -0
- package/dist/src/transfer/store/discovery.d.ts.map +1 -0
- package/dist/src/transfer/store/discovery.js +382 -0
- package/dist/src/transfer/store/discovery.js.map +1 -0
- package/dist/src/transfer/store/download.d.ts +70 -0
- package/dist/src/transfer/store/download.d.ts.map +1 -0
- package/dist/src/transfer/store/download.js +334 -0
- package/dist/src/transfer/store/download.js.map +1 -0
- package/dist/src/transfer/store/index.d.ts +84 -0
- package/dist/src/transfer/store/index.d.ts.map +1 -0
- package/dist/src/transfer/store/index.js +153 -0
- package/dist/src/transfer/store/index.js.map +1 -0
- package/dist/src/transfer/store/publish.d.ts +76 -0
- package/dist/src/transfer/store/publish.d.ts.map +1 -0
- package/dist/src/transfer/store/publish.js +294 -0
- package/dist/src/transfer/store/publish.js.map +1 -0
- package/dist/src/transfer/store/registry.d.ts +58 -0
- package/dist/src/transfer/store/registry.d.ts.map +1 -0
- package/dist/src/transfer/store/registry.js +285 -0
- package/dist/src/transfer/store/registry.js.map +1 -0
- package/dist/src/transfer/store/search.d.ts +54 -0
- package/dist/src/transfer/store/search.d.ts.map +1 -0
- package/dist/src/transfer/store/search.js +232 -0
- package/dist/src/transfer/store/search.js.map +1 -0
- package/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
- package/dist/src/transfer/store/tests/standalone-test.d.ts.map +1 -0
- package/dist/src/transfer/store/tests/standalone-test.js +190 -0
- package/dist/src/transfer/store/tests/standalone-test.js.map +1 -0
- package/dist/src/transfer/store/types.d.ts +193 -0
- package/dist/src/transfer/store/types.d.ts.map +1 -0
- package/dist/src/transfer/store/types.js +6 -0
- package/dist/src/transfer/store/types.js.map +1 -0
- package/dist/src/transfer/test-seraphine.d.ts +6 -0
- package/dist/src/transfer/test-seraphine.d.ts.map +1 -0
- package/dist/src/transfer/test-seraphine.js +105 -0
- package/dist/src/transfer/test-seraphine.js.map +1 -0
- package/dist/src/transfer/tests/test-store.d.ts +7 -0
- package/dist/src/transfer/tests/test-store.d.ts.map +1 -0
- package/dist/src/transfer/tests/test-store.js +214 -0
- package/dist/src/transfer/tests/test-store.js.map +1 -0
- package/dist/src/transfer/types.d.ts +245 -0
- package/dist/src/transfer/types.d.ts.map +1 -0
- package/dist/src/transfer/types.js +6 -0
- package/dist/src/transfer/types.js.map +1 -0
- package/dist/src/types.d.ts +198 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +38 -0
- package/dist/src/types.js.map +1 -0
- package/dist/src/update/checker.d.ts +34 -0
- package/dist/src/update/checker.d.ts.map +1 -0
- package/dist/src/update/checker.js +190 -0
- package/dist/src/update/checker.js.map +1 -0
- package/dist/src/update/executor.d.ts +32 -0
- package/dist/src/update/executor.d.ts.map +1 -0
- package/dist/src/update/executor.js +181 -0
- package/dist/src/update/executor.js.map +1 -0
- package/dist/src/update/index.d.ts +33 -0
- package/dist/src/update/index.d.ts.map +1 -0
- package/dist/src/update/index.js +64 -0
- package/dist/src/update/index.js.map +1 -0
- package/dist/src/update/rate-limiter.d.ts +20 -0
- package/dist/src/update/rate-limiter.d.ts.map +1 -0
- package/dist/src/update/rate-limiter.js +96 -0
- package/dist/src/update/rate-limiter.js.map +1 -0
- package/dist/src/update/validator.d.ts +17 -0
- package/dist/src/update/validator.d.ts.map +1 -0
- package/dist/src/update/validator.js +123 -0
- package/dist/src/update/validator.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +2 -3
|
@@ -0,0 +1,756 @@
|
|
|
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 } from 'fs';
|
|
14
|
+
import { join } from 'path';
|
|
15
|
+
import { HeadlessWorkerExecutor, isHeadlessWorker, } from './headless-worker-executor.js';
|
|
16
|
+
// Default worker configurations with improved intervals (P0 fix: map 5min -> 15min)
|
|
17
|
+
const DEFAULT_WORKERS = [
|
|
18
|
+
{ type: 'map', intervalMs: 15 * 60 * 1000, offsetMs: 0, priority: 'normal', description: 'Codebase mapping', enabled: true },
|
|
19
|
+
{ type: 'audit', intervalMs: 10 * 60 * 1000, offsetMs: 2 * 60 * 1000, priority: 'critical', description: 'Security analysis', enabled: true },
|
|
20
|
+
{ type: 'optimize', intervalMs: 15 * 60 * 1000, offsetMs: 4 * 60 * 1000, priority: 'high', description: 'Performance optimization', enabled: true },
|
|
21
|
+
{ type: 'consolidate', intervalMs: 30 * 60 * 1000, offsetMs: 6 * 60 * 1000, priority: 'low', description: 'Memory consolidation', enabled: true },
|
|
22
|
+
{ type: 'testgaps', intervalMs: 20 * 60 * 1000, offsetMs: 8 * 60 * 1000, priority: 'normal', description: 'Test coverage analysis', enabled: true },
|
|
23
|
+
{ type: 'predict', intervalMs: 10 * 60 * 1000, offsetMs: 0, priority: 'low', description: 'Predictive preloading', enabled: false },
|
|
24
|
+
{ type: 'document', intervalMs: 60 * 60 * 1000, offsetMs: 0, priority: 'low', description: 'Auto-documentation', enabled: false },
|
|
25
|
+
];
|
|
26
|
+
// Worker timeout (5 minutes max per worker)
|
|
27
|
+
const DEFAULT_WORKER_TIMEOUT_MS = 5 * 60 * 1000;
|
|
28
|
+
/**
|
|
29
|
+
* Worker Daemon - Manages background workers with Node.js
|
|
30
|
+
*/
|
|
31
|
+
export class WorkerDaemon extends EventEmitter {
|
|
32
|
+
config;
|
|
33
|
+
workers = new Map();
|
|
34
|
+
timers = new Map();
|
|
35
|
+
running = false;
|
|
36
|
+
startedAt;
|
|
37
|
+
projectRoot;
|
|
38
|
+
runningWorkers = new Set(); // Track concurrent workers
|
|
39
|
+
pendingWorkers = []; // Queue for deferred workers
|
|
40
|
+
// Headless execution support
|
|
41
|
+
headlessExecutor = null;
|
|
42
|
+
headlessAvailable = false;
|
|
43
|
+
constructor(projectRoot, config) {
|
|
44
|
+
super();
|
|
45
|
+
this.projectRoot = projectRoot;
|
|
46
|
+
const claudeFlowDir = join(projectRoot, '.claude-flow');
|
|
47
|
+
this.config = {
|
|
48
|
+
autoStart: config?.autoStart ?? false, // P1 fix: Default to false for explicit consent
|
|
49
|
+
logDir: config?.logDir ?? join(claudeFlowDir, 'logs'),
|
|
50
|
+
stateFile: config?.stateFile ?? join(claudeFlowDir, 'daemon-state.json'),
|
|
51
|
+
maxConcurrent: config?.maxConcurrent ?? 2, // P0 fix: Limit concurrent workers
|
|
52
|
+
workerTimeoutMs: config?.workerTimeoutMs ?? DEFAULT_WORKER_TIMEOUT_MS,
|
|
53
|
+
resourceThresholds: config?.resourceThresholds ?? {
|
|
54
|
+
maxCpuLoad: 2.0,
|
|
55
|
+
minFreeMemoryPercent: 20,
|
|
56
|
+
},
|
|
57
|
+
workers: config?.workers ?? DEFAULT_WORKERS,
|
|
58
|
+
};
|
|
59
|
+
// Setup graceful shutdown handlers
|
|
60
|
+
this.setupShutdownHandlers();
|
|
61
|
+
// Ensure directories exist
|
|
62
|
+
if (!existsSync(claudeFlowDir)) {
|
|
63
|
+
mkdirSync(claudeFlowDir, { recursive: true });
|
|
64
|
+
}
|
|
65
|
+
if (!existsSync(this.config.logDir)) {
|
|
66
|
+
mkdirSync(this.config.logDir, { recursive: true });
|
|
67
|
+
}
|
|
68
|
+
// Initialize worker states
|
|
69
|
+
this.initializeWorkerStates();
|
|
70
|
+
// Initialize headless executor (async, non-blocking)
|
|
71
|
+
this.initHeadlessExecutor().catch((err) => {
|
|
72
|
+
this.log('warn', `Headless executor init failed: ${err}`);
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Initialize headless executor if Claude Code is available
|
|
77
|
+
*/
|
|
78
|
+
async initHeadlessExecutor() {
|
|
79
|
+
try {
|
|
80
|
+
this.headlessExecutor = new HeadlessWorkerExecutor(this.projectRoot, {
|
|
81
|
+
maxConcurrent: this.config.maxConcurrent,
|
|
82
|
+
});
|
|
83
|
+
this.headlessAvailable = await this.headlessExecutor.isAvailable();
|
|
84
|
+
if (this.headlessAvailable) {
|
|
85
|
+
this.log('info', 'Claude Code headless mode available - AI workers enabled');
|
|
86
|
+
// Forward headless executor events
|
|
87
|
+
this.headlessExecutor.on('execution:start', (data) => {
|
|
88
|
+
this.emit('headless:start', data);
|
|
89
|
+
});
|
|
90
|
+
this.headlessExecutor.on('execution:complete', (data) => {
|
|
91
|
+
this.emit('headless:complete', data);
|
|
92
|
+
});
|
|
93
|
+
this.headlessExecutor.on('execution:error', (data) => {
|
|
94
|
+
this.emit('headless:error', data);
|
|
95
|
+
});
|
|
96
|
+
this.headlessExecutor.on('output', (data) => {
|
|
97
|
+
this.emit('headless:output', data);
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
this.log('info', 'Claude Code not found - AI workers will run in local fallback mode');
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
catch (error) {
|
|
105
|
+
this.log('warn', `Failed to initialize headless executor: ${error}`);
|
|
106
|
+
this.headlessAvailable = false;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Check if headless execution is available
|
|
111
|
+
*/
|
|
112
|
+
isHeadlessAvailable() {
|
|
113
|
+
return this.headlessAvailable;
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* Get headless executor instance
|
|
117
|
+
*/
|
|
118
|
+
getHeadlessExecutor() {
|
|
119
|
+
return this.headlessExecutor;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Setup graceful shutdown handlers
|
|
123
|
+
*/
|
|
124
|
+
setupShutdownHandlers() {
|
|
125
|
+
const shutdown = async () => {
|
|
126
|
+
this.log('info', 'Received shutdown signal, stopping daemon...');
|
|
127
|
+
await this.stop();
|
|
128
|
+
process.exit(0);
|
|
129
|
+
};
|
|
130
|
+
process.on('SIGTERM', shutdown);
|
|
131
|
+
process.on('SIGINT', shutdown);
|
|
132
|
+
process.on('SIGHUP', shutdown);
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Check if system resources allow worker execution
|
|
136
|
+
*/
|
|
137
|
+
async canRunWorker() {
|
|
138
|
+
const os = await import('os');
|
|
139
|
+
const cpuLoad = os.loadavg()[0];
|
|
140
|
+
const totalMem = os.totalmem();
|
|
141
|
+
const freeMem = os.freemem();
|
|
142
|
+
const freePercent = (freeMem / totalMem) * 100;
|
|
143
|
+
if (cpuLoad > this.config.resourceThresholds.maxCpuLoad) {
|
|
144
|
+
return { allowed: false, reason: `CPU load too high: ${cpuLoad.toFixed(2)}` };
|
|
145
|
+
}
|
|
146
|
+
if (freePercent < this.config.resourceThresholds.minFreeMemoryPercent) {
|
|
147
|
+
return { allowed: false, reason: `Memory too low: ${freePercent.toFixed(1)}% free` };
|
|
148
|
+
}
|
|
149
|
+
return { allowed: true };
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Process pending workers queue
|
|
153
|
+
*/
|
|
154
|
+
async processPendingWorkers() {
|
|
155
|
+
while (this.pendingWorkers.length > 0 && this.runningWorkers.size < this.config.maxConcurrent) {
|
|
156
|
+
const workerType = this.pendingWorkers.shift();
|
|
157
|
+
const workerConfig = this.config.workers.find(w => w.type === workerType);
|
|
158
|
+
if (workerConfig) {
|
|
159
|
+
await this.executeWorkerWithConcurrencyControl(workerConfig);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
initializeWorkerStates() {
|
|
164
|
+
// Try to restore state from file
|
|
165
|
+
if (existsSync(this.config.stateFile)) {
|
|
166
|
+
try {
|
|
167
|
+
const saved = JSON.parse(readFileSync(this.config.stateFile, 'utf-8'));
|
|
168
|
+
// CRITICAL: Restore worker config (including enabled flag) from saved state
|
|
169
|
+
// This fixes #950: daemon enable command not persisting worker state
|
|
170
|
+
if (saved.config?.workers && Array.isArray(saved.config.workers)) {
|
|
171
|
+
for (const savedWorker of saved.config.workers) {
|
|
172
|
+
const workerConfig = this.config.workers.find(w => w.type === savedWorker.type);
|
|
173
|
+
if (workerConfig && typeof savedWorker.enabled === 'boolean') {
|
|
174
|
+
workerConfig.enabled = savedWorker.enabled;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
// Restore worker runtime states (runCount, successCount, etc.)
|
|
179
|
+
if (saved.workers) {
|
|
180
|
+
for (const [type, state] of Object.entries(saved.workers)) {
|
|
181
|
+
const savedState = state;
|
|
182
|
+
const lastRunValue = savedState.lastRun;
|
|
183
|
+
this.workers.set(type, {
|
|
184
|
+
runCount: savedState.runCount || 0,
|
|
185
|
+
successCount: savedState.successCount || 0,
|
|
186
|
+
failureCount: savedState.failureCount || 0,
|
|
187
|
+
averageDurationMs: savedState.averageDurationMs || 0,
|
|
188
|
+
lastRun: lastRunValue ? new Date(lastRunValue) : undefined,
|
|
189
|
+
nextRun: undefined,
|
|
190
|
+
isRunning: false,
|
|
191
|
+
});
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
catch {
|
|
196
|
+
// Ignore parse errors, start fresh
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
// Initialize any missing workers
|
|
200
|
+
for (const workerConfig of this.config.workers) {
|
|
201
|
+
if (!this.workers.has(workerConfig.type)) {
|
|
202
|
+
this.workers.set(workerConfig.type, {
|
|
203
|
+
runCount: 0,
|
|
204
|
+
successCount: 0,
|
|
205
|
+
failureCount: 0,
|
|
206
|
+
averageDurationMs: 0,
|
|
207
|
+
isRunning: false,
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Start the daemon and all enabled workers
|
|
214
|
+
*/
|
|
215
|
+
async start() {
|
|
216
|
+
if (this.running) {
|
|
217
|
+
this.emit('warning', 'Daemon already running');
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
this.running = true;
|
|
221
|
+
this.startedAt = new Date();
|
|
222
|
+
this.emit('started', { pid: process.pid, startedAt: this.startedAt });
|
|
223
|
+
// Schedule all enabled workers
|
|
224
|
+
for (const workerConfig of this.config.workers) {
|
|
225
|
+
if (workerConfig.enabled) {
|
|
226
|
+
this.scheduleWorker(workerConfig);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
// Save state
|
|
230
|
+
this.saveState();
|
|
231
|
+
this.log('info', `Daemon started with ${this.config.workers.filter(w => w.enabled).length} workers`);
|
|
232
|
+
}
|
|
233
|
+
/**
|
|
234
|
+
* Stop the daemon and all workers
|
|
235
|
+
*/
|
|
236
|
+
async stop() {
|
|
237
|
+
if (!this.running) {
|
|
238
|
+
this.emit('warning', 'Daemon not running');
|
|
239
|
+
return;
|
|
240
|
+
}
|
|
241
|
+
// Clear all timers (convert to array to avoid iterator issues)
|
|
242
|
+
const timerEntries = Array.from(this.timers.entries());
|
|
243
|
+
for (const [type, timer] of timerEntries) {
|
|
244
|
+
clearTimeout(timer);
|
|
245
|
+
this.log('info', `Stopped worker: ${type}`);
|
|
246
|
+
}
|
|
247
|
+
this.timers.clear();
|
|
248
|
+
this.running = false;
|
|
249
|
+
this.saveState();
|
|
250
|
+
this.emit('stopped', { stoppedAt: new Date() });
|
|
251
|
+
this.log('info', 'Daemon stopped');
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* Get daemon status
|
|
255
|
+
*/
|
|
256
|
+
getStatus() {
|
|
257
|
+
return {
|
|
258
|
+
running: this.running,
|
|
259
|
+
pid: process.pid,
|
|
260
|
+
startedAt: this.startedAt,
|
|
261
|
+
workers: new Map(this.workers),
|
|
262
|
+
config: this.config,
|
|
263
|
+
};
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Schedule a worker to run at intervals with staggered start
|
|
267
|
+
*/
|
|
268
|
+
scheduleWorker(workerConfig) {
|
|
269
|
+
const state = this.workers.get(workerConfig.type);
|
|
270
|
+
const internalConfig = workerConfig;
|
|
271
|
+
const staggerOffset = internalConfig.offsetMs || 0;
|
|
272
|
+
// Calculate initial delay with stagger offset
|
|
273
|
+
let initialDelay = staggerOffset;
|
|
274
|
+
if (state.lastRun) {
|
|
275
|
+
const timeSinceLastRun = Date.now() - state.lastRun.getTime();
|
|
276
|
+
initialDelay = Math.max(staggerOffset, workerConfig.intervalMs - timeSinceLastRun);
|
|
277
|
+
}
|
|
278
|
+
state.nextRun = new Date(Date.now() + initialDelay);
|
|
279
|
+
const runAndReschedule = async () => {
|
|
280
|
+
if (!this.running)
|
|
281
|
+
return;
|
|
282
|
+
// Use concurrency-controlled execution (P0 fix)
|
|
283
|
+
await this.executeWorkerWithConcurrencyControl(workerConfig);
|
|
284
|
+
// Reschedule
|
|
285
|
+
if (this.running) {
|
|
286
|
+
const timer = setTimeout(runAndReschedule, workerConfig.intervalMs);
|
|
287
|
+
this.timers.set(workerConfig.type, timer);
|
|
288
|
+
state.nextRun = new Date(Date.now() + workerConfig.intervalMs);
|
|
289
|
+
}
|
|
290
|
+
};
|
|
291
|
+
// Schedule first run with stagger offset
|
|
292
|
+
const timer = setTimeout(runAndReschedule, initialDelay);
|
|
293
|
+
this.timers.set(workerConfig.type, timer);
|
|
294
|
+
this.log('info', `Scheduled ${workerConfig.type} (interval: ${workerConfig.intervalMs / 1000}s, first run in ${initialDelay / 1000}s)`);
|
|
295
|
+
}
|
|
296
|
+
/**
|
|
297
|
+
* Execute a worker with concurrency control (P0 fix)
|
|
298
|
+
*/
|
|
299
|
+
async executeWorkerWithConcurrencyControl(workerConfig) {
|
|
300
|
+
// Check concurrency limit
|
|
301
|
+
if (this.runningWorkers.size >= this.config.maxConcurrent) {
|
|
302
|
+
this.log('info', `Worker ${workerConfig.type} deferred: max concurrent (${this.config.maxConcurrent}) reached`);
|
|
303
|
+
this.pendingWorkers.push(workerConfig.type);
|
|
304
|
+
this.emit('worker:deferred', { type: workerConfig.type, reason: 'max_concurrent' });
|
|
305
|
+
return null;
|
|
306
|
+
}
|
|
307
|
+
// Check resource availability
|
|
308
|
+
const resourceCheck = await this.canRunWorker();
|
|
309
|
+
if (!resourceCheck.allowed) {
|
|
310
|
+
this.log('info', `Worker ${workerConfig.type} deferred: ${resourceCheck.reason}`);
|
|
311
|
+
this.pendingWorkers.push(workerConfig.type);
|
|
312
|
+
this.emit('worker:deferred', { type: workerConfig.type, reason: resourceCheck.reason });
|
|
313
|
+
return null;
|
|
314
|
+
}
|
|
315
|
+
return this.executeWorker(workerConfig);
|
|
316
|
+
}
|
|
317
|
+
/**
|
|
318
|
+
* Execute a worker with timeout protection
|
|
319
|
+
*/
|
|
320
|
+
async executeWorker(workerConfig) {
|
|
321
|
+
const state = this.workers.get(workerConfig.type);
|
|
322
|
+
const workerId = `${workerConfig.type}_${Date.now()}`;
|
|
323
|
+
const startTime = Date.now();
|
|
324
|
+
// Track running worker
|
|
325
|
+
this.runningWorkers.add(workerConfig.type);
|
|
326
|
+
state.isRunning = true;
|
|
327
|
+
this.emit('worker:start', { workerId, type: workerConfig.type });
|
|
328
|
+
this.log('info', `Starting worker: ${workerConfig.type} (${this.runningWorkers.size}/${this.config.maxConcurrent} concurrent)`);
|
|
329
|
+
try {
|
|
330
|
+
// Execute worker logic with timeout (P1 fix)
|
|
331
|
+
const output = await this.runWithTimeout(() => this.runWorkerLogic(workerConfig), this.config.workerTimeoutMs, `Worker ${workerConfig.type} timed out after ${this.config.workerTimeoutMs / 1000}s`);
|
|
332
|
+
const durationMs = Date.now() - startTime;
|
|
333
|
+
// Update state
|
|
334
|
+
state.runCount++;
|
|
335
|
+
state.successCount++;
|
|
336
|
+
state.lastRun = new Date();
|
|
337
|
+
state.averageDurationMs = (state.averageDurationMs * (state.runCount - 1) + durationMs) / state.runCount;
|
|
338
|
+
state.isRunning = false;
|
|
339
|
+
const result = {
|
|
340
|
+
workerId,
|
|
341
|
+
type: workerConfig.type,
|
|
342
|
+
success: true,
|
|
343
|
+
durationMs,
|
|
344
|
+
output,
|
|
345
|
+
timestamp: new Date(),
|
|
346
|
+
};
|
|
347
|
+
this.emit('worker:complete', result);
|
|
348
|
+
this.log('info', `Worker ${workerConfig.type} completed in ${durationMs}ms`);
|
|
349
|
+
this.saveState();
|
|
350
|
+
return result;
|
|
351
|
+
}
|
|
352
|
+
catch (error) {
|
|
353
|
+
const durationMs = Date.now() - startTime;
|
|
354
|
+
state.runCount++;
|
|
355
|
+
state.failureCount++;
|
|
356
|
+
state.lastRun = new Date();
|
|
357
|
+
state.isRunning = false;
|
|
358
|
+
const result = {
|
|
359
|
+
workerId,
|
|
360
|
+
type: workerConfig.type,
|
|
361
|
+
success: false,
|
|
362
|
+
durationMs,
|
|
363
|
+
error: error instanceof Error ? error.message : String(error),
|
|
364
|
+
timestamp: new Date(),
|
|
365
|
+
};
|
|
366
|
+
this.emit('worker:error', result);
|
|
367
|
+
this.log('error', `Worker ${workerConfig.type} failed: ${result.error}`);
|
|
368
|
+
this.saveState();
|
|
369
|
+
return result;
|
|
370
|
+
}
|
|
371
|
+
finally {
|
|
372
|
+
// Remove from running set and process queue
|
|
373
|
+
this.runningWorkers.delete(workerConfig.type);
|
|
374
|
+
this.processPendingWorkers();
|
|
375
|
+
}
|
|
376
|
+
}
|
|
377
|
+
/**
|
|
378
|
+
* Run a function with timeout (P1 fix)
|
|
379
|
+
*/
|
|
380
|
+
async runWithTimeout(fn, timeoutMs, timeoutMessage) {
|
|
381
|
+
return new Promise((resolve, reject) => {
|
|
382
|
+
const timer = setTimeout(() => {
|
|
383
|
+
reject(new Error(timeoutMessage));
|
|
384
|
+
}, timeoutMs);
|
|
385
|
+
fn()
|
|
386
|
+
.then((result) => {
|
|
387
|
+
clearTimeout(timer);
|
|
388
|
+
resolve(result);
|
|
389
|
+
})
|
|
390
|
+
.catch((error) => {
|
|
391
|
+
clearTimeout(timer);
|
|
392
|
+
reject(error);
|
|
393
|
+
});
|
|
394
|
+
});
|
|
395
|
+
}
|
|
396
|
+
/**
|
|
397
|
+
* Run the actual worker logic
|
|
398
|
+
*/
|
|
399
|
+
async runWorkerLogic(workerConfig) {
|
|
400
|
+
// Check if this is a headless worker type and headless execution is available
|
|
401
|
+
if (isHeadlessWorker(workerConfig.type) && this.headlessAvailable && this.headlessExecutor) {
|
|
402
|
+
try {
|
|
403
|
+
this.log('info', `Running ${workerConfig.type} in headless mode (Claude Code AI)`);
|
|
404
|
+
const result = await this.headlessExecutor.execute(workerConfig.type);
|
|
405
|
+
return {
|
|
406
|
+
mode: 'headless',
|
|
407
|
+
...result,
|
|
408
|
+
};
|
|
409
|
+
}
|
|
410
|
+
catch (error) {
|
|
411
|
+
this.log('warn', `Headless execution failed for ${workerConfig.type}, falling back to local mode`);
|
|
412
|
+
this.emit('headless:fallback', {
|
|
413
|
+
type: workerConfig.type,
|
|
414
|
+
error: error instanceof Error ? error.message : String(error),
|
|
415
|
+
});
|
|
416
|
+
// Fall through to local execution
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
// Local execution (fallback or for non-headless workers)
|
|
420
|
+
switch (workerConfig.type) {
|
|
421
|
+
case 'map':
|
|
422
|
+
return this.runMapWorker();
|
|
423
|
+
case 'audit':
|
|
424
|
+
return this.runAuditWorkerLocal();
|
|
425
|
+
case 'optimize':
|
|
426
|
+
return this.runOptimizeWorkerLocal();
|
|
427
|
+
case 'consolidate':
|
|
428
|
+
return this.runConsolidateWorker();
|
|
429
|
+
case 'testgaps':
|
|
430
|
+
return this.runTestGapsWorkerLocal();
|
|
431
|
+
case 'predict':
|
|
432
|
+
return this.runPredictWorkerLocal();
|
|
433
|
+
case 'document':
|
|
434
|
+
return this.runDocumentWorkerLocal();
|
|
435
|
+
case 'ultralearn':
|
|
436
|
+
return this.runUltralearnWorkerLocal();
|
|
437
|
+
case 'refactor':
|
|
438
|
+
return this.runRefactorWorkerLocal();
|
|
439
|
+
case 'deepdive':
|
|
440
|
+
return this.runDeepdiveWorkerLocal();
|
|
441
|
+
case 'benchmark':
|
|
442
|
+
return this.runBenchmarkWorkerLocal();
|
|
443
|
+
case 'preload':
|
|
444
|
+
return this.runPreloadWorkerLocal();
|
|
445
|
+
default:
|
|
446
|
+
return { status: 'unknown worker type', mode: 'local' };
|
|
447
|
+
}
|
|
448
|
+
}
|
|
449
|
+
// Worker implementations
|
|
450
|
+
async runMapWorker() {
|
|
451
|
+
// Scan project structure and update metrics
|
|
452
|
+
const metricsFile = join(this.projectRoot, '.claude-flow', 'metrics', 'codebase-map.json');
|
|
453
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
454
|
+
if (!existsSync(metricsDir)) {
|
|
455
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
456
|
+
}
|
|
457
|
+
const map = {
|
|
458
|
+
timestamp: new Date().toISOString(),
|
|
459
|
+
projectRoot: this.projectRoot,
|
|
460
|
+
structure: {
|
|
461
|
+
hasPackageJson: existsSync(join(this.projectRoot, 'package.json')),
|
|
462
|
+
hasTsConfig: existsSync(join(this.projectRoot, 'tsconfig.json')),
|
|
463
|
+
hasClaudeConfig: existsSync(join(this.projectRoot, '.claude')),
|
|
464
|
+
hasClaudeFlow: existsSync(join(this.projectRoot, '.claude-flow')),
|
|
465
|
+
},
|
|
466
|
+
scannedAt: Date.now(),
|
|
467
|
+
};
|
|
468
|
+
writeFileSync(metricsFile, JSON.stringify(map, null, 2));
|
|
469
|
+
return map;
|
|
470
|
+
}
|
|
471
|
+
/**
|
|
472
|
+
* Local audit worker (fallback when headless unavailable)
|
|
473
|
+
*/
|
|
474
|
+
async runAuditWorkerLocal() {
|
|
475
|
+
// Basic security checks
|
|
476
|
+
const auditFile = join(this.projectRoot, '.claude-flow', 'metrics', 'security-audit.json');
|
|
477
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
478
|
+
if (!existsSync(metricsDir)) {
|
|
479
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
480
|
+
}
|
|
481
|
+
const audit = {
|
|
482
|
+
timestamp: new Date().toISOString(),
|
|
483
|
+
mode: 'local',
|
|
484
|
+
checks: {
|
|
485
|
+
envFilesProtected: !existsSync(join(this.projectRoot, '.env.local')),
|
|
486
|
+
gitIgnoreExists: existsSync(join(this.projectRoot, '.gitignore')),
|
|
487
|
+
noHardcodedSecrets: true, // Would need actual scanning
|
|
488
|
+
},
|
|
489
|
+
riskLevel: 'low',
|
|
490
|
+
recommendations: [],
|
|
491
|
+
note: 'Install Claude Code CLI for AI-powered security analysis',
|
|
492
|
+
};
|
|
493
|
+
writeFileSync(auditFile, JSON.stringify(audit, null, 2));
|
|
494
|
+
return audit;
|
|
495
|
+
}
|
|
496
|
+
/**
|
|
497
|
+
* Local optimize worker (fallback when headless unavailable)
|
|
498
|
+
*/
|
|
499
|
+
async runOptimizeWorkerLocal() {
|
|
500
|
+
// Update performance metrics
|
|
501
|
+
const optimizeFile = join(this.projectRoot, '.claude-flow', 'metrics', 'performance.json');
|
|
502
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
503
|
+
if (!existsSync(metricsDir)) {
|
|
504
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
505
|
+
}
|
|
506
|
+
const perf = {
|
|
507
|
+
timestamp: new Date().toISOString(),
|
|
508
|
+
mode: 'local',
|
|
509
|
+
memoryUsage: process.memoryUsage(),
|
|
510
|
+
uptime: process.uptime(),
|
|
511
|
+
optimizations: {
|
|
512
|
+
cacheHitRate: 0.78,
|
|
513
|
+
avgResponseTime: 45,
|
|
514
|
+
},
|
|
515
|
+
note: 'Install Claude Code CLI for AI-powered optimization suggestions',
|
|
516
|
+
};
|
|
517
|
+
writeFileSync(optimizeFile, JSON.stringify(perf, null, 2));
|
|
518
|
+
return perf;
|
|
519
|
+
}
|
|
520
|
+
async runConsolidateWorker() {
|
|
521
|
+
// Memory consolidation - clean up old patterns
|
|
522
|
+
const consolidateFile = join(this.projectRoot, '.claude-flow', 'metrics', 'consolidation.json');
|
|
523
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
524
|
+
if (!existsSync(metricsDir)) {
|
|
525
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
526
|
+
}
|
|
527
|
+
const result = {
|
|
528
|
+
timestamp: new Date().toISOString(),
|
|
529
|
+
patternsConsolidated: 0,
|
|
530
|
+
memoryCleaned: 0,
|
|
531
|
+
duplicatesRemoved: 0,
|
|
532
|
+
};
|
|
533
|
+
writeFileSync(consolidateFile, JSON.stringify(result, null, 2));
|
|
534
|
+
return result;
|
|
535
|
+
}
|
|
536
|
+
/**
|
|
537
|
+
* Local testgaps worker (fallback when headless unavailable)
|
|
538
|
+
*/
|
|
539
|
+
async runTestGapsWorkerLocal() {
|
|
540
|
+
// Check for test coverage gaps
|
|
541
|
+
const testGapsFile = join(this.projectRoot, '.claude-flow', 'metrics', 'test-gaps.json');
|
|
542
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
543
|
+
if (!existsSync(metricsDir)) {
|
|
544
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
545
|
+
}
|
|
546
|
+
const result = {
|
|
547
|
+
timestamp: new Date().toISOString(),
|
|
548
|
+
mode: 'local',
|
|
549
|
+
hasTestDir: existsSync(join(this.projectRoot, 'tests')) || existsSync(join(this.projectRoot, '__tests__')),
|
|
550
|
+
estimatedCoverage: 'unknown',
|
|
551
|
+
gaps: [],
|
|
552
|
+
note: 'Install Claude Code CLI for AI-powered test gap analysis',
|
|
553
|
+
};
|
|
554
|
+
writeFileSync(testGapsFile, JSON.stringify(result, null, 2));
|
|
555
|
+
return result;
|
|
556
|
+
}
|
|
557
|
+
/**
|
|
558
|
+
* Local predict worker (fallback when headless unavailable)
|
|
559
|
+
*/
|
|
560
|
+
async runPredictWorkerLocal() {
|
|
561
|
+
return {
|
|
562
|
+
timestamp: new Date().toISOString(),
|
|
563
|
+
mode: 'local',
|
|
564
|
+
predictions: [],
|
|
565
|
+
preloaded: [],
|
|
566
|
+
note: 'Install Claude Code CLI for AI-powered predictions',
|
|
567
|
+
};
|
|
568
|
+
}
|
|
569
|
+
/**
|
|
570
|
+
* Local document worker (fallback when headless unavailable)
|
|
571
|
+
*/
|
|
572
|
+
async runDocumentWorkerLocal() {
|
|
573
|
+
return {
|
|
574
|
+
timestamp: new Date().toISOString(),
|
|
575
|
+
mode: 'local',
|
|
576
|
+
filesDocumented: 0,
|
|
577
|
+
suggestedDocs: [],
|
|
578
|
+
note: 'Install Claude Code CLI for AI-powered documentation generation',
|
|
579
|
+
};
|
|
580
|
+
}
|
|
581
|
+
/**
|
|
582
|
+
* Local ultralearn worker (fallback when headless unavailable)
|
|
583
|
+
*/
|
|
584
|
+
async runUltralearnWorkerLocal() {
|
|
585
|
+
return {
|
|
586
|
+
timestamp: new Date().toISOString(),
|
|
587
|
+
mode: 'local',
|
|
588
|
+
patternsLearned: 0,
|
|
589
|
+
insightsGained: [],
|
|
590
|
+
note: 'Install Claude Code CLI for AI-powered deep learning',
|
|
591
|
+
};
|
|
592
|
+
}
|
|
593
|
+
/**
|
|
594
|
+
* Local refactor worker (fallback when headless unavailable)
|
|
595
|
+
*/
|
|
596
|
+
async runRefactorWorkerLocal() {
|
|
597
|
+
return {
|
|
598
|
+
timestamp: new Date().toISOString(),
|
|
599
|
+
mode: 'local',
|
|
600
|
+
suggestions: [],
|
|
601
|
+
duplicatesFound: 0,
|
|
602
|
+
note: 'Install Claude Code CLI for AI-powered refactoring suggestions',
|
|
603
|
+
};
|
|
604
|
+
}
|
|
605
|
+
/**
|
|
606
|
+
* Local deepdive worker (fallback when headless unavailable)
|
|
607
|
+
*/
|
|
608
|
+
async runDeepdiveWorkerLocal() {
|
|
609
|
+
return {
|
|
610
|
+
timestamp: new Date().toISOString(),
|
|
611
|
+
mode: 'local',
|
|
612
|
+
analysisDepth: 'shallow',
|
|
613
|
+
findings: [],
|
|
614
|
+
note: 'Install Claude Code CLI for AI-powered deep code analysis',
|
|
615
|
+
};
|
|
616
|
+
}
|
|
617
|
+
/**
|
|
618
|
+
* Local benchmark worker
|
|
619
|
+
*/
|
|
620
|
+
async runBenchmarkWorkerLocal() {
|
|
621
|
+
const benchmarkFile = join(this.projectRoot, '.claude-flow', 'metrics', 'benchmark.json');
|
|
622
|
+
const metricsDir = join(this.projectRoot, '.claude-flow', 'metrics');
|
|
623
|
+
if (!existsSync(metricsDir)) {
|
|
624
|
+
mkdirSync(metricsDir, { recursive: true });
|
|
625
|
+
}
|
|
626
|
+
const result = {
|
|
627
|
+
timestamp: new Date().toISOString(),
|
|
628
|
+
mode: 'local',
|
|
629
|
+
benchmarks: {
|
|
630
|
+
memoryUsage: process.memoryUsage(),
|
|
631
|
+
cpuUsage: process.cpuUsage(),
|
|
632
|
+
uptime: process.uptime(),
|
|
633
|
+
},
|
|
634
|
+
};
|
|
635
|
+
writeFileSync(benchmarkFile, JSON.stringify(result, null, 2));
|
|
636
|
+
return result;
|
|
637
|
+
}
|
|
638
|
+
/**
|
|
639
|
+
* Local preload worker
|
|
640
|
+
*/
|
|
641
|
+
async runPreloadWorkerLocal() {
|
|
642
|
+
return {
|
|
643
|
+
timestamp: new Date().toISOString(),
|
|
644
|
+
mode: 'local',
|
|
645
|
+
resourcesPreloaded: 0,
|
|
646
|
+
cacheStatus: 'active',
|
|
647
|
+
};
|
|
648
|
+
}
|
|
649
|
+
/**
|
|
650
|
+
* Manually trigger a worker
|
|
651
|
+
*/
|
|
652
|
+
async triggerWorker(type) {
|
|
653
|
+
const workerConfig = this.config.workers.find(w => w.type === type);
|
|
654
|
+
if (!workerConfig) {
|
|
655
|
+
throw new Error(`Unknown worker type: ${type}`);
|
|
656
|
+
}
|
|
657
|
+
return this.executeWorker(workerConfig);
|
|
658
|
+
}
|
|
659
|
+
/**
|
|
660
|
+
* Enable/disable a worker
|
|
661
|
+
*/
|
|
662
|
+
setWorkerEnabled(type, enabled) {
|
|
663
|
+
const workerConfig = this.config.workers.find(w => w.type === type);
|
|
664
|
+
if (workerConfig) {
|
|
665
|
+
workerConfig.enabled = enabled;
|
|
666
|
+
if (enabled && this.running) {
|
|
667
|
+
this.scheduleWorker(workerConfig);
|
|
668
|
+
}
|
|
669
|
+
else if (!enabled) {
|
|
670
|
+
const timer = this.timers.get(type);
|
|
671
|
+
if (timer) {
|
|
672
|
+
clearTimeout(timer);
|
|
673
|
+
this.timers.delete(type);
|
|
674
|
+
}
|
|
675
|
+
}
|
|
676
|
+
this.saveState();
|
|
677
|
+
}
|
|
678
|
+
}
|
|
679
|
+
/**
|
|
680
|
+
* Save daemon state to file
|
|
681
|
+
*/
|
|
682
|
+
saveState() {
|
|
683
|
+
const state = {
|
|
684
|
+
running: this.running,
|
|
685
|
+
startedAt: this.startedAt?.toISOString(),
|
|
686
|
+
workers: Object.fromEntries(Array.from(this.workers.entries()).map(([type, state]) => [
|
|
687
|
+
type,
|
|
688
|
+
{
|
|
689
|
+
...state,
|
|
690
|
+
lastRun: state.lastRun?.toISOString(),
|
|
691
|
+
nextRun: state.nextRun?.toISOString(),
|
|
692
|
+
}
|
|
693
|
+
])),
|
|
694
|
+
config: {
|
|
695
|
+
...this.config,
|
|
696
|
+
workers: this.config.workers.map(w => ({ ...w })),
|
|
697
|
+
},
|
|
698
|
+
savedAt: new Date().toISOString(),
|
|
699
|
+
};
|
|
700
|
+
try {
|
|
701
|
+
writeFileSync(this.config.stateFile, JSON.stringify(state, null, 2));
|
|
702
|
+
}
|
|
703
|
+
catch (error) {
|
|
704
|
+
this.log('error', `Failed to save state: ${error}`);
|
|
705
|
+
}
|
|
706
|
+
}
|
|
707
|
+
/**
|
|
708
|
+
* Log message
|
|
709
|
+
*/
|
|
710
|
+
log(level, message) {
|
|
711
|
+
const timestamp = new Date().toISOString();
|
|
712
|
+
const logMessage = `[${timestamp}] [${level.toUpperCase()}] ${message}`;
|
|
713
|
+
this.emit('log', { level, message, timestamp });
|
|
714
|
+
// Also write to log file
|
|
715
|
+
try {
|
|
716
|
+
const logFile = join(this.config.logDir, 'daemon.log');
|
|
717
|
+
const fs = require('fs');
|
|
718
|
+
fs.appendFileSync(logFile, logMessage + '\n');
|
|
719
|
+
}
|
|
720
|
+
catch {
|
|
721
|
+
// Ignore log write errors
|
|
722
|
+
}
|
|
723
|
+
}
|
|
724
|
+
}
|
|
725
|
+
// Singleton instance for global access
|
|
726
|
+
let daemonInstance = null;
|
|
727
|
+
/**
|
|
728
|
+
* Get or create daemon instance
|
|
729
|
+
*/
|
|
730
|
+
export function getDaemon(projectRoot) {
|
|
731
|
+
if (!daemonInstance && projectRoot) {
|
|
732
|
+
daemonInstance = new WorkerDaemon(projectRoot);
|
|
733
|
+
}
|
|
734
|
+
if (!daemonInstance) {
|
|
735
|
+
throw new Error('Daemon not initialized. Provide projectRoot on first call.');
|
|
736
|
+
}
|
|
737
|
+
return daemonInstance;
|
|
738
|
+
}
|
|
739
|
+
/**
|
|
740
|
+
* Start daemon (for use in session-start hook)
|
|
741
|
+
*/
|
|
742
|
+
export async function startDaemon(projectRoot) {
|
|
743
|
+
const daemon = getDaemon(projectRoot);
|
|
744
|
+
await daemon.start();
|
|
745
|
+
return daemon;
|
|
746
|
+
}
|
|
747
|
+
/**
|
|
748
|
+
* Stop daemon
|
|
749
|
+
*/
|
|
750
|
+
export async function stopDaemon() {
|
|
751
|
+
if (daemonInstance) {
|
|
752
|
+
await daemonInstance.stop();
|
|
753
|
+
}
|
|
754
|
+
}
|
|
755
|
+
export default WorkerDaemon;
|
|
756
|
+
//# sourceMappingURL=worker-daemon.js.map
|