@aigentic/claude-flow 3.7.0-alpha.69

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 (807) hide show
  1. package/.claude/agents/MIGRATION_SUMMARY.md +222 -0
  2. package/.claude/agents/analysis/analyze-code-quality.md +58 -0
  3. package/.claude/agents/analysis/code-analyzer.md +189 -0
  4. package/.claude/agents/analysis/code-review/analyze-code-quality.md +58 -0
  5. package/.claude/agents/architecture/arch-system-design.md +157 -0
  6. package/.claude/agents/architecture/system-design/arch-system-design.md +36 -0
  7. package/.claude/agents/base-template-generator.md +41 -0
  8. package/.claude/agents/browser/browser-agent.yaml +182 -0
  9. package/.claude/agents/consensus/byzantine-coordinator.md +43 -0
  10. package/.claude/agents/consensus/crdt-synchronizer.md +977 -0
  11. package/.claude/agents/consensus/gossip-coordinator.md +43 -0
  12. package/.claude/agents/consensus/performance-benchmarker.md +831 -0
  13. package/.claude/agents/consensus/quorum-manager.md +803 -0
  14. package/.claude/agents/consensus/raft-manager.md +43 -0
  15. package/.claude/agents/consensus/security-manager.md +602 -0
  16. package/.claude/agents/core/coder.md +255 -0
  17. package/.claude/agents/core/planner.md +152 -0
  18. package/.claude/agents/core/researcher.md +174 -0
  19. package/.claude/agents/core/reviewer.md +309 -0
  20. package/.claude/agents/core/tester.md +300 -0
  21. package/.claude/agents/custom/test-long-runner.md +43 -0
  22. package/.claude/agents/data/data-ml-model.md +445 -0
  23. package/.claude/agents/data/ml/data-ml-model.md +76 -0
  24. package/.claude/agents/database-specialist.md +9 -0
  25. package/.claude/agents/development/backend/dev-backend-api.md +29 -0
  26. package/.claude/agents/development/dev-backend-api.md +178 -0
  27. package/.claude/agents/devops/ci-cd/ops-cicd-github.md +52 -0
  28. package/.claude/agents/devops/ops-cicd-github.md +165 -0
  29. package/.claude/agents/documentation/api-docs/docs-api-openapi.md +63 -0
  30. package/.claude/agents/documentation/docs-api-openapi.md +355 -0
  31. package/.claude/agents/dual-mode/codex-coordinator.md +206 -0
  32. package/.claude/agents/dual-mode/codex-worker.md +190 -0
  33. package/.claude/agents/dual-mode/dual-orchestrator.md +253 -0
  34. package/.claude/agents/flow-nexus/app-store.md +88 -0
  35. package/.claude/agents/flow-nexus/authentication.md +69 -0
  36. package/.claude/agents/flow-nexus/challenges.md +81 -0
  37. package/.claude/agents/flow-nexus/neural-network.md +88 -0
  38. package/.claude/agents/flow-nexus/payments.md +83 -0
  39. package/.claude/agents/flow-nexus/sandbox.md +76 -0
  40. package/.claude/agents/flow-nexus/swarm.md +76 -0
  41. package/.claude/agents/flow-nexus/user-tools.md +96 -0
  42. package/.claude/agents/flow-nexus/workflow.md +84 -0
  43. package/.claude/agents/github/code-review-swarm.md +521 -0
  44. package/.claude/agents/github/github-modes.md +154 -0
  45. package/.claude/agents/github/issue-tracker.md +299 -0
  46. package/.claude/agents/github/multi-repo-swarm.md +525 -0
  47. package/.claude/agents/github/pr-manager.md +163 -0
  48. package/.claude/agents/github/project-board-sync.md +478 -0
  49. package/.claude/agents/github/release-manager.md +336 -0
  50. package/.claude/agents/github/release-swarm.md +551 -0
  51. package/.claude/agents/github/repo-architect.md +365 -0
  52. package/.claude/agents/github/swarm-issue.md +548 -0
  53. package/.claude/agents/github/swarm-pr.md +399 -0
  54. package/.claude/agents/github/sync-coordinator.md +423 -0
  55. package/.claude/agents/github/workflow-automation.md +605 -0
  56. package/.claude/agents/goal/agent.md +817 -0
  57. package/.claude/agents/goal/code-goal-planner.md +445 -0
  58. package/.claude/agents/goal/goal-planner.md +168 -0
  59. package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +129 -0
  60. package/.claude/agents/hive-mind/queen-coordinator.md +202 -0
  61. package/.claude/agents/hive-mind/scout-explorer.md +241 -0
  62. package/.claude/agents/hive-mind/swarm-memory-manager.md +192 -0
  63. package/.claude/agents/hive-mind/worker-specialist.md +216 -0
  64. package/.claude/agents/neural/safla-neural.md +74 -0
  65. package/.claude/agents/optimization/benchmark-suite.md +663 -0
  66. package/.claude/agents/optimization/load-balancer.md +429 -0
  67. package/.claude/agents/optimization/performance-monitor.md +670 -0
  68. package/.claude/agents/optimization/resource-allocator.md +672 -0
  69. package/.claude/agents/optimization/topology-optimizer.md +806 -0
  70. package/.claude/agents/payments/agentic-payments.md +126 -0
  71. package/.claude/agents/project-coordinator.md +8 -0
  72. package/.claude/agents/python-specialist.md +9 -0
  73. package/.claude/agents/reasoning/agent.md +817 -0
  74. package/.claude/agents/reasoning/goal-planner.md +73 -0
  75. package/.claude/agents/security-auditor.md +9 -0
  76. package/.claude/agents/sona/sona-learning-optimizer.md +65 -0
  77. package/.claude/agents/sparc/architecture.md +453 -0
  78. package/.claude/agents/sparc/pseudocode.md +299 -0
  79. package/.claude/agents/sparc/refinement.md +504 -0
  80. package/.claude/agents/sparc/specification.md +258 -0
  81. package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +88 -0
  82. package/.claude/agents/specialized/spec-mobile-react-native.md +227 -0
  83. package/.claude/agents/sublinear/consensus-coordinator.md +338 -0
  84. package/.claude/agents/sublinear/matrix-optimizer.md +185 -0
  85. package/.claude/agents/sublinear/pagerank-analyzer.md +299 -0
  86. package/.claude/agents/sublinear/performance-optimizer.md +368 -0
  87. package/.claude/agents/sublinear/trading-predictor.md +246 -0
  88. package/.claude/agents/swarm/adaptive-coordinator.md +364 -0
  89. package/.claude/agents/swarm/hierarchical-coordinator.md +300 -0
  90. package/.claude/agents/swarm/mesh-coordinator.md +363 -0
  91. package/.claude/agents/templates/automation-smart-agent.md +185 -0
  92. package/.claude/agents/templates/base-template-generator.md +289 -0
  93. package/.claude/agents/templates/coordinator-swarm-init.md +83 -0
  94. package/.claude/agents/templates/github-pr-manager.md +155 -0
  95. package/.claude/agents/templates/implementer-sparc-coder.md +243 -0
  96. package/.claude/agents/templates/memory-coordinator.md +163 -0
  97. package/.claude/agents/templates/migration-plan.md +724 -0
  98. package/.claude/agents/templates/orchestrator-task.md +120 -0
  99. package/.claude/agents/templates/performance-analyzer.md +179 -0
  100. package/.claude/agents/templates/sparc-coordinator.md +163 -0
  101. package/.claude/agents/testing/production-validator.md +373 -0
  102. package/.claude/agents/testing/tdd-london-swarm.md +222 -0
  103. package/.claude/agents/testing/unit/tdd-london-swarm.md +222 -0
  104. package/.claude/agents/testing/validation/production-validator.md +373 -0
  105. package/.claude/agents/typescript-specialist.md +9 -0
  106. package/.claude/agents/v3/adr-architect.md +184 -0
  107. package/.claude/agents/v3/aidefence-guardian.md +282 -0
  108. package/.claude/agents/v3/claims-authorizer.md +208 -0
  109. package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -0
  110. package/.claude/agents/v3/database-specialist.md +9 -0
  111. package/.claude/agents/v3/ddd-domain-expert.md +220 -0
  112. package/.claude/agents/v3/injection-analyst.md +236 -0
  113. package/.claude/agents/v3/memory-specialist.md +995 -0
  114. package/.claude/agents/v3/performance-engineer.md +1233 -0
  115. package/.claude/agents/v3/pii-detector.md +151 -0
  116. package/.claude/agents/v3/project-coordinator.md +8 -0
  117. package/.claude/agents/v3/python-specialist.md +9 -0
  118. package/.claude/agents/v3/reasoningbank-learner.md +213 -0
  119. package/.claude/agents/v3/security-architect-aidefence.md +410 -0
  120. package/.claude/agents/v3/security-architect.md +867 -0
  121. package/.claude/agents/v3/security-auditor.md +771 -0
  122. package/.claude/agents/v3/sparc-orchestrator.md +182 -0
  123. package/.claude/agents/v3/swarm-memory-manager.md +157 -0
  124. package/.claude/agents/v3/test-architect.md +9 -0
  125. package/.claude/agents/v3/typescript-specialist.md +9 -0
  126. package/.claude/agents/v3/v3-integration-architect.md +312 -0
  127. package/.claude/agents/v3/v3-memory-specialist.md +281 -0
  128. package/.claude/agents/v3/v3-performance-engineer.md +363 -0
  129. package/.claude/agents/v3/v3-queen-coordinator.md +63 -0
  130. package/.claude/agents/v3/v3-security-architect.md +140 -0
  131. package/.claude/checkpoints/1767754460.json +8 -0
  132. package/.claude/commands/agents/README.md +10 -0
  133. package/.claude/commands/agents/agent-capabilities.md +21 -0
  134. package/.claude/commands/agents/agent-coordination.md +28 -0
  135. package/.claude/commands/agents/agent-spawning.md +28 -0
  136. package/.claude/commands/agents/agent-types.md +26 -0
  137. package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
  138. package/.claude/commands/analysis/README.md +9 -0
  139. package/.claude/commands/analysis/bottleneck-detect.md +162 -0
  140. package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
  141. package/.claude/commands/analysis/performance-report.md +25 -0
  142. package/.claude/commands/analysis/token-efficiency.md +45 -0
  143. package/.claude/commands/analysis/token-usage.md +25 -0
  144. package/.claude/commands/automation/README.md +9 -0
  145. package/.claude/commands/automation/auto-agent.md +122 -0
  146. package/.claude/commands/automation/self-healing.md +106 -0
  147. package/.claude/commands/automation/session-memory.md +90 -0
  148. package/.claude/commands/automation/smart-agents.md +73 -0
  149. package/.claude/commands/automation/smart-spawn.md +25 -0
  150. package/.claude/commands/automation/workflow-select.md +25 -0
  151. package/.claude/commands/claude-flow-help.md +103 -0
  152. package/.claude/commands/claude-flow-memory.md +107 -0
  153. package/.claude/commands/claude-flow-swarm.md +205 -0
  154. package/.claude/commands/coordination/README.md +9 -0
  155. package/.claude/commands/coordination/agent-spawn.md +25 -0
  156. package/.claude/commands/coordination/init.md +44 -0
  157. package/.claude/commands/coordination/orchestrate.md +43 -0
  158. package/.claude/commands/coordination/spawn.md +45 -0
  159. package/.claude/commands/coordination/swarm-init.md +85 -0
  160. package/.claude/commands/coordination/task-orchestrate.md +25 -0
  161. package/.claude/commands/flow-nexus/app-store.md +124 -0
  162. package/.claude/commands/flow-nexus/challenges.md +120 -0
  163. package/.claude/commands/flow-nexus/login-registration.md +65 -0
  164. package/.claude/commands/flow-nexus/neural-network.md +134 -0
  165. package/.claude/commands/flow-nexus/payments.md +116 -0
  166. package/.claude/commands/flow-nexus/sandbox.md +83 -0
  167. package/.claude/commands/flow-nexus/swarm.md +87 -0
  168. package/.claude/commands/flow-nexus/user-tools.md +152 -0
  169. package/.claude/commands/flow-nexus/workflow.md +115 -0
  170. package/.claude/commands/github/README.md +11 -0
  171. package/.claude/commands/github/code-review-swarm.md +514 -0
  172. package/.claude/commands/github/code-review.md +25 -0
  173. package/.claude/commands/github/github-modes.md +147 -0
  174. package/.claude/commands/github/github-swarm.md +121 -0
  175. package/.claude/commands/github/issue-tracker.md +292 -0
  176. package/.claude/commands/github/issue-triage.md +25 -0
  177. package/.claude/commands/github/multi-repo-swarm.md +519 -0
  178. package/.claude/commands/github/pr-enhance.md +26 -0
  179. package/.claude/commands/github/pr-manager.md +170 -0
  180. package/.claude/commands/github/project-board-sync.md +471 -0
  181. package/.claude/commands/github/release-manager.md +338 -0
  182. package/.claude/commands/github/release-swarm.md +544 -0
  183. package/.claude/commands/github/repo-analyze.md +25 -0
  184. package/.claude/commands/github/repo-architect.md +367 -0
  185. package/.claude/commands/github/swarm-issue.md +482 -0
  186. package/.claude/commands/github/swarm-pr.md +285 -0
  187. package/.claude/commands/github/sync-coordinator.md +301 -0
  188. package/.claude/commands/github/workflow-automation.md +442 -0
  189. package/.claude/commands/hive-mind/README.md +17 -0
  190. package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -0
  191. package/.claude/commands/hive-mind/hive-mind-init.md +18 -0
  192. package/.claude/commands/hive-mind/hive-mind-memory.md +8 -0
  193. package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -0
  194. package/.claude/commands/hive-mind/hive-mind-resume.md +8 -0
  195. package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -0
  196. package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -0
  197. package/.claude/commands/hive-mind/hive-mind-status.md +8 -0
  198. package/.claude/commands/hive-mind/hive-mind-stop.md +8 -0
  199. package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -0
  200. package/.claude/commands/hive-mind/hive-mind.md +27 -0
  201. package/.claude/commands/hooks/README.md +11 -0
  202. package/.claude/commands/hooks/overview.md +58 -0
  203. package/.claude/commands/hooks/post-edit.md +117 -0
  204. package/.claude/commands/hooks/post-task.md +112 -0
  205. package/.claude/commands/hooks/pre-edit.md +113 -0
  206. package/.claude/commands/hooks/pre-task.md +111 -0
  207. package/.claude/commands/hooks/session-end.md +118 -0
  208. package/.claude/commands/hooks/setup.md +103 -0
  209. package/.claude/commands/memory/README.md +9 -0
  210. package/.claude/commands/memory/memory-persist.md +25 -0
  211. package/.claude/commands/memory/memory-search.md +25 -0
  212. package/.claude/commands/memory/memory-usage.md +25 -0
  213. package/.claude/commands/memory/neural.md +47 -0
  214. package/.claude/commands/monitoring/README.md +9 -0
  215. package/.claude/commands/monitoring/agent-metrics.md +25 -0
  216. package/.claude/commands/monitoring/agents.md +44 -0
  217. package/.claude/commands/monitoring/real-time-view.md +25 -0
  218. package/.claude/commands/monitoring/status.md +46 -0
  219. package/.claude/commands/monitoring/swarm-monitor.md +25 -0
  220. package/.claude/commands/optimization/README.md +9 -0
  221. package/.claude/commands/optimization/auto-topology.md +62 -0
  222. package/.claude/commands/optimization/cache-manage.md +25 -0
  223. package/.claude/commands/optimization/parallel-execute.md +25 -0
  224. package/.claude/commands/optimization/parallel-execution.md +50 -0
  225. package/.claude/commands/optimization/topology-optimize.md +25 -0
  226. package/.claude/commands/pair/README.md +261 -0
  227. package/.claude/commands/pair/commands.md +546 -0
  228. package/.claude/commands/pair/config.md +510 -0
  229. package/.claude/commands/pair/examples.md +512 -0
  230. package/.claude/commands/pair/modes.md +348 -0
  231. package/.claude/commands/pair/session.md +407 -0
  232. package/.claude/commands/pair/start.md +209 -0
  233. package/.claude/commands/sparc/analyzer.md +52 -0
  234. package/.claude/commands/sparc/architect.md +53 -0
  235. package/.claude/commands/sparc/ask.md +97 -0
  236. package/.claude/commands/sparc/batch-executor.md +54 -0
  237. package/.claude/commands/sparc/code.md +89 -0
  238. package/.claude/commands/sparc/coder.md +54 -0
  239. package/.claude/commands/sparc/debug.md +83 -0
  240. package/.claude/commands/sparc/debugger.md +54 -0
  241. package/.claude/commands/sparc/designer.md +53 -0
  242. package/.claude/commands/sparc/devops.md +109 -0
  243. package/.claude/commands/sparc/docs-writer.md +80 -0
  244. package/.claude/commands/sparc/documenter.md +54 -0
  245. package/.claude/commands/sparc/innovator.md +54 -0
  246. package/.claude/commands/sparc/integration.md +83 -0
  247. package/.claude/commands/sparc/mcp.md +117 -0
  248. package/.claude/commands/sparc/memory-manager.md +54 -0
  249. package/.claude/commands/sparc/optimizer.md +54 -0
  250. package/.claude/commands/sparc/orchestrator.md +132 -0
  251. package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -0
  252. package/.claude/commands/sparc/refinement-optimization-mode.md +83 -0
  253. package/.claude/commands/sparc/researcher.md +54 -0
  254. package/.claude/commands/sparc/reviewer.md +54 -0
  255. package/.claude/commands/sparc/security-review.md +80 -0
  256. package/.claude/commands/sparc/sparc-modes.md +174 -0
  257. package/.claude/commands/sparc/sparc.md +111 -0
  258. package/.claude/commands/sparc/spec-pseudocode.md +80 -0
  259. package/.claude/commands/sparc/supabase-admin.md +348 -0
  260. package/.claude/commands/sparc/swarm-coordinator.md +54 -0
  261. package/.claude/commands/sparc/tdd.md +54 -0
  262. package/.claude/commands/sparc/tester.md +54 -0
  263. package/.claude/commands/sparc/tutorial.md +79 -0
  264. package/.claude/commands/sparc/workflow-manager.md +54 -0
  265. package/.claude/commands/sparc.md +166 -0
  266. package/.claude/commands/stream-chain/pipeline.md +121 -0
  267. package/.claude/commands/stream-chain/run.md +70 -0
  268. package/.claude/commands/swarm/README.md +15 -0
  269. package/.claude/commands/swarm/analysis.md +95 -0
  270. package/.claude/commands/swarm/development.md +96 -0
  271. package/.claude/commands/swarm/examples.md +168 -0
  272. package/.claude/commands/swarm/maintenance.md +102 -0
  273. package/.claude/commands/swarm/optimization.md +117 -0
  274. package/.claude/commands/swarm/research.md +136 -0
  275. package/.claude/commands/swarm/swarm-analysis.md +8 -0
  276. package/.claude/commands/swarm/swarm-background.md +8 -0
  277. package/.claude/commands/swarm/swarm-init.md +19 -0
  278. package/.claude/commands/swarm/swarm-modes.md +8 -0
  279. package/.claude/commands/swarm/swarm-monitor.md +8 -0
  280. package/.claude/commands/swarm/swarm-spawn.md +19 -0
  281. package/.claude/commands/swarm/swarm-status.md +8 -0
  282. package/.claude/commands/swarm/swarm-strategies.md +8 -0
  283. package/.claude/commands/swarm/swarm.md +27 -0
  284. package/.claude/commands/swarm/testing.md +131 -0
  285. package/.claude/commands/training/README.md +9 -0
  286. package/.claude/commands/training/model-update.md +25 -0
  287. package/.claude/commands/training/neural-patterns.md +74 -0
  288. package/.claude/commands/training/neural-train.md +25 -0
  289. package/.claude/commands/training/pattern-learn.md +25 -0
  290. package/.claude/commands/training/specialization.md +63 -0
  291. package/.claude/commands/truth/start.md +143 -0
  292. package/.claude/commands/verify/check.md +50 -0
  293. package/.claude/commands/verify/start.md +128 -0
  294. package/.claude/commands/workflows/README.md +9 -0
  295. package/.claude/commands/workflows/development.md +78 -0
  296. package/.claude/commands/workflows/research.md +63 -0
  297. package/.claude/commands/workflows/workflow-create.md +25 -0
  298. package/.claude/commands/workflows/workflow-execute.md +25 -0
  299. package/.claude/commands/workflows/workflow-export.md +25 -0
  300. package/.claude/config/v3-dependency-optimization.json +266 -0
  301. package/.claude/config/v3-performance-targets.json +251 -0
  302. package/.claude/helpers/README.md +97 -0
  303. package/.claude/helpers/adr-compliance.sh +186 -0
  304. package/.claude/helpers/aggressive-microcompact.mjs +36 -0
  305. package/.claude/helpers/auto-commit.sh +178 -0
  306. package/.claude/helpers/auto-memory-hook.mjs +564 -0
  307. package/.claude/helpers/checkpoint-manager.sh +251 -0
  308. package/.claude/helpers/context-persistence-hook.mjs +1979 -0
  309. package/.claude/helpers/daemon-manager.sh +252 -0
  310. package/.claude/helpers/ddd-tracker.sh +144 -0
  311. package/.claude/helpers/github-safe.js +106 -0
  312. package/.claude/helpers/github-setup.sh +28 -0
  313. package/.claude/helpers/guidance-hook.sh +13 -0
  314. package/.claude/helpers/guidance-hooks.sh +102 -0
  315. package/.claude/helpers/health-monitor.sh +108 -0
  316. package/.claude/helpers/hook-handler.cjs +269 -0
  317. package/.claude/helpers/intelligence.cjs +230 -0
  318. package/.claude/helpers/learning-hooks.sh +329 -0
  319. package/.claude/helpers/learning-optimizer.sh +127 -0
  320. package/.claude/helpers/learning-service.mjs +1144 -0
  321. package/.claude/helpers/memory.cjs +84 -0
  322. package/.claude/helpers/memory.js +83 -0
  323. package/.claude/helpers/metrics-db.mjs +488 -0
  324. package/.claude/helpers/patch-aggressive-prune.mjs +184 -0
  325. package/.claude/helpers/pattern-consolidator.sh +86 -0
  326. package/.claude/helpers/perf-worker.sh +160 -0
  327. package/.claude/helpers/post-commit +16 -0
  328. package/.claude/helpers/pre-commit +26 -0
  329. package/.claude/helpers/quick-start.sh +19 -0
  330. package/.claude/helpers/router.cjs +62 -0
  331. package/.claude/helpers/router.js +66 -0
  332. package/.claude/helpers/security-scanner.sh +127 -0
  333. package/.claude/helpers/session.cjs +125 -0
  334. package/.claude/helpers/session.js +135 -0
  335. package/.claude/helpers/setup-mcp.sh +18 -0
  336. package/.claude/helpers/standard-checkpoint-hooks.sh +189 -0
  337. package/.claude/helpers/statusline-hook.sh +21 -0
  338. package/.claude/helpers/statusline.cjs +878 -0
  339. package/.claude/helpers/statusline.js +352 -0
  340. package/.claude/helpers/swarm-comms.sh +353 -0
  341. package/.claude/helpers/swarm-hooks.sh +761 -0
  342. package/.claude/helpers/swarm-monitor.sh +211 -0
  343. package/.claude/helpers/sync-v3-metrics.sh +245 -0
  344. package/.claude/helpers/update-v3-progress.sh +166 -0
  345. package/.claude/helpers/v3-quick-status.sh +58 -0
  346. package/.claude/helpers/v3.sh +111 -0
  347. package/.claude/helpers/validate-v3-config.sh +216 -0
  348. package/.claude/helpers/worker-manager.sh +170 -0
  349. package/.claude/mcp.json +13 -0
  350. package/.claude/scheduled_tasks.lock +1 -0
  351. package/.claude/settings.json +285 -0
  352. package/.claude/settings.json.bak +526 -0
  353. package/.claude/skills/agentdb-advanced/SKILL.md +550 -0
  354. package/.claude/skills/agentdb-learning/SKILL.md +545 -0
  355. package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -0
  356. package/.claude/skills/agentdb-optimization/SKILL.md +509 -0
  357. package/.claude/skills/agentdb-vector-search/SKILL.md +339 -0
  358. package/.claude/skills/agentic-jujutsu/SKILL.md +645 -0
  359. package/.claude/skills/browser/SKILL.md +204 -0
  360. package/.claude/skills/dual-mode/README.md +71 -0
  361. package/.claude/skills/dual-mode/dual-collect.md +103 -0
  362. package/.claude/skills/dual-mode/dual-coordinate.md +85 -0
  363. package/.claude/skills/dual-mode/dual-spawn.md +81 -0
  364. package/.claude/skills/flow-nexus-neural/SKILL.md +727 -0
  365. package/.claude/skills/flow-nexus-platform/SKILL.md +1154 -0
  366. package/.claude/skills/flow-nexus-swarm/SKILL.md +604 -0
  367. package/.claude/skills/github-code-review/SKILL.md +1125 -0
  368. package/.claude/skills/github-multi-repo/SKILL.md +862 -0
  369. package/.claude/skills/github-project-management/SKILL.md +1263 -0
  370. package/.claude/skills/github-release-management/SKILL.md +1064 -0
  371. package/.claude/skills/github-workflow-automation/SKILL.md +1047 -0
  372. package/.claude/skills/hive-mind-advanced/SKILL.md +709 -0
  373. package/.claude/skills/hooks-automation/SKILL.md +1201 -0
  374. package/.claude/skills/pair-programming/SKILL.md +1202 -0
  375. package/.claude/skills/performance-analysis/SKILL.md +560 -0
  376. package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -0
  377. package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
  378. package/.claude/skills/skill-builder/SKILL.md +910 -0
  379. package/.claude/skills/sparc-methodology/SKILL.md +1106 -0
  380. package/.claude/skills/stream-chain/SKILL.md +560 -0
  381. package/.claude/skills/swarm-advanced/SKILL.md +970 -0
  382. package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
  383. package/.claude/skills/v3-cli-modernization/SKILL.md +872 -0
  384. package/.claude/skills/v3-core-implementation/SKILL.md +797 -0
  385. package/.claude/skills/v3-ddd-architecture/SKILL.md +442 -0
  386. package/.claude/skills/v3-integration-deep/SKILL.md +241 -0
  387. package/.claude/skills/v3-mcp-optimization/SKILL.md +777 -0
  388. package/.claude/skills/v3-memory-unification/SKILL.md +174 -0
  389. package/.claude/skills/v3-performance-optimization/SKILL.md +390 -0
  390. package/.claude/skills/v3-security-overhaul/SKILL.md +82 -0
  391. package/.claude/skills/v3-swarm-coordination/SKILL.md +340 -0
  392. package/.claude/skills/verification-quality/SKILL.md +691 -0
  393. package/.claude/skills/worker-benchmarks/SKILL.md +129 -0
  394. package/.claude/skills/worker-integration/SKILL.md +147 -0
  395. package/.claude/statusline-command.sh +176 -0
  396. package/.claude/statusline.mjs +109 -0
  397. package/.claude/statusline.sh +431 -0
  398. package/.claude-plugin/README.md +720 -0
  399. package/.claude-plugin/docs/INSTALLATION.md +261 -0
  400. package/.claude-plugin/docs/PLUGIN_SUMMARY.md +361 -0
  401. package/.claude-plugin/docs/QUICKSTART.md +361 -0
  402. package/.claude-plugin/docs/STRUCTURE.md +128 -0
  403. package/.claude-plugin/hooks/hooks.json +75 -0
  404. package/.claude-plugin/marketplace.json +170 -0
  405. package/.claude-plugin/plugin.json +71 -0
  406. package/.claude-plugin/scripts/install.sh +234 -0
  407. package/.claude-plugin/scripts/ruflo-hook.sh +33 -0
  408. package/.claude-plugin/scripts/uninstall.sh +36 -0
  409. package/.claude-plugin/scripts/verify.sh +108 -0
  410. package/LICENSE +21 -0
  411. package/README.md +410 -0
  412. package/bin/cli.js +11 -0
  413. package/bin/npx-repair.js +7 -0
  414. package/bin/npx-safe-launch.js +9 -0
  415. package/package.json +159 -0
  416. package/v3/@claude-flow/cli/README.md +410 -0
  417. package/v3/@claude-flow/cli/bin/cli.js +233 -0
  418. package/v3/@claude-flow/cli/bin/mcp-server.js +224 -0
  419. package/v3/@claude-flow/cli/bin/preinstall.cjs +2 -0
  420. package/v3/@claude-flow/cli/dist/src/appliance/gguf-engine.d.ts +91 -0
  421. package/v3/@claude-flow/cli/dist/src/appliance/gguf-engine.js +425 -0
  422. package/v3/@claude-flow/cli/dist/src/appliance/ruvllm-bridge.d.ts +102 -0
  423. package/v3/@claude-flow/cli/dist/src/appliance/ruvllm-bridge.js +292 -0
  424. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-builder.d.ts +44 -0
  425. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-builder.js +329 -0
  426. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-distribution.d.ts +97 -0
  427. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-distribution.js +370 -0
  428. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-format.d.ts +111 -0
  429. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-format.js +393 -0
  430. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-runner.d.ts +69 -0
  431. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-runner.js +237 -0
  432. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-signing.d.ts +123 -0
  433. package/v3/@claude-flow/cli/dist/src/appliance/rvfa-signing.js +347 -0
  434. package/v3/@claude-flow/cli/dist/src/autopilot-state.d.ts +77 -0
  435. package/v3/@claude-flow/cli/dist/src/autopilot-state.js +271 -0
  436. package/v3/@claude-flow/cli/dist/src/benchmarks/pretrain/index.d.ts +58 -0
  437. package/v3/@claude-flow/cli/dist/src/benchmarks/pretrain/index.js +404 -0
  438. package/v3/@claude-flow/cli/dist/src/commands/agent-wasm.d.ts +14 -0
  439. package/v3/@claude-flow/cli/dist/src/commands/agent-wasm.js +333 -0
  440. package/v3/@claude-flow/cli/dist/src/commands/agent.d.ts +8 -0
  441. package/v3/@claude-flow/cli/dist/src/commands/agent.js +927 -0
  442. package/v3/@claude-flow/cli/dist/src/commands/analyze.d.ts +19 -0
  443. package/v3/@claude-flow/cli/dist/src/commands/analyze.js +2048 -0
  444. package/v3/@claude-flow/cli/dist/src/commands/appliance-advanced.d.ts +9 -0
  445. package/v3/@claude-flow/cli/dist/src/commands/appliance-advanced.js +215 -0
  446. package/v3/@claude-flow/cli/dist/src/commands/appliance.d.ts +8 -0
  447. package/v3/@claude-flow/cli/dist/src/commands/appliance.js +404 -0
  448. package/v3/@claude-flow/cli/dist/src/commands/autopilot.d.ts +15 -0
  449. package/v3/@claude-flow/cli/dist/src/commands/autopilot.js +362 -0
  450. package/v3/@claude-flow/cli/dist/src/commands/benchmark.d.ts +10 -0
  451. package/v3/@claude-flow/cli/dist/src/commands/benchmark.js +460 -0
  452. package/v3/@claude-flow/cli/dist/src/commands/claims.d.ts +10 -0
  453. package/v3/@claude-flow/cli/dist/src/commands/claims.js +620 -0
  454. package/v3/@claude-flow/cli/dist/src/commands/cleanup.d.ts +13 -0
  455. package/v3/@claude-flow/cli/dist/src/commands/cleanup.js +250 -0
  456. package/v3/@claude-flow/cli/dist/src/commands/completions.d.ts +10 -0
  457. package/v3/@claude-flow/cli/dist/src/commands/completions.js +539 -0
  458. package/v3/@claude-flow/cli/dist/src/commands/config.d.ts +8 -0
  459. package/v3/@claude-flow/cli/dist/src/commands/config.js +430 -0
  460. package/v3/@claude-flow/cli/dist/src/commands/daemon.d.ts +28 -0
  461. package/v3/@claude-flow/cli/dist/src/commands/daemon.js +1093 -0
  462. package/v3/@claude-flow/cli/dist/src/commands/deployment.d.ts +10 -0
  463. package/v3/@claude-flow/cli/dist/src/commands/deployment.js +672 -0
  464. package/v3/@claude-flow/cli/dist/src/commands/doctor.d.ts +10 -0
  465. package/v3/@claude-flow/cli/dist/src/commands/doctor.js +885 -0
  466. package/v3/@claude-flow/cli/dist/src/commands/embeddings.d.ts +18 -0
  467. package/v3/@claude-flow/cli/dist/src/commands/embeddings.js +1623 -0
  468. package/v3/@claude-flow/cli/dist/src/commands/guidance.d.ts +8 -0
  469. package/v3/@claude-flow/cli/dist/src/commands/guidance.js +556 -0
  470. package/v3/@claude-flow/cli/dist/src/commands/hive-mind.d.ts +11 -0
  471. package/v3/@claude-flow/cli/dist/src/commands/hive-mind.js +1297 -0
  472. package/v3/@claude-flow/cli/dist/src/commands/hooks.d.ts +8 -0
  473. package/v3/@claude-flow/cli/dist/src/commands/hooks.js +4499 -0
  474. package/v3/@claude-flow/cli/dist/src/commands/index.d.ts +118 -0
  475. package/v3/@claude-flow/cli/dist/src/commands/index.js +344 -0
  476. package/v3/@claude-flow/cli/dist/src/commands/init.d.ts +8 -0
  477. package/v3/@claude-flow/cli/dist/src/commands/init.js +997 -0
  478. package/v3/@claude-flow/cli/dist/src/commands/issues.d.ts +21 -0
  479. package/v3/@claude-flow/cli/dist/src/commands/issues.js +567 -0
  480. package/v3/@claude-flow/cli/dist/src/commands/mcp.d.ts +11 -0
  481. package/v3/@claude-flow/cli/dist/src/commands/mcp.js +718 -0
  482. package/v3/@claude-flow/cli/dist/src/commands/memory.d.ts +8 -0
  483. package/v3/@claude-flow/cli/dist/src/commands/memory.js +1456 -0
  484. package/v3/@claude-flow/cli/dist/src/commands/migrate.d.ts +8 -0
  485. package/v3/@claude-flow/cli/dist/src/commands/migrate.js +742 -0
  486. package/v3/@claude-flow/cli/dist/src/commands/neural.d.ts +10 -0
  487. package/v3/@claude-flow/cli/dist/src/commands/neural.js +1531 -0
  488. package/v3/@claude-flow/cli/dist/src/commands/performance.d.ts +10 -0
  489. package/v3/@claude-flow/cli/dist/src/commands/performance.js +583 -0
  490. package/v3/@claude-flow/cli/dist/src/commands/plugins.d.ts +11 -0
  491. package/v3/@claude-flow/cli/dist/src/commands/plugins.js +826 -0
  492. package/v3/@claude-flow/cli/dist/src/commands/process.d.ts +10 -0
  493. package/v3/@claude-flow/cli/dist/src/commands/process.js +694 -0
  494. package/v3/@claude-flow/cli/dist/src/commands/progress.d.ts +11 -0
  495. package/v3/@claude-flow/cli/dist/src/commands/progress.js +259 -0
  496. package/v3/@claude-flow/cli/dist/src/commands/providers.d.ts +10 -0
  497. package/v3/@claude-flow/cli/dist/src/commands/providers.js +502 -0
  498. package/v3/@claude-flow/cli/dist/src/commands/route.d.ts +16 -0
  499. package/v3/@claude-flow/cli/dist/src/commands/route.js +813 -0
  500. package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.d.ts +11 -0
  501. package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.js +747 -0
  502. package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.d.ts +11 -0
  503. package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.js +490 -0
  504. package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.d.ts +18 -0
  505. package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.js +373 -0
  506. package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.d.ts +29 -0
  507. package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.js +129 -0
  508. package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.d.ts +11 -0
  509. package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.js +467 -0
  510. package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.d.ts +11 -0
  511. package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.js +498 -0
  512. package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.d.ts +11 -0
  513. package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.js +505 -0
  514. package/v3/@claude-flow/cli/dist/src/commands/ruvector/pg-utils.d.ts +14 -0
  515. package/v3/@claude-flow/cli/dist/src/commands/ruvector/pg-utils.js +41 -0
  516. package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.d.ts +18 -0
  517. package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.js +765 -0
  518. package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.d.ts +11 -0
  519. package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.js +479 -0
  520. package/v3/@claude-flow/cli/dist/src/commands/security.d.ts +10 -0
  521. package/v3/@claude-flow/cli/dist/src/commands/security.js +920 -0
  522. package/v3/@claude-flow/cli/dist/src/commands/session.d.ts +8 -0
  523. package/v3/@claude-flow/cli/dist/src/commands/session.js +757 -0
  524. package/v3/@claude-flow/cli/dist/src/commands/start.d.ts +8 -0
  525. package/v3/@claude-flow/cli/dist/src/commands/start.js +418 -0
  526. package/v3/@claude-flow/cli/dist/src/commands/status.d.ts +8 -0
  527. package/v3/@claude-flow/cli/dist/src/commands/status.js +591 -0
  528. package/v3/@claude-flow/cli/dist/src/commands/swarm.d.ts +8 -0
  529. package/v3/@claude-flow/cli/dist/src/commands/swarm.js +887 -0
  530. package/v3/@claude-flow/cli/dist/src/commands/task.d.ts +8 -0
  531. package/v3/@claude-flow/cli/dist/src/commands/task.js +675 -0
  532. package/v3/@claude-flow/cli/dist/src/commands/transfer-store.d.ts +13 -0
  533. package/v3/@claude-flow/cli/dist/src/commands/transfer-store.js +428 -0
  534. package/v3/@claude-flow/cli/dist/src/commands/update.d.ts +8 -0
  535. package/v3/@claude-flow/cli/dist/src/commands/update.js +276 -0
  536. package/v3/@claude-flow/cli/dist/src/commands/verify.d.ts +19 -0
  537. package/v3/@claude-flow/cli/dist/src/commands/verify.js +261 -0
  538. package/v3/@claude-flow/cli/dist/src/commands/workflow.d.ts +8 -0
  539. package/v3/@claude-flow/cli/dist/src/commands/workflow.js +617 -0
  540. package/v3/@claude-flow/cli/dist/src/config-adapter.d.ts +15 -0
  541. package/v3/@claude-flow/cli/dist/src/config-adapter.js +186 -0
  542. package/v3/@claude-flow/cli/dist/src/encryption/vault.d.ts +94 -0
  543. package/v3/@claude-flow/cli/dist/src/encryption/vault.js +172 -0
  544. package/v3/@claude-flow/cli/dist/src/fs-secure.d.ts +67 -0
  545. package/v3/@claude-flow/cli/dist/src/fs-secure.js +74 -0
  546. package/v3/@claude-flow/cli/dist/src/index.d.ts +81 -0
  547. package/v3/@claude-flow/cli/dist/src/index.js +538 -0
  548. package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.d.ts +68 -0
  549. package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.js +264 -0
  550. package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts +16 -0
  551. package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.js +363 -0
  552. package/v3/@claude-flow/cli/dist/src/init/executor.d.ts +41 -0
  553. package/v3/@claude-flow/cli/dist/src/init/executor.js +1904 -0
  554. package/v3/@claude-flow/cli/dist/src/init/helpers-generator.d.ts +60 -0
  555. package/v3/@claude-flow/cli/dist/src/init/helpers-generator.js +1185 -0
  556. package/v3/@claude-flow/cli/dist/src/init/index.d.ts +13 -0
  557. package/v3/@claude-flow/cli/dist/src/init/index.js +15 -0
  558. package/v3/@claude-flow/cli/dist/src/init/mcp-generator.d.ts +26 -0
  559. package/v3/@claude-flow/cli/dist/src/init/mcp-generator.js +116 -0
  560. package/v3/@claude-flow/cli/dist/src/init/settings-generator.d.ts +14 -0
  561. package/v3/@claude-flow/cli/dist/src/init/settings-generator.js +456 -0
  562. package/v3/@claude-flow/cli/dist/src/init/statusline-generator.d.ts +28 -0
  563. package/v3/@claude-flow/cli/dist/src/init/statusline-generator.js +937 -0
  564. package/v3/@claude-flow/cli/dist/src/init/types.d.ts +308 -0
  565. package/v3/@claude-flow/cli/dist/src/init/types.js +263 -0
  566. package/v3/@claude-flow/cli/dist/src/log-filters.d.ts +22 -0
  567. package/v3/@claude-flow/cli/dist/src/log-filters.js +36 -0
  568. package/v3/@claude-flow/cli/dist/src/mcp-client.d.ts +92 -0
  569. package/v3/@claude-flow/cli/dist/src/mcp-client.js +287 -0
  570. package/v3/@claude-flow/cli/dist/src/mcp-server.d.ts +163 -0
  571. package/v3/@claude-flow/cli/dist/src/mcp-server.js +732 -0
  572. package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-execute-core.d.ts +92 -0
  573. package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-execute-core.js +328 -0
  574. package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.d.ts +9 -0
  575. package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.js +716 -0
  576. package/v3/@claude-flow/cli/dist/src/mcp-tools/agentdb-tools.d.ts +33 -0
  577. package/v3/@claude-flow/cli/dist/src/mcp-tools/agentdb-tools.js +867 -0
  578. package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
  579. package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.js +346 -0
  580. package/v3/@claude-flow/cli/dist/src/mcp-tools/auto-install.d.ts +83 -0
  581. package/v3/@claude-flow/cli/dist/src/mcp-tools/auto-install.js +131 -0
  582. package/v3/@claude-flow/cli/dist/src/mcp-tools/autopilot-tools.d.ts +12 -0
  583. package/v3/@claude-flow/cli/dist/src/mcp-tools/autopilot-tools.js +231 -0
  584. package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-session-tools.d.ts +23 -0
  585. package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-session-tools.js +324 -0
  586. package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-tools.d.ts +13 -0
  587. package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-tools.js +757 -0
  588. package/v3/@claude-flow/cli/dist/src/mcp-tools/claims-tools.d.ts +12 -0
  589. package/v3/@claude-flow/cli/dist/src/mcp-tools/claims-tools.js +863 -0
  590. package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.d.ts +8 -0
  591. package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.js +411 -0
  592. package/v3/@claude-flow/cli/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
  593. package/v3/@claude-flow/cli/dist/src/mcp-tools/coordination-tools.js +729 -0
  594. package/v3/@claude-flow/cli/dist/src/mcp-tools/daa-tools.d.ts +13 -0
  595. package/v3/@claude-flow/cli/dist/src/mcp-tools/daa-tools.js +534 -0
  596. package/v3/@claude-flow/cli/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
  597. package/v3/@claude-flow/cli/dist/src/mcp-tools/embeddings-tools.js +904 -0
  598. package/v3/@claude-flow/cli/dist/src/mcp-tools/github-tools.d.ts +9 -0
  599. package/v3/@claude-flow/cli/dist/src/mcp-tools/github-tools.js +659 -0
  600. package/v3/@claude-flow/cli/dist/src/mcp-tools/guidance-tools.d.ts +15 -0
  601. package/v3/@claude-flow/cli/dist/src/mcp-tools/guidance-tools.js +639 -0
  602. package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
  603. package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.js +953 -0
  604. package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.d.ts +46 -0
  605. package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js +3939 -0
  606. package/v3/@claude-flow/cli/dist/src/mcp-tools/index.d.ts +27 -0
  607. package/v3/@claude-flow/cli/dist/src/mcp-tools/index.js +26 -0
  608. package/v3/@claude-flow/cli/dist/src/mcp-tools/managed-agent-tools.d.ts +22 -0
  609. package/v3/@claude-flow/cli/dist/src/mcp-tools/managed-agent-tools.js +357 -0
  610. package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.d.ts +14 -0
  611. package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.js +1240 -0
  612. package/v3/@claude-flow/cli/dist/src/mcp-tools/neural-tools.d.ts +16 -0
  613. package/v3/@claude-flow/cli/dist/src/mcp-tools/neural-tools.js +793 -0
  614. package/v3/@claude-flow/cli/dist/src/mcp-tools/performance-tools.d.ts +16 -0
  615. package/v3/@claude-flow/cli/dist/src/mcp-tools/performance-tools.js +675 -0
  616. package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.d.ts +14 -0
  617. package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.js +348 -0
  618. package/v3/@claude-flow/cli/dist/src/mcp-tools/request-tracker.d.ts +17 -0
  619. package/v3/@claude-flow/cli/dist/src/mcp-tools/request-tracker.js +27 -0
  620. package/v3/@claude-flow/cli/dist/src/mcp-tools/ruvllm-tools.d.ts +9 -0
  621. package/v3/@claude-flow/cli/dist/src/mcp-tools/ruvllm-tools.js +339 -0
  622. package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.d.ts +18 -0
  623. package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.js +556 -0
  624. package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.d.ts +8 -0
  625. package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.js +517 -0
  626. package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.d.ts +9 -0
  627. package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.js +388 -0
  628. package/v3/@claude-flow/cli/dist/src/mcp-tools/system-tools.d.ts +13 -0
  629. package/v3/@claude-flow/cli/dist/src/mcp-tools/system-tools.js +674 -0
  630. package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.d.ts +8 -0
  631. package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.js +487 -0
  632. package/v3/@claude-flow/cli/dist/src/mcp-tools/terminal-tools.d.ts +8 -0
  633. package/v3/@claude-flow/cli/dist/src/mcp-tools/terminal-tools.js +306 -0
  634. package/v3/@claude-flow/cli/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
  635. package/v3/@claude-flow/cli/dist/src/mcp-tools/transfer-tools.js +447 -0
  636. package/v3/@claude-flow/cli/dist/src/mcp-tools/types.d.ts +8 -0
  637. package/v3/@claude-flow/cli/dist/src/mcp-tools/types.js +8 -0
  638. package/v3/@claude-flow/cli/dist/src/mcp-tools/validate-input.d.ts +9 -0
  639. package/v3/@claude-flow/cli/dist/src/mcp-tools/validate-input.js +9 -0
  640. package/v3/@claude-flow/cli/dist/src/mcp-tools/wasm-agent-tools.d.ts +9 -0
  641. package/v3/@claude-flow/cli/dist/src/mcp-tools/wasm-agent-tools.js +291 -0
  642. package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
  643. package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.js +884 -0
  644. package/v3/@claude-flow/cli/dist/src/memory/ewc-consolidation.d.ts +295 -0
  645. package/v3/@claude-flow/cli/dist/src/memory/ewc-consolidation.js +601 -0
  646. package/v3/@claude-flow/cli/dist/src/memory/intelligence.d.ts +357 -0
  647. package/v3/@claude-flow/cli/dist/src/memory/intelligence.js +1200 -0
  648. package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.d.ts +492 -0
  649. package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.js +2101 -0
  650. package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.d.ts +420 -0
  651. package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.js +2376 -0
  652. package/v3/@claude-flow/cli/dist/src/memory/neural-package-bridge.d.ts +48 -0
  653. package/v3/@claude-flow/cli/dist/src/memory/neural-package-bridge.js +87 -0
  654. package/v3/@claude-flow/cli/dist/src/memory/rabitq-index.d.ts +60 -0
  655. package/v3/@claude-flow/cli/dist/src/memory/rabitq-index.js +242 -0
  656. package/v3/@claude-flow/cli/dist/src/memory/sona-optimizer.d.ts +267 -0
  657. package/v3/@claude-flow/cli/dist/src/memory/sona-optimizer.js +779 -0
  658. package/v3/@claude-flow/cli/dist/src/output.d.ts +9 -0
  659. package/v3/@claude-flow/cli/dist/src/output.js +9 -0
  660. package/v3/@claude-flow/cli/dist/src/parser.d.ts +69 -0
  661. package/v3/@claude-flow/cli/dist/src/parser.js +473 -0
  662. package/v3/@claude-flow/cli/dist/src/plugins/manager.d.ts +133 -0
  663. package/v3/@claude-flow/cli/dist/src/plugins/manager.js +402 -0
  664. package/v3/@claude-flow/cli/dist/src/plugins/store/discovery.d.ts +91 -0
  665. package/v3/@claude-flow/cli/dist/src/plugins/store/discovery.js +1202 -0
  666. package/v3/@claude-flow/cli/dist/src/plugins/store/index.d.ts +76 -0
  667. package/v3/@claude-flow/cli/dist/src/plugins/store/index.js +141 -0
  668. package/v3/@claude-flow/cli/dist/src/plugins/store/search.d.ts +46 -0
  669. package/v3/@claude-flow/cli/dist/src/plugins/store/search.js +230 -0
  670. package/v3/@claude-flow/cli/dist/src/plugins/store/types.d.ts +274 -0
  671. package/v3/@claude-flow/cli/dist/src/plugins/store/types.js +7 -0
  672. package/v3/@claude-flow/cli/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
  673. package/v3/@claude-flow/cli/dist/src/plugins/tests/demo-plugin-store.js +126 -0
  674. package/v3/@claude-flow/cli/dist/src/plugins/tests/standalone-test.d.ts +12 -0
  675. package/v3/@claude-flow/cli/dist/src/plugins/tests/standalone-test.js +188 -0
  676. package/v3/@claude-flow/cli/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
  677. package/v3/@claude-flow/cli/dist/src/plugins/tests/test-plugin-store.js +206 -0
  678. package/v3/@claude-flow/cli/dist/src/production/circuit-breaker.d.ts +101 -0
  679. package/v3/@claude-flow/cli/dist/src/production/circuit-breaker.js +241 -0
  680. package/v3/@claude-flow/cli/dist/src/production/error-handler.d.ts +92 -0
  681. package/v3/@claude-flow/cli/dist/src/production/error-handler.js +299 -0
  682. package/v3/@claude-flow/cli/dist/src/production/index.d.ts +23 -0
  683. package/v3/@claude-flow/cli/dist/src/production/index.js +18 -0
  684. package/v3/@claude-flow/cli/dist/src/production/monitoring.d.ts +161 -0
  685. package/v3/@claude-flow/cli/dist/src/production/monitoring.js +356 -0
  686. package/v3/@claude-flow/cli/dist/src/production/rate-limiter.d.ts +80 -0
  687. package/v3/@claude-flow/cli/dist/src/production/rate-limiter.js +201 -0
  688. package/v3/@claude-flow/cli/dist/src/production/retry.d.ts +48 -0
  689. package/v3/@claude-flow/cli/dist/src/production/retry.js +179 -0
  690. package/v3/@claude-flow/cli/dist/src/prompt.d.ts +44 -0
  691. package/v3/@claude-flow/cli/dist/src/prompt.js +501 -0
  692. package/v3/@claude-flow/cli/dist/src/runtime/headless.d.ts +60 -0
  693. package/v3/@claude-flow/cli/dist/src/runtime/headless.js +284 -0
  694. package/v3/@claude-flow/cli/dist/src/ruvector/agent-wasm.d.ts +193 -0
  695. package/v3/@claude-flow/cli/dist/src/ruvector/agent-wasm.js +354 -0
  696. package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.d.ts +67 -0
  697. package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.js +277 -0
  698. package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.d.ts +160 -0
  699. package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.js +531 -0
  700. package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.d.ts +33 -0
  701. package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.js +157 -0
  702. package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.d.ts +175 -0
  703. package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.js +699 -0
  704. package/v3/@claude-flow/cli/dist/src/ruvector/diskann-backend.d.ts +78 -0
  705. package/v3/@claude-flow/cli/dist/src/ruvector/diskann-backend.js +310 -0
  706. package/v3/@claude-flow/cli/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
  707. package/v3/@claude-flow/cli/dist/src/ruvector/enhanced-model-router.js +529 -0
  708. package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.d.ts +187 -0
  709. package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.js +929 -0
  710. package/v3/@claude-flow/cli/dist/src/ruvector/graph-backend.d.ts +79 -0
  711. package/v3/@claude-flow/cli/dist/src/ruvector/graph-backend.js +220 -0
  712. package/v3/@claude-flow/cli/dist/src/ruvector/index.d.ts +38 -0
  713. package/v3/@claude-flow/cli/dist/src/ruvector/index.js +82 -0
  714. package/v3/@claude-flow/cli/dist/src/ruvector/lora-adapter.d.ts +240 -0
  715. package/v3/@claude-flow/cli/dist/src/ruvector/lora-adapter.js +550 -0
  716. package/v3/@claude-flow/cli/dist/src/ruvector/model-router.d.ts +241 -0
  717. package/v3/@claude-flow/cli/dist/src/ruvector/model-router.js +608 -0
  718. package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.d.ts +211 -0
  719. package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.js +681 -0
  720. package/v3/@claude-flow/cli/dist/src/ruvector/ruvllm-wasm.d.ts +179 -0
  721. package/v3/@claude-flow/cli/dist/src/ruvector/ruvllm-wasm.js +367 -0
  722. package/v3/@claude-flow/cli/dist/src/ruvector/semantic-router.d.ts +77 -0
  723. package/v3/@claude-flow/cli/dist/src/ruvector/semantic-router.js +178 -0
  724. package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.d.ts +73 -0
  725. package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.js +264 -0
  726. package/v3/@claude-flow/cli/dist/src/services/agentic-flow-bridge.d.ts +50 -0
  727. package/v3/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +95 -0
  728. package/v3/@claude-flow/cli/dist/src/services/claim-service.d.ts +204 -0
  729. package/v3/@claude-flow/cli/dist/src/services/claim-service.js +818 -0
  730. package/v3/@claude-flow/cli/dist/src/services/config-file-manager.d.ts +37 -0
  731. package/v3/@claude-flow/cli/dist/src/services/config-file-manager.js +233 -0
  732. package/v3/@claude-flow/cli/dist/src/services/container-worker-pool.d.ts +197 -0
  733. package/v3/@claude-flow/cli/dist/src/services/container-worker-pool.js +583 -0
  734. package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.d.ts +310 -0
  735. package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.js +1058 -0
  736. package/v3/@claude-flow/cli/dist/src/services/index.d.ts +13 -0
  737. package/v3/@claude-flow/cli/dist/src/services/index.js +11 -0
  738. package/v3/@claude-flow/cli/dist/src/services/registry-api.d.ts +58 -0
  739. package/v3/@claude-flow/cli/dist/src/services/registry-api.js +146 -0
  740. package/v3/@claude-flow/cli/dist/src/services/ruvector-training.d.ts +222 -0
  741. package/v3/@claude-flow/cli/dist/src/services/ruvector-training.js +688 -0
  742. package/v3/@claude-flow/cli/dist/src/services/worker-daemon.d.ts +323 -0
  743. package/v3/@claude-flow/cli/dist/src/services/worker-daemon.js +1323 -0
  744. package/v3/@claude-flow/cli/dist/src/services/worker-queue.d.ts +194 -0
  745. package/v3/@claude-flow/cli/dist/src/services/worker-queue.js +513 -0
  746. package/v3/@claude-flow/cli/dist/src/suggest.d.ts +53 -0
  747. package/v3/@claude-flow/cli/dist/src/suggest.js +200 -0
  748. package/v3/@claude-flow/cli/dist/src/transfer/anonymization/index.d.ts +25 -0
  749. package/v3/@claude-flow/cli/dist/src/transfer/anonymization/index.js +175 -0
  750. package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.d.ts +13 -0
  751. package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.js +205 -0
  752. package/v3/@claude-flow/cli/dist/src/transfer/export.d.ts +25 -0
  753. package/v3/@claude-flow/cli/dist/src/transfer/export.js +113 -0
  754. package/v3/@claude-flow/cli/dist/src/transfer/index.d.ts +12 -0
  755. package/v3/@claude-flow/cli/dist/src/transfer/index.js +31 -0
  756. package/v3/@claude-flow/cli/dist/src/transfer/ipfs/client.d.ts +109 -0
  757. package/v3/@claude-flow/cli/dist/src/transfer/ipfs/client.js +307 -0
  758. package/v3/@claude-flow/cli/dist/src/transfer/ipfs/upload.d.ts +95 -0
  759. package/v3/@claude-flow/cli/dist/src/transfer/ipfs/upload.js +413 -0
  760. package/v3/@claude-flow/cli/dist/src/transfer/models/seraphine.d.ts +72 -0
  761. package/v3/@claude-flow/cli/dist/src/transfer/models/seraphine.js +373 -0
  762. package/v3/@claude-flow/cli/dist/src/transfer/serialization/cfp.d.ts +49 -0
  763. package/v3/@claude-flow/cli/dist/src/transfer/serialization/cfp.js +183 -0
  764. package/v3/@claude-flow/cli/dist/src/transfer/storage/gcs.d.ts +82 -0
  765. package/v3/@claude-flow/cli/dist/src/transfer/storage/gcs.js +272 -0
  766. package/v3/@claude-flow/cli/dist/src/transfer/storage/index.d.ts +6 -0
  767. package/v3/@claude-flow/cli/dist/src/transfer/storage/index.js +6 -0
  768. package/v3/@claude-flow/cli/dist/src/transfer/store/discovery.d.ts +84 -0
  769. package/v3/@claude-flow/cli/dist/src/transfer/store/discovery.js +382 -0
  770. package/v3/@claude-flow/cli/dist/src/transfer/store/download.d.ts +70 -0
  771. package/v3/@claude-flow/cli/dist/src/transfer/store/download.js +334 -0
  772. package/v3/@claude-flow/cli/dist/src/transfer/store/index.d.ts +84 -0
  773. package/v3/@claude-flow/cli/dist/src/transfer/store/index.js +153 -0
  774. package/v3/@claude-flow/cli/dist/src/transfer/store/publish.d.ts +76 -0
  775. package/v3/@claude-flow/cli/dist/src/transfer/store/publish.js +294 -0
  776. package/v3/@claude-flow/cli/dist/src/transfer/store/registry.d.ts +58 -0
  777. package/v3/@claude-flow/cli/dist/src/transfer/store/registry.js +285 -0
  778. package/v3/@claude-flow/cli/dist/src/transfer/store/search.d.ts +54 -0
  779. package/v3/@claude-flow/cli/dist/src/transfer/store/search.js +232 -0
  780. package/v3/@claude-flow/cli/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
  781. package/v3/@claude-flow/cli/dist/src/transfer/store/tests/standalone-test.js +190 -0
  782. package/v3/@claude-flow/cli/dist/src/transfer/store/types.d.ts +193 -0
  783. package/v3/@claude-flow/cli/dist/src/transfer/store/types.js +6 -0
  784. package/v3/@claude-flow/cli/dist/src/transfer/test-seraphine.d.ts +6 -0
  785. package/v3/@claude-flow/cli/dist/src/transfer/test-seraphine.js +105 -0
  786. package/v3/@claude-flow/cli/dist/src/transfer/tests/test-store.d.ts +7 -0
  787. package/v3/@claude-flow/cli/dist/src/transfer/tests/test-store.js +214 -0
  788. package/v3/@claude-flow/cli/dist/src/transfer/types.d.ts +245 -0
  789. package/v3/@claude-flow/cli/dist/src/transfer/types.js +6 -0
  790. package/v3/@claude-flow/cli/dist/src/types.d.ts +13 -0
  791. package/v3/@claude-flow/cli/dist/src/types.js +13 -0
  792. package/v3/@claude-flow/cli/dist/src/update/checker.d.ts +34 -0
  793. package/v3/@claude-flow/cli/dist/src/update/checker.js +191 -0
  794. package/v3/@claude-flow/cli/dist/src/update/executor.d.ts +33 -0
  795. package/v3/@claude-flow/cli/dist/src/update/executor.js +217 -0
  796. package/v3/@claude-flow/cli/dist/src/update/index.d.ts +33 -0
  797. package/v3/@claude-flow/cli/dist/src/update/index.js +64 -0
  798. package/v3/@claude-flow/cli/dist/src/update/rate-limiter.d.ts +20 -0
  799. package/v3/@claude-flow/cli/dist/src/update/rate-limiter.js +96 -0
  800. package/v3/@claude-flow/cli/dist/src/update/validator.d.ts +17 -0
  801. package/v3/@claude-flow/cli/dist/src/update/validator.js +123 -0
  802. package/v3/@claude-flow/cli/package.json +133 -0
  803. package/v3/@claude-flow/guidance/README.md +1195 -0
  804. package/v3/@claude-flow/guidance/package.json +198 -0
  805. package/v3/@claude-flow/shared/README.md +323 -0
  806. package/v3/@claude-flow/shared/package.json +43 -0
  807. package/v3/README.md +493 -0
@@ -0,0 +1,920 @@
1
+ /**
2
+ * V3 CLI Security Command
3
+ * Security scanning, CVE detection, threat modeling, vulnerability management
4
+ *
5
+ * Created with ❤️ by ruv.io
6
+ */
7
+ import { output } from '../output.js';
8
+ import { execSync } from 'node:child_process';
9
+ // Scan subcommand
10
+ const scanCommand = {
11
+ name: 'scan',
12
+ description: 'Run security scan on target (code, dependencies, containers)',
13
+ options: [
14
+ { name: 'target', short: 't', type: 'string', description: 'Target path or URL to scan', default: '.' },
15
+ { name: 'depth', short: 'd', type: 'string', description: 'Scan depth: quick, standard, deep', default: 'standard' },
16
+ { name: 'type', type: 'string', description: 'Scan type: code, deps, container, all', default: 'all' },
17
+ { name: 'output', short: 'o', type: 'string', description: 'Output format: text, json, sarif', default: 'text' },
18
+ { name: 'fix', short: 'f', type: 'boolean', description: 'Auto-fix vulnerabilities where possible' },
19
+ ],
20
+ examples: [
21
+ { command: 'claude-flow security scan -t ./src', description: 'Scan source directory' },
22
+ { command: 'claude-flow security scan --depth deep --fix', description: 'Deep scan with auto-fix' },
23
+ ],
24
+ action: async (ctx) => {
25
+ const target = ctx.flags.target || '.';
26
+ const depth = ctx.flags.depth || 'standard';
27
+ const scanType = ctx.flags.type || 'all';
28
+ const fix = ctx.flags.fix;
29
+ output.writeln();
30
+ output.writeln(output.bold('Security Scan'));
31
+ output.writeln(output.dim('─'.repeat(50)));
32
+ const spinner = output.createSpinner({ text: `Scanning ${target}...`, spinner: 'dots' });
33
+ spinner.start();
34
+ const findings = [];
35
+ let criticalCount = 0, highCount = 0, mediumCount = 0, lowCount = 0;
36
+ try {
37
+ const fs = await import('fs');
38
+ const path = await import('path');
39
+ const { execSync } = await import('child_process');
40
+ // Phase 1: npm audit for dependency vulnerabilities
41
+ if (scanType === 'all' || scanType === 'deps') {
42
+ spinner.setText('Checking dependencies with npm audit...');
43
+ try {
44
+ const packageJsonPath = path.resolve(target, 'package.json');
45
+ if (fs.existsSync(packageJsonPath)) {
46
+ let auditResult;
47
+ try {
48
+ auditResult = execSync('npm audit --json', {
49
+ cwd: path.resolve(target),
50
+ encoding: 'utf-8',
51
+ maxBuffer: 10 * 1024 * 1024,
52
+ stdio: ['pipe', 'pipe', 'pipe'],
53
+ });
54
+ }
55
+ catch (auditErr) {
56
+ // npm audit exits non-zero when vulnerabilities found — stdout still has JSON
57
+ auditResult = (auditErr instanceof Error && 'stdout' in auditErr ? auditErr.stdout : undefined) || '{}';
58
+ }
59
+ try {
60
+ const audit = JSON.parse(auditResult);
61
+ if (audit.vulnerabilities) {
62
+ for (const [pkg, vuln] of Object.entries(audit.vulnerabilities)) {
63
+ const sev = vuln.severity || 'low';
64
+ const title = Array.isArray(vuln.via) && vuln.via[0]?.title ? vuln.via[0].title : 'Vulnerability';
65
+ if (sev === 'critical')
66
+ criticalCount++;
67
+ else if (sev === 'high')
68
+ highCount++;
69
+ else if (sev === 'moderate' || sev === 'medium')
70
+ mediumCount++;
71
+ else
72
+ lowCount++;
73
+ findings.push({
74
+ severity: sev === 'critical' ? output.error('CRITICAL') :
75
+ sev === 'high' ? output.warning('HIGH') :
76
+ sev === 'moderate' || sev === 'medium' ? output.warning('MEDIUM') : output.info('LOW'),
77
+ type: 'Dependency CVE',
78
+ location: `package.json:${pkg}`,
79
+ description: title.substring(0, 35),
80
+ });
81
+ }
82
+ }
83
+ }
84
+ catch { /* JSON parse failed, no vulns */ }
85
+ }
86
+ }
87
+ catch { /* npm audit failed */ }
88
+ }
89
+ // Phase 2: Scan for hardcoded secrets
90
+ if (scanType === 'all' || scanType === 'code') {
91
+ spinner.setText('Scanning for hardcoded secrets...');
92
+ const secretPatterns = [
93
+ { pattern: /['"](?:sk-|sk_live_|sk_test_)[a-zA-Z0-9]{20,}['"]/g, type: 'API Key (Stripe/OpenAI)' },
94
+ { pattern: /['"]AKIA[A-Z0-9]{16}['"]/g, type: 'AWS Access Key' },
95
+ { pattern: /['"]ghp_[a-zA-Z0-9]{36}['"]/g, type: 'GitHub Token' },
96
+ { pattern: /['"]xox[baprs]-[a-zA-Z0-9-]+['"]/g, type: 'Slack Token' },
97
+ { pattern: /password\s*[:=]\s*['"][^'"]{8,}['"]/gi, type: 'Hardcoded Password' },
98
+ ];
99
+ const scanDir = (dir, depthLimit) => {
100
+ if (depthLimit <= 0)
101
+ return;
102
+ try {
103
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
104
+ for (const entry of entries) {
105
+ if (entry.name.startsWith('.') || entry.name === 'node_modules' || entry.name === 'dist')
106
+ continue;
107
+ const fullPath = path.join(dir, entry.name);
108
+ if (entry.isDirectory()) {
109
+ scanDir(fullPath, depthLimit - 1);
110
+ }
111
+ else if (entry.isFile() && /\.(ts|js|json|env|yml|yaml)$/.test(entry.name) && !entry.name.endsWith('.d.ts')) {
112
+ try {
113
+ const content = fs.readFileSync(fullPath, 'utf-8');
114
+ const lines = content.split('\n');
115
+ for (let i = 0; i < lines.length; i++) {
116
+ for (const { pattern, type } of secretPatterns) {
117
+ if (pattern.test(lines[i])) {
118
+ highCount++;
119
+ findings.push({
120
+ severity: output.warning('HIGH'),
121
+ type: 'Hardcoded Secret',
122
+ location: `${path.relative(target, fullPath)}:${i + 1}`,
123
+ description: type,
124
+ });
125
+ pattern.lastIndex = 0;
126
+ }
127
+ }
128
+ }
129
+ }
130
+ catch { /* file read error */ }
131
+ }
132
+ }
133
+ }
134
+ catch { /* dir read error */ }
135
+ };
136
+ const scanDepth = depth === 'deep' ? 10 : depth === 'standard' ? 5 : 3;
137
+ scanDir(path.resolve(target), scanDepth);
138
+ }
139
+ // Phase 3: Check for common security issues in code
140
+ if ((scanType === 'all' || scanType === 'code') && depth !== 'quick') {
141
+ spinner.setText('Analyzing code patterns...');
142
+ const codePatterns = [
143
+ { pattern: /eval\s*\(/g, type: 'Eval Usage', severity: 'medium', desc: 'eval() can execute arbitrary code' },
144
+ { pattern: /innerHTML\s*=/g, type: 'innerHTML', severity: 'medium', desc: 'XSS risk with innerHTML' },
145
+ { pattern: /dangerouslySetInnerHTML/g, type: 'React XSS', severity: 'medium', desc: 'React XSS risk' },
146
+ { pattern: /child_process.*exec[^S]/g, type: 'Command Injection', severity: 'high', desc: 'Possible command injection' },
147
+ { pattern: /\$\{.*\}.*sql|sql.*\$\{/gi, type: 'SQL Injection', severity: 'high', desc: 'Possible SQL injection' },
148
+ ];
149
+ const scanCodeDir = (dir, depthLimit) => {
150
+ if (depthLimit <= 0)
151
+ return;
152
+ try {
153
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
154
+ for (const entry of entries) {
155
+ if (entry.name.startsWith('.') || entry.name === 'node_modules' || entry.name === 'dist')
156
+ continue;
157
+ const fullPath = path.join(dir, entry.name);
158
+ if (entry.isDirectory()) {
159
+ scanCodeDir(fullPath, depthLimit - 1);
160
+ }
161
+ else if (entry.isFile() && /\.(ts|js|tsx|jsx)$/.test(entry.name) && !entry.name.endsWith('.d.ts')) {
162
+ try {
163
+ const content = fs.readFileSync(fullPath, 'utf-8');
164
+ const lines = content.split('\n');
165
+ for (let i = 0; i < lines.length; i++) {
166
+ for (const { pattern, type, severity, desc } of codePatterns) {
167
+ if (pattern.test(lines[i])) {
168
+ if (severity === 'high')
169
+ highCount++;
170
+ else
171
+ mediumCount++;
172
+ findings.push({
173
+ severity: severity === 'high' ? output.warning('HIGH') : output.warning('MEDIUM'),
174
+ type,
175
+ location: `${path.relative(target, fullPath)}:${i + 1}`,
176
+ description: desc,
177
+ });
178
+ pattern.lastIndex = 0;
179
+ }
180
+ }
181
+ }
182
+ }
183
+ catch { /* file read error */ }
184
+ }
185
+ }
186
+ }
187
+ catch { /* dir read error */ }
188
+ };
189
+ const scanDepth = depth === 'deep' ? 10 : 5;
190
+ scanCodeDir(path.resolve(target), scanDepth);
191
+ }
192
+ spinner.succeed('Scan complete');
193
+ // Display results
194
+ output.writeln();
195
+ if (findings.length > 0) {
196
+ output.printTable({
197
+ columns: [
198
+ { key: 'severity', header: 'Severity', width: 12 },
199
+ { key: 'type', header: 'Type', width: 18 },
200
+ { key: 'location', header: 'Location', width: 25 },
201
+ { key: 'description', header: 'Description', width: 35 },
202
+ ],
203
+ data: findings.slice(0, 20), // Show first 20
204
+ });
205
+ if (findings.length > 20) {
206
+ output.writeln(output.dim(`... and ${findings.length - 20} more issues`));
207
+ }
208
+ }
209
+ else {
210
+ output.writeln(output.success('No security issues found!'));
211
+ }
212
+ output.writeln();
213
+ output.printBox([
214
+ `Target: ${target}`,
215
+ `Depth: ${depth}`,
216
+ `Type: ${scanType}`,
217
+ ``,
218
+ `Critical: ${criticalCount} High: ${highCount} Medium: ${mediumCount} Low: ${lowCount}`,
219
+ `Total Issues: ${findings.length}`,
220
+ ].join('\n'), 'Scan Summary');
221
+ // Auto-fix if requested
222
+ if (fix && criticalCount + highCount > 0) {
223
+ output.writeln();
224
+ const fixSpinner = output.createSpinner({ text: 'Attempting to fix vulnerabilities...', spinner: 'dots' });
225
+ fixSpinner.start();
226
+ try {
227
+ try {
228
+ execSync('npm audit fix', { cwd: path.resolve(target), encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] });
229
+ }
230
+ catch { /* npm audit fix may exit non-zero */ }
231
+ fixSpinner.succeed('Applied available fixes (run scan again to verify)');
232
+ }
233
+ catch {
234
+ fixSpinner.fail('Some fixes could not be applied automatically');
235
+ }
236
+ }
237
+ return { success: findings.length === 0 || (criticalCount === 0 && highCount === 0) };
238
+ }
239
+ catch (error) {
240
+ spinner.fail('Scan failed');
241
+ output.printError(`Error: ${error}`);
242
+ return { success: false };
243
+ }
244
+ },
245
+ };
246
+ // CVE subcommand
247
+ const cveCommand = {
248
+ name: 'cve',
249
+ description: 'Check and manage CVE vulnerabilities',
250
+ options: [
251
+ { name: 'check', short: 'c', type: 'string', description: 'Check specific CVE ID' },
252
+ { name: 'list', short: 'l', type: 'boolean', description: 'List all known CVEs' },
253
+ { name: 'severity', short: 's', type: 'string', description: 'Filter by severity: critical, high, medium, low' },
254
+ ],
255
+ examples: [
256
+ { command: 'claude-flow security cve --list', description: 'List all CVEs' },
257
+ { command: 'claude-flow security cve -c CVE-2024-1234', description: 'Check specific CVE' },
258
+ ],
259
+ action: async (ctx) => {
260
+ const checkCve = ctx.flags.check;
261
+ output.writeln();
262
+ output.writeln(output.bold('CVE Database'));
263
+ output.writeln(output.dim('─'.repeat(50)));
264
+ output.writeln(output.warning('⚠ No CVE database configured.'));
265
+ output.writeln(output.dim('This command requires a CVE data source (e.g., NVD API) which is not yet integrated.'));
266
+ output.writeln();
267
+ if (checkCve) {
268
+ output.writeln(`To look up ${output.bold(checkCve)}, use one of these real sources:`);
269
+ }
270
+ else {
271
+ output.writeln('To check for real vulnerabilities, use:');
272
+ }
273
+ output.writeln();
274
+ output.writeln(` ${output.dim('$')} npm audit ${output.dim('# dependency vulnerabilities')}`);
275
+ output.writeln(` ${output.dim('$')} claude-flow security scan ${output.dim('# real code + dependency scan')}`);
276
+ if (checkCve) {
277
+ output.writeln(` ${output.dim('$')} open https://nvd.nist.gov/vuln/detail/${checkCve} ${output.dim('# NVD lookup')}`);
278
+ }
279
+ return { success: true };
280
+ },
281
+ };
282
+ // Threats subcommand
283
+ const threatsCommand = {
284
+ name: 'threats',
285
+ description: 'Threat modeling and analysis',
286
+ options: [
287
+ { name: 'model', short: 'm', type: 'string', description: 'Threat model: stride, dread, pasta', default: 'stride' },
288
+ { name: 'scope', short: 's', type: 'string', description: 'Analysis scope', default: '.' },
289
+ { name: 'export', short: 'e', type: 'string', description: 'Export format: json, md, html' },
290
+ ],
291
+ examples: [
292
+ { command: 'claude-flow security threats --model stride', description: 'Run STRIDE analysis' },
293
+ { command: 'claude-flow security threats -e md', description: 'Export as markdown' },
294
+ ],
295
+ action: async (ctx) => {
296
+ const model = ctx.flags.model || 'stride';
297
+ const scope = ctx.flags.scope || '.';
298
+ const exportFormat = ctx.flags.export;
299
+ output.writeln();
300
+ output.writeln(output.bold(`Threat Model: ${model.toUpperCase()}`));
301
+ output.writeln(output.dim('─'.repeat(50)));
302
+ const spinner = output.createSpinner({ text: `Scanning ${scope} for threat indicators...`, spinner: 'dots' });
303
+ spinner.start();
304
+ const fs = await import('fs');
305
+ const path = await import('path');
306
+ const rootDir = path.resolve(scope);
307
+ const findings = [];
308
+ const extensions = new Set(['.ts', '.js', '.json', '.yaml', '.yml', '.tsx', '.jsx']);
309
+ const skipDirs = new Set(['node_modules', 'dist', '.git']);
310
+ let filesScanned = 0;
311
+ const MAX_FILES = 500;
312
+ // Threat indicator patterns mapped to STRIDE categories
313
+ const threatPatterns = [
314
+ // Spoofing — weak/missing authentication
315
+ { pattern: /(?:app|router|server)\s*\.\s*(?:get|post|put|patch|delete)\s*\(\s*['"][^'"]+['"]\s*,\s*(?:async\s+)?\(?(?:req|request)/g, category: 'Spoofing', severity: 'medium', description: 'HTTP endpoint without auth middleware' },
316
+ // Tampering — code injection vectors
317
+ { pattern: /\beval\s*\(/g, category: 'Tampering', severity: 'high', description: 'eval() usage — arbitrary code execution risk' },
318
+ { pattern: /\bexecSync\s*\(/g, category: 'Tampering', severity: 'high', description: 'execSync() usage — command injection risk' },
319
+ { pattern: /\bexec\s*\(\s*[^)]*\$\{/g, category: 'Tampering', severity: 'high', description: 'exec() with template literal — injection risk' },
320
+ { pattern: /child_process.*\bexec\b/g, category: 'Tampering', severity: 'medium', description: 'child_process exec import — review for injection' },
321
+ { pattern: /new\s+Function\s*\(/g, category: 'Tampering', severity: 'high', description: 'new Function() — dynamic code execution risk' },
322
+ // Repudiation — missing audit/logging
323
+ // (checked via absence of logging imports, handled separately)
324
+ // Info Disclosure — secrets and data leaks
325
+ { pattern: /(?:api[_-]?key|secret|token|password|passwd|credential)\s*[:=]\s*['"][^'"]{8,}['"]/gi, category: 'Info Disclosure', severity: 'high', description: 'Hardcoded credential or secret' },
326
+ { pattern: /AKIA[0-9A-Z]{16}/g, category: 'Info Disclosure', severity: 'critical', description: 'AWS Access Key ID detected' },
327
+ { pattern: /gh[ps]_[A-Za-z0-9_]{36,}/g, category: 'Info Disclosure', severity: 'high', description: 'GitHub token detected' },
328
+ { pattern: /-----BEGIN (?:RSA|EC|DSA|OPENSSH) PRIVATE KEY-----/g, category: 'Info Disclosure', severity: 'critical', description: 'Private key detected' },
329
+ { pattern: /http:\/\/(?!localhost|127\.0\.0\.1|0\.0\.0\.0)/g, category: 'Info Disclosure', severity: 'medium', description: 'Non-localhost HTTP URL — should use HTTPS' },
330
+ // DoS — missing rate limiting / resource protection
331
+ { pattern: /require\s*\(\s*['"]express['"]\s*\)/g, category: 'DoS', severity: 'low', description: 'Express detected — verify rate-limiting is configured' },
332
+ { pattern: /require\s*\(\s*['"]fastify['"]\s*\)/g, category: 'DoS', severity: 'low', description: 'Fastify detected — verify rate-limiting is configured' },
333
+ // Elevation of privilege — unsafe deserialization, prototype pollution
334
+ { pattern: /JSON\.parse\s*\(\s*(?:req\.|request\.)/g, category: 'Elevation', severity: 'medium', description: 'Unsanitized JSON.parse from request — validate input' },
335
+ { pattern: /\.__proto__/g, category: 'Elevation', severity: 'high', description: '__proto__ access — prototype pollution risk' },
336
+ { pattern: /Object\.assign\s*\(\s*\{\s*\}\s*,\s*(?:req|request)\./g, category: 'Elevation', severity: 'medium', description: 'Object.assign from request — prototype pollution risk' },
337
+ ];
338
+ // Check for .env files committed to git
339
+ const checkEnvInGit = () => {
340
+ try {
341
+ const tracked = execSync('git ls-files --cached', { cwd: rootDir, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'] });
342
+ const envFiles = tracked.split('\n').filter((f) => /(?:^|\/)\.env(?:\.|$)/.test(f));
343
+ for (const envFile of envFiles) {
344
+ findings.push({
345
+ category: 'Info Disclosure',
346
+ severity: output.error('CRITICAL'),
347
+ location: envFile,
348
+ description: '.env file tracked in git — secrets may be exposed',
349
+ });
350
+ }
351
+ }
352
+ catch { /* not a git repo or git not available */ }
353
+ };
354
+ // Recursive file scanner
355
+ const scanDir = (dir) => {
356
+ if (filesScanned >= MAX_FILES)
357
+ return;
358
+ let entries;
359
+ try {
360
+ entries = fs.readdirSync(dir, { withFileTypes: true });
361
+ }
362
+ catch {
363
+ return;
364
+ }
365
+ for (const entry of entries) {
366
+ if (filesScanned >= MAX_FILES)
367
+ break;
368
+ if (skipDirs.has(entry.name) || entry.name.startsWith('.'))
369
+ continue;
370
+ const fullPath = path.join(dir, entry.name);
371
+ if (entry.isDirectory()) {
372
+ scanDir(fullPath);
373
+ }
374
+ else if (entry.isFile() && extensions.has(path.extname(entry.name)) && !entry.name.endsWith('.d.ts')) {
375
+ filesScanned++;
376
+ try {
377
+ const stat = fs.statSync(fullPath);
378
+ if (stat.size > 1024 * 1024)
379
+ continue; // skip files > 1MB
380
+ const content = fs.readFileSync(fullPath, 'utf-8');
381
+ const lines = content.split('\n');
382
+ const relPath = path.relative(rootDir, fullPath);
383
+ for (let i = 0; i < lines.length; i++) {
384
+ for (const tp of threatPatterns) {
385
+ tp.pattern.lastIndex = 0;
386
+ if (tp.pattern.test(lines[i])) {
387
+ const sevLabel = tp.severity === 'critical' ? output.error('CRITICAL') :
388
+ tp.severity === 'high' ? output.warning('HIGH') :
389
+ tp.severity === 'medium' ? output.warning('MEDIUM') : output.info('LOW');
390
+ findings.push({
391
+ category: tp.category,
392
+ severity: sevLabel,
393
+ location: `${relPath}:${i + 1}`,
394
+ description: tp.description,
395
+ });
396
+ tp.pattern.lastIndex = 0;
397
+ }
398
+ }
399
+ }
400
+ }
401
+ catch { /* file read error */ }
402
+ }
403
+ }
404
+ };
405
+ // Check for missing security middleware in Express/Fastify apps
406
+ const checkMissingMiddleware = () => {
407
+ const serverFiles = [];
408
+ const collectServerFiles = (dir, depth) => {
409
+ if (depth <= 0 || filesScanned >= MAX_FILES)
410
+ return;
411
+ try {
412
+ const entries = fs.readdirSync(dir, { withFileTypes: true });
413
+ for (const entry of entries) {
414
+ if (skipDirs.has(entry.name) || entry.name.startsWith('.'))
415
+ continue;
416
+ const fullPath = path.join(dir, entry.name);
417
+ if (entry.isDirectory()) {
418
+ collectServerFiles(fullPath, depth - 1);
419
+ }
420
+ else if (/\.(ts|js)$/.test(entry.name) && !entry.name.endsWith('.d.ts')) {
421
+ try {
422
+ const content = fs.readFileSync(fullPath, 'utf-8');
423
+ if (/require\s*\(\s*['"](?:express|fastify)['"]\s*\)/.test(content) || /from\s+['"](?:express|fastify)['"]/.test(content)) {
424
+ serverFiles.push(fullPath);
425
+ const relPath = path.relative(rootDir, fullPath);
426
+ if (!/(?:helmet|lusca)/.test(content)) {
427
+ findings.push({ category: 'Tampering', severity: output.warning('MEDIUM'), location: relPath, description: 'No helmet/lusca security headers middleware' });
428
+ }
429
+ if (!/(?:cors)/.test(content)) {
430
+ findings.push({ category: 'Spoofing', severity: output.info('LOW'), location: relPath, description: 'No CORS middleware detected' });
431
+ }
432
+ if (!/(?:rate.?limit|throttle)/.test(content)) {
433
+ findings.push({ category: 'DoS', severity: output.warning('MEDIUM'), location: relPath, description: 'No rate-limiting middleware detected' });
434
+ }
435
+ }
436
+ }
437
+ catch { /* skip */ }
438
+ }
439
+ }
440
+ }
441
+ catch { /* skip */ }
442
+ };
443
+ collectServerFiles(rootDir, 5);
444
+ };
445
+ checkEnvInGit();
446
+ scanDir(rootDir);
447
+ checkMissingMiddleware();
448
+ spinner.succeed(`Scanned ${filesScanned} files`);
449
+ // STRIDE reference framework
450
+ const strideRef = [
451
+ { category: 'Spoofing', description: 'Can an attacker impersonate a user or service?', example: 'Strong authentication, mTLS' },
452
+ { category: 'Tampering', description: 'Can data or code be modified without detection?', example: 'Input validation, integrity checks' },
453
+ { category: 'Repudiation', description: 'Can actions be performed without accountability?', example: 'Audit logging, signed commits' },
454
+ { category: 'Info Disclosure', description: 'Can sensitive data leak to unauthorized parties?', example: 'Encryption at rest and in transit' },
455
+ { category: 'DoS', description: 'Can service availability be degraded?', example: 'Rate limiting, resource quotas' },
456
+ { category: 'Elevation', description: 'Can privileges be escalated beyond granted level?', example: 'RBAC, principle of least privilege' },
457
+ ];
458
+ // Display real findings
459
+ output.writeln();
460
+ if (findings.length > 0) {
461
+ output.writeln(output.bold(`Findings (${findings.length}):`));
462
+ output.writeln();
463
+ output.printTable({
464
+ columns: [
465
+ { key: 'category', header: 'STRIDE Category', width: 18 },
466
+ { key: 'severity', header: 'Severity', width: 12 },
467
+ { key: 'location', header: 'Location', width: 30 },
468
+ { key: 'description', header: 'Description', width: 40 },
469
+ ],
470
+ data: findings.slice(0, 30),
471
+ });
472
+ if (findings.length > 30) {
473
+ output.writeln(output.dim(`... and ${findings.length - 30} more findings`));
474
+ }
475
+ // Summary by STRIDE category
476
+ const byCat = {};
477
+ for (const f of findings)
478
+ byCat[f.category] = (byCat[f.category] || 0) + 1;
479
+ output.writeln();
480
+ output.writeln(output.bold('Summary by STRIDE category:'));
481
+ for (const [cat, count] of Object.entries(byCat).sort((a, b) => b[1] - a[1])) {
482
+ output.writeln(` ${cat}: ${count} finding${count === 1 ? '' : 's'}`);
483
+ }
484
+ }
485
+ else {
486
+ output.writeln(output.success('No threat indicators detected in scanned files.'));
487
+ }
488
+ // Always show STRIDE reference
489
+ output.writeln();
490
+ output.writeln(output.bold(`${model.toUpperCase()} Reference Framework${findings.length === 0 ? ' (reference only — no issues detected)' : ''}:`));
491
+ output.writeln();
492
+ output.printTable({
493
+ columns: [
494
+ { key: 'category', header: `${model.toUpperCase()} Category`, width: 20 },
495
+ { key: 'description', header: 'What to Assess', width: 40 },
496
+ { key: 'example', header: 'Example Mitigation', width: 30 },
497
+ ],
498
+ data: strideRef,
499
+ });
500
+ // Export if requested
501
+ if (exportFormat && findings.length > 0) {
502
+ const exportData = {
503
+ model: model.toUpperCase(),
504
+ timestamp: new Date().toISOString(),
505
+ scope,
506
+ filesScanned,
507
+ totalFindings: findings.length,
508
+ findings: findings.map(f => ({ ...f, severity: f.severity.replace(/\x1b\[[0-9;]*m/g, '') })),
509
+ strideReference: strideRef,
510
+ };
511
+ if (exportFormat === 'json') {
512
+ output.writeln();
513
+ output.writeln(JSON.stringify(exportData, null, 2));
514
+ }
515
+ }
516
+ output.writeln();
517
+ output.writeln(output.dim(`Files scanned: ${filesScanned} (max ${MAX_FILES})`));
518
+ return { success: true };
519
+ },
520
+ };
521
+ // Audit subcommand
522
+ const auditCommand = {
523
+ name: 'audit',
524
+ description: 'Security audit logging and compliance',
525
+ options: [
526
+ { name: 'action', short: 'a', type: 'string', description: 'Action: log, list, export, clear', default: 'list' },
527
+ { name: 'limit', short: 'l', type: 'number', description: 'Number of entries to show', default: '20' },
528
+ { name: 'filter', short: 'f', type: 'string', description: 'Filter by event type' },
529
+ ],
530
+ examples: [
531
+ { command: 'claude-flow security audit --action list', description: 'List audit logs' },
532
+ { command: 'claude-flow security audit -a export', description: 'Export audit trail' },
533
+ ],
534
+ action: async (ctx) => {
535
+ const action = ctx.flags.action || 'list';
536
+ output.writeln();
537
+ output.writeln(output.bold('Security Audit Log'));
538
+ output.writeln(output.dim('─'.repeat(60)));
539
+ // Generate real audit entries from .swarm/ state and session history
540
+ const { existsSync, readFileSync, readdirSync, statSync } = await import('fs');
541
+ const { join } = await import('path');
542
+ const auditEntries = [];
543
+ const swarmDir = join(process.cwd(), '.swarm');
544
+ // Check session files for real audit events
545
+ if (existsSync(swarmDir)) {
546
+ try {
547
+ const files = readdirSync(swarmDir).filter(f => f.endsWith('.json'));
548
+ for (const file of files.slice(-10)) {
549
+ try {
550
+ const stat = statSync(join(swarmDir, file));
551
+ const ts = stat.mtime.toISOString().replace('T', ' ').substring(0, 19);
552
+ auditEntries.push({
553
+ timestamp: ts,
554
+ event: file.includes('session') ? 'SESSION_UPDATE' :
555
+ file.includes('swarm') ? 'SWARM_ACTIVITY' :
556
+ file.includes('memory') ? 'MEMORY_WRITE' : 'CONFIG_CHANGE',
557
+ user: 'system',
558
+ status: output.success('Success')
559
+ });
560
+ }
561
+ catch { /* skip */ }
562
+ }
563
+ }
564
+ catch { /* ignore */ }
565
+ }
566
+ // Add current session entry
567
+ const now = new Date().toISOString().replace('T', ' ').substring(0, 19);
568
+ auditEntries.push({ timestamp: now, event: 'AUDIT_RUN', user: 'cli', status: output.success('Success') });
569
+ // Sort by timestamp desc
570
+ auditEntries.sort((a, b) => b.timestamp.localeCompare(a.timestamp));
571
+ if (auditEntries.length === 0) {
572
+ output.writeln(output.dim('No audit events found. Initialize a project first: claude-flow init'));
573
+ }
574
+ else {
575
+ output.printTable({
576
+ columns: [
577
+ { key: 'timestamp', header: 'Timestamp', width: 22 },
578
+ { key: 'event', header: 'Event', width: 20 },
579
+ { key: 'user', header: 'User', width: 15 },
580
+ { key: 'status', header: 'Status', width: 12 },
581
+ ],
582
+ data: auditEntries.slice(0, parseInt(ctx.flags.limit || '20', 10)),
583
+ });
584
+ }
585
+ return { success: true };
586
+ },
587
+ };
588
+ // Secrets subcommand
589
+ const secretsCommand = {
590
+ name: 'secrets',
591
+ description: 'Detect and manage secrets in codebase',
592
+ options: [
593
+ { name: 'action', short: 'a', type: 'string', description: 'Action: scan, list, rotate', default: 'scan' },
594
+ { name: 'path', short: 'p', type: 'string', description: 'Path to scan', default: '.' },
595
+ { name: 'ignore', short: 'i', type: 'string', description: 'Patterns to ignore' },
596
+ ],
597
+ examples: [
598
+ { command: 'claude-flow security secrets --action scan', description: 'Scan for secrets' },
599
+ { command: 'claude-flow security secrets -a rotate', description: 'Rotate compromised secrets' },
600
+ ],
601
+ action: async (ctx) => {
602
+ const scanPath = ctx.flags.path || '.';
603
+ const ignorePatterns = ctx.flags.ignore;
604
+ output.writeln();
605
+ output.writeln(output.bold('Secret Detection'));
606
+ output.writeln(output.dim('─'.repeat(50)));
607
+ const spinner = output.createSpinner({ text: `Scanning ${scanPath} for secrets...`, spinner: 'dots' });
608
+ spinner.start();
609
+ const fs = await import('fs');
610
+ const path = await import('path');
611
+ const rootDir = path.resolve(scanPath);
612
+ const skipDirs = new Set(['node_modules', 'dist', '.git']);
613
+ const extensions = new Set(['.ts', '.js', '.json', '.yaml', '.yml', '.tsx', '.jsx', '.env', '.toml', '.cfg', '.conf', '.ini', '.properties', '.sh', '.bash', '.zsh']);
614
+ const ignoreList = ignorePatterns ? ignorePatterns.split(',').map(p => p.trim()) : [];
615
+ const secretPatterns = [
616
+ { pattern: /AKIA[0-9A-Z]{16}/g, type: 'AWS Access Key', risk: 'Critical', action: 'Rotate immediately' },
617
+ { pattern: /gh[ps]_[A-Za-z0-9_]{36,}/g, type: 'GitHub Token', risk: 'Critical', action: 'Revoke and rotate' },
618
+ { pattern: /eyJ[A-Za-z0-9_-]{10,}\.[A-Za-z0-9_-]{10,}/g, type: 'JWT Token', risk: 'High', action: 'Remove from source' },
619
+ { pattern: /-----BEGIN (?:RSA|EC|DSA|OPENSSH) PRIVATE KEY-----/g, type: 'Private Key', risk: 'Critical', action: 'Remove and regenerate' },
620
+ { pattern: /(?:mongodb|postgres|mysql|redis):\/\/[^\s'"]+/g, type: 'Connection String', risk: 'High', action: 'Use env variable' },
621
+ { pattern: /['"](?:sk-|sk_live_|sk_test_)[a-zA-Z0-9]{20,}['"]/g, type: 'API Key (Stripe/OpenAI)', risk: 'Critical', action: 'Rotate immediately' },
622
+ { pattern: /['"]xox[baprs]-[a-zA-Z0-9-]+['"]/g, type: 'Slack Token', risk: 'High', action: 'Revoke and rotate' },
623
+ { pattern: /[a-zA-Z0-9_-]*(?:api[_-]?key|secret[_-]?key|auth[_-]?token|access[_-]?token|private[_-]?key)\s*[:=]\s*['"][^'"]{8,}['"]/gi, type: 'Generic Secret/API Key', risk: 'High', action: 'Use env variable' },
624
+ { pattern: /(?:password|passwd|pwd)\s*[:=]\s*['"][^'"]{8,}['"]/gi, type: 'Hardcoded Password', risk: 'High', action: 'Use secrets manager' },
625
+ ];
626
+ const findings = [];
627
+ let filesScanned = 0;
628
+ const MAX_FILES = 500;
629
+ const shouldIgnore = (filePath) => {
630
+ return ignoreList.some(p => filePath.includes(p));
631
+ };
632
+ const scanDir = (dir) => {
633
+ if (filesScanned >= MAX_FILES)
634
+ return;
635
+ let entries;
636
+ try {
637
+ entries = fs.readdirSync(dir, { withFileTypes: true });
638
+ }
639
+ catch {
640
+ return;
641
+ }
642
+ for (const entry of entries) {
643
+ if (filesScanned >= MAX_FILES)
644
+ break;
645
+ if (skipDirs.has(entry.name))
646
+ continue;
647
+ // Allow dotfiles like .env but skip .git
648
+ const fullPath = path.join(dir, entry.name);
649
+ if (entry.isDirectory()) {
650
+ if (entry.name.startsWith('.') && entry.name !== '.env')
651
+ continue;
652
+ scanDir(fullPath);
653
+ }
654
+ else if (entry.isFile()) {
655
+ const ext = path.extname(entry.name);
656
+ const isEnvFile = entry.name.startsWith('.env');
657
+ if (!extensions.has(ext) && !isEnvFile)
658
+ continue;
659
+ if (entry.name.endsWith('.d.ts'))
660
+ continue;
661
+ const relPath = path.relative(rootDir, fullPath);
662
+ if (shouldIgnore(relPath))
663
+ continue;
664
+ filesScanned++;
665
+ try {
666
+ const stat = fs.statSync(fullPath);
667
+ if (stat.size > 1024 * 1024)
668
+ continue; // skip files > 1MB
669
+ const content = fs.readFileSync(fullPath, 'utf-8');
670
+ // Quick binary check — skip if null bytes present
671
+ if (content.includes('\0'))
672
+ continue;
673
+ const lines = content.split('\n');
674
+ for (let i = 0; i < lines.length; i++) {
675
+ const line = lines[i];
676
+ for (const sp of secretPatterns) {
677
+ sp.pattern.lastIndex = 0;
678
+ const match = sp.pattern.exec(line);
679
+ if (match) {
680
+ // Mask the matched secret for safe display
681
+ const matched = match[0];
682
+ const masked = matched.length > 12
683
+ ? matched.substring(0, 6) + '***' + matched.substring(matched.length - 3)
684
+ : '***';
685
+ findings.push({
686
+ type: sp.type,
687
+ location: `${relPath}:${i + 1}`,
688
+ risk: sp.risk,
689
+ action: sp.action,
690
+ line: masked,
691
+ });
692
+ sp.pattern.lastIndex = 0;
693
+ }
694
+ }
695
+ }
696
+ }
697
+ catch { /* file read error */ }
698
+ }
699
+ }
700
+ };
701
+ scanDir(rootDir);
702
+ spinner.succeed(`Scanned ${filesScanned} files`);
703
+ output.writeln();
704
+ if (findings.length > 0) {
705
+ const criticalCount = findings.filter(f => f.risk === 'Critical').length;
706
+ const highCount = findings.filter(f => f.risk === 'High').length;
707
+ const mediumCount = findings.filter(f => f.risk === 'Medium').length;
708
+ output.printTable({
709
+ columns: [
710
+ { key: 'type', header: 'Secret Type', width: 25 },
711
+ { key: 'location', header: 'Location', width: 35 },
712
+ { key: 'risk', header: 'Risk', width: 12 },
713
+ { key: 'action', header: 'Recommended', width: 22 },
714
+ ],
715
+ data: findings.slice(0, 25).map(f => ({
716
+ type: f.type,
717
+ location: f.location,
718
+ risk: f.risk === 'Critical' ? output.error(f.risk) :
719
+ f.risk === 'High' ? output.warning(f.risk) :
720
+ output.warning(f.risk),
721
+ action: f.action,
722
+ })),
723
+ });
724
+ if (findings.length > 25) {
725
+ output.writeln(output.dim(`... and ${findings.length - 25} more secrets found`));
726
+ }
727
+ output.writeln();
728
+ output.printBox([
729
+ `Path: ${scanPath}`,
730
+ `Files scanned: ${filesScanned}`,
731
+ ``,
732
+ `Critical: ${criticalCount} High: ${highCount} Medium: ${mediumCount}`,
733
+ `Total secrets found: ${findings.length}`,
734
+ ].join('\n'), 'Secrets Summary');
735
+ }
736
+ else {
737
+ output.writeln(output.success('No secrets detected.'));
738
+ output.writeln();
739
+ output.printBox([
740
+ `Path: ${scanPath}`,
741
+ `Files scanned: ${filesScanned}`,
742
+ ``,
743
+ `No hardcoded secrets, API keys, tokens, or credentials found.`,
744
+ ].join('\n'), 'Secrets Summary');
745
+ }
746
+ return { success: findings.length === 0 };
747
+ },
748
+ };
749
+ // Defend subcommand (AIDefence integration)
750
+ const defendCommand = {
751
+ name: 'defend',
752
+ description: 'AI manipulation defense - detect prompt injection, jailbreaks, and PII',
753
+ options: [
754
+ { name: 'input', short: 'i', type: 'string', description: 'Input text to scan for threats' },
755
+ { name: 'file', short: 'f', type: 'string', description: 'File to scan for threats' },
756
+ { name: 'quick', short: 'Q', type: 'boolean', description: 'Quick scan (faster, less detailed)' },
757
+ { name: 'learn', short: 'l', type: 'boolean', description: 'Enable learning mode', default: 'true' },
758
+ { name: 'stats', short: 's', type: 'boolean', description: 'Show detection statistics' },
759
+ { name: 'output', short: 'o', type: 'string', description: 'Output format: text, json', default: 'text' },
760
+ ],
761
+ examples: [
762
+ { command: 'claude-flow security defend -i "ignore previous instructions"', description: 'Scan text for threats' },
763
+ { command: 'claude-flow security defend -f ./prompts.txt', description: 'Scan file for threats' },
764
+ { command: 'claude-flow security defend --stats', description: 'Show detection statistics' },
765
+ ],
766
+ action: async (ctx) => {
767
+ const inputText = ctx.flags.input;
768
+ const filePath = ctx.flags.file;
769
+ const quickMode = ctx.flags.quick;
770
+ const showStats = ctx.flags.stats;
771
+ const outputFormat = ctx.flags.output || 'text';
772
+ const enableLearning = ctx.flags.learn !== false;
773
+ output.writeln();
774
+ output.writeln(output.bold('🛡️ AIDefence - AI Manipulation Defense System'));
775
+ output.writeln(output.dim('─'.repeat(55)));
776
+ // Dynamic import of aidefence (allows package to be optional)
777
+ let createAIDefence;
778
+ try {
779
+ const aidefence = await import('@claude-flow/aidefence');
780
+ createAIDefence = aidefence.createAIDefence;
781
+ }
782
+ catch {
783
+ output.error('AIDefence package not installed. Run: npm install @claude-flow/aidefence');
784
+ return { success: false, message: 'AIDefence not available' };
785
+ }
786
+ const defender = createAIDefence({ enableLearning });
787
+ // Show stats mode
788
+ if (showStats) {
789
+ const stats = await defender.getStats();
790
+ output.writeln();
791
+ output.printBox([
792
+ `Detection Count: ${stats.detectionCount}`,
793
+ `Avg Detection Time: ${stats.avgDetectionTimeMs.toFixed(3)}ms`,
794
+ `Learned Patterns: ${stats.learnedPatterns}`,
795
+ `Mitigation Strategies: ${stats.mitigationStrategies}`,
796
+ `Avg Mitigation Effectiveness: ${(stats.avgMitigationEffectiveness * 100).toFixed(1)}%`,
797
+ ].join('\n'), 'Detection Statistics');
798
+ return { success: true };
799
+ }
800
+ // Get input to scan
801
+ let textToScan = inputText;
802
+ if (filePath) {
803
+ try {
804
+ const fs = await import('fs/promises');
805
+ textToScan = await fs.readFile(filePath, 'utf-8');
806
+ output.writeln(output.dim(`Reading file: ${filePath}`));
807
+ }
808
+ catch (err) {
809
+ output.error(`Failed to read file: ${filePath}`);
810
+ return { success: false, message: 'File not found' };
811
+ }
812
+ }
813
+ if (!textToScan) {
814
+ output.writeln('Usage: claude-flow security defend -i "<text>" or -f <file>');
815
+ output.writeln();
816
+ output.writeln('Options:');
817
+ output.printList([
818
+ '-i, --input Text to scan for AI manipulation attempts',
819
+ '-f, --file File path to scan',
820
+ '-q, --quick Quick scan mode (faster)',
821
+ '-s, --stats Show detection statistics',
822
+ '--learn Enable pattern learning (default: true)',
823
+ ]);
824
+ return { success: true };
825
+ }
826
+ const spinner = output.createSpinner({ text: 'Scanning for threats...', spinner: 'dots' });
827
+ spinner.start();
828
+ // Perform scan
829
+ const startTime = performance.now();
830
+ const result = quickMode
831
+ ? { ...defender.quickScan(textToScan), threats: [], piiFound: false, detectionTimeMs: 0, inputHash: '', safe: !defender.quickScan(textToScan).threat }
832
+ : await defender.detect(textToScan);
833
+ const scanTime = performance.now() - startTime;
834
+ spinner.stop();
835
+ // JSON output
836
+ if (outputFormat === 'json') {
837
+ output.writeln(JSON.stringify({
838
+ safe: result.safe,
839
+ threats: result.threats || [],
840
+ piiFound: result.piiFound,
841
+ detectionTimeMs: scanTime,
842
+ }, null, 2));
843
+ return { success: true };
844
+ }
845
+ // Text output
846
+ output.writeln();
847
+ if (result.safe && !result.piiFound) {
848
+ output.writeln(output.success('✅ No threats detected'));
849
+ }
850
+ else {
851
+ if (!result.safe && result.threats) {
852
+ output.writeln(output.error(`⚠️ ${result.threats.length} threat(s) detected:`));
853
+ output.writeln();
854
+ for (const threat of result.threats) {
855
+ const severityColor = {
856
+ critical: output.error,
857
+ high: output.warning,
858
+ medium: output.info,
859
+ low: output.dim,
860
+ }[threat.severity] || output.dim;
861
+ output.writeln(` ${severityColor(`[${threat.severity.toUpperCase()}]`)} ${threat.type}`);
862
+ output.writeln(` ${output.dim(threat.description)}`);
863
+ output.writeln(` Confidence: ${(threat.confidence * 100).toFixed(1)}%`);
864
+ output.writeln();
865
+ }
866
+ // Show mitigation recommendations
867
+ const criticalThreats = result.threats.filter(t => t.severity === 'critical');
868
+ if (criticalThreats.length > 0 && enableLearning) {
869
+ output.writeln(output.bold('Recommended Mitigations:'));
870
+ for (const threat of criticalThreats) {
871
+ const mitigation = await defender.getBestMitigation(threat.type);
872
+ if (mitigation) {
873
+ output.writeln(` ${threat.type}: ${output.bold(mitigation.strategy)} (${(mitigation.effectiveness * 100).toFixed(0)}% effective)`);
874
+ }
875
+ }
876
+ output.writeln();
877
+ }
878
+ }
879
+ if (result.piiFound) {
880
+ output.writeln(output.warning('⚠️ PII detected (emails, SSNs, API keys, etc.)'));
881
+ output.writeln();
882
+ }
883
+ }
884
+ output.writeln(output.dim(`Detection time: ${scanTime.toFixed(3)}ms`));
885
+ return { success: result.safe };
886
+ },
887
+ };
888
+ // Main security command
889
+ export const securityCommand = {
890
+ name: 'security',
891
+ description: 'Security scanning, CVE detection, threat modeling, AI defense',
892
+ subcommands: [scanCommand, cveCommand, threatsCommand, auditCommand, secretsCommand, defendCommand],
893
+ examples: [
894
+ { command: 'claude-flow security scan', description: 'Run security scan' },
895
+ { command: 'claude-flow security cve --list', description: 'List known CVEs' },
896
+ { command: 'claude-flow security threats', description: 'Run threat analysis' },
897
+ ],
898
+ action: async () => {
899
+ output.writeln();
900
+ output.writeln(output.bold('RuFlo Security Suite'));
901
+ output.writeln(output.dim('Comprehensive security scanning and vulnerability management'));
902
+ output.writeln();
903
+ output.writeln('Subcommands:');
904
+ output.printList([
905
+ 'scan - Run security scans on code, deps, containers',
906
+ 'cve - Check and manage CVE vulnerabilities',
907
+ 'threats - Threat modeling (STRIDE, DREAD, PASTA)',
908
+ 'audit - Security audit logging and compliance',
909
+ 'secrets - Detect and manage secrets in codebase',
910
+ 'defend - AI manipulation defense (prompt injection, jailbreaks, PII)',
911
+ ]);
912
+ output.writeln();
913
+ output.writeln('Use --help with subcommands for more info');
914
+ output.writeln();
915
+ output.writeln(output.dim('Created with ❤️ by ruv.io'));
916
+ return { success: true };
917
+ },
918
+ };
919
+ export default securityCommand;
920
+ //# sourceMappingURL=security.js.map