@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.
- package/.claude/agents/MIGRATION_SUMMARY.md +222 -0
- package/.claude/agents/analysis/analyze-code-quality.md +58 -0
- package/.claude/agents/analysis/code-analyzer.md +189 -0
- package/.claude/agents/analysis/code-review/analyze-code-quality.md +58 -0
- package/.claude/agents/architecture/arch-system-design.md +157 -0
- package/.claude/agents/architecture/system-design/arch-system-design.md +36 -0
- package/.claude/agents/base-template-generator.md +41 -0
- package/.claude/agents/browser/browser-agent.yaml +182 -0
- package/.claude/agents/consensus/byzantine-coordinator.md +43 -0
- package/.claude/agents/consensus/crdt-synchronizer.md +977 -0
- package/.claude/agents/consensus/gossip-coordinator.md +43 -0
- package/.claude/agents/consensus/performance-benchmarker.md +831 -0
- package/.claude/agents/consensus/quorum-manager.md +803 -0
- package/.claude/agents/consensus/raft-manager.md +43 -0
- package/.claude/agents/consensus/security-manager.md +602 -0
- package/.claude/agents/core/coder.md +255 -0
- package/.claude/agents/core/planner.md +152 -0
- package/.claude/agents/core/researcher.md +174 -0
- package/.claude/agents/core/reviewer.md +309 -0
- package/.claude/agents/core/tester.md +300 -0
- package/.claude/agents/custom/test-long-runner.md +43 -0
- package/.claude/agents/data/data-ml-model.md +445 -0
- package/.claude/agents/data/ml/data-ml-model.md +76 -0
- package/.claude/agents/database-specialist.md +9 -0
- package/.claude/agents/development/backend/dev-backend-api.md +29 -0
- package/.claude/agents/development/dev-backend-api.md +178 -0
- package/.claude/agents/devops/ci-cd/ops-cicd-github.md +52 -0
- package/.claude/agents/devops/ops-cicd-github.md +165 -0
- package/.claude/agents/documentation/api-docs/docs-api-openapi.md +63 -0
- package/.claude/agents/documentation/docs-api-openapi.md +355 -0
- package/.claude/agents/dual-mode/codex-coordinator.md +206 -0
- package/.claude/agents/dual-mode/codex-worker.md +190 -0
- package/.claude/agents/dual-mode/dual-orchestrator.md +253 -0
- package/.claude/agents/flow-nexus/app-store.md +88 -0
- package/.claude/agents/flow-nexus/authentication.md +69 -0
- package/.claude/agents/flow-nexus/challenges.md +81 -0
- package/.claude/agents/flow-nexus/neural-network.md +88 -0
- package/.claude/agents/flow-nexus/payments.md +83 -0
- package/.claude/agents/flow-nexus/sandbox.md +76 -0
- package/.claude/agents/flow-nexus/swarm.md +76 -0
- package/.claude/agents/flow-nexus/user-tools.md +96 -0
- package/.claude/agents/flow-nexus/workflow.md +84 -0
- package/.claude/agents/github/code-review-swarm.md +521 -0
- package/.claude/agents/github/github-modes.md +154 -0
- package/.claude/agents/github/issue-tracker.md +299 -0
- package/.claude/agents/github/multi-repo-swarm.md +525 -0
- package/.claude/agents/github/pr-manager.md +163 -0
- package/.claude/agents/github/project-board-sync.md +478 -0
- package/.claude/agents/github/release-manager.md +336 -0
- package/.claude/agents/github/release-swarm.md +551 -0
- package/.claude/agents/github/repo-architect.md +365 -0
- package/.claude/agents/github/swarm-issue.md +548 -0
- package/.claude/agents/github/swarm-pr.md +399 -0
- package/.claude/agents/github/sync-coordinator.md +423 -0
- package/.claude/agents/github/workflow-automation.md +605 -0
- package/.claude/agents/goal/agent.md +817 -0
- package/.claude/agents/goal/code-goal-planner.md +445 -0
- package/.claude/agents/goal/goal-planner.md +168 -0
- package/.claude/agents/hive-mind/collective-intelligence-coordinator.md +129 -0
- package/.claude/agents/hive-mind/queen-coordinator.md +202 -0
- package/.claude/agents/hive-mind/scout-explorer.md +241 -0
- package/.claude/agents/hive-mind/swarm-memory-manager.md +192 -0
- package/.claude/agents/hive-mind/worker-specialist.md +216 -0
- package/.claude/agents/neural/safla-neural.md +74 -0
- package/.claude/agents/optimization/benchmark-suite.md +663 -0
- package/.claude/agents/optimization/load-balancer.md +429 -0
- package/.claude/agents/optimization/performance-monitor.md +670 -0
- package/.claude/agents/optimization/resource-allocator.md +672 -0
- package/.claude/agents/optimization/topology-optimizer.md +806 -0
- package/.claude/agents/payments/agentic-payments.md +126 -0
- package/.claude/agents/project-coordinator.md +8 -0
- package/.claude/agents/python-specialist.md +9 -0
- package/.claude/agents/reasoning/agent.md +817 -0
- package/.claude/agents/reasoning/goal-planner.md +73 -0
- package/.claude/agents/security-auditor.md +9 -0
- package/.claude/agents/sona/sona-learning-optimizer.md +65 -0
- package/.claude/agents/sparc/architecture.md +453 -0
- package/.claude/agents/sparc/pseudocode.md +299 -0
- package/.claude/agents/sparc/refinement.md +504 -0
- package/.claude/agents/sparc/specification.md +258 -0
- package/.claude/agents/specialized/mobile/spec-mobile-react-native.md +88 -0
- package/.claude/agents/specialized/spec-mobile-react-native.md +227 -0
- package/.claude/agents/sublinear/consensus-coordinator.md +338 -0
- package/.claude/agents/sublinear/matrix-optimizer.md +185 -0
- package/.claude/agents/sublinear/pagerank-analyzer.md +299 -0
- package/.claude/agents/sublinear/performance-optimizer.md +368 -0
- package/.claude/agents/sublinear/trading-predictor.md +246 -0
- package/.claude/agents/swarm/adaptive-coordinator.md +364 -0
- package/.claude/agents/swarm/hierarchical-coordinator.md +300 -0
- package/.claude/agents/swarm/mesh-coordinator.md +363 -0
- package/.claude/agents/templates/automation-smart-agent.md +185 -0
- package/.claude/agents/templates/base-template-generator.md +289 -0
- package/.claude/agents/templates/coordinator-swarm-init.md +83 -0
- package/.claude/agents/templates/github-pr-manager.md +155 -0
- package/.claude/agents/templates/implementer-sparc-coder.md +243 -0
- package/.claude/agents/templates/memory-coordinator.md +163 -0
- package/.claude/agents/templates/migration-plan.md +724 -0
- package/.claude/agents/templates/orchestrator-task.md +120 -0
- package/.claude/agents/templates/performance-analyzer.md +179 -0
- package/.claude/agents/templates/sparc-coordinator.md +163 -0
- package/.claude/agents/testing/production-validator.md +373 -0
- package/.claude/agents/testing/tdd-london-swarm.md +222 -0
- package/.claude/agents/testing/unit/tdd-london-swarm.md +222 -0
- package/.claude/agents/testing/validation/production-validator.md +373 -0
- package/.claude/agents/typescript-specialist.md +9 -0
- package/.claude/agents/v3/adr-architect.md +184 -0
- package/.claude/agents/v3/aidefence-guardian.md +282 -0
- package/.claude/agents/v3/claims-authorizer.md +208 -0
- package/.claude/agents/v3/collective-intelligence-coordinator.md +993 -0
- package/.claude/agents/v3/database-specialist.md +9 -0
- package/.claude/agents/v3/ddd-domain-expert.md +220 -0
- package/.claude/agents/v3/injection-analyst.md +236 -0
- package/.claude/agents/v3/memory-specialist.md +995 -0
- package/.claude/agents/v3/performance-engineer.md +1233 -0
- package/.claude/agents/v3/pii-detector.md +151 -0
- package/.claude/agents/v3/project-coordinator.md +8 -0
- package/.claude/agents/v3/python-specialist.md +9 -0
- package/.claude/agents/v3/reasoningbank-learner.md +213 -0
- package/.claude/agents/v3/security-architect-aidefence.md +410 -0
- package/.claude/agents/v3/security-architect.md +867 -0
- package/.claude/agents/v3/security-auditor.md +771 -0
- package/.claude/agents/v3/sparc-orchestrator.md +182 -0
- package/.claude/agents/v3/swarm-memory-manager.md +157 -0
- package/.claude/agents/v3/test-architect.md +9 -0
- package/.claude/agents/v3/typescript-specialist.md +9 -0
- package/.claude/agents/v3/v3-integration-architect.md +312 -0
- package/.claude/agents/v3/v3-memory-specialist.md +281 -0
- package/.claude/agents/v3/v3-performance-engineer.md +363 -0
- package/.claude/agents/v3/v3-queen-coordinator.md +63 -0
- package/.claude/agents/v3/v3-security-architect.md +140 -0
- package/.claude/checkpoints/1767754460.json +8 -0
- package/.claude/commands/agents/README.md +10 -0
- package/.claude/commands/agents/agent-capabilities.md +21 -0
- package/.claude/commands/agents/agent-coordination.md +28 -0
- package/.claude/commands/agents/agent-spawning.md +28 -0
- package/.claude/commands/agents/agent-types.md +26 -0
- package/.claude/commands/analysis/COMMAND_COMPLIANCE_REPORT.md +54 -0
- package/.claude/commands/analysis/README.md +9 -0
- package/.claude/commands/analysis/bottleneck-detect.md +162 -0
- package/.claude/commands/analysis/performance-bottlenecks.md +59 -0
- package/.claude/commands/analysis/performance-report.md +25 -0
- package/.claude/commands/analysis/token-efficiency.md +45 -0
- package/.claude/commands/analysis/token-usage.md +25 -0
- package/.claude/commands/automation/README.md +9 -0
- package/.claude/commands/automation/auto-agent.md +122 -0
- package/.claude/commands/automation/self-healing.md +106 -0
- package/.claude/commands/automation/session-memory.md +90 -0
- package/.claude/commands/automation/smart-agents.md +73 -0
- package/.claude/commands/automation/smart-spawn.md +25 -0
- package/.claude/commands/automation/workflow-select.md +25 -0
- package/.claude/commands/claude-flow-help.md +103 -0
- package/.claude/commands/claude-flow-memory.md +107 -0
- package/.claude/commands/claude-flow-swarm.md +205 -0
- package/.claude/commands/coordination/README.md +9 -0
- package/.claude/commands/coordination/agent-spawn.md +25 -0
- package/.claude/commands/coordination/init.md +44 -0
- package/.claude/commands/coordination/orchestrate.md +43 -0
- package/.claude/commands/coordination/spawn.md +45 -0
- package/.claude/commands/coordination/swarm-init.md +85 -0
- package/.claude/commands/coordination/task-orchestrate.md +25 -0
- package/.claude/commands/flow-nexus/app-store.md +124 -0
- package/.claude/commands/flow-nexus/challenges.md +120 -0
- package/.claude/commands/flow-nexus/login-registration.md +65 -0
- package/.claude/commands/flow-nexus/neural-network.md +134 -0
- package/.claude/commands/flow-nexus/payments.md +116 -0
- package/.claude/commands/flow-nexus/sandbox.md +83 -0
- package/.claude/commands/flow-nexus/swarm.md +87 -0
- package/.claude/commands/flow-nexus/user-tools.md +152 -0
- package/.claude/commands/flow-nexus/workflow.md +115 -0
- package/.claude/commands/github/README.md +11 -0
- package/.claude/commands/github/code-review-swarm.md +514 -0
- package/.claude/commands/github/code-review.md +25 -0
- package/.claude/commands/github/github-modes.md +147 -0
- package/.claude/commands/github/github-swarm.md +121 -0
- package/.claude/commands/github/issue-tracker.md +292 -0
- package/.claude/commands/github/issue-triage.md +25 -0
- package/.claude/commands/github/multi-repo-swarm.md +519 -0
- package/.claude/commands/github/pr-enhance.md +26 -0
- package/.claude/commands/github/pr-manager.md +170 -0
- package/.claude/commands/github/project-board-sync.md +471 -0
- package/.claude/commands/github/release-manager.md +338 -0
- package/.claude/commands/github/release-swarm.md +544 -0
- package/.claude/commands/github/repo-analyze.md +25 -0
- package/.claude/commands/github/repo-architect.md +367 -0
- package/.claude/commands/github/swarm-issue.md +482 -0
- package/.claude/commands/github/swarm-pr.md +285 -0
- package/.claude/commands/github/sync-coordinator.md +301 -0
- package/.claude/commands/github/workflow-automation.md +442 -0
- package/.claude/commands/hive-mind/README.md +17 -0
- package/.claude/commands/hive-mind/hive-mind-consensus.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-init.md +18 -0
- package/.claude/commands/hive-mind/hive-mind-memory.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-metrics.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-resume.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-sessions.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-spawn.md +21 -0
- package/.claude/commands/hive-mind/hive-mind-status.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-stop.md +8 -0
- package/.claude/commands/hive-mind/hive-mind-wizard.md +8 -0
- package/.claude/commands/hive-mind/hive-mind.md +27 -0
- package/.claude/commands/hooks/README.md +11 -0
- package/.claude/commands/hooks/overview.md +58 -0
- package/.claude/commands/hooks/post-edit.md +117 -0
- package/.claude/commands/hooks/post-task.md +112 -0
- package/.claude/commands/hooks/pre-edit.md +113 -0
- package/.claude/commands/hooks/pre-task.md +111 -0
- package/.claude/commands/hooks/session-end.md +118 -0
- package/.claude/commands/hooks/setup.md +103 -0
- package/.claude/commands/memory/README.md +9 -0
- package/.claude/commands/memory/memory-persist.md +25 -0
- package/.claude/commands/memory/memory-search.md +25 -0
- package/.claude/commands/memory/memory-usage.md +25 -0
- package/.claude/commands/memory/neural.md +47 -0
- package/.claude/commands/monitoring/README.md +9 -0
- package/.claude/commands/monitoring/agent-metrics.md +25 -0
- package/.claude/commands/monitoring/agents.md +44 -0
- package/.claude/commands/monitoring/real-time-view.md +25 -0
- package/.claude/commands/monitoring/status.md +46 -0
- package/.claude/commands/monitoring/swarm-monitor.md +25 -0
- package/.claude/commands/optimization/README.md +9 -0
- package/.claude/commands/optimization/auto-topology.md +62 -0
- package/.claude/commands/optimization/cache-manage.md +25 -0
- package/.claude/commands/optimization/parallel-execute.md +25 -0
- package/.claude/commands/optimization/parallel-execution.md +50 -0
- package/.claude/commands/optimization/topology-optimize.md +25 -0
- package/.claude/commands/pair/README.md +261 -0
- package/.claude/commands/pair/commands.md +546 -0
- package/.claude/commands/pair/config.md +510 -0
- package/.claude/commands/pair/examples.md +512 -0
- package/.claude/commands/pair/modes.md +348 -0
- package/.claude/commands/pair/session.md +407 -0
- package/.claude/commands/pair/start.md +209 -0
- package/.claude/commands/sparc/analyzer.md +52 -0
- package/.claude/commands/sparc/architect.md +53 -0
- package/.claude/commands/sparc/ask.md +97 -0
- package/.claude/commands/sparc/batch-executor.md +54 -0
- package/.claude/commands/sparc/code.md +89 -0
- package/.claude/commands/sparc/coder.md +54 -0
- package/.claude/commands/sparc/debug.md +83 -0
- package/.claude/commands/sparc/debugger.md +54 -0
- package/.claude/commands/sparc/designer.md +53 -0
- package/.claude/commands/sparc/devops.md +109 -0
- package/.claude/commands/sparc/docs-writer.md +80 -0
- package/.claude/commands/sparc/documenter.md +54 -0
- package/.claude/commands/sparc/innovator.md +54 -0
- package/.claude/commands/sparc/integration.md +83 -0
- package/.claude/commands/sparc/mcp.md +117 -0
- package/.claude/commands/sparc/memory-manager.md +54 -0
- package/.claude/commands/sparc/optimizer.md +54 -0
- package/.claude/commands/sparc/orchestrator.md +132 -0
- package/.claude/commands/sparc/post-deployment-monitoring-mode.md +83 -0
- package/.claude/commands/sparc/refinement-optimization-mode.md +83 -0
- package/.claude/commands/sparc/researcher.md +54 -0
- package/.claude/commands/sparc/reviewer.md +54 -0
- package/.claude/commands/sparc/security-review.md +80 -0
- package/.claude/commands/sparc/sparc-modes.md +174 -0
- package/.claude/commands/sparc/sparc.md +111 -0
- package/.claude/commands/sparc/spec-pseudocode.md +80 -0
- package/.claude/commands/sparc/supabase-admin.md +348 -0
- package/.claude/commands/sparc/swarm-coordinator.md +54 -0
- package/.claude/commands/sparc/tdd.md +54 -0
- package/.claude/commands/sparc/tester.md +54 -0
- package/.claude/commands/sparc/tutorial.md +79 -0
- package/.claude/commands/sparc/workflow-manager.md +54 -0
- package/.claude/commands/sparc.md +166 -0
- package/.claude/commands/stream-chain/pipeline.md +121 -0
- package/.claude/commands/stream-chain/run.md +70 -0
- package/.claude/commands/swarm/README.md +15 -0
- package/.claude/commands/swarm/analysis.md +95 -0
- package/.claude/commands/swarm/development.md +96 -0
- package/.claude/commands/swarm/examples.md +168 -0
- package/.claude/commands/swarm/maintenance.md +102 -0
- package/.claude/commands/swarm/optimization.md +117 -0
- package/.claude/commands/swarm/research.md +136 -0
- package/.claude/commands/swarm/swarm-analysis.md +8 -0
- package/.claude/commands/swarm/swarm-background.md +8 -0
- package/.claude/commands/swarm/swarm-init.md +19 -0
- package/.claude/commands/swarm/swarm-modes.md +8 -0
- package/.claude/commands/swarm/swarm-monitor.md +8 -0
- package/.claude/commands/swarm/swarm-spawn.md +19 -0
- package/.claude/commands/swarm/swarm-status.md +8 -0
- package/.claude/commands/swarm/swarm-strategies.md +8 -0
- package/.claude/commands/swarm/swarm.md +27 -0
- package/.claude/commands/swarm/testing.md +131 -0
- package/.claude/commands/training/README.md +9 -0
- package/.claude/commands/training/model-update.md +25 -0
- package/.claude/commands/training/neural-patterns.md +74 -0
- package/.claude/commands/training/neural-train.md +25 -0
- package/.claude/commands/training/pattern-learn.md +25 -0
- package/.claude/commands/training/specialization.md +63 -0
- package/.claude/commands/truth/start.md +143 -0
- package/.claude/commands/verify/check.md +50 -0
- package/.claude/commands/verify/start.md +128 -0
- package/.claude/commands/workflows/README.md +9 -0
- package/.claude/commands/workflows/development.md +78 -0
- package/.claude/commands/workflows/research.md +63 -0
- package/.claude/commands/workflows/workflow-create.md +25 -0
- package/.claude/commands/workflows/workflow-execute.md +25 -0
- package/.claude/commands/workflows/workflow-export.md +25 -0
- package/.claude/config/v3-dependency-optimization.json +266 -0
- package/.claude/config/v3-performance-targets.json +251 -0
- package/.claude/helpers/README.md +97 -0
- package/.claude/helpers/adr-compliance.sh +186 -0
- package/.claude/helpers/aggressive-microcompact.mjs +36 -0
- package/.claude/helpers/auto-commit.sh +178 -0
- package/.claude/helpers/auto-memory-hook.mjs +564 -0
- package/.claude/helpers/checkpoint-manager.sh +251 -0
- package/.claude/helpers/context-persistence-hook.mjs +1979 -0
- package/.claude/helpers/daemon-manager.sh +252 -0
- package/.claude/helpers/ddd-tracker.sh +144 -0
- package/.claude/helpers/github-safe.js +106 -0
- package/.claude/helpers/github-setup.sh +28 -0
- package/.claude/helpers/guidance-hook.sh +13 -0
- package/.claude/helpers/guidance-hooks.sh +102 -0
- package/.claude/helpers/health-monitor.sh +108 -0
- package/.claude/helpers/hook-handler.cjs +269 -0
- package/.claude/helpers/intelligence.cjs +230 -0
- package/.claude/helpers/learning-hooks.sh +329 -0
- package/.claude/helpers/learning-optimizer.sh +127 -0
- package/.claude/helpers/learning-service.mjs +1144 -0
- package/.claude/helpers/memory.cjs +84 -0
- package/.claude/helpers/memory.js +83 -0
- package/.claude/helpers/metrics-db.mjs +488 -0
- package/.claude/helpers/patch-aggressive-prune.mjs +184 -0
- package/.claude/helpers/pattern-consolidator.sh +86 -0
- package/.claude/helpers/perf-worker.sh +160 -0
- package/.claude/helpers/post-commit +16 -0
- package/.claude/helpers/pre-commit +26 -0
- package/.claude/helpers/quick-start.sh +19 -0
- package/.claude/helpers/router.cjs +62 -0
- package/.claude/helpers/router.js +66 -0
- package/.claude/helpers/security-scanner.sh +127 -0
- package/.claude/helpers/session.cjs +125 -0
- package/.claude/helpers/session.js +135 -0
- package/.claude/helpers/setup-mcp.sh +18 -0
- package/.claude/helpers/standard-checkpoint-hooks.sh +189 -0
- package/.claude/helpers/statusline-hook.sh +21 -0
- package/.claude/helpers/statusline.cjs +878 -0
- package/.claude/helpers/statusline.js +352 -0
- package/.claude/helpers/swarm-comms.sh +353 -0
- package/.claude/helpers/swarm-hooks.sh +761 -0
- package/.claude/helpers/swarm-monitor.sh +211 -0
- package/.claude/helpers/sync-v3-metrics.sh +245 -0
- package/.claude/helpers/update-v3-progress.sh +166 -0
- package/.claude/helpers/v3-quick-status.sh +58 -0
- package/.claude/helpers/v3.sh +111 -0
- package/.claude/helpers/validate-v3-config.sh +216 -0
- package/.claude/helpers/worker-manager.sh +170 -0
- package/.claude/mcp.json +13 -0
- package/.claude/scheduled_tasks.lock +1 -0
- package/.claude/settings.json +285 -0
- package/.claude/settings.json.bak +526 -0
- package/.claude/skills/agentdb-advanced/SKILL.md +550 -0
- package/.claude/skills/agentdb-learning/SKILL.md +545 -0
- package/.claude/skills/agentdb-memory-patterns/SKILL.md +339 -0
- package/.claude/skills/agentdb-optimization/SKILL.md +509 -0
- package/.claude/skills/agentdb-vector-search/SKILL.md +339 -0
- package/.claude/skills/agentic-jujutsu/SKILL.md +645 -0
- package/.claude/skills/browser/SKILL.md +204 -0
- package/.claude/skills/dual-mode/README.md +71 -0
- package/.claude/skills/dual-mode/dual-collect.md +103 -0
- package/.claude/skills/dual-mode/dual-coordinate.md +85 -0
- package/.claude/skills/dual-mode/dual-spawn.md +81 -0
- package/.claude/skills/flow-nexus-neural/SKILL.md +727 -0
- package/.claude/skills/flow-nexus-platform/SKILL.md +1154 -0
- package/.claude/skills/flow-nexus-swarm/SKILL.md +604 -0
- package/.claude/skills/github-code-review/SKILL.md +1125 -0
- package/.claude/skills/github-multi-repo/SKILL.md +862 -0
- package/.claude/skills/github-project-management/SKILL.md +1263 -0
- package/.claude/skills/github-release-management/SKILL.md +1064 -0
- package/.claude/skills/github-workflow-automation/SKILL.md +1047 -0
- package/.claude/skills/hive-mind-advanced/SKILL.md +709 -0
- package/.claude/skills/hooks-automation/SKILL.md +1201 -0
- package/.claude/skills/pair-programming/SKILL.md +1202 -0
- package/.claude/skills/performance-analysis/SKILL.md +560 -0
- package/.claude/skills/reasoningbank-agentdb/SKILL.md +446 -0
- package/.claude/skills/reasoningbank-intelligence/SKILL.md +201 -0
- package/.claude/skills/skill-builder/SKILL.md +910 -0
- package/.claude/skills/sparc-methodology/SKILL.md +1106 -0
- package/.claude/skills/stream-chain/SKILL.md +560 -0
- package/.claude/skills/swarm-advanced/SKILL.md +970 -0
- package/.claude/skills/swarm-orchestration/SKILL.md +179 -0
- package/.claude/skills/v3-cli-modernization/SKILL.md +872 -0
- package/.claude/skills/v3-core-implementation/SKILL.md +797 -0
- package/.claude/skills/v3-ddd-architecture/SKILL.md +442 -0
- package/.claude/skills/v3-integration-deep/SKILL.md +241 -0
- package/.claude/skills/v3-mcp-optimization/SKILL.md +777 -0
- package/.claude/skills/v3-memory-unification/SKILL.md +174 -0
- package/.claude/skills/v3-performance-optimization/SKILL.md +390 -0
- package/.claude/skills/v3-security-overhaul/SKILL.md +82 -0
- package/.claude/skills/v3-swarm-coordination/SKILL.md +340 -0
- package/.claude/skills/verification-quality/SKILL.md +691 -0
- package/.claude/skills/worker-benchmarks/SKILL.md +129 -0
- package/.claude/skills/worker-integration/SKILL.md +147 -0
- package/.claude/statusline-command.sh +176 -0
- package/.claude/statusline.mjs +109 -0
- package/.claude/statusline.sh +431 -0
- package/.claude-plugin/README.md +720 -0
- package/.claude-plugin/docs/INSTALLATION.md +261 -0
- package/.claude-plugin/docs/PLUGIN_SUMMARY.md +361 -0
- package/.claude-plugin/docs/QUICKSTART.md +361 -0
- package/.claude-plugin/docs/STRUCTURE.md +128 -0
- package/.claude-plugin/hooks/hooks.json +75 -0
- package/.claude-plugin/marketplace.json +170 -0
- package/.claude-plugin/plugin.json +71 -0
- package/.claude-plugin/scripts/install.sh +234 -0
- package/.claude-plugin/scripts/ruflo-hook.sh +33 -0
- package/.claude-plugin/scripts/uninstall.sh +36 -0
- package/.claude-plugin/scripts/verify.sh +108 -0
- package/LICENSE +21 -0
- package/README.md +410 -0
- package/bin/cli.js +11 -0
- package/bin/npx-repair.js +7 -0
- package/bin/npx-safe-launch.js +9 -0
- package/package.json +159 -0
- package/v3/@claude-flow/cli/README.md +410 -0
- package/v3/@claude-flow/cli/bin/cli.js +233 -0
- package/v3/@claude-flow/cli/bin/mcp-server.js +224 -0
- package/v3/@claude-flow/cli/bin/preinstall.cjs +2 -0
- package/v3/@claude-flow/cli/dist/src/appliance/gguf-engine.d.ts +91 -0
- package/v3/@claude-flow/cli/dist/src/appliance/gguf-engine.js +425 -0
- package/v3/@claude-flow/cli/dist/src/appliance/ruvllm-bridge.d.ts +102 -0
- package/v3/@claude-flow/cli/dist/src/appliance/ruvllm-bridge.js +292 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-builder.d.ts +44 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-builder.js +329 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-distribution.d.ts +97 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-distribution.js +370 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-format.d.ts +111 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-format.js +393 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-runner.d.ts +69 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-runner.js +237 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-signing.d.ts +123 -0
- package/v3/@claude-flow/cli/dist/src/appliance/rvfa-signing.js +347 -0
- package/v3/@claude-flow/cli/dist/src/autopilot-state.d.ts +77 -0
- package/v3/@claude-flow/cli/dist/src/autopilot-state.js +271 -0
- package/v3/@claude-flow/cli/dist/src/benchmarks/pretrain/index.d.ts +58 -0
- package/v3/@claude-flow/cli/dist/src/benchmarks/pretrain/index.js +404 -0
- package/v3/@claude-flow/cli/dist/src/commands/agent-wasm.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/commands/agent-wasm.js +333 -0
- package/v3/@claude-flow/cli/dist/src/commands/agent.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/agent.js +927 -0
- package/v3/@claude-flow/cli/dist/src/commands/analyze.d.ts +19 -0
- package/v3/@claude-flow/cli/dist/src/commands/analyze.js +2048 -0
- package/v3/@claude-flow/cli/dist/src/commands/appliance-advanced.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/commands/appliance-advanced.js +215 -0
- package/v3/@claude-flow/cli/dist/src/commands/appliance.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/appliance.js +404 -0
- package/v3/@claude-flow/cli/dist/src/commands/autopilot.d.ts +15 -0
- package/v3/@claude-flow/cli/dist/src/commands/autopilot.js +362 -0
- package/v3/@claude-flow/cli/dist/src/commands/benchmark.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/benchmark.js +460 -0
- package/v3/@claude-flow/cli/dist/src/commands/claims.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/claims.js +620 -0
- package/v3/@claude-flow/cli/dist/src/commands/cleanup.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/commands/cleanup.js +250 -0
- package/v3/@claude-flow/cli/dist/src/commands/completions.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/completions.js +539 -0
- package/v3/@claude-flow/cli/dist/src/commands/config.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/config.js +430 -0
- package/v3/@claude-flow/cli/dist/src/commands/daemon.d.ts +28 -0
- package/v3/@claude-flow/cli/dist/src/commands/daemon.js +1093 -0
- package/v3/@claude-flow/cli/dist/src/commands/deployment.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/deployment.js +672 -0
- package/v3/@claude-flow/cli/dist/src/commands/doctor.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/doctor.js +885 -0
- package/v3/@claude-flow/cli/dist/src/commands/embeddings.d.ts +18 -0
- package/v3/@claude-flow/cli/dist/src/commands/embeddings.js +1623 -0
- package/v3/@claude-flow/cli/dist/src/commands/guidance.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/guidance.js +556 -0
- package/v3/@claude-flow/cli/dist/src/commands/hive-mind.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/hive-mind.js +1297 -0
- package/v3/@claude-flow/cli/dist/src/commands/hooks.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/hooks.js +4499 -0
- package/v3/@claude-flow/cli/dist/src/commands/index.d.ts +118 -0
- package/v3/@claude-flow/cli/dist/src/commands/index.js +344 -0
- package/v3/@claude-flow/cli/dist/src/commands/init.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/init.js +997 -0
- package/v3/@claude-flow/cli/dist/src/commands/issues.d.ts +21 -0
- package/v3/@claude-flow/cli/dist/src/commands/issues.js +567 -0
- package/v3/@claude-flow/cli/dist/src/commands/mcp.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/mcp.js +718 -0
- package/v3/@claude-flow/cli/dist/src/commands/memory.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/memory.js +1456 -0
- package/v3/@claude-flow/cli/dist/src/commands/migrate.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/migrate.js +742 -0
- package/v3/@claude-flow/cli/dist/src/commands/neural.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/neural.js +1531 -0
- package/v3/@claude-flow/cli/dist/src/commands/performance.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/performance.js +583 -0
- package/v3/@claude-flow/cli/dist/src/commands/plugins.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/plugins.js +826 -0
- package/v3/@claude-flow/cli/dist/src/commands/process.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/process.js +694 -0
- package/v3/@claude-flow/cli/dist/src/commands/progress.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/progress.js +259 -0
- package/v3/@claude-flow/cli/dist/src/commands/providers.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/providers.js +502 -0
- package/v3/@claude-flow/cli/dist/src/commands/route.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/commands/route.js +813 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/backup.js +747 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/benchmark.js +490 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.d.ts +18 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/import.js +373 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.d.ts +29 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/index.js +129 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/init.js +467 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/migrate.js +498 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/optimize.js +505 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/pg-utils.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/pg-utils.js +41 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.d.ts +18 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/setup.js +765 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.d.ts +11 -0
- package/v3/@claude-flow/cli/dist/src/commands/ruvector/status.js +479 -0
- package/v3/@claude-flow/cli/dist/src/commands/security.d.ts +10 -0
- package/v3/@claude-flow/cli/dist/src/commands/security.js +920 -0
- package/v3/@claude-flow/cli/dist/src/commands/session.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/session.js +757 -0
- package/v3/@claude-flow/cli/dist/src/commands/start.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/start.js +418 -0
- package/v3/@claude-flow/cli/dist/src/commands/status.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/status.js +591 -0
- package/v3/@claude-flow/cli/dist/src/commands/swarm.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/swarm.js +887 -0
- package/v3/@claude-flow/cli/dist/src/commands/task.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/task.js +675 -0
- package/v3/@claude-flow/cli/dist/src/commands/transfer-store.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/commands/transfer-store.js +428 -0
- package/v3/@claude-flow/cli/dist/src/commands/update.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/update.js +276 -0
- package/v3/@claude-flow/cli/dist/src/commands/verify.d.ts +19 -0
- package/v3/@claude-flow/cli/dist/src/commands/verify.js +261 -0
- package/v3/@claude-flow/cli/dist/src/commands/workflow.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/commands/workflow.js +617 -0
- package/v3/@claude-flow/cli/dist/src/config-adapter.d.ts +15 -0
- package/v3/@claude-flow/cli/dist/src/config-adapter.js +186 -0
- package/v3/@claude-flow/cli/dist/src/encryption/vault.d.ts +94 -0
- package/v3/@claude-flow/cli/dist/src/encryption/vault.js +172 -0
- package/v3/@claude-flow/cli/dist/src/fs-secure.d.ts +67 -0
- package/v3/@claude-flow/cli/dist/src/fs-secure.js +74 -0
- package/v3/@claude-flow/cli/dist/src/index.d.ts +81 -0
- package/v3/@claude-flow/cli/dist/src/index.js +538 -0
- package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.d.ts +68 -0
- package/v3/@claude-flow/cli/dist/src/infrastructure/in-memory-repositories.js +264 -0
- package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/init/claudemd-generator.js +363 -0
- package/v3/@claude-flow/cli/dist/src/init/executor.d.ts +41 -0
- package/v3/@claude-flow/cli/dist/src/init/executor.js +1904 -0
- package/v3/@claude-flow/cli/dist/src/init/helpers-generator.d.ts +60 -0
- package/v3/@claude-flow/cli/dist/src/init/helpers-generator.js +1185 -0
- package/v3/@claude-flow/cli/dist/src/init/index.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/init/index.js +15 -0
- package/v3/@claude-flow/cli/dist/src/init/mcp-generator.d.ts +26 -0
- package/v3/@claude-flow/cli/dist/src/init/mcp-generator.js +116 -0
- package/v3/@claude-flow/cli/dist/src/init/settings-generator.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/init/settings-generator.js +456 -0
- package/v3/@claude-flow/cli/dist/src/init/statusline-generator.d.ts +28 -0
- package/v3/@claude-flow/cli/dist/src/init/statusline-generator.js +937 -0
- package/v3/@claude-flow/cli/dist/src/init/types.d.ts +308 -0
- package/v3/@claude-flow/cli/dist/src/init/types.js +263 -0
- package/v3/@claude-flow/cli/dist/src/log-filters.d.ts +22 -0
- package/v3/@claude-flow/cli/dist/src/log-filters.js +36 -0
- package/v3/@claude-flow/cli/dist/src/mcp-client.d.ts +92 -0
- package/v3/@claude-flow/cli/dist/src/mcp-client.js +287 -0
- package/v3/@claude-flow/cli/dist/src/mcp-server.d.ts +163 -0
- package/v3/@claude-flow/cli/dist/src/mcp-server.js +732 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-execute-core.d.ts +92 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-execute-core.js +328 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agent-tools.js +716 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agentdb-tools.d.ts +33 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/agentdb-tools.js +867 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/analyze-tools.js +346 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/auto-install.d.ts +83 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/auto-install.js +131 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/autopilot-tools.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/autopilot-tools.js +231 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-session-tools.d.ts +23 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-session-tools.js +324 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-tools.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/browser-tools.js +757 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/claims-tools.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/claims-tools.js +863 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/config-tools.js +411 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/coordination-tools.js +729 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/daa-tools.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/daa-tools.js +534 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/embeddings-tools.js +904 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/github-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/github-tools.js +659 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/guidance-tools.d.ts +15 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/guidance-tools.js +639 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hive-mind-tools.js +953 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.d.ts +46 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/hooks-tools.js +3939 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/index.d.ts +27 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/index.js +26 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/managed-agent-tools.d.ts +22 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/managed-agent-tools.js +357 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/memory-tools.js +1240 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/neural-tools.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/neural-tools.js +793 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/performance-tools.d.ts +16 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/performance-tools.js +675 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/progress-tools.js +348 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/request-tracker.d.ts +17 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/request-tracker.js +27 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/ruvllm-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/ruvllm-tools.js +339 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.d.ts +18 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/security-tools.js +556 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/session-tools.js +517 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/swarm-tools.js +388 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/system-tools.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/system-tools.js +674 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/task-tools.js +487 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/terminal-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/terminal-tools.js +306 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/transfer-tools.js +447 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/types.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/types.js +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/validate-input.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/validate-input.js +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/wasm-agent-tools.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/wasm-agent-tools.js +291 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
- package/v3/@claude-flow/cli/dist/src/mcp-tools/workflow-tools.js +884 -0
- package/v3/@claude-flow/cli/dist/src/memory/ewc-consolidation.d.ts +295 -0
- package/v3/@claude-flow/cli/dist/src/memory/ewc-consolidation.js +601 -0
- package/v3/@claude-flow/cli/dist/src/memory/intelligence.d.ts +357 -0
- package/v3/@claude-flow/cli/dist/src/memory/intelligence.js +1200 -0
- package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.d.ts +492 -0
- package/v3/@claude-flow/cli/dist/src/memory/memory-bridge.js +2101 -0
- package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.d.ts +420 -0
- package/v3/@claude-flow/cli/dist/src/memory/memory-initializer.js +2376 -0
- package/v3/@claude-flow/cli/dist/src/memory/neural-package-bridge.d.ts +48 -0
- package/v3/@claude-flow/cli/dist/src/memory/neural-package-bridge.js +87 -0
- package/v3/@claude-flow/cli/dist/src/memory/rabitq-index.d.ts +60 -0
- package/v3/@claude-flow/cli/dist/src/memory/rabitq-index.js +242 -0
- package/v3/@claude-flow/cli/dist/src/memory/sona-optimizer.d.ts +267 -0
- package/v3/@claude-flow/cli/dist/src/memory/sona-optimizer.js +779 -0
- package/v3/@claude-flow/cli/dist/src/output.d.ts +9 -0
- package/v3/@claude-flow/cli/dist/src/output.js +9 -0
- package/v3/@claude-flow/cli/dist/src/parser.d.ts +69 -0
- package/v3/@claude-flow/cli/dist/src/parser.js +473 -0
- package/v3/@claude-flow/cli/dist/src/plugins/manager.d.ts +133 -0
- package/v3/@claude-flow/cli/dist/src/plugins/manager.js +402 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/discovery.d.ts +91 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/discovery.js +1202 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/index.d.ts +76 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/index.js +141 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/search.d.ts +46 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/search.js +230 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/types.d.ts +274 -0
- package/v3/@claude-flow/cli/dist/src/plugins/store/types.js +7 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/demo-plugin-store.js +126 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/standalone-test.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/standalone-test.js +188 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
- package/v3/@claude-flow/cli/dist/src/plugins/tests/test-plugin-store.js +206 -0
- package/v3/@claude-flow/cli/dist/src/production/circuit-breaker.d.ts +101 -0
- package/v3/@claude-flow/cli/dist/src/production/circuit-breaker.js +241 -0
- package/v3/@claude-flow/cli/dist/src/production/error-handler.d.ts +92 -0
- package/v3/@claude-flow/cli/dist/src/production/error-handler.js +299 -0
- package/v3/@claude-flow/cli/dist/src/production/index.d.ts +23 -0
- package/v3/@claude-flow/cli/dist/src/production/index.js +18 -0
- package/v3/@claude-flow/cli/dist/src/production/monitoring.d.ts +161 -0
- package/v3/@claude-flow/cli/dist/src/production/monitoring.js +356 -0
- package/v3/@claude-flow/cli/dist/src/production/rate-limiter.d.ts +80 -0
- package/v3/@claude-flow/cli/dist/src/production/rate-limiter.js +201 -0
- package/v3/@claude-flow/cli/dist/src/production/retry.d.ts +48 -0
- package/v3/@claude-flow/cli/dist/src/production/retry.js +179 -0
- package/v3/@claude-flow/cli/dist/src/prompt.d.ts +44 -0
- package/v3/@claude-flow/cli/dist/src/prompt.js +501 -0
- package/v3/@claude-flow/cli/dist/src/runtime/headless.d.ts +60 -0
- package/v3/@claude-flow/cli/dist/src/runtime/headless.js +284 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/agent-wasm.d.ts +193 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/agent-wasm.js +354 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.d.ts +67 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/ast-analyzer.js +277 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.d.ts +160 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-router.js +531 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.d.ts +33 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/coverage-tools.js +157 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.d.ts +175 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/diff-classifier.js +699 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/diskann-backend.d.ts +78 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/diskann-backend.js +310 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/enhanced-model-router.js +529 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.d.ts +187 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-analyzer.js +929 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-backend.d.ts +79 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/graph-backend.js +220 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/index.d.ts +38 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/index.js +82 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/lora-adapter.d.ts +240 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/lora-adapter.js +550 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/model-router.d.ts +241 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/model-router.js +608 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.d.ts +211 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/q-learning-router.js +681 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/ruvllm-wasm.d.ts +179 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/ruvllm-wasm.js +367 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/semantic-router.d.ts +77 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/semantic-router.js +178 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.d.ts +73 -0
- package/v3/@claude-flow/cli/dist/src/ruvector/vector-db.js +264 -0
- package/v3/@claude-flow/cli/dist/src/services/agentic-flow-bridge.d.ts +50 -0
- package/v3/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +95 -0
- package/v3/@claude-flow/cli/dist/src/services/claim-service.d.ts +204 -0
- package/v3/@claude-flow/cli/dist/src/services/claim-service.js +818 -0
- package/v3/@claude-flow/cli/dist/src/services/config-file-manager.d.ts +37 -0
- package/v3/@claude-flow/cli/dist/src/services/config-file-manager.js +233 -0
- package/v3/@claude-flow/cli/dist/src/services/container-worker-pool.d.ts +197 -0
- package/v3/@claude-flow/cli/dist/src/services/container-worker-pool.js +583 -0
- package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.d.ts +310 -0
- package/v3/@claude-flow/cli/dist/src/services/headless-worker-executor.js +1058 -0
- package/v3/@claude-flow/cli/dist/src/services/index.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/services/index.js +11 -0
- package/v3/@claude-flow/cli/dist/src/services/registry-api.d.ts +58 -0
- package/v3/@claude-flow/cli/dist/src/services/registry-api.js +146 -0
- package/v3/@claude-flow/cli/dist/src/services/ruvector-training.d.ts +222 -0
- package/v3/@claude-flow/cli/dist/src/services/ruvector-training.js +688 -0
- package/v3/@claude-flow/cli/dist/src/services/worker-daemon.d.ts +323 -0
- package/v3/@claude-flow/cli/dist/src/services/worker-daemon.js +1323 -0
- package/v3/@claude-flow/cli/dist/src/services/worker-queue.d.ts +194 -0
- package/v3/@claude-flow/cli/dist/src/services/worker-queue.js +513 -0
- package/v3/@claude-flow/cli/dist/src/suggest.d.ts +53 -0
- package/v3/@claude-flow/cli/dist/src/suggest.js +200 -0
- package/v3/@claude-flow/cli/dist/src/transfer/anonymization/index.d.ts +25 -0
- package/v3/@claude-flow/cli/dist/src/transfer/anonymization/index.js +175 -0
- package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/transfer/deploy-seraphine.js +205 -0
- package/v3/@claude-flow/cli/dist/src/transfer/export.d.ts +25 -0
- package/v3/@claude-flow/cli/dist/src/transfer/export.js +113 -0
- package/v3/@claude-flow/cli/dist/src/transfer/index.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/transfer/index.js +31 -0
- package/v3/@claude-flow/cli/dist/src/transfer/ipfs/client.d.ts +109 -0
- package/v3/@claude-flow/cli/dist/src/transfer/ipfs/client.js +307 -0
- package/v3/@claude-flow/cli/dist/src/transfer/ipfs/upload.d.ts +95 -0
- package/v3/@claude-flow/cli/dist/src/transfer/ipfs/upload.js +413 -0
- package/v3/@claude-flow/cli/dist/src/transfer/models/seraphine.d.ts +72 -0
- package/v3/@claude-flow/cli/dist/src/transfer/models/seraphine.js +373 -0
- package/v3/@claude-flow/cli/dist/src/transfer/serialization/cfp.d.ts +49 -0
- package/v3/@claude-flow/cli/dist/src/transfer/serialization/cfp.js +183 -0
- package/v3/@claude-flow/cli/dist/src/transfer/storage/gcs.d.ts +82 -0
- package/v3/@claude-flow/cli/dist/src/transfer/storage/gcs.js +272 -0
- package/v3/@claude-flow/cli/dist/src/transfer/storage/index.d.ts +6 -0
- package/v3/@claude-flow/cli/dist/src/transfer/storage/index.js +6 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/discovery.d.ts +84 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/discovery.js +382 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/download.d.ts +70 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/download.js +334 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/index.d.ts +84 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/index.js +153 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/publish.d.ts +76 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/publish.js +294 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/registry.d.ts +58 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/registry.js +285 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/search.d.ts +54 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/search.js +232 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/tests/standalone-test.js +190 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/types.d.ts +193 -0
- package/v3/@claude-flow/cli/dist/src/transfer/store/types.js +6 -0
- package/v3/@claude-flow/cli/dist/src/transfer/test-seraphine.d.ts +6 -0
- package/v3/@claude-flow/cli/dist/src/transfer/test-seraphine.js +105 -0
- package/v3/@claude-flow/cli/dist/src/transfer/tests/test-store.d.ts +7 -0
- package/v3/@claude-flow/cli/dist/src/transfer/tests/test-store.js +214 -0
- package/v3/@claude-flow/cli/dist/src/transfer/types.d.ts +245 -0
- package/v3/@claude-flow/cli/dist/src/transfer/types.js +6 -0
- package/v3/@claude-flow/cli/dist/src/types.d.ts +13 -0
- package/v3/@claude-flow/cli/dist/src/types.js +13 -0
- package/v3/@claude-flow/cli/dist/src/update/checker.d.ts +34 -0
- package/v3/@claude-flow/cli/dist/src/update/checker.js +191 -0
- package/v3/@claude-flow/cli/dist/src/update/executor.d.ts +33 -0
- package/v3/@claude-flow/cli/dist/src/update/executor.js +217 -0
- package/v3/@claude-flow/cli/dist/src/update/index.d.ts +33 -0
- package/v3/@claude-flow/cli/dist/src/update/index.js +64 -0
- package/v3/@claude-flow/cli/dist/src/update/rate-limiter.d.ts +20 -0
- package/v3/@claude-flow/cli/dist/src/update/rate-limiter.js +96 -0
- package/v3/@claude-flow/cli/dist/src/update/validator.d.ts +17 -0
- package/v3/@claude-flow/cli/dist/src/update/validator.js +123 -0
- package/v3/@claude-flow/cli/package.json +133 -0
- package/v3/@claude-flow/guidance/README.md +1195 -0
- package/v3/@claude-flow/guidance/package.json +198 -0
- package/v3/@claude-flow/shared/README.md +323 -0
- package/v3/@claude-flow/shared/package.json +43 -0
- 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
|