@cloudpftc/opencode-orchestrator 3.5.15

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.
Files changed (715) hide show
  1. package/.opencode/agents/architect.yaml +33 -0
  2. package/.opencode/agents/coder.yaml +45 -0
  3. package/.opencode/agents/coordinator.yaml +38 -0
  4. package/.opencode/agents/performance-engineer.yaml +33 -0
  5. package/.opencode/agents/researcher.yaml +32 -0
  6. package/.opencode/agents/reviewer.yaml +32 -0
  7. package/.opencode/agents/security-architect.yaml +32 -0
  8. package/.opencode/agents/tester.yaml +37 -0
  9. package/.opencode/skills/agent-adaptive-coordinator/SKILL.md +403 -0
  10. package/.opencode/skills/agent-agent/SKILL.md +823 -0
  11. package/.opencode/skills/agent-agentic-payments/SKILL.md +133 -0
  12. package/.opencode/skills/agent-analyze-code-quality/SKILL.md +186 -0
  13. package/.opencode/skills/agent-app-store/SKILL.md +95 -0
  14. package/.opencode/skills/agent-arch-system-design/SKILL.md +162 -0
  15. package/.opencode/skills/agent-architecture/SKILL.md +479 -0
  16. package/.opencode/skills/agent-authentication/SKILL.md +76 -0
  17. package/.opencode/skills/agent-automation-smart-agent/SKILL.md +212 -0
  18. package/.opencode/skills/agent-base-template-generator/SKILL.md +49 -0
  19. package/.opencode/skills/agent-benchmark-suite/SKILL.md +672 -0
  20. package/.opencode/skills/agent-byzantine-coordinator/SKILL.md +70 -0
  21. package/.opencode/skills/agent-challenges/SKILL.md +88 -0
  22. package/.opencode/skills/agent-code-analyzer/SKILL.md +217 -0
  23. package/.opencode/skills/agent-code-goal-planner/SKILL.md +453 -0
  24. package/.opencode/skills/agent-code-review-swarm/SKILL.md +545 -0
  25. package/.opencode/skills/agent-coder/SKILL.md +273 -0
  26. package/.opencode/skills/agent-collective-intelligence-coordinator/SKILL.md +137 -0
  27. package/.opencode/skills/agent-consensus-coordinator/SKILL.md +345 -0
  28. package/.opencode/skills/agent-coordination/SKILL.md +82 -0
  29. package/.opencode/skills/agent-coordinator-swarm-init/SKILL.md +112 -0
  30. package/.opencode/skills/agent-crdt-synchronizer/SKILL.md +1004 -0
  31. package/.opencode/skills/agent-data-ml-model/SKILL.md +200 -0
  32. package/.opencode/skills/agent-dev-backend-api/SKILL.md +352 -0
  33. package/.opencode/skills/agent-docs-api-openapi/SKILL.md +181 -0
  34. package/.opencode/skills/agent-github-modes/SKILL.md +180 -0
  35. package/.opencode/skills/agent-github-pr-manager/SKILL.md +184 -0
  36. package/.opencode/skills/agent-goal-planner/SKILL.md +80 -0
  37. package/.opencode/skills/agent-gossip-coordinator/SKILL.md +70 -0
  38. package/.opencode/skills/agent-hierarchical-coordinator/SKILL.md +334 -0
  39. package/.opencode/skills/agent-implementer-sparc-coder/SKILL.md +266 -0
  40. package/.opencode/skills/agent-issue-tracker/SKILL.md +326 -0
  41. package/.opencode/skills/agent-load-balancer/SKILL.md +438 -0
  42. package/.opencode/skills/agent-matrix-optimizer/SKILL.md +192 -0
  43. package/.opencode/skills/agent-memory-coordinator/SKILL.md +194 -0
  44. package/.opencode/skills/agent-mesh-coordinator/SKILL.md +399 -0
  45. package/.opencode/skills/agent-migration-plan/SKILL.md +753 -0
  46. package/.opencode/skills/agent-multi-repo-swarm/SKILL.md +560 -0
  47. package/.opencode/skills/agent-neural-network/SKILL.md +95 -0
  48. package/.opencode/skills/agent-ops-cicd-github/SKILL.md +171 -0
  49. package/.opencode/skills/agent-orchestrator-task/SKILL.md +146 -0
  50. package/.opencode/skills/agent-pagerank-analyzer/SKILL.md +306 -0
  51. package/.opencode/skills/agent-payments/SKILL.md +90 -0
  52. package/.opencode/skills/agent-performance-analyzer/SKILL.md +206 -0
  53. package/.opencode/skills/agent-performance-benchmarker/SKILL.md +858 -0
  54. package/.opencode/skills/agent-performance-monitor/SKILL.md +679 -0
  55. package/.opencode/skills/agent-performance-optimizer/SKILL.md +375 -0
  56. package/.opencode/skills/agent-planner/SKILL.md +175 -0
  57. package/.opencode/skills/agent-pr-manager/SKILL.md +198 -0
  58. package/.opencode/skills/agent-production-validator/SKILL.md +402 -0
  59. package/.opencode/skills/agent-project-board-sync/SKILL.md +516 -0
  60. package/.opencode/skills/agent-pseudocode/SKILL.md +325 -0
  61. package/.opencode/skills/agent-queen-coordinator/SKILL.md +210 -0
  62. package/.opencode/skills/agent-quorum-manager/SKILL.md +830 -0
  63. package/.opencode/skills/agent-raft-manager/SKILL.md +70 -0
  64. package/.opencode/skills/agent-refinement/SKILL.md +532 -0
  65. package/.opencode/skills/agent-release-manager/SKILL.md +374 -0
  66. package/.opencode/skills/agent-release-swarm/SKILL.md +590 -0
  67. package/.opencode/skills/agent-repo-architect/SKILL.md +405 -0
  68. package/.opencode/skills/agent-researcher/SKILL.md +197 -0
  69. package/.opencode/skills/agent-resource-allocator/SKILL.md +681 -0
  70. package/.opencode/skills/agent-reviewer/SKILL.md +333 -0
  71. package/.opencode/skills/agent-safla-neural/SKILL.md +81 -0
  72. package/.opencode/skills/agent-sandbox/SKILL.md +83 -0
  73. package/.opencode/skills/agent-scout-explorer/SKILL.md +249 -0
  74. package/.opencode/skills/agent-security-manager/SKILL.md +629 -0
  75. package/.opencode/skills/agent-sona-learning-optimizer/SKILL.md +81 -0
  76. package/.opencode/skills/agent-sparc-coordinator/SKILL.md +190 -0
  77. package/.opencode/skills/agent-spec-mobile-react-native/SKILL.md +232 -0
  78. package/.opencode/skills/agent-specification/SKILL.md +283 -0
  79. package/.opencode/skills/agent-swarm/SKILL.md +83 -0
  80. package/.opencode/skills/agent-swarm-issue/SKILL.md +580 -0
  81. package/.opencode/skills/agent-swarm-memory-manager/SKILL.md +200 -0
  82. package/.opencode/skills/agent-swarm-pr/SKILL.md +435 -0
  83. package/.opencode/skills/agent-sync-coordinator/SKILL.md +459 -0
  84. package/.opencode/skills/agent-tdd-london-swarm/SKILL.md +251 -0
  85. package/.opencode/skills/agent-test-long-runner/SKILL.md +51 -0
  86. package/.opencode/skills/agent-tester/SKILL.md +326 -0
  87. package/.opencode/skills/agent-topology-optimizer/SKILL.md +815 -0
  88. package/.opencode/skills/agent-trading-predictor/SKILL.md +253 -0
  89. package/.opencode/skills/agent-user-tools/SKILL.md +103 -0
  90. package/.opencode/skills/agent-v3-integration-architect/SKILL.md +353 -0
  91. package/.opencode/skills/agent-v3-memory-specialist/SKILL.md +325 -0
  92. package/.opencode/skills/agent-v3-performance-engineer/SKILL.md +404 -0
  93. package/.opencode/skills/agent-v3-queen-coordinator/SKILL.md +105 -0
  94. package/.opencode/skills/agent-v3-security-architect/SKILL.md +181 -0
  95. package/.opencode/skills/agent-worker-specialist/SKILL.md +224 -0
  96. package/.opencode/skills/agent-workflow/SKILL.md +91 -0
  97. package/.opencode/skills/agent-workflow-automation/SKILL.md +642 -0
  98. package/.opencode/skills/agentdb-advanced/SKILL.md +552 -0
  99. package/.opencode/skills/agentdb-learning/SKILL.md +547 -0
  100. package/.opencode/skills/agentdb-memory-patterns/SKILL.md +341 -0
  101. package/.opencode/skills/agentdb-optimization/SKILL.md +511 -0
  102. package/.opencode/skills/agentdb-vector-search/SKILL.md +341 -0
  103. package/.opencode/skills/agentic-jujutsu/SKILL.md +647 -0
  104. package/.opencode/skills/claims/SKILL.md +72 -0
  105. package/.opencode/skills/embeddings/SKILL.md +71 -0
  106. package/.opencode/skills/flow-nexus-neural/SKILL.md +740 -0
  107. package/.opencode/skills/flow-nexus-platform/SKILL.md +1159 -0
  108. package/.opencode/skills/flow-nexus-swarm/SKILL.md +612 -0
  109. package/.opencode/skills/github-automation/SKILL.md +65 -0
  110. package/.opencode/skills/github-code-review/SKILL.md +1142 -0
  111. package/.opencode/skills/github-multi-repo/SKILL.md +876 -0
  112. package/.opencode/skills/github-project-management/SKILL.md +1279 -0
  113. package/.opencode/skills/github-release-management/SKILL.md +1083 -0
  114. package/.opencode/skills/github-workflow-automation/SKILL.md +1067 -0
  115. package/.opencode/skills/hive-mind/SKILL.md +67 -0
  116. package/.opencode/skills/hive-mind-advanced/SKILL.md +714 -0
  117. package/.opencode/skills/hooks-automation/SKILL.md +1203 -0
  118. package/.opencode/skills/memory-management/SKILL.md +128 -0
  119. package/.opencode/skills/neural-training/SKILL.md +70 -0
  120. package/.opencode/skills/pair-programming/SKILL.md +1204 -0
  121. package/.opencode/skills/performance-analysis/SKILL.md +565 -0
  122. package/.opencode/skills/reasoningbank-agentdb/SKILL.md +448 -0
  123. package/.opencode/skills/reasoningbank-intelligence/SKILL.md +203 -0
  124. package/.opencode/skills/security-audit/SKILL.md +137 -0
  125. package/.opencode/skills/skill-builder/SKILL.md +912 -0
  126. package/.opencode/skills/sparc-methodology/SKILL.md +120 -0
  127. package/.opencode/skills/stream-chain/SKILL.md +565 -0
  128. package/.opencode/skills/swarm-advanced/SKILL.md +975 -0
  129. package/.opencode/skills/swarm-orchestration/SKILL.md +116 -0
  130. package/.opencode/skills/v3-cli-modernization/SKILL.md +874 -0
  131. package/.opencode/skills/v3-core-implementation/SKILL.md +799 -0
  132. package/.opencode/skills/v3-ddd-architecture/SKILL.md +444 -0
  133. package/.opencode/skills/v3-integration-deep/SKILL.md +243 -0
  134. package/.opencode/skills/v3-mcp-optimization/SKILL.md +779 -0
  135. package/.opencode/skills/v3-memory-unification/SKILL.md +176 -0
  136. package/.opencode/skills/v3-performance-optimization/SKILL.md +392 -0
  137. package/.opencode/skills/v3-security-overhaul/SKILL.md +84 -0
  138. package/.opencode/skills/v3-swarm-coordination/SKILL.md +342 -0
  139. package/.opencode/skills/verification-quality/SKILL.md +651 -0
  140. package/.opencode/skills/worker-benchmarks/SKILL.md +137 -0
  141. package/.opencode/skills/worker-integration/SKILL.md +156 -0
  142. package/.opencode/skills/workflow-automation/SKILL.md +80 -0
  143. package/LICENSE +21 -0
  144. package/README.md +7393 -0
  145. package/bin/cli.js +11 -0
  146. package/bin/npx-repair.js +7 -0
  147. package/bin/npx-safe-launch.js +9 -0
  148. package/opencode.json +84 -0
  149. package/package.json +131 -0
  150. package/v3/@claude-flow/cli/README.md +7536 -0
  151. package/v3/@claude-flow/cli/bin/cli.js +156 -0
  152. package/v3/@claude-flow/cli/bin/mcp-server.js +189 -0
  153. package/v3/@claude-flow/cli/bin/preinstall.cjs +2 -0
  154. package/v3/@claude-flow/cli/dist/src/appliance/gguf-engine.d.ts +91 -0
  155. package/v3/@claude-flow/cli/dist/src/appliance/gguf-engine.js +425 -0
  156. package/v3/@claude-flow/cli/dist/src/appliance/ruvllm-bridge.d.ts +102 -0
  157. package/v3/@claude-flow/cli/dist/src/appliance/ruvllm-bridge.js +292 -0
  158. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-builder.d.ts +44 -0
  159. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-builder.js +328 -0
  160. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-distribution.d.ts +97 -0
  161. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-distribution.js +370 -0
  162. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-format.d.ts +111 -0
  163. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-format.js +393 -0
  164. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-runner.d.ts +69 -0
  165. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-runner.js +237 -0
  166. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-signing.d.ts +123 -0
  167. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-signing.js +347 -0
  168. package/v3/@claude-flow/cli/dist/src/benchmarks/pretrain/index.d.ts +58 -0
  169. package/v3/@claude-flow/cli/dist/src/benchmarks/pretrain/index.js +404 -0
  170. package/v3/@claude-flow/cli/dist/src/commands/agent.d.ts +8 -0
  171. package/v3/@claude-flow/cli/dist/src/commands/agent.js +819 -0
  172. package/v3/@claude-flow/cli/dist/src/commands/analyze.d.ts +19 -0
  173. package/v3/@claude-flow/cli/dist/src/commands/analyze.js +1823 -0
  174. package/v3/@claude-flow/cli/dist/src/commands/appliance-advanced.d.ts +9 -0
  175. package/v3/@claude-flow/cli/dist/src/commands/appliance-advanced.js +215 -0
  176. package/v3/@claude-flow/cli/dist/src/commands/appliance.d.ts +8 -0
  177. package/v3/@claude-flow/cli/dist/src/commands/appliance.js +406 -0
  178. package/v3/@claude-flow/cli/dist/src/commands/benchmark.d.ts +10 -0
  179. package/v3/@claude-flow/cli/dist/src/commands/benchmark.js +459 -0
  180. package/v3/@claude-flow/cli/dist/src/commands/claims.d.ts +10 -0
  181. package/v3/@claude-flow/cli/dist/src/commands/claims.js +373 -0
  182. package/v3/@claude-flow/cli/dist/src/commands/completions.d.ts +10 -0
  183. package/v3/@claude-flow/cli/dist/src/commands/completions.js +539 -0
  184. package/v3/@claude-flow/cli/dist/src/commands/config.d.ts +8 -0
  185. package/v3/@claude-flow/cli/dist/src/commands/config.js +406 -0
  186. package/v3/@claude-flow/cli/dist/src/commands/daemon.d.ts +8 -0
  187. package/v3/@claude-flow/cli/dist/src/commands/daemon.js +609 -0
  188. package/v3/@claude-flow/cli/dist/src/commands/deployment.d.ts +10 -0
  189. package/v3/@claude-flow/cli/dist/src/commands/deployment.js +289 -0
  190. package/v3/@claude-flow/cli/dist/src/commands/doctor.d.ts +10 -0
  191. package/v3/@claude-flow/cli/dist/src/commands/doctor.js +548 -0
  192. package/v3/@claude-flow/cli/dist/src/commands/embeddings.d.ts +18 -0
  193. package/v3/@claude-flow/cli/dist/src/commands/embeddings.js +1576 -0
  194. package/v3/@claude-flow/cli/dist/src/commands/guidance.d.ts +8 -0
  195. package/v3/@claude-flow/cli/dist/src/commands/guidance.js +560 -0
  196. package/v3/@claude-flow/cli/dist/src/commands/hive-mind.d.ts +11 -0
  197. package/v3/@claude-flow/cli/dist/src/commands/hive-mind.js +1145 -0
  198. package/v3/@claude-flow/cli/dist/src/commands/hooks.d.ts +8 -0
  199. package/v3/@claude-flow/cli/dist/src/commands/hooks.js +3759 -0
  200. package/v3/@claude-flow/cli/dist/src/commands/index.d.ts +113 -0
  201. package/v3/@claude-flow/cli/dist/src/commands/index.js +368 -0
  202. package/v3/@claude-flow/cli/dist/src/commands/init.d.ts +8 -0
  203. package/v3/@claude-flow/cli/dist/src/commands/init.js +822 -0
  204. package/v3/@claude-flow/cli/dist/src/commands/issues.d.ts +21 -0
  205. package/v3/@claude-flow/cli/dist/src/commands/issues.js +567 -0
  206. package/v3/@claude-flow/cli/dist/src/commands/mcp.d.ts +11 -0
  207. package/v3/@claude-flow/cli/dist/src/commands/mcp.js +715 -0
  208. package/v3/@claude-flow/cli/dist/src/commands/memory.d.ts +8 -0
  209. package/v3/@claude-flow/cli/dist/src/commands/memory.js +1292 -0
  210. package/v3/@claude-flow/cli/dist/src/commands/migrate.d.ts +8 -0
  211. package/v3/@claude-flow/cli/dist/src/commands/migrate.js +410 -0
  212. package/v3/@claude-flow/cli/dist/src/commands/neural.d.ts +10 -0
  213. package/v3/@claude-flow/cli/dist/src/commands/neural.js +1448 -0
  214. package/v3/@claude-flow/cli/dist/src/commands/performance.d.ts +10 -0
  215. package/v3/@claude-flow/cli/dist/src/commands/performance.js +579 -0
  216. package/v3/@claude-flow/cli/dist/src/commands/plugins.d.ts +11 -0
  217. package/v3/@claude-flow/cli/dist/src/commands/plugins.js +820 -0
  218. package/v3/@claude-flow/cli/dist/src/commands/process.d.ts +10 -0
  219. package/v3/@claude-flow/cli/dist/src/commands/process.js +641 -0
  220. package/v3/@claude-flow/cli/dist/src/commands/progress.d.ts +11 -0
  221. package/v3/@claude-flow/cli/dist/src/commands/progress.js +259 -0
  222. package/v3/@claude-flow/cli/dist/src/commands/providers.d.ts +10 -0
  223. package/v3/@claude-flow/cli/dist/src/commands/providers.js +232 -0
  224. package/v3/@claude-flow/cli/dist/src/commands/route.d.ts +16 -0
  225. package/v3/@claude-flow/cli/dist/src/commands/route.js +813 -0
  226. package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.d.ts +11 -0
  227. package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.js +746 -0
  228. package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.d.ts +11 -0
  229. package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.js +480 -0
  230. package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.d.ts +18 -0
  231. package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.js +349 -0
  232. package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.d.ts +29 -0
  233. package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.js +129 -0
  234. package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.d.ts +11 -0
  235. package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.js +431 -0
  236. package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.d.ts +11 -0
  237. package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.js +481 -0
  238. package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.d.ts +11 -0
  239. package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.js +503 -0
  240. package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.d.ts +18 -0
  241. package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.js +765 -0
  242. package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.d.ts +11 -0
  243. package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.js +456 -0
  244. package/v3/@claude-flow/cli/dist/src/commands/security.d.ts +10 -0
  245. package/v3/@claude-flow/cli/dist/src/commands/security.js +575 -0
  246. package/v3/@claude-flow/cli/dist/src/commands/session.d.ts +8 -0
  247. package/v3/@claude-flow/cli/dist/src/commands/session.js +750 -0
  248. package/v3/@claude-flow/cli/dist/src/commands/start.d.ts +8 -0
  249. package/v3/@claude-flow/cli/dist/src/commands/start.js +418 -0
  250. package/v3/@claude-flow/cli/dist/src/commands/status.d.ts +8 -0
  251. package/v3/@claude-flow/cli/dist/src/commands/status.js +591 -0
  252. package/v3/@claude-flow/cli/dist/src/commands/swarm.d.ts +8 -0
  253. package/v3/@claude-flow/cli/dist/src/commands/swarm.js +748 -0
  254. package/v3/@claude-flow/cli/dist/src/commands/task.d.ts +8 -0
  255. package/v3/@claude-flow/cli/dist/src/commands/task.js +671 -0
  256. package/v3/@claude-flow/cli/dist/src/commands/transfer-store.d.ts +13 -0
  257. package/v3/@claude-flow/cli/dist/src/commands/transfer-store.js +428 -0
  258. package/v3/@claude-flow/cli/dist/src/commands/update.d.ts +8 -0
  259. package/v3/@claude-flow/cli/dist/src/commands/update.js +276 -0
  260. package/v3/@claude-flow/cli/dist/src/commands/workflow.d.ts +8 -0
  261. package/v3/@claude-flow/cli/dist/src/commands/workflow.js +617 -0
  262. package/v3/@claude-flow/cli/dist/src/config-adapter.d.ts +15 -0
  263. package/v3/@claude-flow/cli/dist/src/config-adapter.js +186 -0
  264. package/v3/@claude-flow/cli/dist/src/index.d.ts +76 -0
  265. package/v3/@claude-flow/cli/dist/src/index.js +470 -0
  266. package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.d.ts +68 -0
  267. package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.js +264 -0
  268. package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts +25 -0
  269. package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.js +486 -0
  270. package/v3/@claude-flow/cli/dist/src/init/executor.d.ts +41 -0
  271. package/v3/@claude-flow/cli/dist/src/init/executor.js +1734 -0
  272. package/v3/@claude-flow/cli/dist/src/init/helpers-generator.d.ts +60 -0
  273. package/v3/@claude-flow/cli/dist/src/init/helpers-generator.js +1166 -0
  274. package/v3/@claude-flow/cli/dist/src/init/index.d.ts +13 -0
  275. package/v3/@claude-flow/cli/dist/src/init/index.js +15 -0
  276. package/v3/@claude-flow/cli/dist/src/init/mcp-generator.d.ts +31 -0
  277. package/v3/@claude-flow/cli/dist/src/init/mcp-generator.js +147 -0
  278. package/v3/@claude-flow/cli/dist/src/init/settings-generator.d.ts +14 -0
  279. package/v3/@claude-flow/cli/dist/src/init/settings-generator.js +399 -0
  280. package/v3/@claude-flow/cli/dist/src/init/statusline-generator.d.ts +28 -0
  281. package/v3/@claude-flow/cli/dist/src/init/statusline-generator.js +817 -0
  282. package/v3/@claude-flow/cli/dist/src/init/types.d.ts +283 -0
  283. package/v3/@claude-flow/cli/dist/src/init/types.js +254 -0
  284. package/v3/@claude-flow/cli/dist/src/mcp-client.d.ts +92 -0
  285. package/v3/@claude-flow/cli/dist/src/mcp-client.js +237 -0
  286. package/v3/@claude-flow/cli/dist/src/mcp-server.d.ts +161 -0
  287. package/v3/@claude-flow/cli/dist/src/mcp-server.js +627 -0
  288. package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.d.ts +9 -0
  289. package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.js +549 -0
  290. package/v3/@claude-flow/cli/dist/src/mcp-tools/agentdb-tools.d.ts +30 -0
  291. package/v3/@claude-flow/cli/dist/src/mcp-tools/agentdb-tools.js +557 -0
  292. package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
  293. package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.js +317 -0
  294. package/v3/@claude-flow/cli/dist/src/mcp-tools/auto-install.d.ts +83 -0
  295. package/v3/@claude-flow/cli/dist/src/mcp-tools/auto-install.js +131 -0
  296. package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-tools.d.ts +13 -0
  297. package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-tools.js +550 -0
  298. package/v3/@claude-flow/cli/dist/src/mcp-tools/claims-tools.d.ts +12 -0
  299. package/v3/@claude-flow/cli/dist/src/mcp-tools/claims-tools.js +732 -0
  300. package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.d.ts +8 -0
  301. package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.js +343 -0
  302. package/v3/@claude-flow/cli/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
  303. package/v3/@claude-flow/cli/dist/src/mcp-tools/coordination-tools.js +486 -0
  304. package/v3/@claude-flow/cli/dist/src/mcp-tools/daa-tools.d.ts +13 -0
  305. package/v3/@claude-flow/cli/dist/src/mcp-tools/daa-tools.js +426 -0
  306. package/v3/@claude-flow/cli/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
  307. package/v3/@claude-flow/cli/dist/src/mcp-tools/embeddings-tools.js +782 -0
  308. package/v3/@claude-flow/cli/dist/src/mcp-tools/github-tools.d.ts +13 -0
  309. package/v3/@claude-flow/cli/dist/src/mcp-tools/github-tools.js +373 -0
  310. package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
  311. package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.js +583 -0
  312. package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.d.ts +44 -0
  313. package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js +2969 -0
  314. package/v3/@claude-flow/cli/dist/src/mcp-tools/index.d.ts +23 -0
  315. package/v3/@claude-flow/cli/dist/src/mcp-tools/index.js +22 -0
  316. package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.d.ts +14 -0
  317. package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.js +499 -0
  318. package/v3/@claude-flow/cli/dist/src/mcp-tools/neural-tools.d.ts +16 -0
  319. package/v3/@claude-flow/cli/dist/src/mcp-tools/neural-tools.js +461 -0
  320. package/v3/@claude-flow/cli/dist/src/mcp-tools/performance-tools.d.ts +16 -0
  321. package/v3/@claude-flow/cli/dist/src/mcp-tools/performance-tools.js +534 -0
  322. package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.d.ts +14 -0
  323. package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.js +348 -0
  324. package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.d.ts +18 -0
  325. package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.js +434 -0
  326. package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.d.ts +8 -0
  327. package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.js +315 -0
  328. package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.d.ts +9 -0
  329. package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.js +197 -0
  330. package/v3/@claude-flow/cli/dist/src/mcp-tools/system-tools.d.ts +13 -0
  331. package/v3/@claude-flow/cli/dist/src/mcp-tools/system-tools.js +417 -0
  332. package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.d.ts +8 -0
  333. package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.js +338 -0
  334. package/v3/@claude-flow/cli/dist/src/mcp-tools/terminal-tools.d.ts +13 -0
  335. package/v3/@claude-flow/cli/dist/src/mcp-tools/terminal-tools.js +246 -0
  336. package/v3/@claude-flow/cli/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
  337. package/v3/@claude-flow/cli/dist/src/mcp-tools/transfer-tools.js +396 -0
  338. package/v3/@claude-flow/cli/dist/src/mcp-tools/types.d.ts +31 -0
  339. package/v3/@claude-flow/cli/dist/src/mcp-tools/types.js +7 -0
  340. package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
  341. package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.js +572 -0
  342. package/v3/@claude-flow/cli/dist/src/memory/ewc-consolidation.d.ts +271 -0
  343. package/v3/@claude-flow/cli/dist/src/memory/ewc-consolidation.js +542 -0
  344. package/v3/@claude-flow/cli/dist/src/memory/intelligence.d.ts +285 -0
  345. package/v3/@claude-flow/cli/dist/src/memory/intelligence.js +794 -0
  346. package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.d.ts +407 -0
  347. package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.js +1494 -0
  348. package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.d.ts +405 -0
  349. package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.js +2105 -0
  350. package/v3/@claude-flow/cli/dist/src/memory/sona-optimizer.d.ts +227 -0
  351. package/v3/@claude-flow/cli/dist/src/memory/sona-optimizer.js +633 -0
  352. package/v3/@claude-flow/cli/dist/src/output.d.ts +133 -0
  353. package/v3/@claude-flow/cli/dist/src/output.js +514 -0
  354. package/v3/@claude-flow/cli/dist/src/parser.d.ts +41 -0
  355. package/v3/@claude-flow/cli/dist/src/parser.js +377 -0
  356. package/v3/@claude-flow/cli/dist/src/plugins/manager.d.ts +133 -0
  357. package/v3/@claude-flow/cli/dist/src/plugins/manager.js +400 -0
  358. package/v3/@claude-flow/cli/dist/src/plugins/store/discovery.d.ts +88 -0
  359. package/v3/@claude-flow/cli/dist/src/plugins/store/discovery.js +1147 -0
  360. package/v3/@claude-flow/cli/dist/src/plugins/store/index.d.ts +76 -0
  361. package/v3/@claude-flow/cli/dist/src/plugins/store/index.js +141 -0
  362. package/v3/@claude-flow/cli/dist/src/plugins/store/search.d.ts +46 -0
  363. package/v3/@claude-flow/cli/dist/src/plugins/store/search.js +230 -0
  364. package/v3/@claude-flow/cli/dist/src/plugins/store/types.d.ts +274 -0
  365. package/v3/@claude-flow/cli/dist/src/plugins/store/types.js +7 -0
  366. package/v3/@claude-flow/cli/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
  367. package/v3/@claude-flow/cli/dist/src/plugins/tests/demo-plugin-store.js +126 -0
  368. package/v3/@claude-flow/cli/dist/src/plugins/tests/standalone-test.d.ts +12 -0
  369. package/v3/@claude-flow/cli/dist/src/plugins/tests/standalone-test.js +188 -0
  370. package/v3/@claude-flow/cli/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
  371. package/v3/@claude-flow/cli/dist/src/plugins/tests/test-plugin-store.js +206 -0
  372. package/v3/@claude-flow/cli/dist/src/production/circuit-breaker.d.ts +101 -0
  373. package/v3/@claude-flow/cli/dist/src/production/circuit-breaker.js +241 -0
  374. package/v3/@claude-flow/cli/dist/src/production/error-handler.d.ts +92 -0
  375. package/v3/@claude-flow/cli/dist/src/production/error-handler.js +299 -0
  376. package/v3/@claude-flow/cli/dist/src/production/index.d.ts +23 -0
  377. package/v3/@claude-flow/cli/dist/src/production/index.js +18 -0
  378. package/v3/@claude-flow/cli/dist/src/production/monitoring.d.ts +161 -0
  379. package/v3/@claude-flow/cli/dist/src/production/monitoring.js +356 -0
  380. package/v3/@claude-flow/cli/dist/src/production/rate-limiter.d.ts +80 -0
  381. package/v3/@claude-flow/cli/dist/src/production/rate-limiter.js +201 -0
  382. package/v3/@claude-flow/cli/dist/src/production/retry.d.ts +48 -0
  383. package/v3/@claude-flow/cli/dist/src/production/retry.js +179 -0
  384. package/v3/@claude-flow/cli/dist/src/prompt.d.ts +44 -0
  385. package/v3/@claude-flow/cli/dist/src/prompt.js +501 -0
  386. package/v3/@claude-flow/cli/dist/src/runtime/headless.d.ts +60 -0
  387. package/v3/@claude-flow/cli/dist/src/runtime/headless.js +284 -0
  388. package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.d.ts +67 -0
  389. package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.js +277 -0
  390. package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.d.ts +160 -0
  391. package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.js +529 -0
  392. package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.d.ts +33 -0
  393. package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.js +157 -0
  394. package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.d.ts +175 -0
  395. package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.js +698 -0
  396. package/v3/@claude-flow/cli/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
  397. package/v3/@claude-flow/cli/dist/src/ruvector/enhanced-model-router.js +529 -0
  398. package/v3/@claude-flow/cli/dist/src/ruvector/flash-attention.d.ts +195 -0
  399. package/v3/@claude-flow/cli/dist/src/ruvector/flash-attention.js +643 -0
  400. package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.d.ts +187 -0
  401. package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.js +929 -0
  402. package/v3/@claude-flow/cli/dist/src/ruvector/index.d.ts +34 -0
  403. package/v3/@claude-flow/cli/dist/src/ruvector/index.js +60 -0
  404. package/v3/@claude-flow/cli/dist/src/ruvector/lora-adapter.d.ts +218 -0
  405. package/v3/@claude-flow/cli/dist/src/ruvector/lora-adapter.js +455 -0
  406. package/v3/@claude-flow/cli/dist/src/ruvector/model-router.d.ts +220 -0
  407. package/v3/@claude-flow/cli/dist/src/ruvector/model-router.js +488 -0
  408. package/v3/@claude-flow/cli/dist/src/ruvector/moe-router.d.ts +206 -0
  409. package/v3/@claude-flow/cli/dist/src/ruvector/moe-router.js +626 -0
  410. package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.d.ts +211 -0
  411. package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.js +681 -0
  412. package/v3/@claude-flow/cli/dist/src/ruvector/semantic-router.d.ts +77 -0
  413. package/v3/@claude-flow/cli/dist/src/ruvector/semantic-router.js +178 -0
  414. package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.d.ts +69 -0
  415. package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.js +243 -0
  416. package/v3/@claude-flow/cli/dist/src/services/agentic-flow-bridge.d.ts +50 -0
  417. package/v3/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +95 -0
  418. package/v3/@claude-flow/cli/dist/src/services/claim-service.d.ts +204 -0
  419. package/v3/@claude-flow/cli/dist/src/services/claim-service.js +818 -0
  420. package/v3/@claude-flow/cli/dist/src/services/container-worker-pool.d.ts +197 -0
  421. package/v3/@claude-flow/cli/dist/src/services/container-worker-pool.js +583 -0
  422. package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.d.ts +302 -0
  423. package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.js +971 -0
  424. package/v3/@claude-flow/cli/dist/src/services/index.d.ts +13 -0
  425. package/v3/@claude-flow/cli/dist/src/services/index.js +11 -0
  426. package/v3/@claude-flow/cli/dist/src/services/registry-api.d.ts +58 -0
  427. package/v3/@claude-flow/cli/dist/src/services/registry-api.js +146 -0
  428. package/v3/@claude-flow/cli/dist/src/services/ruvector-training.d.ts +214 -0
  429. package/v3/@claude-flow/cli/dist/src/services/ruvector-training.js +497 -0
  430. package/v3/@claude-flow/cli/dist/src/services/worker-daemon.d.ts +203 -0
  431. package/v3/@claude-flow/cli/dist/src/services/worker-daemon.js +756 -0
  432. package/v3/@claude-flow/cli/dist/src/services/worker-queue.d.ts +194 -0
  433. package/v3/@claude-flow/cli/dist/src/services/worker-queue.js +513 -0
  434. package/v3/@claude-flow/cli/dist/src/suggest.d.ts +53 -0
  435. package/v3/@claude-flow/cli/dist/src/suggest.js +200 -0
  436. package/v3/@claude-flow/cli/dist/src/transfer/anonymization/index.d.ts +25 -0
  437. package/v3/@claude-flow/cli/dist/src/transfer/anonymization/index.js +175 -0
  438. package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.d.ts +13 -0
  439. package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.js +205 -0
  440. package/v3/@claude-flow/cli/dist/src/transfer/export.d.ts +25 -0
  441. package/v3/@claude-flow/cli/dist/src/transfer/export.js +113 -0
  442. package/v3/@claude-flow/cli/dist/src/transfer/index.d.ts +12 -0
  443. package/v3/@claude-flow/cli/dist/src/transfer/index.js +31 -0
  444. package/v3/@claude-flow/cli/dist/src/transfer/ipfs/client.d.ts +109 -0
  445. package/v3/@claude-flow/cli/dist/src/transfer/ipfs/client.js +307 -0
  446. package/v3/@claude-flow/cli/dist/src/transfer/ipfs/upload.d.ts +95 -0
  447. package/v3/@claude-flow/cli/dist/src/transfer/ipfs/upload.js +411 -0
  448. package/v3/@claude-flow/cli/dist/src/transfer/models/seraphine.d.ts +72 -0
  449. package/v3/@claude-flow/cli/dist/src/transfer/models/seraphine.js +373 -0
  450. package/v3/@claude-flow/cli/dist/src/transfer/serialization/cfp.d.ts +49 -0
  451. package/v3/@claude-flow/cli/dist/src/transfer/serialization/cfp.js +183 -0
  452. package/v3/@claude-flow/cli/dist/src/transfer/storage/gcs.d.ts +82 -0
  453. package/v3/@claude-flow/cli/dist/src/transfer/storage/gcs.js +256 -0
  454. package/v3/@claude-flow/cli/dist/src/transfer/storage/index.d.ts +6 -0
  455. package/v3/@claude-flow/cli/dist/src/transfer/storage/index.js +6 -0
  456. package/v3/@claude-flow/cli/dist/src/transfer/store/discovery.d.ts +84 -0
  457. package/v3/@claude-flow/cli/dist/src/transfer/store/discovery.js +382 -0
  458. package/v3/@claude-flow/cli/dist/src/transfer/store/download.d.ts +70 -0
  459. package/v3/@claude-flow/cli/dist/src/transfer/store/download.js +334 -0
  460. package/v3/@claude-flow/cli/dist/src/transfer/store/index.d.ts +84 -0
  461. package/v3/@claude-flow/cli/dist/src/transfer/store/index.js +153 -0
  462. package/v3/@claude-flow/cli/dist/src/transfer/store/publish.d.ts +76 -0
  463. package/v3/@claude-flow/cli/dist/src/transfer/store/publish.js +294 -0
  464. package/v3/@claude-flow/cli/dist/src/transfer/store/registry.d.ts +58 -0
  465. package/v3/@claude-flow/cli/dist/src/transfer/store/registry.js +285 -0
  466. package/v3/@claude-flow/cli/dist/src/transfer/store/search.d.ts +54 -0
  467. package/v3/@claude-flow/cli/dist/src/transfer/store/search.js +232 -0
  468. package/v3/@claude-flow/cli/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
  469. package/v3/@claude-flow/cli/dist/src/transfer/store/tests/standalone-test.js +190 -0
  470. package/v3/@claude-flow/cli/dist/src/transfer/store/types.d.ts +193 -0
  471. package/v3/@claude-flow/cli/dist/src/transfer/store/types.js +6 -0
  472. package/v3/@claude-flow/cli/dist/src/transfer/test-seraphine.d.ts +6 -0
  473. package/v3/@claude-flow/cli/dist/src/transfer/test-seraphine.js +105 -0
  474. package/v3/@claude-flow/cli/dist/src/transfer/tests/test-store.d.ts +7 -0
  475. package/v3/@claude-flow/cli/dist/src/transfer/tests/test-store.js +214 -0
  476. package/v3/@claude-flow/cli/dist/src/transfer/types.d.ts +245 -0
  477. package/v3/@claude-flow/cli/dist/src/transfer/types.js +6 -0
  478. package/v3/@claude-flow/cli/dist/src/types.d.ts +198 -0
  479. package/v3/@claude-flow/cli/dist/src/types.js +38 -0
  480. package/v3/@claude-flow/cli/dist/src/update/checker.d.ts +34 -0
  481. package/v3/@claude-flow/cli/dist/src/update/checker.js +190 -0
  482. package/v3/@claude-flow/cli/dist/src/update/executor.d.ts +32 -0
  483. package/v3/@claude-flow/cli/dist/src/update/executor.js +181 -0
  484. package/v3/@claude-flow/cli/dist/src/update/index.d.ts +33 -0
  485. package/v3/@claude-flow/cli/dist/src/update/index.js +64 -0
  486. package/v3/@claude-flow/cli/dist/src/update/rate-limiter.d.ts +20 -0
  487. package/v3/@claude-flow/cli/dist/src/update/rate-limiter.js +96 -0
  488. package/v3/@claude-flow/cli/dist/src/update/validator.d.ts +17 -0
  489. package/v3/@claude-flow/cli/dist/src/update/validator.js +123 -0
  490. package/v3/@claude-flow/cli/package.json +108 -0
  491. package/v3/@claude-flow/guidance/README.md +1195 -0
  492. package/v3/@claude-flow/guidance/dist/adversarial.d.ts +284 -0
  493. package/v3/@claude-flow/guidance/dist/adversarial.js +572 -0
  494. package/v3/@claude-flow/guidance/dist/analyzer.d.ts +530 -0
  495. package/v3/@claude-flow/guidance/dist/analyzer.js +2518 -0
  496. package/v3/@claude-flow/guidance/dist/artifacts.d.ts +283 -0
  497. package/v3/@claude-flow/guidance/dist/artifacts.js +356 -0
  498. package/v3/@claude-flow/guidance/dist/authority.d.ts +290 -0
  499. package/v3/@claude-flow/guidance/dist/authority.js +558 -0
  500. package/v3/@claude-flow/guidance/dist/capabilities.d.ts +209 -0
  501. package/v3/@claude-flow/guidance/dist/capabilities.js +485 -0
  502. package/v3/@claude-flow/guidance/dist/coherence.d.ts +233 -0
  503. package/v3/@claude-flow/guidance/dist/coherence.js +372 -0
  504. package/v3/@claude-flow/guidance/dist/compiler.d.ts +87 -0
  505. package/v3/@claude-flow/guidance/dist/compiler.js +419 -0
  506. package/v3/@claude-flow/guidance/dist/conformance-kit.d.ts +225 -0
  507. package/v3/@claude-flow/guidance/dist/conformance-kit.js +629 -0
  508. package/v3/@claude-flow/guidance/dist/continue-gate.d.ts +214 -0
  509. package/v3/@claude-flow/guidance/dist/continue-gate.js +353 -0
  510. package/v3/@claude-flow/guidance/dist/crypto-utils.d.ts +17 -0
  511. package/v3/@claude-flow/guidance/dist/crypto-utils.js +24 -0
  512. package/v3/@claude-flow/guidance/dist/evolution.d.ts +282 -0
  513. package/v3/@claude-flow/guidance/dist/evolution.js +500 -0
  514. package/v3/@claude-flow/guidance/dist/gates.d.ts +79 -0
  515. package/v3/@claude-flow/guidance/dist/gates.js +302 -0
  516. package/v3/@claude-flow/guidance/dist/gateway.d.ts +206 -0
  517. package/v3/@claude-flow/guidance/dist/gateway.js +452 -0
  518. package/v3/@claude-flow/guidance/dist/generators.d.ts +153 -0
  519. package/v3/@claude-flow/guidance/dist/generators.js +682 -0
  520. package/v3/@claude-flow/guidance/dist/headless.d.ts +177 -0
  521. package/v3/@claude-flow/guidance/dist/headless.js +342 -0
  522. package/v3/@claude-flow/guidance/dist/hooks.d.ts +109 -0
  523. package/v3/@claude-flow/guidance/dist/hooks.js +347 -0
  524. package/v3/@claude-flow/guidance/dist/index.d.ts +205 -0
  525. package/v3/@claude-flow/guidance/dist/index.js +321 -0
  526. package/v3/@claude-flow/guidance/dist/ledger.d.ts +162 -0
  527. package/v3/@claude-flow/guidance/dist/ledger.js +375 -0
  528. package/v3/@claude-flow/guidance/dist/manifest-validator.d.ts +289 -0
  529. package/v3/@claude-flow/guidance/dist/manifest-validator.js +838 -0
  530. package/v3/@claude-flow/guidance/dist/memory-gate.d.ts +222 -0
  531. package/v3/@claude-flow/guidance/dist/memory-gate.js +382 -0
  532. package/v3/@claude-flow/guidance/dist/meta-governance.d.ts +265 -0
  533. package/v3/@claude-flow/guidance/dist/meta-governance.js +348 -0
  534. package/v3/@claude-flow/guidance/dist/optimizer.d.ts +104 -0
  535. package/v3/@claude-flow/guidance/dist/optimizer.js +329 -0
  536. package/v3/@claude-flow/guidance/dist/persistence.d.ts +189 -0
  537. package/v3/@claude-flow/guidance/dist/persistence.js +464 -0
  538. package/v3/@claude-flow/guidance/dist/proof.d.ts +185 -0
  539. package/v3/@claude-flow/guidance/dist/proof.js +238 -0
  540. package/v3/@claude-flow/guidance/dist/retriever.d.ts +116 -0
  541. package/v3/@claude-flow/guidance/dist/retriever.js +394 -0
  542. package/v3/@claude-flow/guidance/dist/ruvbot-integration.d.ts +370 -0
  543. package/v3/@claude-flow/guidance/dist/ruvbot-integration.js +738 -0
  544. package/v3/@claude-flow/guidance/dist/temporal.d.ts +426 -0
  545. package/v3/@claude-flow/guidance/dist/temporal.js +658 -0
  546. package/v3/@claude-flow/guidance/dist/trust.d.ts +283 -0
  547. package/v3/@claude-flow/guidance/dist/trust.js +473 -0
  548. package/v3/@claude-flow/guidance/dist/truth-anchors.d.ts +276 -0
  549. package/v3/@claude-flow/guidance/dist/truth-anchors.js +488 -0
  550. package/v3/@claude-flow/guidance/dist/types.d.ts +378 -0
  551. package/v3/@claude-flow/guidance/dist/types.js +10 -0
  552. package/v3/@claude-flow/guidance/dist/uncertainty.d.ts +372 -0
  553. package/v3/@claude-flow/guidance/dist/uncertainty.js +619 -0
  554. package/v3/@claude-flow/guidance/dist/wasm-kernel.d.ts +48 -0
  555. package/v3/@claude-flow/guidance/dist/wasm-kernel.js +158 -0
  556. package/v3/@claude-flow/guidance/package.json +197 -0
  557. package/v3/@claude-flow/shared/README.md +323 -0
  558. package/v3/@claude-flow/shared/dist/core/config/defaults.d.ts +41 -0
  559. package/v3/@claude-flow/shared/dist/core/config/defaults.js +186 -0
  560. package/v3/@claude-flow/shared/dist/core/config/index.d.ts +8 -0
  561. package/v3/@claude-flow/shared/dist/core/config/index.js +12 -0
  562. package/v3/@claude-flow/shared/dist/core/config/loader.d.ts +45 -0
  563. package/v3/@claude-flow/shared/dist/core/config/loader.js +222 -0
  564. package/v3/@claude-flow/shared/dist/core/config/schema.d.ts +1134 -0
  565. package/v3/@claude-flow/shared/dist/core/config/schema.js +158 -0
  566. package/v3/@claude-flow/shared/dist/core/config/validator.d.ts +92 -0
  567. package/v3/@claude-flow/shared/dist/core/config/validator.js +147 -0
  568. package/v3/@claude-flow/shared/dist/core/event-bus.d.ts +31 -0
  569. package/v3/@claude-flow/shared/dist/core/event-bus.js +197 -0
  570. package/v3/@claude-flow/shared/dist/core/index.d.ts +15 -0
  571. package/v3/@claude-flow/shared/dist/core/index.js +19 -0
  572. package/v3/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +200 -0
  573. package/v3/@claude-flow/shared/dist/core/interfaces/agent.interface.js +6 -0
  574. package/v3/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +310 -0
  575. package/v3/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +7 -0
  576. package/v3/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +224 -0
  577. package/v3/@claude-flow/shared/dist/core/interfaces/event.interface.js +46 -0
  578. package/v3/@claude-flow/shared/dist/core/interfaces/index.d.ts +10 -0
  579. package/v3/@claude-flow/shared/dist/core/interfaces/index.js +15 -0
  580. package/v3/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +298 -0
  581. package/v3/@claude-flow/shared/dist/core/interfaces/memory.interface.js +7 -0
  582. package/v3/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +185 -0
  583. package/v3/@claude-flow/shared/dist/core/interfaces/task.interface.js +6 -0
  584. package/v3/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +35 -0
  585. package/v3/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +101 -0
  586. package/v3/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +60 -0
  587. package/v3/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +166 -0
  588. package/v3/@claude-flow/shared/dist/core/orchestrator/index.d.ts +46 -0
  589. package/v3/@claude-flow/shared/dist/core/orchestrator/index.js +64 -0
  590. package/v3/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
  591. package/v3/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +195 -0
  592. package/v3/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +83 -0
  593. package/v3/@claude-flow/shared/dist/core/orchestrator/session-manager.js +193 -0
  594. package/v3/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +49 -0
  595. package/v3/@claude-flow/shared/dist/core/orchestrator/task-manager.js +253 -0
  596. package/v3/@claude-flow/shared/dist/events/domain-events.d.ts +282 -0
  597. package/v3/@claude-flow/shared/dist/events/domain-events.js +165 -0
  598. package/v3/@claude-flow/shared/dist/events/event-store.d.ts +126 -0
  599. package/v3/@claude-flow/shared/dist/events/event-store.js +416 -0
  600. package/v3/@claude-flow/shared/dist/events/event-store.test.d.ts +8 -0
  601. package/v3/@claude-flow/shared/dist/events/event-store.test.js +293 -0
  602. package/v3/@claude-flow/shared/dist/events/example-usage.d.ts +10 -0
  603. package/v3/@claude-flow/shared/dist/events/example-usage.js +193 -0
  604. package/v3/@claude-flow/shared/dist/events/index.d.ts +21 -0
  605. package/v3/@claude-flow/shared/dist/events/index.js +22 -0
  606. package/v3/@claude-flow/shared/dist/events/projections.d.ts +177 -0
  607. package/v3/@claude-flow/shared/dist/events/projections.js +421 -0
  608. package/v3/@claude-flow/shared/dist/events/rvf-event-log.d.ts +82 -0
  609. package/v3/@claude-flow/shared/dist/events/rvf-event-log.js +340 -0
  610. package/v3/@claude-flow/shared/dist/events/state-reconstructor.d.ts +101 -0
  611. package/v3/@claude-flow/shared/dist/events/state-reconstructor.js +263 -0
  612. package/v3/@claude-flow/shared/dist/events.d.ts +80 -0
  613. package/v3/@claude-flow/shared/dist/events.js +249 -0
  614. package/v3/@claude-flow/shared/dist/hooks/example-usage.d.ts +42 -0
  615. package/v3/@claude-flow/shared/dist/hooks/example-usage.js +351 -0
  616. package/v3/@claude-flow/shared/dist/hooks/executor.d.ts +100 -0
  617. package/v3/@claude-flow/shared/dist/hooks/executor.js +264 -0
  618. package/v3/@claude-flow/shared/dist/hooks/hooks.test.d.ts +9 -0
  619. package/v3/@claude-flow/shared/dist/hooks/hooks.test.js +322 -0
  620. package/v3/@claude-flow/shared/dist/hooks/index.d.ts +52 -0
  621. package/v3/@claude-flow/shared/dist/hooks/index.js +51 -0
  622. package/v3/@claude-flow/shared/dist/hooks/registry.d.ts +133 -0
  623. package/v3/@claude-flow/shared/dist/hooks/registry.js +277 -0
  624. package/v3/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +105 -0
  625. package/v3/@claude-flow/shared/dist/hooks/safety/bash-safety.js +481 -0
  626. package/v3/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +144 -0
  627. package/v3/@claude-flow/shared/dist/hooks/safety/file-organization.js +328 -0
  628. package/v3/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +158 -0
  629. package/v3/@claude-flow/shared/dist/hooks/safety/git-commit.js +450 -0
  630. package/v3/@claude-flow/shared/dist/hooks/safety/index.d.ts +17 -0
  631. package/v3/@claude-flow/shared/dist/hooks/safety/index.js +17 -0
  632. package/v3/@claude-flow/shared/dist/hooks/session-hooks.d.ts +234 -0
  633. package/v3/@claude-flow/shared/dist/hooks/session-hooks.js +334 -0
  634. package/v3/@claude-flow/shared/dist/hooks/task-hooks.d.ts +163 -0
  635. package/v3/@claude-flow/shared/dist/hooks/task-hooks.js +326 -0
  636. package/v3/@claude-flow/shared/dist/hooks/types.d.ts +267 -0
  637. package/v3/@claude-flow/shared/dist/hooks/types.js +62 -0
  638. package/v3/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +9 -0
  639. package/v3/@claude-flow/shared/dist/hooks/verify-exports.test.js +93 -0
  640. package/v3/@claude-flow/shared/dist/index.d.ts +20 -0
  641. package/v3/@claude-flow/shared/dist/index.js +50 -0
  642. package/v3/@claude-flow/shared/dist/mcp/connection-pool.d.ts +98 -0
  643. package/v3/@claude-flow/shared/dist/mcp/connection-pool.js +364 -0
  644. package/v3/@claude-flow/shared/dist/mcp/index.d.ts +69 -0
  645. package/v3/@claude-flow/shared/dist/mcp/index.js +84 -0
  646. package/v3/@claude-flow/shared/dist/mcp/server.d.ts +166 -0
  647. package/v3/@claude-flow/shared/dist/mcp/server.js +593 -0
  648. package/v3/@claude-flow/shared/dist/mcp/session-manager.d.ts +136 -0
  649. package/v3/@claude-flow/shared/dist/mcp/session-manager.js +335 -0
  650. package/v3/@claude-flow/shared/dist/mcp/tool-registry.d.ts +178 -0
  651. package/v3/@claude-flow/shared/dist/mcp/tool-registry.js +439 -0
  652. package/v3/@claude-flow/shared/dist/mcp/transport/http.d.ts +104 -0
  653. package/v3/@claude-flow/shared/dist/mcp/transport/http.js +476 -0
  654. package/v3/@claude-flow/shared/dist/mcp/transport/index.d.ts +102 -0
  655. package/v3/@claude-flow/shared/dist/mcp/transport/index.js +238 -0
  656. package/v3/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +104 -0
  657. package/v3/@claude-flow/shared/dist/mcp/transport/stdio.js +263 -0
  658. package/v3/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +133 -0
  659. package/v3/@claude-flow/shared/dist/mcp/transport/websocket.js +396 -0
  660. package/v3/@claude-flow/shared/dist/mcp/types.d.ts +438 -0
  661. package/v3/@claude-flow/shared/dist/mcp/types.js +54 -0
  662. package/v3/@claude-flow/shared/dist/plugin-interface.d.ts +544 -0
  663. package/v3/@claude-flow/shared/dist/plugin-interface.js +23 -0
  664. package/v3/@claude-flow/shared/dist/plugin-loader.d.ts +139 -0
  665. package/v3/@claude-flow/shared/dist/plugin-loader.js +434 -0
  666. package/v3/@claude-flow/shared/dist/plugin-registry.d.ts +183 -0
  667. package/v3/@claude-flow/shared/dist/plugin-registry.js +457 -0
  668. package/v3/@claude-flow/shared/dist/plugins/index.d.ts +10 -0
  669. package/v3/@claude-flow/shared/dist/plugins/index.js +10 -0
  670. package/v3/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
  671. package/v3/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +241 -0
  672. package/v3/@claude-flow/shared/dist/plugins/official/index.d.ts +10 -0
  673. package/v3/@claude-flow/shared/dist/plugins/official/index.js +10 -0
  674. package/v3/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +121 -0
  675. package/v3/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +355 -0
  676. package/v3/@claude-flow/shared/dist/plugins/types.d.ts +93 -0
  677. package/v3/@claude-flow/shared/dist/plugins/types.js +9 -0
  678. package/v3/@claude-flow/shared/dist/resilience/bulkhead.d.ts +105 -0
  679. package/v3/@claude-flow/shared/dist/resilience/bulkhead.js +206 -0
  680. package/v3/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +132 -0
  681. package/v3/@claude-flow/shared/dist/resilience/circuit-breaker.js +233 -0
  682. package/v3/@claude-flow/shared/dist/resilience/index.d.ts +19 -0
  683. package/v3/@claude-flow/shared/dist/resilience/index.js +19 -0
  684. package/v3/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +168 -0
  685. package/v3/@claude-flow/shared/dist/resilience/rate-limiter.js +314 -0
  686. package/v3/@claude-flow/shared/dist/resilience/retry.d.ts +91 -0
  687. package/v3/@claude-flow/shared/dist/resilience/retry.js +159 -0
  688. package/v3/@claude-flow/shared/dist/security/index.d.ts +10 -0
  689. package/v3/@claude-flow/shared/dist/security/index.js +12 -0
  690. package/v3/@claude-flow/shared/dist/security/input-validation.d.ts +73 -0
  691. package/v3/@claude-flow/shared/dist/security/input-validation.js +201 -0
  692. package/v3/@claude-flow/shared/dist/security/secure-random.d.ts +92 -0
  693. package/v3/@claude-flow/shared/dist/security/secure-random.js +142 -0
  694. package/v3/@claude-flow/shared/dist/services/index.d.ts +7 -0
  695. package/v3/@claude-flow/shared/dist/services/index.js +7 -0
  696. package/v3/@claude-flow/shared/dist/services/v3-progress.service.d.ts +124 -0
  697. package/v3/@claude-flow/shared/dist/services/v3-progress.service.js +402 -0
  698. package/v3/@claude-flow/shared/dist/types/agent.types.d.ts +137 -0
  699. package/v3/@claude-flow/shared/dist/types/agent.types.js +6 -0
  700. package/v3/@claude-flow/shared/dist/types/index.d.ts +11 -0
  701. package/v3/@claude-flow/shared/dist/types/index.js +17 -0
  702. package/v3/@claude-flow/shared/dist/types/mcp.types.d.ts +266 -0
  703. package/v3/@claude-flow/shared/dist/types/mcp.types.js +7 -0
  704. package/v3/@claude-flow/shared/dist/types/memory.types.d.ts +236 -0
  705. package/v3/@claude-flow/shared/dist/types/memory.types.js +7 -0
  706. package/v3/@claude-flow/shared/dist/types/swarm.types.d.ts +186 -0
  707. package/v3/@claude-flow/shared/dist/types/swarm.types.js +65 -0
  708. package/v3/@claude-flow/shared/dist/types/task.types.d.ts +178 -0
  709. package/v3/@claude-flow/shared/dist/types/task.types.js +32 -0
  710. package/v3/@claude-flow/shared/dist/types.d.ts +197 -0
  711. package/v3/@claude-flow/shared/dist/types.js +21 -0
  712. package/v3/@claude-flow/shared/dist/utils/secure-logger.d.ts +69 -0
  713. package/v3/@claude-flow/shared/dist/utils/secure-logger.js +208 -0
  714. package/v3/@claude-flow/shared/package.json +42 -0
  715. package/v3/README.md +493 -0
@@ -0,0 +1,160 @@
1
+ /**
2
+ * Coverage Router for Test Routing
3
+ *
4
+ * Optimizations:
5
+ * - Async file I/O for non-blocking coverage loading
6
+ * - TTL-based caching of coverage data
7
+ * - Singleton router instance
8
+ */
9
+ /**
10
+ * Clear coverage cache
11
+ */
12
+ export declare function clearCoverageCache(): void;
13
+ /**
14
+ * Get coverage cache stats
15
+ */
16
+ export declare function getCoverageCacheStats(): {
17
+ size: number;
18
+ };
19
+ export interface CoverageRouterConfig {
20
+ minCoverage: number;
21
+ targetCoverage: number;
22
+ incremental: boolean;
23
+ coverageTypes: ('line' | 'branch' | 'function' | 'statement')[];
24
+ }
25
+ export interface FileCoverage {
26
+ path: string;
27
+ lineCoverage: number;
28
+ branchCoverage: number;
29
+ functionCoverage: number;
30
+ statementCoverage: number;
31
+ uncoveredLines: number[];
32
+ totalLines: number;
33
+ coveredLines: number;
34
+ }
35
+ export interface CoverageReport {
36
+ overall: number;
37
+ byType: {
38
+ line: number;
39
+ branch: number;
40
+ function: number;
41
+ statement: number;
42
+ };
43
+ byFile: FileCoverage[];
44
+ lowestCoverage: FileCoverage[];
45
+ highestCoverage: FileCoverage[];
46
+ uncoveredCritical: string[];
47
+ timestamp: number;
48
+ }
49
+ export interface CoverageRouteResult {
50
+ action: 'add-tests' | 'review-coverage' | 'skip' | 'prioritize';
51
+ priority: number;
52
+ targetFiles: string[];
53
+ testTypes: ('unit' | 'integration' | 'e2e')[];
54
+ gaps: Array<{
55
+ file: string;
56
+ currentCoverage: number;
57
+ targetCoverage: number;
58
+ gap: number;
59
+ suggestedTests: string[];
60
+ }>;
61
+ estimatedEffort: number;
62
+ impactScore: number;
63
+ }
64
+ export declare class CoverageRouter {
65
+ private config;
66
+ private ruvectorEngine;
67
+ private useNative;
68
+ private coverageHistory;
69
+ constructor(config?: Partial<CoverageRouterConfig>);
70
+ initialize(): Promise<void>;
71
+ parseCoverage(data: unknown, format?: 'lcov' | 'istanbul' | 'cobertura' | 'json'): CoverageReport;
72
+ route(coverage: CoverageReport, changedFiles?: string[]): CoverageRouteResult;
73
+ getTrend(): {
74
+ direction: 'up' | 'down' | 'stable';
75
+ change: number;
76
+ };
77
+ addToHistory(report: CoverageReport): void;
78
+ getStats(): Record<string, number | boolean>;
79
+ private parseLcov;
80
+ private parseIstanbul;
81
+ private parseCobertura;
82
+ private parseJson;
83
+ private finalizeFileCoverage;
84
+ private buildReport;
85
+ private findCriticalUncovered;
86
+ private calculateGaps;
87
+ private suggestTests;
88
+ private prioritizeFiles;
89
+ private determineAction;
90
+ private calculatePriority;
91
+ private recommendTestTypes;
92
+ private estimateEffort;
93
+ private calculateImpact;
94
+ }
95
+ export declare function createCoverageRouter(config?: Partial<CoverageRouterConfig>): CoverageRouter;
96
+ /**
97
+ * Coverage suggestion result
98
+ */
99
+ export interface CoverageSuggestResult {
100
+ path: string;
101
+ suggestions: Array<{
102
+ file: string;
103
+ currentCoverage: number;
104
+ targetCoverage: number;
105
+ gap: number;
106
+ priority: number;
107
+ suggestedTests: string[];
108
+ }>;
109
+ totalGap: number;
110
+ estimatedEffort: number;
111
+ }
112
+ /**
113
+ * Coverage gaps result
114
+ */
115
+ export interface CoverageGapsResult {
116
+ totalGaps: number;
117
+ gaps: Array<{
118
+ file: string;
119
+ currentCoverage: number;
120
+ targetCoverage: number;
121
+ gap: number;
122
+ priority: number;
123
+ suggestedAgent: string;
124
+ }>;
125
+ byAgent: Record<string, string[]>;
126
+ summary: string;
127
+ }
128
+ /**
129
+ * Coverage route options
130
+ */
131
+ export interface CoverageRouteOptions {
132
+ projectRoot?: string;
133
+ threshold?: number;
134
+ useRuvector?: boolean;
135
+ }
136
+ /**
137
+ * Coverage suggest options
138
+ */
139
+ export interface CoverageSuggestOptions extends CoverageRouteOptions {
140
+ limit?: number;
141
+ }
142
+ /**
143
+ * Coverage gaps options
144
+ */
145
+ export interface CoverageGapsOptions extends CoverageRouteOptions {
146
+ groupByAgent?: boolean;
147
+ }
148
+ /**
149
+ * Route a task based on coverage analysis
150
+ */
151
+ export declare function coverageRoute(task: string, options?: CoverageRouteOptions): Promise<CoverageRouteResult>;
152
+ /**
153
+ * Suggest coverage improvements for a path
154
+ */
155
+ export declare function coverageSuggest(path: string, options?: CoverageSuggestOptions): Promise<CoverageSuggestResult>;
156
+ /**
157
+ * List all coverage gaps with agent assignments
158
+ */
159
+ export declare function coverageGaps(options?: CoverageGapsOptions): Promise<CoverageGapsResult>;
160
+ //# sourceMappingURL=coverage-router.d.ts.map
@@ -0,0 +1,529 @@
1
+ /**
2
+ * Coverage Router for Test Routing
3
+ *
4
+ * Optimizations:
5
+ * - Async file I/O for non-blocking coverage loading
6
+ * - TTL-based caching of coverage data
7
+ * - Singleton router instance
8
+ */
9
+ // ============================================================================
10
+ // Caching for Performance
11
+ // ============================================================================
12
+ /**
13
+ * Cache for coverage data (1 minute TTL)
14
+ */
15
+ const coverageDataCache = new Map();
16
+ const COVERAGE_CACHE_TTL_MS = 60 * 1000; // 1 minute
17
+ /**
18
+ * Clear coverage cache
19
+ */
20
+ export function clearCoverageCache() {
21
+ coverageDataCache.clear();
22
+ }
23
+ /**
24
+ * Get coverage cache stats
25
+ */
26
+ export function getCoverageCacheStats() {
27
+ return { size: coverageDataCache.size };
28
+ }
29
+ const DEFAULT_CONFIG = {
30
+ minCoverage: 70,
31
+ targetCoverage: 85,
32
+ incremental: true,
33
+ coverageTypes: ['line', 'branch', 'function', 'statement'],
34
+ };
35
+ export class CoverageRouter {
36
+ config;
37
+ ruvectorEngine = null;
38
+ useNative = false;
39
+ coverageHistory = [];
40
+ constructor(config = {}) {
41
+ this.config = { ...DEFAULT_CONFIG, ...config };
42
+ }
43
+ async initialize() {
44
+ try {
45
+ // @ruvector/coverage is optional - gracefully fallback if not installed
46
+ const ruvector = await import('@ruvector/coverage').catch(() => null);
47
+ if (ruvector) {
48
+ this.ruvectorEngine = ruvector.createCoverageRouter?.(this.config);
49
+ this.useNative = !!this.ruvectorEngine;
50
+ }
51
+ }
52
+ catch {
53
+ this.useNative = false;
54
+ }
55
+ }
56
+ parseCoverage(data, format = 'json') {
57
+ switch (format) {
58
+ case 'lcov': return this.parseLcov(data);
59
+ case 'istanbul': return this.parseIstanbul(data);
60
+ case 'cobertura': return this.parseCobertura(data);
61
+ default: return this.parseJson(data);
62
+ }
63
+ }
64
+ route(coverage, changedFiles) {
65
+ const gaps = this.calculateGaps(coverage);
66
+ const targetFiles = this.prioritizeFiles(coverage, changedFiles);
67
+ const action = this.determineAction(coverage, gaps);
68
+ const priority = this.calculatePriority(coverage, changedFiles);
69
+ const testTypes = this.recommendTestTypes(gaps);
70
+ const estimatedEffort = this.estimateEffort(gaps);
71
+ const impactScore = this.calculateImpact(coverage, targetFiles);
72
+ return { action, priority, targetFiles, testTypes, gaps, estimatedEffort, impactScore };
73
+ }
74
+ getTrend() {
75
+ if (this.coverageHistory.length < 2)
76
+ return { direction: 'stable', change: 0 };
77
+ const recent = this.coverageHistory[this.coverageHistory.length - 1];
78
+ const previous = this.coverageHistory[this.coverageHistory.length - 2];
79
+ const change = recent.overall - previous.overall;
80
+ return { direction: change > 0.5 ? 'up' : change < -0.5 ? 'down' : 'stable', change };
81
+ }
82
+ addToHistory(report) {
83
+ this.coverageHistory.push(report);
84
+ if (this.coverageHistory.length > 10)
85
+ this.coverageHistory.shift();
86
+ }
87
+ getStats() {
88
+ return { useNative: this.useNative, historySize: this.coverageHistory.length, minCoverage: this.config.minCoverage, targetCoverage: this.config.targetCoverage };
89
+ }
90
+ parseLcov(data) {
91
+ const files = [];
92
+ let currentFile = null;
93
+ const lines = data.split('\n');
94
+ for (const line of lines) {
95
+ if (line.startsWith('SF:')) {
96
+ if (currentFile?.path)
97
+ files.push(this.finalizeFileCoverage(currentFile));
98
+ currentFile = { path: line.substring(3), uncoveredLines: [], totalLines: 0, coveredLines: 0 };
99
+ }
100
+ else if (line.startsWith('LF:')) {
101
+ if (currentFile)
102
+ currentFile.totalLines = parseInt(line.substring(3), 10);
103
+ }
104
+ else if (line.startsWith('LH:')) {
105
+ if (currentFile)
106
+ currentFile.coveredLines = parseInt(line.substring(3), 10);
107
+ }
108
+ else if (line.startsWith('DA:')) {
109
+ const [lineNum, hits] = line.substring(3).split(',').map(Number);
110
+ if (currentFile && hits === 0)
111
+ currentFile.uncoveredLines?.push(lineNum);
112
+ }
113
+ else if (line === 'end_of_record') {
114
+ if (currentFile?.path)
115
+ files.push(this.finalizeFileCoverage(currentFile));
116
+ currentFile = null;
117
+ }
118
+ }
119
+ return this.buildReport(files);
120
+ }
121
+ parseIstanbul(data) {
122
+ const files = [];
123
+ for (const [path, coverage] of Object.entries(data)) {
124
+ const cov = coverage;
125
+ const statements = cov.s;
126
+ const functions = cov.f;
127
+ const branches = cov.b;
128
+ const statementCovered = Object.values(statements).filter(v => v > 0).length;
129
+ const statementTotal = Object.values(statements).length;
130
+ const functionCovered = Object.values(functions).filter(v => v > 0).length;
131
+ const functionTotal = Object.values(functions).length;
132
+ const branchCovered = Object.values(branches).flat().filter(v => v > 0).length;
133
+ const branchTotal = Object.values(branches).flat().length;
134
+ files.push({
135
+ path, lineCoverage: statementTotal > 0 ? (statementCovered / statementTotal) * 100 : 100,
136
+ branchCoverage: branchTotal > 0 ? (branchCovered / branchTotal) * 100 : 100,
137
+ functionCoverage: functionTotal > 0 ? (functionCovered / functionTotal) * 100 : 100,
138
+ statementCoverage: statementTotal > 0 ? (statementCovered / statementTotal) * 100 : 100,
139
+ uncoveredLines: [], totalLines: statementTotal, coveredLines: statementCovered,
140
+ });
141
+ }
142
+ return this.buildReport(files);
143
+ }
144
+ parseCobertura(data) {
145
+ const files = [];
146
+ const classMatches = data.matchAll(/<class[^>]*filename="([^"]+)"[^>]*line-rate="([^"]+)"[^>]*branch-rate="([^"]+)"[^>]*>/g);
147
+ for (const match of classMatches) {
148
+ files.push({
149
+ path: match[1], lineCoverage: parseFloat(match[2]) * 100, branchCoverage: parseFloat(match[3]) * 100,
150
+ functionCoverage: parseFloat(match[2]) * 100, statementCoverage: parseFloat(match[2]) * 100,
151
+ uncoveredLines: [], totalLines: 0, coveredLines: 0,
152
+ });
153
+ }
154
+ return this.buildReport(files);
155
+ }
156
+ parseJson(data) {
157
+ if (Array.isArray(data))
158
+ return this.buildReport(data);
159
+ const files = [];
160
+ for (const [path, coverage] of Object.entries(data)) {
161
+ const cov = coverage;
162
+ files.push({
163
+ path, lineCoverage: cov.lineCoverage || 0, branchCoverage: cov.branchCoverage || 0,
164
+ functionCoverage: cov.functionCoverage || 0, statementCoverage: cov.statementCoverage || 0,
165
+ uncoveredLines: cov.uncoveredLines || [], totalLines: cov.totalLines || 0, coveredLines: cov.coveredLines || 0,
166
+ });
167
+ }
168
+ return this.buildReport(files);
169
+ }
170
+ finalizeFileCoverage(partial) {
171
+ const lineCoverage = partial.totalLines && partial.totalLines > 0 ? (partial.coveredLines || 0) / partial.totalLines * 100 : 100;
172
+ return { path: partial.path || 'unknown', lineCoverage, branchCoverage: lineCoverage, functionCoverage: lineCoverage, statementCoverage: lineCoverage, uncoveredLines: partial.uncoveredLines || [], totalLines: partial.totalLines || 0, coveredLines: partial.coveredLines || 0 };
173
+ }
174
+ buildReport(files) {
175
+ const totalLines = files.reduce((sum, f) => sum + f.totalLines, 0);
176
+ const coveredLines = files.reduce((sum, f) => sum + f.coveredLines, 0);
177
+ const overall = totalLines > 0 ? (coveredLines / totalLines) * 100 : 100;
178
+ const avgLine = files.length > 0 ? files.reduce((sum, f) => sum + f.lineCoverage, 0) / files.length : 100;
179
+ const avgBranch = files.length > 0 ? files.reduce((sum, f) => sum + f.branchCoverage, 0) / files.length : 100;
180
+ const avgFunction = files.length > 0 ? files.reduce((sum, f) => sum + f.functionCoverage, 0) / files.length : 100;
181
+ const avgStatement = files.length > 0 ? files.reduce((sum, f) => sum + f.statementCoverage, 0) / files.length : 100;
182
+ const sortedByLine = [...files].sort((a, b) => a.lineCoverage - b.lineCoverage);
183
+ return { overall, byType: { line: avgLine, branch: avgBranch, function: avgFunction, statement: avgStatement }, byFile: files, lowestCoverage: sortedByLine.slice(0, 5), highestCoverage: sortedByLine.slice(-5).reverse(), uncoveredCritical: this.findCriticalUncovered(files), timestamp: Date.now() };
184
+ }
185
+ findCriticalUncovered(files) {
186
+ const critical = [];
187
+ const criticalPatterns = [/auth/, /security/, /payment/, /core/, /main/, /index/];
188
+ for (const file of files) {
189
+ if (file.lineCoverage < this.config.minCoverage) {
190
+ for (const pattern of criticalPatterns) {
191
+ if (pattern.test(file.path)) {
192
+ critical.push(file.path);
193
+ break;
194
+ }
195
+ }
196
+ }
197
+ }
198
+ return critical.slice(0, 10);
199
+ }
200
+ calculateGaps(coverage) {
201
+ const gaps = [];
202
+ for (const file of coverage.byFile) {
203
+ if (file.lineCoverage < this.config.targetCoverage) {
204
+ const gap = this.config.targetCoverage - file.lineCoverage;
205
+ gaps.push({ file: file.path, currentCoverage: file.lineCoverage, targetCoverage: this.config.targetCoverage, gap, suggestedTests: this.suggestTests(file) });
206
+ }
207
+ }
208
+ return gaps.sort((a, b) => b.gap - a.gap).slice(0, 10);
209
+ }
210
+ suggestTests(file) {
211
+ const suggestions = [];
212
+ if (file.uncoveredLines.length > 10)
213
+ suggestions.push('Add unit tests for uncovered code paths');
214
+ if (file.branchCoverage < 50)
215
+ suggestions.push('Add branch coverage tests (if/else paths)');
216
+ if (file.functionCoverage < 80)
217
+ suggestions.push('Add tests for untested functions');
218
+ if (/api|endpoint|route|handler/.test(file.path))
219
+ suggestions.push('Add integration tests for API endpoints');
220
+ return suggestions.slice(0, 3);
221
+ }
222
+ prioritizeFiles(coverage, changedFiles) {
223
+ let targetFiles = coverage.lowestCoverage.map(f => f.path);
224
+ if (changedFiles && changedFiles.length > 0) {
225
+ const changedWithLowCoverage = coverage.byFile.filter(f => changedFiles.some(cf => f.path.includes(cf))).filter(f => f.lineCoverage < this.config.targetCoverage).map(f => f.path);
226
+ targetFiles = [...new Set([...changedWithLowCoverage, ...targetFiles])];
227
+ }
228
+ return targetFiles.slice(0, 10);
229
+ }
230
+ determineAction(coverage, gaps) {
231
+ if (coverage.overall < this.config.minCoverage)
232
+ return 'prioritize';
233
+ if (gaps.length > 5)
234
+ return 'add-tests';
235
+ if (coverage.overall < this.config.targetCoverage)
236
+ return 'review-coverage';
237
+ return 'skip';
238
+ }
239
+ calculatePriority(coverage, changedFiles) {
240
+ let priority = 5;
241
+ if (coverage.overall < 50)
242
+ priority += 4;
243
+ else if (coverage.overall < 70)
244
+ priority += 2;
245
+ else if (coverage.overall < 85)
246
+ priority += 1;
247
+ priority += Math.min(3, coverage.uncoveredCritical.length);
248
+ if (changedFiles && changedFiles.length > 0) {
249
+ const changedLowCoverage = coverage.byFile.filter(f => changedFiles.some(cf => f.path.includes(cf))).filter(f => f.lineCoverage < this.config.minCoverage);
250
+ priority += Math.min(2, changedLowCoverage.length);
251
+ }
252
+ return Math.min(10, priority);
253
+ }
254
+ recommendTestTypes(gaps) {
255
+ const types = new Set(['unit']);
256
+ for (const gap of gaps) {
257
+ if (/api|endpoint|route|handler|service/.test(gap.file))
258
+ types.add('integration');
259
+ if (/page|component|view|ui/.test(gap.file))
260
+ types.add('e2e');
261
+ }
262
+ return Array.from(types);
263
+ }
264
+ estimateEffort(gaps) {
265
+ let effort = 0;
266
+ for (const gap of gaps)
267
+ effort += (gap.gap / 10) * 0.5;
268
+ return Math.round(effort * 10) / 10;
269
+ }
270
+ calculateImpact(coverage, targetFiles) {
271
+ const potentialGain = targetFiles.reduce((sum, file) => {
272
+ const fileCov = coverage.byFile.find(f => f.path === file);
273
+ return fileCov ? sum + (this.config.targetCoverage - fileCov.lineCoverage) : sum;
274
+ }, 0);
275
+ return Math.min(100, Math.round(potentialGain / targetFiles.length || 0));
276
+ }
277
+ }
278
+ export function createCoverageRouter(config) {
279
+ return new CoverageRouter(config);
280
+ }
281
+ /**
282
+ * Route a task based on coverage analysis
283
+ */
284
+ export async function coverageRoute(task, options = {}) {
285
+ const router = new CoverageRouter({
286
+ targetCoverage: options.threshold || 80,
287
+ });
288
+ // Try to load coverage data
289
+ const coverage = await loadProjectCoverage(options.projectRoot);
290
+ if (!coverage) {
291
+ return {
292
+ action: 'skip',
293
+ priority: 1,
294
+ targetFiles: [],
295
+ testTypes: ['unit'],
296
+ gaps: [],
297
+ estimatedEffort: 0,
298
+ impactScore: 0,
299
+ };
300
+ }
301
+ return router.route(coverage);
302
+ }
303
+ /**
304
+ * Suggest coverage improvements for a path
305
+ */
306
+ export async function coverageSuggest(path, options = {}) {
307
+ const limit = options.limit || 20;
308
+ const threshold = options.threshold || 80;
309
+ const coverage = await loadProjectCoverage(options.projectRoot);
310
+ if (!coverage) {
311
+ return {
312
+ path,
313
+ suggestions: [],
314
+ totalGap: 0,
315
+ estimatedEffort: 0,
316
+ };
317
+ }
318
+ // Filter files matching the path
319
+ const matchingFiles = coverage.byFile.filter(f => f.path.includes(path));
320
+ const belowThreshold = matchingFiles.filter(f => f.lineCoverage < threshold);
321
+ const suggestions = belowThreshold
322
+ .map(f => ({
323
+ file: f.path,
324
+ currentCoverage: f.lineCoverage,
325
+ targetCoverage: threshold,
326
+ gap: threshold - f.lineCoverage,
327
+ priority: calculateFilePriority(f.path, f.lineCoverage, threshold),
328
+ suggestedTests: suggestTestsForFile(f),
329
+ }))
330
+ .sort((a, b) => b.priority - a.priority)
331
+ .slice(0, limit);
332
+ const totalGap = suggestions.reduce((sum, s) => sum + s.gap, 0);
333
+ const estimatedEffort = totalGap * 0.1; // Rough estimate: 0.1 hours per % gap
334
+ return { path, suggestions, totalGap, estimatedEffort };
335
+ }
336
+ /**
337
+ * List all coverage gaps with agent assignments
338
+ */
339
+ export async function coverageGaps(options = {}) {
340
+ const threshold = options.threshold || 80;
341
+ const groupByAgent = options.groupByAgent !== false;
342
+ const coverage = await loadProjectCoverage(options.projectRoot);
343
+ if (!coverage) {
344
+ return {
345
+ totalGaps: 0,
346
+ gaps: [],
347
+ byAgent: {},
348
+ summary: 'No coverage data found',
349
+ };
350
+ }
351
+ const belowThreshold = coverage.byFile.filter(f => f.lineCoverage < threshold);
352
+ const gaps = belowThreshold.map(f => ({
353
+ file: f.path,
354
+ currentCoverage: f.lineCoverage,
355
+ targetCoverage: threshold,
356
+ gap: threshold - f.lineCoverage,
357
+ priority: calculateFilePriority(f.path, f.lineCoverage, threshold),
358
+ suggestedAgent: suggestAgentForFile(f.path),
359
+ }));
360
+ const byAgent = {};
361
+ if (groupByAgent) {
362
+ for (const gap of gaps) {
363
+ if (!byAgent[gap.suggestedAgent]) {
364
+ byAgent[gap.suggestedAgent] = [];
365
+ }
366
+ byAgent[gap.suggestedAgent].push(gap.file);
367
+ }
368
+ }
369
+ return {
370
+ totalGaps: gaps.length,
371
+ gaps,
372
+ byAgent,
373
+ summary: `${gaps.length} files below ${threshold}% coverage threshold`,
374
+ };
375
+ }
376
+ /**
377
+ * Validate and normalize path to prevent directory traversal
378
+ * Returns null if path is invalid or attempts traversal
379
+ */
380
+ function validateProjectPath(inputPath) {
381
+ const { resolve, normalize, isAbsolute } = require('path');
382
+ // Default to cwd if not provided
383
+ const basePath = inputPath || process.cwd();
384
+ // Normalize and resolve the path
385
+ const normalizedPath = normalize(basePath);
386
+ const resolvedPath = isAbsolute(normalizedPath) ? normalizedPath : resolve(process.cwd(), normalizedPath);
387
+ // Check for path traversal attempts
388
+ if (normalizedPath.includes('..') && !resolvedPath.startsWith(process.cwd())) {
389
+ // Only allow .. if it resolves within or above cwd
390
+ // For safety, reject any path with .. that goes outside project
391
+ return null;
392
+ }
393
+ // Additional validation: no null bytes or control characters
394
+ if (/[\x00-\x1f]/.test(resolvedPath)) {
395
+ return null;
396
+ }
397
+ // Limit path length to prevent DoS
398
+ if (resolvedPath.length > 4096) {
399
+ return null;
400
+ }
401
+ return resolvedPath;
402
+ }
403
+ /**
404
+ * Load project coverage data (async with caching)
405
+ */
406
+ async function loadProjectCoverage(projectRoot, skipCache) {
407
+ // Validate and normalize the project root path
408
+ const root = validateProjectPath(projectRoot);
409
+ if (!root) {
410
+ // Invalid path detected, return null safely
411
+ return null;
412
+ }
413
+ // Check cache first
414
+ if (!skipCache) {
415
+ const cached = coverageDataCache.get(root);
416
+ if (cached && Date.now() - cached.timestamp < COVERAGE_CACHE_TTL_MS) {
417
+ return cached.report;
418
+ }
419
+ }
420
+ const { existsSync } = require('fs');
421
+ const { readFile } = require('fs/promises');
422
+ const { join, normalize } = require('path');
423
+ // Try common coverage locations (all relative to validated root)
424
+ const coverageLocations = [
425
+ ['coverage', 'coverage-final.json'],
426
+ ['coverage', 'lcov.info'],
427
+ ['.nyc_output', 'coverage.json'],
428
+ ['coverage.json'],
429
+ ];
430
+ for (const pathParts of coverageLocations) {
431
+ // Join and normalize to prevent traversal in coverage paths
432
+ const coveragePath = normalize(join(root, ...pathParts));
433
+ // Ensure the coverage path is still within or under root
434
+ if (!coveragePath.startsWith(root)) {
435
+ continue;
436
+ }
437
+ if (existsSync(coveragePath)) {
438
+ try {
439
+ // Use async file read for non-blocking I/O
440
+ const content = await readFile(coveragePath, 'utf-8');
441
+ const router = new CoverageRouter();
442
+ let report = null;
443
+ if (coveragePath.endsWith('.json')) {
444
+ report = router.parseCoverage(JSON.parse(content), 'istanbul');
445
+ }
446
+ else if (coveragePath.endsWith('.info')) {
447
+ report = router.parseCoverage(content, 'lcov');
448
+ }
449
+ // Cache the result
450
+ if (report) {
451
+ coverageDataCache.set(root, { report, timestamp: Date.now() });
452
+ return report;
453
+ }
454
+ }
455
+ catch {
456
+ // Continue to next path
457
+ }
458
+ }
459
+ }
460
+ return null;
461
+ }
462
+ /**
463
+ * Calculate priority for a file based on path and coverage
464
+ */
465
+ function calculateFilePriority(path, coverage, threshold) {
466
+ let priority = 5;
467
+ // Gap-based priority
468
+ const gap = threshold - coverage;
469
+ if (gap > 50)
470
+ priority += 3;
471
+ else if (gap > 30)
472
+ priority += 2;
473
+ else if (gap > 15)
474
+ priority += 1;
475
+ // Path-based priority
476
+ const lowerPath = path.toLowerCase();
477
+ if (/core|main|index/.test(lowerPath))
478
+ priority += 2;
479
+ if (/auth|security|payment/.test(lowerPath))
480
+ priority += 3;
481
+ if (/api|service|controller/.test(lowerPath))
482
+ priority += 1;
483
+ if (/util|helper/.test(lowerPath))
484
+ priority -= 1;
485
+ if (/test|spec|mock/.test(lowerPath))
486
+ priority -= 2;
487
+ return Math.max(1, Math.min(10, priority));
488
+ }
489
+ /**
490
+ * Suggest tests for a file based on its coverage
491
+ */
492
+ function suggestTestsForFile(file) {
493
+ const suggestions = [];
494
+ if (file.uncoveredLines.length > 10) {
495
+ suggestions.push('Add unit tests for uncovered code paths');
496
+ }
497
+ if (file.branchCoverage < 50) {
498
+ suggestions.push('Add branch coverage tests (if/else paths)');
499
+ }
500
+ if (file.functionCoverage < 80) {
501
+ suggestions.push('Add tests for untested functions');
502
+ }
503
+ const lowerPath = file.path.toLowerCase();
504
+ if (/api|endpoint|route|handler/.test(lowerPath)) {
505
+ suggestions.push('Add integration tests for API endpoints');
506
+ }
507
+ if (/component|view|ui/.test(lowerPath)) {
508
+ suggestions.push('Add component tests with user interactions');
509
+ }
510
+ return suggestions.slice(0, 3);
511
+ }
512
+ /**
513
+ * Suggest an agent type for a file
514
+ */
515
+ function suggestAgentForFile(path) {
516
+ const lowerPath = path.toLowerCase();
517
+ if (/api|endpoint|route|controller/.test(lowerPath))
518
+ return 'api-tester';
519
+ if (/component|view|ui|page/.test(lowerPath))
520
+ return 'ui-tester';
521
+ if (/service|repository|model/.test(lowerPath))
522
+ return 'unit-tester';
523
+ if (/integration|e2e/.test(lowerPath))
524
+ return 'e2e-tester';
525
+ if (/util|helper|lib/.test(lowerPath))
526
+ return 'unit-tester';
527
+ return 'tester';
528
+ }
529
+ //# sourceMappingURL=coverage-router.js.map