agentic-qe 3.3.3 → 3.3.5
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/v3/README.md +100 -0
- package/.claude/agents/v3/qe-accessibility-auditor.md +112 -11
- package/.claude/agents/v3/qe-bdd-generator.md +40 -0
- package/.claude/agents/v3/qe-coverage-specialist.md +39 -0
- package/.claude/agents/v3/qe-defect-predictor.md +36 -0
- package/.claude/agents/v3/qe-gap-detector.md +39 -0
- package/.claude/agents/v3/qe-pattern-learner.md +31 -0
- package/.claude/agents/v3/qe-product-factors-assessor.md +34 -0
- package/.claude/agents/v3/qe-quality-criteria-recommender.md +32 -0
- package/.claude/agents/v3/qe-quality-gate.md +39 -0
- package/.claude/agents/v3/qe-queen-coordinator.md +332 -166
- package/.claude/agents/v3/qe-requirements-validator.md +37 -0
- package/.claude/agents/v3/qe-risk-assessor.md +33 -0
- package/.claude/agents/v3/qe-tdd-specialist.md +33 -0
- package/.claude/agents/v3/qe-test-architect.md +36 -0
- package/.claude/helpers/statusline-v3.cjs +38 -42
- package/.claude/skills/README.md +30 -104
- package/.claude/skills/a11y-ally/SKILL.md +1658 -0
- package/.claude/skills/qcsd-ideation-swarm/SKILL.md +1750 -0
- package/.claude/skills/skills-manifest.json +78 -8
- package/README.md +18 -4
- package/package.json +1 -1
- package/scripts/cloud-db-config.json +10 -5
- package/scripts/demo-warmup.sh +45 -0
- package/scripts/fetch-content.js +460 -0
- package/scripts/merge-v3-to-root.sql +48 -0
- package/v3/CHANGELOG.md +166 -0
- package/v3/README.md +11 -6
- package/v3/assets/agents/v3/README.md +100 -0
- package/v3/assets/agents/v3/qe-accessibility-auditor.md +112 -11
- package/v3/assets/agents/v3/qe-bdd-generator.md +40 -0
- package/v3/assets/agents/v3/qe-coverage-specialist.md +39 -0
- package/v3/assets/agents/v3/qe-defect-predictor.md +36 -0
- package/v3/assets/agents/v3/qe-gap-detector.md +39 -0
- package/v3/assets/agents/v3/qe-pattern-learner.md +31 -0
- package/v3/assets/agents/v3/qe-product-factors-assessor.md +34 -0
- package/v3/assets/agents/v3/qe-quality-criteria-recommender.md +32 -0
- package/v3/assets/agents/v3/qe-quality-gate.md +39 -0
- package/v3/assets/agents/v3/qe-queen-coordinator.md +332 -166
- package/v3/assets/agents/v3/qe-requirements-validator.md +37 -0
- package/v3/assets/agents/v3/qe-risk-assessor.md +33 -0
- package/v3/assets/agents/v3/qe-tdd-specialist.md +33 -0
- package/v3/assets/agents/v3/qe-test-architect.md +36 -0
- package/v3/assets/hooks/cross-phase-memory.yaml +253 -0
- package/v3/assets/skills/a11y-ally/SKILL.md +1658 -0
- package/v3/assets/skills/qcsd-ideation-swarm/SKILL.md +1750 -0
- package/v3/assets/skills/skills-manifest.json +753 -0
- package/v3/dist/adapters/claude-flow/model-router-bridge.d.ts.map +1 -1
- package/v3/dist/adapters/claude-flow/model-router-bridge.js +6 -4
- package/v3/dist/adapters/claude-flow/model-router-bridge.js.map +1 -1
- package/v3/dist/adapters/claude-flow/pretrain-bridge.d.ts.map +1 -1
- package/v3/dist/adapters/claude-flow/pretrain-bridge.js +13 -8
- package/v3/dist/adapters/claude-flow/pretrain-bridge.js.map +1 -1
- package/v3/dist/adapters/claude-flow/trajectory-bridge.d.ts.map +1 -1
- package/v3/dist/adapters/claude-flow/trajectory-bridge.js +9 -6
- package/v3/dist/adapters/claude-flow/trajectory-bridge.js.map +1 -1
- package/v3/dist/benchmarks/performance-benchmarks.d.ts.map +1 -1
- package/v3/dist/benchmarks/performance-benchmarks.js +5 -3
- package/v3/dist/benchmarks/performance-benchmarks.js.map +1 -1
- package/v3/dist/cli/bundle.js +27646 -23204
- package/v3/dist/cli/commands/hooks.d.ts.map +1 -1
- package/v3/dist/cli/commands/hooks.js +288 -0
- package/v3/dist/cli/commands/hooks.js.map +1 -1
- package/v3/dist/cli/commands/sync.d.ts.map +1 -1
- package/v3/dist/cli/commands/sync.js +0 -6
- package/v3/dist/cli/commands/sync.js.map +1 -1
- package/v3/dist/cli/handlers/init-handler.d.ts.map +1 -1
- package/v3/dist/cli/handlers/init-handler.js +11 -0
- package/v3/dist/cli/handlers/init-handler.js.map +1 -1
- package/v3/dist/cli/index.js +14 -2
- package/v3/dist/cli/index.js.map +1 -1
- package/v3/dist/cli/scheduler/persistent-scheduler.d.ts.map +1 -1
- package/v3/dist/cli/scheduler/persistent-scheduler.js +3 -2
- package/v3/dist/cli/scheduler/persistent-scheduler.js.map +1 -1
- package/v3/dist/cli/wizards/test-wizard.d.ts.map +1 -1
- package/v3/dist/cli/wizards/test-wizard.js +6 -4
- package/v3/dist/cli/wizards/test-wizard.js.map +1 -1
- package/v3/dist/coordination/consensus/providers/claude-provider.js +1 -1
- package/v3/dist/coordination/consensus/providers/gemini-provider.js +1 -1
- package/v3/dist/coordination/consensus/providers/native-learning-provider.d.ts.map +1 -1
- package/v3/dist/coordination/consensus/providers/native-learning-provider.js +10 -8
- package/v3/dist/coordination/consensus/providers/native-learning-provider.js.map +1 -1
- package/v3/dist/coordination/consensus/providers/ollama-provider.d.ts.map +1 -1
- package/v3/dist/coordination/consensus/providers/ollama-provider.js +5 -4
- package/v3/dist/coordination/consensus/providers/ollama-provider.js.map +1 -1
- package/v3/dist/coordination/consensus/providers/openai-provider.d.ts.map +1 -1
- package/v3/dist/coordination/consensus/providers/openai-provider.js +5 -4
- package/v3/dist/coordination/consensus/providers/openai-provider.js.map +1 -1
- package/v3/dist/coordination/constants.d.ts +198 -0
- package/v3/dist/coordination/constants.d.ts.map +1 -0
- package/v3/dist/coordination/constants.js +210 -0
- package/v3/dist/coordination/constants.js.map +1 -0
- package/v3/dist/coordination/mincut/dream-integration.d.ts.map +1 -1
- package/v3/dist/coordination/mincut/dream-integration.js +5 -1
- package/v3/dist/coordination/mincut/dream-integration.js.map +1 -1
- package/v3/dist/coordination/queen-coordinator.d.ts +9 -1
- package/v3/dist/coordination/queen-coordinator.d.ts.map +1 -1
- package/v3/dist/coordination/queen-coordinator.js +49 -9
- package/v3/dist/coordination/queen-coordinator.js.map +1 -1
- package/v3/dist/coordination/task-executor.d.ts.map +1 -1
- package/v3/dist/coordination/task-executor.js +7 -8
- package/v3/dist/coordination/task-executor.js.map +1 -1
- package/v3/dist/coordination/workflow-orchestrator.d.ts.map +1 -1
- package/v3/dist/coordination/workflow-orchestrator.js +261 -0
- package/v3/dist/coordination/workflow-orchestrator.js.map +1 -1
- package/v3/dist/domains/chaos-resilience/plugin.d.ts +14 -3
- package/v3/dist/domains/chaos-resilience/plugin.d.ts.map +1 -1
- package/v3/dist/domains/chaos-resilience/plugin.js +96 -0
- package/v3/dist/domains/chaos-resilience/plugin.js.map +1 -1
- package/v3/dist/domains/chaos-resilience/services/performance-profiler.d.ts.map +1 -1
- package/v3/dist/domains/chaos-resilience/services/performance-profiler.js +12 -8
- package/v3/dist/domains/chaos-resilience/services/performance-profiler.js.map +1 -1
- package/v3/dist/domains/code-intelligence/plugin.d.ts +13 -3
- package/v3/dist/domains/code-intelligence/plugin.d.ts.map +1 -1
- package/v3/dist/domains/code-intelligence/plugin.js +85 -0
- package/v3/dist/domains/code-intelligence/plugin.js.map +1 -1
- package/v3/dist/domains/code-intelligence/services/product-factors-bridge.d.ts.map +1 -1
- package/v3/dist/domains/code-intelligence/services/product-factors-bridge.js +3 -2
- package/v3/dist/domains/code-intelligence/services/product-factors-bridge.js.map +1 -1
- package/v3/dist/domains/constants.d.ts +481 -0
- package/v3/dist/domains/constants.d.ts.map +1 -0
- package/v3/dist/domains/constants.js +503 -0
- package/v3/dist/domains/constants.js.map +1 -0
- package/v3/dist/domains/contract-testing/plugin.d.ts +6 -1
- package/v3/dist/domains/contract-testing/plugin.d.ts.map +1 -1
- package/v3/dist/domains/contract-testing/plugin.js +80 -1
- package/v3/dist/domains/contract-testing/plugin.js.map +1 -1
- package/v3/dist/domains/contract-testing/services/contract-validator.d.ts.map +1 -1
- package/v3/dist/domains/contract-testing/services/contract-validator.js +5 -4
- package/v3/dist/domains/contract-testing/services/contract-validator.js.map +1 -1
- package/v3/dist/domains/coverage-analysis/services/hnsw-index.d.ts.map +1 -1
- package/v3/dist/domains/coverage-analysis/services/hnsw-index.js +1 -0
- package/v3/dist/domains/coverage-analysis/services/hnsw-index.js.map +1 -1
- package/v3/dist/domains/defect-intelligence/coordinator.d.ts +2 -2
- package/v3/dist/domains/defect-intelligence/coordinator.d.ts.map +1 -1
- package/v3/dist/domains/defect-intelligence/coordinator.js.map +1 -1
- package/v3/dist/domains/defect-intelligence/plugin.d.ts +6 -1
- package/v3/dist/domains/defect-intelligence/plugin.d.ts.map +1 -1
- package/v3/dist/domains/defect-intelligence/plugin.js +101 -0
- package/v3/dist/domains/defect-intelligence/plugin.js.map +1 -1
- package/v3/dist/domains/defect-intelligence/services/defect-predictor.d.ts.map +1 -1
- package/v3/dist/domains/defect-intelligence/services/defect-predictor.js +3 -2
- package/v3/dist/domains/defect-intelligence/services/defect-predictor.js.map +1 -1
- package/v3/dist/domains/domain-interface.d.ts.map +1 -1
- package/v3/dist/domains/domain-interface.js +24 -9
- package/v3/dist/domains/domain-interface.js.map +1 -1
- package/v3/dist/domains/learning-optimization/plugin.d.ts +2 -1
- package/v3/dist/domains/learning-optimization/plugin.d.ts.map +1 -1
- package/v3/dist/domains/learning-optimization/plugin.js +49 -0
- package/v3/dist/domains/learning-optimization/plugin.js.map +1 -1
- package/v3/dist/domains/quality-assessment/coordinator.d.ts +90 -1
- package/v3/dist/domains/quality-assessment/coordinator.d.ts.map +1 -1
- package/v3/dist/domains/quality-assessment/coordinator.js +310 -0
- package/v3/dist/domains/quality-assessment/coordinator.js.map +1 -1
- package/v3/dist/domains/requirements-validation/index.d.ts +1 -0
- package/v3/dist/domains/requirements-validation/index.d.ts.map +1 -1
- package/v3/dist/domains/requirements-validation/index.js +2 -0
- package/v3/dist/domains/requirements-validation/index.js.map +1 -1
- package/v3/dist/domains/requirements-validation/plugin.d.ts +13 -1
- package/v3/dist/domains/requirements-validation/plugin.d.ts.map +1 -1
- package/v3/dist/domains/requirements-validation/plugin.js +94 -0
- package/v3/dist/domains/requirements-validation/plugin.js.map +1 -1
- package/v3/dist/domains/requirements-validation/qcsd-ideation-plugin.d.ts +245 -0
- package/v3/dist/domains/requirements-validation/qcsd-ideation-plugin.d.ts.map +1 -0
- package/v3/dist/domains/requirements-validation/qcsd-ideation-plugin.js +1143 -0
- package/v3/dist/domains/requirements-validation/qcsd-ideation-plugin.js.map +1 -0
- package/v3/dist/domains/requirements-validation/services/product-factors-assessment/code-intelligence/codebase-analyzer.d.ts.map +1 -1
- package/v3/dist/domains/requirements-validation/services/product-factors-assessment/code-intelligence/codebase-analyzer.js +3 -2
- package/v3/dist/domains/requirements-validation/services/product-factors-assessment/code-intelligence/codebase-analyzer.js.map +1 -1
- package/v3/dist/domains/security-compliance/plugin.d.ts +3 -2
- package/v3/dist/domains/security-compliance/plugin.d.ts.map +1 -1
- package/v3/dist/domains/security-compliance/plugin.js +64 -0
- package/v3/dist/domains/security-compliance/plugin.js.map +1 -1
- package/v3/dist/domains/security-compliance/services/scanners/dast-auth-testing.d.ts +25 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-auth-testing.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-auth-testing.js +160 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-auth-testing.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-helpers.d.ts +48 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-helpers.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-helpers.js +385 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-helpers.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-injection-testing.d.ts +20 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-injection-testing.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-injection-testing.js +99 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-injection-testing.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-scanner.d.ts +62 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-scanner.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-scanner.js +329 -0
- package/v3/dist/domains/security-compliance/services/scanners/dast-scanner.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dependency-scanner.d.ts +46 -0
- package/v3/dist/domains/security-compliance/services/scanners/dependency-scanner.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/dependency-scanner.js +180 -0
- package/v3/dist/domains/security-compliance/services/scanners/dependency-scanner.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/index.d.ts +14 -0
- package/v3/dist/domains/security-compliance/services/scanners/index.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/index.js +16 -0
- package/v3/dist/domains/security-compliance/services/scanners/index.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/sast-scanner.d.ts +92 -0
- package/v3/dist/domains/security-compliance/services/scanners/sast-scanner.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/sast-scanner.js +440 -0
- package/v3/dist/domains/security-compliance/services/scanners/sast-scanner.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/scanner-orchestrator.d.ts +78 -0
- package/v3/dist/domains/security-compliance/services/scanners/scanner-orchestrator.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/scanner-orchestrator.js +179 -0
- package/v3/dist/domains/security-compliance/services/scanners/scanner-orchestrator.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/scanner-types.d.ts +91 -0
- package/v3/dist/domains/security-compliance/services/scanners/scanner-types.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/scanner-types.js +15 -0
- package/v3/dist/domains/security-compliance/services/scanners/scanner-types.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/security-patterns.d.ts +16 -0
- package/v3/dist/domains/security-compliance/services/scanners/security-patterns.d.ts.map +1 -0
- package/v3/dist/domains/security-compliance/services/scanners/security-patterns.js +507 -0
- package/v3/dist/domains/security-compliance/services/scanners/security-patterns.js.map +1 -0
- package/v3/dist/domains/security-compliance/services/security-auditor.d.ts.map +1 -1
- package/v3/dist/domains/security-compliance/services/security-auditor.js +2 -1
- package/v3/dist/domains/security-compliance/services/security-auditor.js.map +1 -1
- package/v3/dist/domains/security-compliance/services/security-scanner.d.ts +20 -213
- package/v3/dist/domains/security-compliance/services/security-scanner.d.ts.map +1 -1
- package/v3/dist/domains/security-compliance/services/security-scanner.js +37 -2013
- package/v3/dist/domains/security-compliance/services/security-scanner.js.map +1 -1
- package/v3/dist/domains/security-compliance/services/semgrep-integration.d.ts.map +1 -1
- package/v3/dist/domains/security-compliance/services/semgrep-integration.js +7 -6
- package/v3/dist/domains/security-compliance/services/semgrep-integration.js.map +1 -1
- package/v3/dist/domains/test-execution/services/auth-state-manager.d.ts.map +1 -1
- package/v3/dist/domains/test-execution/services/auth-state-manager.js +6 -4
- package/v3/dist/domains/test-execution/services/auth-state-manager.js.map +1 -1
- package/v3/dist/domains/test-execution/services/e2e/assertion-handlers.d.ts +55 -0
- package/v3/dist/domains/test-execution/services/e2e/assertion-handlers.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/assertion-handlers.js +407 -0
- package/v3/dist/domains/test-execution/services/e2e/assertion-handlers.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/browser-orchestrator.d.ts +122 -0
- package/v3/dist/domains/test-execution/services/e2e/browser-orchestrator.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/browser-orchestrator.js +325 -0
- package/v3/dist/domains/test-execution/services/e2e/browser-orchestrator.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/e2e-coordinator.d.ts +97 -0
- package/v3/dist/domains/test-execution/services/e2e/e2e-coordinator.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/e2e-coordinator.js +297 -0
- package/v3/dist/domains/test-execution/services/e2e/e2e-coordinator.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/index.d.ts +22 -0
- package/v3/dist/domains/test-execution/services/e2e/index.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/index.js +52 -0
- package/v3/dist/domains/test-execution/services/e2e/index.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/result-collector.d.ts +51 -0
- package/v3/dist/domains/test-execution/services/e2e/result-collector.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/result-collector.js +133 -0
- package/v3/dist/domains/test-execution/services/e2e/result-collector.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/step-executors.d.ts +48 -0
- package/v3/dist/domains/test-execution/services/e2e/step-executors.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/step-executors.js +422 -0
- package/v3/dist/domains/test-execution/services/e2e/step-executors.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/step-retry-handler.d.ts +49 -0
- package/v3/dist/domains/test-execution/services/e2e/step-retry-handler.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/step-retry-handler.js +146 -0
- package/v3/dist/domains/test-execution/services/e2e/step-retry-handler.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/types.d.ts +138 -0
- package/v3/dist/domains/test-execution/services/e2e/types.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/types.js +65 -0
- package/v3/dist/domains/test-execution/services/e2e/types.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/wait-condition-handler.d.ts +33 -0
- package/v3/dist/domains/test-execution/services/e2e/wait-condition-handler.d.ts.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e/wait-condition-handler.js +114 -0
- package/v3/dist/domains/test-execution/services/e2e/wait-condition-handler.js.map +1 -0
- package/v3/dist/domains/test-execution/services/e2e-runner.d.ts +18 -392
- package/v3/dist/domains/test-execution/services/e2e-runner.d.ts.map +1 -1
- package/v3/dist/domains/test-execution/services/e2e-runner.js +25 -1757
- package/v3/dist/domains/test-execution/services/e2e-runner.js.map +1 -1
- package/v3/dist/domains/test-execution/services/flaky-detector.d.ts.map +1 -1
- package/v3/dist/domains/test-execution/services/flaky-detector.js +12 -9
- package/v3/dist/domains/test-execution/services/flaky-detector.js.map +1 -1
- package/v3/dist/domains/test-execution/services/retry-handler.d.ts.map +1 -1
- package/v3/dist/domains/test-execution/services/retry-handler.js +7 -5
- package/v3/dist/domains/test-execution/services/retry-handler.js.map +1 -1
- package/v3/dist/domains/test-execution/services/test-executor.d.ts.map +1 -1
- package/v3/dist/domains/test-execution/services/test-executor.js +4 -3
- package/v3/dist/domains/test-execution/services/test-executor.js.map +1 -1
- package/v3/dist/domains/visual-accessibility/coordinator.d.ts +70 -0
- package/v3/dist/domains/visual-accessibility/coordinator.d.ts.map +1 -1
- package/v3/dist/domains/visual-accessibility/coordinator.js +172 -0
- package/v3/dist/domains/visual-accessibility/coordinator.js.map +1 -1
- package/v3/dist/domains/visual-accessibility/plugin.d.ts +2 -1
- package/v3/dist/domains/visual-accessibility/plugin.d.ts.map +1 -1
- package/v3/dist/domains/visual-accessibility/plugin.js +63 -0
- package/v3/dist/domains/visual-accessibility/plugin.js.map +1 -1
- package/v3/dist/domains/visual-accessibility/services/accessibility-tester.d.ts.map +1 -1
- package/v3/dist/domains/visual-accessibility/services/accessibility-tester.js +3 -2
- package/v3/dist/domains/visual-accessibility/services/accessibility-tester.js.map +1 -1
- package/v3/dist/domains/visual-accessibility/services/browser-security-scanner.d.ts.map +1 -1
- package/v3/dist/domains/visual-accessibility/services/browser-security-scanner.js +22 -12
- package/v3/dist/domains/visual-accessibility/services/browser-security-scanner.js.map +1 -1
- package/v3/dist/domains/visual-accessibility/services/viewport-capture.d.ts.map +1 -1
- package/v3/dist/domains/visual-accessibility/services/viewport-capture.js +3 -2
- package/v3/dist/domains/visual-accessibility/services/viewport-capture.js.map +1 -1
- package/v3/dist/domains/visual-accessibility/services/visual-regression.d.ts.map +1 -1
- package/v3/dist/domains/visual-accessibility/services/visual-regression.js +3 -2
- package/v3/dist/domains/visual-accessibility/services/visual-regression.js.map +1 -1
- package/v3/dist/hooks/cross-phase-hooks.d.ts +42 -0
- package/v3/dist/hooks/cross-phase-hooks.d.ts.map +1 -0
- package/v3/dist/hooks/cross-phase-hooks.js +338 -0
- package/v3/dist/hooks/cross-phase-hooks.js.map +1 -0
- package/v3/dist/hooks/index.d.ts +9 -0
- package/v3/dist/hooks/index.d.ts.map +1 -0
- package/v3/dist/hooks/index.js +9 -0
- package/v3/dist/hooks/index.js.map +1 -0
- package/v3/dist/init/agents-installer.d.ts.map +1 -1
- package/v3/dist/init/agents-installer.js +6 -4
- package/v3/dist/init/agents-installer.js.map +1 -1
- package/v3/dist/init/enhancements/claude-flow-adapter.d.ts.map +1 -1
- package/v3/dist/init/enhancements/claude-flow-adapter.js +15 -9
- package/v3/dist/init/enhancements/claude-flow-adapter.js.map +1 -1
- package/v3/dist/init/enhancements/detector.js +6 -4
- package/v3/dist/init/enhancements/detector.js.map +1 -1
- package/v3/dist/init/init-wizard.d.ts +5 -0
- package/v3/dist/init/init-wizard.d.ts.map +1 -1
- package/v3/dist/init/init-wizard.js +77 -14
- package/v3/dist/init/init-wizard.js.map +1 -1
- package/v3/dist/init/migration/data-migrator.d.ts.map +1 -1
- package/v3/dist/init/migration/data-migrator.js +6 -4
- package/v3/dist/init/migration/data-migrator.js.map +1 -1
- package/v3/dist/init/phases/02-analysis.js +2 -2
- package/v3/dist/init/phases/02-analysis.js.map +1 -1
- package/v3/dist/init/phases/04-database.d.ts.map +1 -1
- package/v3/dist/init/phases/04-database.js +0 -1
- package/v3/dist/init/phases/04-database.js.map +1 -1
- package/v3/dist/init/phases/05-learning.js +1 -1
- package/v3/dist/init/phases/05-learning.js.map +1 -1
- package/v3/dist/init/phases/11-claude-md.d.ts.map +1 -1
- package/v3/dist/init/phases/11-claude-md.js +25 -0
- package/v3/dist/init/phases/11-claude-md.js.map +1 -1
- package/v3/dist/init/phases/12-verification.d.ts.map +1 -1
- package/v3/dist/init/phases/12-verification.js +2 -1
- package/v3/dist/init/phases/12-verification.js.map +1 -1
- package/v3/dist/init/project-analyzer.d.ts.map +1 -1
- package/v3/dist/init/project-analyzer.js +12 -8
- package/v3/dist/init/project-analyzer.js.map +1 -1
- package/v3/dist/init/skills-installer.d.ts.map +1 -1
- package/v3/dist/init/skills-installer.js +6 -4
- package/v3/dist/init/skills-installer.js.map +1 -1
- package/v3/dist/init/token-bootstrap.d.ts.map +1 -1
- package/v3/dist/init/token-bootstrap.js +2 -1
- package/v3/dist/init/token-bootstrap.js.map +1 -1
- package/v3/dist/integrations/agent-booster-wasm/index.d.ts.map +1 -1
- package/v3/dist/integrations/agent-booster-wasm/index.js +8 -4
- package/v3/dist/integrations/agent-booster-wasm/index.js.map +1 -1
- package/v3/dist/integrations/agentic-flow/model-router/signal-collector.d.ts.map +1 -1
- package/v3/dist/integrations/agentic-flow/model-router/signal-collector.js +3 -2
- package/v3/dist/integrations/agentic-flow/model-router/signal-collector.js.map +1 -1
- package/v3/dist/integrations/agentic-flow/reasoning-bank/experience-replay.d.ts.map +1 -1
- package/v3/dist/integrations/agentic-flow/reasoning-bank/experience-replay.js.map +1 -1
- package/v3/dist/integrations/agentic-flow/reasoning-bank/trajectory-tracker.d.ts.map +1 -1
- package/v3/dist/integrations/agentic-flow/reasoning-bank/trajectory-tracker.js.map +1 -1
- package/v3/dist/integrations/browser/agent-browser/client.d.ts.map +1 -1
- package/v3/dist/integrations/browser/agent-browser/client.js +9 -6
- package/v3/dist/integrations/browser/agent-browser/client.js.map +1 -1
- package/v3/dist/integrations/browser/agent-browser/command-executor.d.ts.map +1 -1
- package/v3/dist/integrations/browser/agent-browser/command-executor.js +3 -2
- package/v3/dist/integrations/browser/agent-browser/command-executor.js.map +1 -1
- package/v3/dist/integrations/browser/index.d.ts +1 -0
- package/v3/dist/integrations/browser/index.d.ts.map +1 -1
- package/v3/dist/integrations/browser/index.js +6 -0
- package/v3/dist/integrations/browser/index.js.map +1 -1
- package/v3/dist/integrations/browser/web-content-fetcher.d.ts +154 -0
- package/v3/dist/integrations/browser/web-content-fetcher.d.ts.map +1 -0
- package/v3/dist/integrations/browser/web-content-fetcher.js +529 -0
- package/v3/dist/integrations/browser/web-content-fetcher.js.map +1 -0
- package/v3/dist/integrations/coherence/threshold-tuner.d.ts.map +1 -1
- package/v3/dist/integrations/coherence/threshold-tuner.js +3 -2
- package/v3/dist/integrations/coherence/threshold-tuner.js.map +1 -1
- package/v3/dist/integrations/coherence/wasm-loader.d.ts.map +1 -1
- package/v3/dist/integrations/coherence/wasm-loader.js +3 -2
- package/v3/dist/integrations/coherence/wasm-loader.js.map +1 -1
- package/v3/dist/integrations/n8n/agent-factory.d.ts.map +1 -1
- package/v3/dist/integrations/n8n/agent-factory.js +6 -4
- package/v3/dist/integrations/n8n/agent-factory.js.map +1 -1
- package/v3/dist/integrations/rl-suite/persistence/q-value-store.d.ts.map +1 -1
- package/v3/dist/integrations/rl-suite/persistence/q-value-store.js.map +1 -1
- package/v3/dist/integrations/ruvector/interfaces.js +1 -1
- package/v3/dist/integrations/ruvector/interfaces.js.map +1 -1
- package/v3/dist/integrations/ruvector/sona-persistence.d.ts.map +1 -1
- package/v3/dist/integrations/ruvector/sona-persistence.js +6 -4
- package/v3/dist/integrations/ruvector/sona-persistence.js.map +1 -1
- package/v3/dist/integrations/vibium/client.d.ts.map +1 -1
- package/v3/dist/integrations/vibium/client.js +3 -2
- package/v3/dist/integrations/vibium/client.js.map +1 -1
- package/v3/dist/kernel/agent-coordinator.d.ts +1 -1
- package/v3/dist/kernel/agent-coordinator.d.ts.map +1 -1
- package/v3/dist/kernel/agent-coordinator.js +4 -4
- package/v3/dist/kernel/agent-coordinator.js.map +1 -1
- package/v3/dist/kernel/constants.d.ts +155 -0
- package/v3/dist/kernel/constants.d.ts.map +1 -0
- package/v3/dist/kernel/constants.js +169 -0
- package/v3/dist/kernel/constants.js.map +1 -0
- package/v3/dist/kernel/event-bus.d.ts +8 -0
- package/v3/dist/kernel/event-bus.d.ts.map +1 -1
- package/v3/dist/kernel/event-bus.js +79 -17
- package/v3/dist/kernel/event-bus.js.map +1 -1
- package/v3/dist/kernel/hybrid-backend.d.ts.map +1 -1
- package/v3/dist/kernel/hybrid-backend.js +4 -3
- package/v3/dist/kernel/hybrid-backend.js.map +1 -1
- package/v3/dist/kernel/index.d.ts +1 -1
- package/v3/dist/kernel/index.d.ts.map +1 -1
- package/v3/dist/kernel/index.js +3 -1
- package/v3/dist/kernel/index.js.map +1 -1
- package/v3/dist/kernel/kernel.d.ts.map +1 -1
- package/v3/dist/kernel/kernel.js +3 -2
- package/v3/dist/kernel/kernel.js.map +1 -1
- package/v3/dist/kernel/memory-backend.d.ts.map +1 -1
- package/v3/dist/kernel/memory-backend.js +4 -3
- package/v3/dist/kernel/memory-backend.js.map +1 -1
- package/v3/dist/kernel/unified-memory.d.ts +26 -0
- package/v3/dist/kernel/unified-memory.d.ts.map +1 -1
- package/v3/dist/kernel/unified-memory.js +68 -13
- package/v3/dist/kernel/unified-memory.js.map +1 -1
- package/v3/dist/kernel/unified-persistence.js +3 -2
- package/v3/dist/kernel/unified-persistence.js.map +1 -1
- package/v3/dist/learning/aqe-learning-engine.d.ts.map +1 -1
- package/v3/dist/learning/aqe-learning-engine.js +12 -8
- package/v3/dist/learning/aqe-learning-engine.js.map +1 -1
- package/v3/dist/learning/dream/index.d.ts +1 -1
- package/v3/dist/learning/dream/index.d.ts.map +1 -1
- package/v3/dist/learning/dream/index.js +3 -1
- package/v3/dist/learning/dream/index.js.map +1 -1
- package/v3/dist/learning/dream/spreading-activation.d.ts +41 -0
- package/v3/dist/learning/dream/spreading-activation.d.ts.map +1 -1
- package/v3/dist/learning/dream/spreading-activation.js +79 -0
- package/v3/dist/learning/dream/spreading-activation.js.map +1 -1
- package/v3/dist/learning/pattern-store.d.ts.map +1 -1
- package/v3/dist/learning/pattern-store.js +16 -6
- package/v3/dist/learning/pattern-store.js.map +1 -1
- package/v3/dist/learning/qe-unified-memory.js +1 -1
- package/v3/dist/learning/qe-unified-memory.js.map +1 -1
- package/v3/dist/learning/real-embeddings.d.ts.map +1 -1
- package/v3/dist/learning/real-embeddings.js +7 -1
- package/v3/dist/learning/real-embeddings.js.map +1 -1
- package/v3/dist/learning/real-qe-reasoning-bank.js +2 -2
- package/v3/dist/learning/real-qe-reasoning-bank.js.map +1 -1
- package/v3/dist/learning/sqlite-persistence.d.ts +2 -2
- package/v3/dist/learning/sqlite-persistence.d.ts.map +1 -1
- package/v3/dist/learning/sqlite-persistence.js +1 -1
- package/v3/dist/learning/sqlite-persistence.js.map +1 -1
- package/v3/dist/learning/v2-to-v3-migration.d.ts +2 -2
- package/v3/dist/learning/v2-to-v3-migration.d.ts.map +1 -1
- package/v3/dist/learning/v2-to-v3-migration.js +2 -2
- package/v3/dist/learning/v2-to-v3-migration.js.map +1 -1
- package/v3/dist/logging/console-logger.d.ts +96 -0
- package/v3/dist/logging/console-logger.d.ts.map +1 -0
- package/v3/dist/logging/console-logger.js +247 -0
- package/v3/dist/logging/console-logger.js.map +1 -0
- package/v3/dist/logging/index.d.ts +42 -0
- package/v3/dist/logging/index.d.ts.map +1 -0
- package/v3/dist/logging/index.js +39 -0
- package/v3/dist/logging/index.js.map +1 -0
- package/v3/dist/logging/logger-factory.d.ts +145 -0
- package/v3/dist/logging/logger-factory.d.ts.map +1 -0
- package/v3/dist/logging/logger-factory.js +218 -0
- package/v3/dist/logging/logger-factory.js.map +1 -0
- package/v3/dist/logging/logger.d.ts +89 -0
- package/v3/dist/logging/logger.d.ts.map +1 -0
- package/v3/dist/logging/logger.js +74 -0
- package/v3/dist/logging/logger.js.map +1 -0
- package/v3/dist/mcp/bundle.js +11385 -7526
- package/v3/dist/mcp/handlers/agent-handlers.js +2 -2
- package/v3/dist/mcp/handlers/agent-handlers.js.map +1 -1
- package/v3/dist/mcp/handlers/core-handlers.d.ts +2 -0
- package/v3/dist/mcp/handlers/core-handlers.d.ts.map +1 -1
- package/v3/dist/mcp/handlers/core-handlers.js +33 -0
- package/v3/dist/mcp/handlers/core-handlers.js.map +1 -1
- package/v3/dist/mcp/handlers/cross-phase-handlers.d.ts +110 -0
- package/v3/dist/mcp/handlers/cross-phase-handlers.d.ts.map +1 -0
- package/v3/dist/mcp/handlers/cross-phase-handlers.js +216 -0
- package/v3/dist/mcp/handlers/cross-phase-handlers.js.map +1 -0
- package/v3/dist/mcp/handlers/domain-handler-configs.d.ts +151 -0
- package/v3/dist/mcp/handlers/domain-handler-configs.d.ts.map +1 -0
- package/v3/dist/mcp/handlers/domain-handler-configs.js +486 -0
- package/v3/dist/mcp/handlers/domain-handler-configs.js.map +1 -0
- package/v3/dist/mcp/handlers/domain-handlers.d.ts +174 -120
- package/v3/dist/mcp/handlers/domain-handlers.d.ts.map +1 -1
- package/v3/dist/mcp/handlers/domain-handlers.js +178 -1049
- package/v3/dist/mcp/handlers/domain-handlers.js.map +1 -1
- package/v3/dist/mcp/handlers/handler-factory.d.ts +182 -0
- package/v3/dist/mcp/handlers/handler-factory.d.ts.map +1 -0
- package/v3/dist/mcp/handlers/handler-factory.js +327 -0
- package/v3/dist/mcp/handlers/handler-factory.js.map +1 -0
- package/v3/dist/mcp/handlers/index.d.ts +1 -0
- package/v3/dist/mcp/handlers/index.d.ts.map +1 -1
- package/v3/dist/mcp/handlers/index.js +2 -0
- package/v3/dist/mcp/handlers/index.js.map +1 -1
- package/v3/dist/mcp/handlers/task-handlers.d.ts +1 -0
- package/v3/dist/mcp/handlers/task-handlers.d.ts.map +1 -1
- package/v3/dist/mcp/handlers/task-handlers.js +91 -7
- package/v3/dist/mcp/handlers/task-handlers.js.map +1 -1
- package/v3/dist/mcp/server.d.ts.map +1 -1
- package/v3/dist/mcp/server.js +107 -1
- package/v3/dist/mcp/server.js.map +1 -1
- package/v3/dist/mcp/types.d.ts +5 -3
- package/v3/dist/mcp/types.d.ts.map +1 -1
- package/v3/dist/memory/cross-phase-memory.d.ts +55 -0
- package/v3/dist/memory/cross-phase-memory.d.ts.map +1 -0
- package/v3/dist/memory/cross-phase-memory.js +265 -0
- package/v3/dist/memory/cross-phase-memory.js.map +1 -0
- package/v3/dist/memory/index.d.ts +9 -0
- package/v3/dist/memory/index.d.ts.map +1 -0
- package/v3/dist/memory/index.js +9 -0
- package/v3/dist/memory/index.js.map +1 -0
- package/v3/dist/shared/io/file-reader.d.ts.map +1 -1
- package/v3/dist/shared/io/file-reader.js +3 -2
- package/v3/dist/shared/io/file-reader.js.map +1 -1
- package/v3/dist/shared/utils/binary-insert.d.ts +85 -0
- package/v3/dist/shared/utils/binary-insert.d.ts.map +1 -0
- package/v3/dist/shared/utils/binary-insert.js +122 -0
- package/v3/dist/shared/utils/binary-insert.js.map +1 -0
- package/v3/dist/shared/utils/index.d.ts +1 -0
- package/v3/dist/shared/utils/index.d.ts.map +1 -1
- package/v3/dist/shared/utils/index.js +1 -0
- package/v3/dist/shared/utils/index.js.map +1 -1
- package/v3/dist/strange-loop/belief-reconciler.d.ts.map +1 -1
- package/v3/dist/strange-loop/belief-reconciler.js +3 -2
- package/v3/dist/strange-loop/belief-reconciler.js.map +1 -1
- package/v3/dist/sync/claude-flow-bridge.d.ts +1 -1
- package/v3/dist/sync/claude-flow-bridge.d.ts.map +1 -1
- package/v3/dist/sync/claude-flow-bridge.js +7 -5
- package/v3/dist/sync/claude-flow-bridge.js.map +1 -1
- package/v3/dist/sync/cloud/postgres-writer.d.ts.map +1 -1
- package/v3/dist/sync/cloud/postgres-writer.js +0 -1
- package/v3/dist/sync/cloud/postgres-writer.js.map +1 -1
- package/v3/dist/sync/interfaces.d.ts +6 -0
- package/v3/dist/sync/interfaces.d.ts.map +1 -1
- package/v3/dist/sync/interfaces.js +34 -47
- package/v3/dist/sync/interfaces.js.map +1 -1
- package/v3/dist/sync/readers/sqlite-reader.d.ts +1 -1
- package/v3/dist/sync/readers/sqlite-reader.d.ts.map +1 -1
- package/v3/dist/sync/readers/sqlite-reader.js +4 -3
- package/v3/dist/sync/readers/sqlite-reader.js.map +1 -1
- package/v3/dist/test-scheduling/flaky-tracking/flaky-tracker.d.ts.map +1 -1
- package/v3/dist/test-scheduling/flaky-tracking/flaky-tracker.js +3 -2
- package/v3/dist/test-scheduling/flaky-tracking/flaky-tracker.js.map +1 -1
- package/v3/dist/test-scheduling/git-aware/test-selector.d.ts.map +1 -1
- package/v3/dist/test-scheduling/git-aware/test-selector.js +3 -2
- package/v3/dist/test-scheduling/git-aware/test-selector.js.map +1 -1
- package/v3/dist/types/cross-phase-signals.d.ts +119 -0
- package/v3/dist/types/cross-phase-signals.d.ts.map +1 -0
- package/v3/dist/types/cross-phase-signals.js +33 -0
- package/v3/dist/types/cross-phase-signals.js.map +1 -0
- package/v3/dist/types/index.d.ts +9 -0
- package/v3/dist/types/index.d.ts.map +1 -0
- package/v3/dist/types/index.js +9 -0
- package/v3/dist/types/index.js.map +1 -0
- package/v3/dist/workers/worker-manager.d.ts.map +1 -1
- package/v3/dist/workers/worker-manager.js +3 -2
- package/v3/dist/workers/worker-manager.js.map +1 -1
- package/v3/dist/workflows/browser/workflow-loader.d.ts +3 -3
- package/v3/dist/workflows/browser/workflow-loader.d.ts.map +1 -1
- package/v3/dist/workflows/browser/workflow-loader.js.map +1 -1
- package/v3/package.json +4 -1
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - Security Scanners Module
|
|
3
|
+
* Exports all scanner components and types
|
|
4
|
+
*/
|
|
5
|
+
export { SecurityScannerService } from './scanner-orchestrator.js';
|
|
6
|
+
export { SASTScanner } from './sast-scanner.js';
|
|
7
|
+
export { DASTScanner } from './dast-scanner.js';
|
|
8
|
+
export { DependencyScanner } from './dependency-scanner.js';
|
|
9
|
+
export type { SecurityScannerConfig, SecurityScannerDependencies, ISecurityScannerService, FullScanResult, DependencyScanResult, SecurityPattern, MutableScanSummary, } from './scanner-types.js';
|
|
10
|
+
export { DEFAULT_CONFIG } from './scanner-types.js';
|
|
11
|
+
export type { Vulnerability, VulnerabilitySeverity, VulnerabilityCategory, VulnerabilityLocation, RemediationAdvice, ScanSummary, SecurityCoverage, ScanStatus, SASTResult, DASTResult, DASTOptions, AuthCredentials, RuleSet, FalsePositiveCheck, } from './scanner-types.js';
|
|
12
|
+
export { ALL_SECURITY_PATTERNS, SQL_INJECTION_PATTERNS, XSS_PATTERNS, SECRET_PATTERNS, PATH_TRAVERSAL_PATTERNS, COMMAND_INJECTION_PATTERNS, MISCONFIGURATION_PATTERNS, DESERIALIZATION_PATTERNS, AUTH_PATTERNS, BUILT_IN_RULE_SETS, } from './security-patterns.js';
|
|
13
|
+
export { analyzeSecurityHeaders, analyzeCookieSecurity, analyzeServerHeaders, scanSensitiveFiles, analyzeCORS, extractAndCrawlLinks, testXSS, testSQLi, analyzeFormsForSecurityIssues, testAuthorizationBypass, testIDOR, validateCredentials, buildAuthHeaders, handleFetchError, calculateSummary, storeScanResults, } from './dast-helpers.js';
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAGnE,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAG5D,YAAY,EACV,qBAAqB,EACrB,2BAA2B,EAC3B,uBAAuB,EACvB,cAAc,EACd,oBAAoB,EACpB,eAAe,EACf,kBAAkB,GACnB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAGpD,YAAY,EACV,aAAa,EACb,qBAAqB,EACrB,qBAAqB,EACrB,qBAAqB,EACrB,iBAAiB,EACjB,WAAW,EACX,gBAAgB,EAChB,UAAU,EACV,UAAU,EACV,UAAU,EACV,WAAW,EACX,eAAe,EACf,OAAO,EACP,kBAAkB,GACnB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EACL,qBAAqB,EACrB,sBAAsB,EACtB,YAAY,EACZ,eAAe,EACf,uBAAuB,EACvB,0BAA0B,EAC1B,yBAAyB,EACzB,wBAAwB,EACxB,aAAa,EACb,kBAAkB,GACnB,MAAM,wBAAwB,CAAC;AAGhC,OAAO,EACL,sBAAsB,EACtB,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,EAClB,WAAW,EACX,oBAAoB,EACpB,OAAO,EACP,QAAQ,EACR,6BAA6B,EAC7B,uBAAuB,EACvB,QAAQ,EACR,mBAAmB,EACnB,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - Security Scanners Module
|
|
3
|
+
* Exports all scanner components and types
|
|
4
|
+
*/
|
|
5
|
+
// Main orchestrator (facade for backward compatibility)
|
|
6
|
+
export { SecurityScannerService } from './scanner-orchestrator.js';
|
|
7
|
+
// Individual scanners
|
|
8
|
+
export { SASTScanner } from './sast-scanner.js';
|
|
9
|
+
export { DASTScanner } from './dast-scanner.js';
|
|
10
|
+
export { DependencyScanner } from './dependency-scanner.js';
|
|
11
|
+
export { DEFAULT_CONFIG } from './scanner-types.js';
|
|
12
|
+
// Security patterns
|
|
13
|
+
export { ALL_SECURITY_PATTERNS, SQL_INJECTION_PATTERNS, XSS_PATTERNS, SECRET_PATTERNS, PATH_TRAVERSAL_PATTERNS, COMMAND_INJECTION_PATTERNS, MISCONFIGURATION_PATTERNS, DESERIALIZATION_PATTERNS, AUTH_PATTERNS, BUILT_IN_RULE_SETS, } from './security-patterns.js';
|
|
14
|
+
// DAST helper functions (for advanced/custom usage)
|
|
15
|
+
export { analyzeSecurityHeaders, analyzeCookieSecurity, analyzeServerHeaders, scanSensitiveFiles, analyzeCORS, extractAndCrawlLinks, testXSS, testSQLi, analyzeFormsForSecurityIssues, testAuthorizationBypass, testIDOR, validateCredentials, buildAuthHeaders, handleFetchError, calculateSummary, storeScanResults, } from './dast-helpers.js';
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,wDAAwD;AACxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAEnE,sBAAsB;AACtB,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAa5D,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAoBpD,oBAAoB;AACpB,OAAO,EACL,qBAAqB,EACrB,sBAAsB,EACtB,YAAY,EACZ,eAAe,EACf,uBAAuB,EACvB,0BAA0B,EAC1B,yBAAyB,EACzB,wBAAwB,EACxB,aAAa,EACb,kBAAkB,GACnB,MAAM,wBAAwB,CAAC;AAEhC,oDAAoD;AACpD,OAAO,EACL,sBAAsB,EACtB,qBAAqB,EACrB,oBAAoB,EACpB,kBAAkB,EAClB,WAAW,EACX,oBAAoB,EACpB,OAAO,EACP,QAAQ,EACR,6BAA6B,EAC7B,uBAAuB,EACvB,QAAQ,EACR,mBAAmB,EACnB,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - SAST (Static Application Security Testing) Scanner
|
|
3
|
+
* Performs static code analysis to detect security vulnerabilities
|
|
4
|
+
*/
|
|
5
|
+
import { Result } from '../../../../shared/types/index.js';
|
|
6
|
+
import type { FilePath } from '../../../../shared/value-objects/index.js';
|
|
7
|
+
import type { SecurityScannerConfig, Vulnerability, RemediationAdvice, SASTResult, RuleSet, FalsePositiveCheck, MemoryBackend, HybridRouter, ScanStatus } from './scanner-types.js';
|
|
8
|
+
/**
|
|
9
|
+
* SAST Scanner - Static Application Security Testing
|
|
10
|
+
* Scans source code files for security vulnerabilities using pattern matching
|
|
11
|
+
*/
|
|
12
|
+
export declare class SASTScanner {
|
|
13
|
+
private readonly config;
|
|
14
|
+
private readonly memory;
|
|
15
|
+
private readonly llmRouter?;
|
|
16
|
+
private readonly activeScans;
|
|
17
|
+
constructor(config: SecurityScannerConfig, memory: MemoryBackend, llmRouter?: HybridRouter, activeScans?: Map<string, ScanStatus>);
|
|
18
|
+
/**
|
|
19
|
+
* Scan files for security vulnerabilities using static analysis
|
|
20
|
+
*/
|
|
21
|
+
scanFiles(files: FilePath[]): Promise<Result<SASTResult>>;
|
|
22
|
+
/**
|
|
23
|
+
* Scan with specific rule sets
|
|
24
|
+
*/
|
|
25
|
+
scanWithRules(files: FilePath[], ruleSetIds: string[]): Promise<Result<SASTResult>>;
|
|
26
|
+
/**
|
|
27
|
+
* Get available rule sets
|
|
28
|
+
*/
|
|
29
|
+
getAvailableRuleSets(): Promise<RuleSet[]>;
|
|
30
|
+
/**
|
|
31
|
+
* Check if vulnerability is a false positive
|
|
32
|
+
*/
|
|
33
|
+
checkFalsePositive(vulnerability: Vulnerability): Promise<Result<FalsePositiveCheck>>;
|
|
34
|
+
/**
|
|
35
|
+
* Analyze a file for security vulnerabilities using pattern-based detection
|
|
36
|
+
*/
|
|
37
|
+
private analyzeFile;
|
|
38
|
+
/**
|
|
39
|
+
* Find all matches of a security pattern in the file content
|
|
40
|
+
*/
|
|
41
|
+
private findPatternMatches;
|
|
42
|
+
/**
|
|
43
|
+
* Convert character index to line and column numbers
|
|
44
|
+
*/
|
|
45
|
+
private getLineAndColumn;
|
|
46
|
+
/**
|
|
47
|
+
* Check if the match is inside a comment
|
|
48
|
+
*/
|
|
49
|
+
private isInComment;
|
|
50
|
+
/**
|
|
51
|
+
* Check if the snippet appears to be in documentation or test code examples
|
|
52
|
+
*/
|
|
53
|
+
private isInDocumentation;
|
|
54
|
+
/**
|
|
55
|
+
* Check if the line has a nosec annotation
|
|
56
|
+
*/
|
|
57
|
+
private hasNosecAnnotation;
|
|
58
|
+
/**
|
|
59
|
+
* Create a Vulnerability object from a pattern match
|
|
60
|
+
*/
|
|
61
|
+
private createVulnerabilityFromPattern;
|
|
62
|
+
private getEffortForSeverity;
|
|
63
|
+
/**
|
|
64
|
+
* Analyze if a vulnerability detection is a false positive using heuristics
|
|
65
|
+
*/
|
|
66
|
+
private analyzeFalsePositive;
|
|
67
|
+
/**
|
|
68
|
+
* Calculate scan summary from vulnerabilities
|
|
69
|
+
*/
|
|
70
|
+
private calculateSummary;
|
|
71
|
+
/**
|
|
72
|
+
* Store scan results in memory
|
|
73
|
+
*/
|
|
74
|
+
private storeScanResults;
|
|
75
|
+
/**
|
|
76
|
+
* Check if LLM analysis is available and enabled
|
|
77
|
+
*/
|
|
78
|
+
isLLMAnalysisAvailable(): boolean;
|
|
79
|
+
/**
|
|
80
|
+
* Get model ID for the configured tier
|
|
81
|
+
*/
|
|
82
|
+
getModelForTier(tier: number): string;
|
|
83
|
+
/**
|
|
84
|
+
* Analyze vulnerability with LLM for deeper insights
|
|
85
|
+
*/
|
|
86
|
+
analyzeVulnerabilityWithLLM(vuln: Vulnerability, codeContext: string): Promise<RemediationAdvice>;
|
|
87
|
+
/**
|
|
88
|
+
* Get default remediation advice without LLM
|
|
89
|
+
*/
|
|
90
|
+
private getDefaultRemediation;
|
|
91
|
+
}
|
|
92
|
+
//# sourceMappingURL=sast-scanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sast-scanner.d.ts","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/sast-scanner.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,MAAM,EAAW,MAAM,mCAAmC,CAAC;AACpE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,2CAA2C,CAAC;AAC1E,OAAO,KAAK,EAEV,qBAAqB,EACrB,aAAa,EAGb,iBAAiB,EAGjB,UAAU,EACV,OAAO,EACP,kBAAkB,EAClB,aAAa,EACb,YAAY,EAGZ,UAAU,EACX,MAAM,oBAAoB,CAAC;AAO5B;;;GAGG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAwB;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAgB;IACvC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAe;IAC1C,OAAO,CAAC,QAAQ,CAAC,WAAW,CAA0B;gBAGpD,MAAM,EAAE,qBAAqB,EAC7B,MAAM,EAAE,aAAa,EACrB,SAAS,CAAC,EAAE,YAAY,EACxB,WAAW,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC;IAYvC;;OAEG;IACG,SAAS,CAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAI/D;;OAEG;IACG,aAAa,CACjB,KAAK,EAAE,QAAQ,EAAE,EACjB,UAAU,EAAE,MAAM,EAAE,GACnB,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IA+D9B;;OAEG;IACG,oBAAoB,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;IAShD;;OAEG;IACG,kBAAkB,CACtB,aAAa,EAAE,aAAa,GAC3B,OAAO,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC;IA8BtC;;OAEG;YACW,WAAW;IA2DzB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IA8B1B;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAQxB;;OAEG;IACH,OAAO,CAAC,WAAW;IAuBnB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAWzB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAqB1B;;OAEG;IACH,OAAO,CAAC,8BAA8B;IAmCtC,OAAO,CAAC,oBAAoB;IAa5B;;OAEG;YACW,oBAAoB;IA+BlC;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAsBxB;;OAEG;YACW,gBAAgB;IAuB9B;;OAEG;IACH,sBAAsB,IAAI,OAAO;IAIjC;;OAEG;IACH,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAUrC;;OAEG;IACG,2BAA2B,CAC/B,IAAI,EAAE,aAAa,EACnB,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,iBAAiB,CAAC;IA8D7B;;OAEG;IACH,OAAO,CAAC,qBAAqB;CAO9B"}
|
|
@@ -0,0 +1,440 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - SAST (Static Application Security Testing) Scanner
|
|
3
|
+
* Performs static code analysis to detect security vulnerabilities
|
|
4
|
+
*/
|
|
5
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
6
|
+
import { ok, err } from '../../../../shared/types/index.js';
|
|
7
|
+
import { ALL_SECURITY_PATTERNS, BUILT_IN_RULE_SETS } from './security-patterns.js';
|
|
8
|
+
// ============================================================================
|
|
9
|
+
// SAST Scanner Service
|
|
10
|
+
// ============================================================================
|
|
11
|
+
/**
|
|
12
|
+
* SAST Scanner - Static Application Security Testing
|
|
13
|
+
* Scans source code files for security vulnerabilities using pattern matching
|
|
14
|
+
*/
|
|
15
|
+
export class SASTScanner {
|
|
16
|
+
config;
|
|
17
|
+
memory;
|
|
18
|
+
llmRouter;
|
|
19
|
+
activeScans;
|
|
20
|
+
constructor(config, memory, llmRouter, activeScans) {
|
|
21
|
+
this.config = config;
|
|
22
|
+
this.memory = memory;
|
|
23
|
+
this.llmRouter = llmRouter;
|
|
24
|
+
this.activeScans = activeScans || new Map();
|
|
25
|
+
}
|
|
26
|
+
// ==========================================================================
|
|
27
|
+
// Public Methods
|
|
28
|
+
// ==========================================================================
|
|
29
|
+
/**
|
|
30
|
+
* Scan files for security vulnerabilities using static analysis
|
|
31
|
+
*/
|
|
32
|
+
async scanFiles(files) {
|
|
33
|
+
return this.scanWithRules(files, this.config.defaultRuleSets);
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Scan with specific rule sets
|
|
37
|
+
*/
|
|
38
|
+
async scanWithRules(files, ruleSetIds) {
|
|
39
|
+
const scanId = uuidv4();
|
|
40
|
+
try {
|
|
41
|
+
if (files.length === 0) {
|
|
42
|
+
return err(new Error('No files provided for scanning'));
|
|
43
|
+
}
|
|
44
|
+
this.activeScans.set(scanId, 'running');
|
|
45
|
+
const startTime = Date.now();
|
|
46
|
+
// Get applicable rule sets
|
|
47
|
+
const ruleSets = BUILT_IN_RULE_SETS.filter((rs) => ruleSetIds.includes(rs.id));
|
|
48
|
+
if (ruleSets.length === 0) {
|
|
49
|
+
return err(new Error(`No valid rule sets found: ${ruleSetIds.join(', ')}`));
|
|
50
|
+
}
|
|
51
|
+
// Perform static analysis on each file
|
|
52
|
+
const vulnerabilities = [];
|
|
53
|
+
let linesScanned = 0;
|
|
54
|
+
for (const file of files) {
|
|
55
|
+
const fileVulns = await this.analyzeFile(file, ruleSets);
|
|
56
|
+
vulnerabilities.push(...fileVulns.vulnerabilities);
|
|
57
|
+
linesScanned += fileVulns.linesScanned;
|
|
58
|
+
}
|
|
59
|
+
const scanDurationMs = Date.now() - startTime;
|
|
60
|
+
// Calculate summary
|
|
61
|
+
const summary = this.calculateSummary(vulnerabilities, files.length, scanDurationMs);
|
|
62
|
+
// Calculate coverage
|
|
63
|
+
const coverage = {
|
|
64
|
+
filesScanned: files.length,
|
|
65
|
+
linesScanned,
|
|
66
|
+
rulesApplied: ruleSets.reduce((acc, rs) => acc + rs.ruleCount, 0),
|
|
67
|
+
};
|
|
68
|
+
// Store scan results in memory
|
|
69
|
+
await this.storeScanResults(scanId, 'sast', vulnerabilities, summary);
|
|
70
|
+
this.activeScans.set(scanId, 'completed');
|
|
71
|
+
return ok({
|
|
72
|
+
scanId,
|
|
73
|
+
vulnerabilities,
|
|
74
|
+
summary,
|
|
75
|
+
coverage,
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
catch (error) {
|
|
79
|
+
this.activeScans.set(scanId, 'failed');
|
|
80
|
+
return err(error instanceof Error ? error : new Error(String(error)));
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Get available rule sets
|
|
85
|
+
*/
|
|
86
|
+
async getAvailableRuleSets() {
|
|
87
|
+
// Return built-in rule sets plus any custom ones from memory
|
|
88
|
+
const customRuleSets = await this.memory.get('security:custom-rule-sets');
|
|
89
|
+
return [...BUILT_IN_RULE_SETS, ...(customRuleSets || [])];
|
|
90
|
+
}
|
|
91
|
+
/**
|
|
92
|
+
* Check if vulnerability is a false positive
|
|
93
|
+
*/
|
|
94
|
+
async checkFalsePositive(vulnerability) {
|
|
95
|
+
try {
|
|
96
|
+
if (!this.config.enableFalsePositiveDetection) {
|
|
97
|
+
return ok({
|
|
98
|
+
isFalsePositive: false,
|
|
99
|
+
confidence: 0,
|
|
100
|
+
reason: 'False positive detection is disabled',
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
// Analyze vulnerability using heuristics-based false positive detection
|
|
104
|
+
const analysis = await this.analyzeFalsePositive(vulnerability);
|
|
105
|
+
// Store the check result for learning
|
|
106
|
+
await this.memory.set(`security:fp-check:${vulnerability.id}`, { vulnerability, analysis }, { namespace: 'security-compliance', ttl: 86400 * 30 } // 30 days
|
|
107
|
+
);
|
|
108
|
+
return ok(analysis);
|
|
109
|
+
}
|
|
110
|
+
catch (error) {
|
|
111
|
+
return err(error instanceof Error ? error : new Error(String(error)));
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
// ==========================================================================
|
|
115
|
+
// Private Methods
|
|
116
|
+
// ==========================================================================
|
|
117
|
+
/**
|
|
118
|
+
* Analyze a file for security vulnerabilities using pattern-based detection
|
|
119
|
+
*/
|
|
120
|
+
async analyzeFile(file, ruleSets) {
|
|
121
|
+
const vulnerabilities = [];
|
|
122
|
+
const filePath = file.value;
|
|
123
|
+
const extension = file.extension;
|
|
124
|
+
// Read file content
|
|
125
|
+
let content;
|
|
126
|
+
let lines;
|
|
127
|
+
try {
|
|
128
|
+
const fs = await import('fs/promises');
|
|
129
|
+
content = await fs.readFile(filePath, 'utf-8');
|
|
130
|
+
lines = content.split('\n');
|
|
131
|
+
}
|
|
132
|
+
catch {
|
|
133
|
+
// File not accessible - return empty results
|
|
134
|
+
return { vulnerabilities: [], linesScanned: 0 };
|
|
135
|
+
}
|
|
136
|
+
const linesScanned = lines.length;
|
|
137
|
+
// Only scan supported file types
|
|
138
|
+
const supportedExtensions = ['ts', 'tsx', 'js', 'jsx', 'mjs', 'cjs'];
|
|
139
|
+
if (!supportedExtensions.includes(extension)) {
|
|
140
|
+
return { vulnerabilities: [], linesScanned };
|
|
141
|
+
}
|
|
142
|
+
// Get applicable categories from rule sets
|
|
143
|
+
const applicableCategories = new Set(ruleSets.flatMap((rs) => rs.categories));
|
|
144
|
+
// Filter patterns to only those matching applicable categories
|
|
145
|
+
const applicablePatterns = ALL_SECURITY_PATTERNS.filter((pattern) => applicableCategories.has(pattern.category));
|
|
146
|
+
// Scan content for each pattern
|
|
147
|
+
for (const securityPattern of applicablePatterns) {
|
|
148
|
+
const matches = this.findPatternMatches(content, lines, securityPattern);
|
|
149
|
+
for (const match of matches) {
|
|
150
|
+
// Skip if in comments or string that looks like documentation
|
|
151
|
+
if (this.isInComment(content, match.index) || this.isInDocumentation(match.snippet)) {
|
|
152
|
+
continue;
|
|
153
|
+
}
|
|
154
|
+
// Skip nosec annotations
|
|
155
|
+
if (this.hasNosecAnnotation(lines, match.line)) {
|
|
156
|
+
continue;
|
|
157
|
+
}
|
|
158
|
+
vulnerabilities.push(this.createVulnerabilityFromPattern(securityPattern, filePath, match));
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
return { vulnerabilities, linesScanned };
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* Find all matches of a security pattern in the file content
|
|
165
|
+
*/
|
|
166
|
+
findPatternMatches(content, lines, securityPattern) {
|
|
167
|
+
const matches = [];
|
|
168
|
+
// Reset regex state for global patterns
|
|
169
|
+
const pattern = new RegExp(securityPattern.pattern.source, securityPattern.pattern.flags);
|
|
170
|
+
let match;
|
|
171
|
+
while ((match = pattern.exec(content)) !== null) {
|
|
172
|
+
const index = match.index;
|
|
173
|
+
const { line, column } = this.getLineAndColumn(content, index);
|
|
174
|
+
// Extract snippet with context (the matched line plus surrounding context)
|
|
175
|
+
const snippetLines = [];
|
|
176
|
+
const startLine = Math.max(0, line - 2);
|
|
177
|
+
const endLine = Math.min(lines.length - 1, line + 1);
|
|
178
|
+
for (let i = startLine; i <= endLine; i++) {
|
|
179
|
+
snippetLines.push(lines[i]);
|
|
180
|
+
}
|
|
181
|
+
const snippet = snippetLines.join('\n');
|
|
182
|
+
matches.push({ index, line: line + 1, column: column + 1, snippet }); // 1-indexed
|
|
183
|
+
}
|
|
184
|
+
return matches;
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Convert character index to line and column numbers
|
|
188
|
+
*/
|
|
189
|
+
getLineAndColumn(content, index) {
|
|
190
|
+
const beforeMatch = content.substring(0, index);
|
|
191
|
+
const lines = beforeMatch.split('\n');
|
|
192
|
+
const line = lines.length - 1;
|
|
193
|
+
const column = lines[lines.length - 1].length;
|
|
194
|
+
return { line, column };
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* Check if the match is inside a comment
|
|
198
|
+
*/
|
|
199
|
+
isInComment(content, index) {
|
|
200
|
+
const beforeMatch = content.substring(0, index);
|
|
201
|
+
// Check for single-line comment
|
|
202
|
+
const lastNewline = beforeMatch.lastIndexOf('\n');
|
|
203
|
+
const currentLine = beforeMatch.substring(lastNewline + 1);
|
|
204
|
+
if (currentLine.includes('//')) {
|
|
205
|
+
const commentStart = currentLine.indexOf('//');
|
|
206
|
+
if (index - (beforeMatch.length - currentLine.length) > commentStart) {
|
|
207
|
+
return true;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
// Check for multi-line comment
|
|
211
|
+
const lastBlockCommentStart = beforeMatch.lastIndexOf('/*');
|
|
212
|
+
const lastBlockCommentEnd = beforeMatch.lastIndexOf('*/');
|
|
213
|
+
if (lastBlockCommentStart > lastBlockCommentEnd) {
|
|
214
|
+
return true;
|
|
215
|
+
}
|
|
216
|
+
return false;
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* Check if the snippet appears to be in documentation or test code examples
|
|
220
|
+
*/
|
|
221
|
+
isInDocumentation(snippet) {
|
|
222
|
+
const docPatterns = [
|
|
223
|
+
/\*\s*@example/i,
|
|
224
|
+
/\*\s*@description/i,
|
|
225
|
+
/\/\/\s*example:/i,
|
|
226
|
+
/\/\/\s*e\.g\./i,
|
|
227
|
+
/```[\s\S]*```/,
|
|
228
|
+
];
|
|
229
|
+
return docPatterns.some((pattern) => pattern.test(snippet));
|
|
230
|
+
}
|
|
231
|
+
/**
|
|
232
|
+
* Check if the line has a nosec annotation
|
|
233
|
+
*/
|
|
234
|
+
hasNosecAnnotation(lines, lineNumber) {
|
|
235
|
+
const lineIndex = lineNumber - 1;
|
|
236
|
+
if (lineIndex < 0 || lineIndex >= lines.length) {
|
|
237
|
+
return false;
|
|
238
|
+
}
|
|
239
|
+
const currentLine = lines[lineIndex];
|
|
240
|
+
const previousLine = lineIndex > 0 ? lines[lineIndex - 1] : '';
|
|
241
|
+
const nosecPatterns = [
|
|
242
|
+
/\/\/\s*nosec/i,
|
|
243
|
+
/\/\/\s*security-ignore/i,
|
|
244
|
+
/\/\*\s*nosec\s*\*\//i,
|
|
245
|
+
/#\s*nosec/i,
|
|
246
|
+
];
|
|
247
|
+
return nosecPatterns.some((pattern) => pattern.test(currentLine) || pattern.test(previousLine));
|
|
248
|
+
}
|
|
249
|
+
/**
|
|
250
|
+
* Create a Vulnerability object from a pattern match
|
|
251
|
+
*/
|
|
252
|
+
createVulnerabilityFromPattern(pattern, file, match) {
|
|
253
|
+
const location = {
|
|
254
|
+
file,
|
|
255
|
+
line: match.line,
|
|
256
|
+
column: match.column,
|
|
257
|
+
snippet: match.snippet,
|
|
258
|
+
};
|
|
259
|
+
const remediation = {
|
|
260
|
+
description: pattern.remediation,
|
|
261
|
+
fixExample: pattern.fixExample,
|
|
262
|
+
estimatedEffort: this.getEffortForSeverity(pattern.severity),
|
|
263
|
+
automatable: pattern.severity === 'low' || pattern.severity === 'informational',
|
|
264
|
+
};
|
|
265
|
+
return {
|
|
266
|
+
id: uuidv4(),
|
|
267
|
+
cveId: undefined,
|
|
268
|
+
title: pattern.title,
|
|
269
|
+
description: `${pattern.description} [${pattern.cweId}]`,
|
|
270
|
+
severity: pattern.severity,
|
|
271
|
+
category: pattern.category,
|
|
272
|
+
location,
|
|
273
|
+
remediation,
|
|
274
|
+
references: [
|
|
275
|
+
`https://owasp.org/Top10/${pattern.owaspId.replace(':', '_')}/`,
|
|
276
|
+
`https://cwe.mitre.org/data/definitions/${pattern.cweId.replace('CWE-', '')}.html`,
|
|
277
|
+
],
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
getEffortForSeverity(severity) {
|
|
281
|
+
const efforts = {
|
|
282
|
+
critical: 'major',
|
|
283
|
+
high: 'moderate',
|
|
284
|
+
medium: 'minor',
|
|
285
|
+
low: 'trivial',
|
|
286
|
+
informational: 'trivial',
|
|
287
|
+
};
|
|
288
|
+
return efforts[severity];
|
|
289
|
+
}
|
|
290
|
+
/**
|
|
291
|
+
* Analyze if a vulnerability detection is a false positive using heuristics
|
|
292
|
+
*/
|
|
293
|
+
async analyzeFalsePositive(vulnerability) {
|
|
294
|
+
let isFalsePositive = false;
|
|
295
|
+
let confidence = 0.5;
|
|
296
|
+
let reason = 'Manual review recommended';
|
|
297
|
+
// Check for common false positive patterns
|
|
298
|
+
if (vulnerability.severity === 'informational') {
|
|
299
|
+
confidence = 0.3;
|
|
300
|
+
reason = 'Low severity findings often require manual verification';
|
|
301
|
+
}
|
|
302
|
+
if (vulnerability.location.snippet?.includes('test') ||
|
|
303
|
+
vulnerability.location.file.includes('test')) {
|
|
304
|
+
isFalsePositive = true;
|
|
305
|
+
confidence = 0.8;
|
|
306
|
+
reason = 'Vulnerability found in test code';
|
|
307
|
+
}
|
|
308
|
+
if (vulnerability.location.snippet?.includes('// nosec')) {
|
|
309
|
+
isFalsePositive = true;
|
|
310
|
+
confidence = 0.95;
|
|
311
|
+
reason = 'Explicitly marked as ignored with nosec comment';
|
|
312
|
+
}
|
|
313
|
+
return { isFalsePositive, confidence, reason };
|
|
314
|
+
}
|
|
315
|
+
/**
|
|
316
|
+
* Calculate scan summary from vulnerabilities
|
|
317
|
+
*/
|
|
318
|
+
calculateSummary(vulnerabilities, totalFiles, scanDurationMs) {
|
|
319
|
+
const summary = {
|
|
320
|
+
critical: 0,
|
|
321
|
+
high: 0,
|
|
322
|
+
medium: 0,
|
|
323
|
+
low: 0,
|
|
324
|
+
informational: 0,
|
|
325
|
+
totalFiles,
|
|
326
|
+
scanDurationMs,
|
|
327
|
+
};
|
|
328
|
+
for (const vuln of vulnerabilities) {
|
|
329
|
+
summary[vuln.severity]++;
|
|
330
|
+
}
|
|
331
|
+
return summary;
|
|
332
|
+
}
|
|
333
|
+
/**
|
|
334
|
+
* Store scan results in memory
|
|
335
|
+
*/
|
|
336
|
+
async storeScanResults(scanId, scanType, vulnerabilities, summary) {
|
|
337
|
+
await this.memory.set(`security:scan:${scanId}`, {
|
|
338
|
+
scanId,
|
|
339
|
+
scanType,
|
|
340
|
+
vulnerabilities,
|
|
341
|
+
summary,
|
|
342
|
+
timestamp: new Date().toISOString(),
|
|
343
|
+
}, { namespace: 'security-compliance', ttl: 86400 * 7 } // 7 days
|
|
344
|
+
);
|
|
345
|
+
}
|
|
346
|
+
// ==========================================================================
|
|
347
|
+
// LLM Enhancement Methods (ADR-051)
|
|
348
|
+
// ==========================================================================
|
|
349
|
+
/**
|
|
350
|
+
* Check if LLM analysis is available and enabled
|
|
351
|
+
*/
|
|
352
|
+
isLLMAnalysisAvailable() {
|
|
353
|
+
return this.config.enableLLMAnalysis && this.llmRouter !== undefined;
|
|
354
|
+
}
|
|
355
|
+
/**
|
|
356
|
+
* Get model ID for the configured tier
|
|
357
|
+
*/
|
|
358
|
+
getModelForTier(tier) {
|
|
359
|
+
switch (tier) {
|
|
360
|
+
case 1: return 'claude-3-5-haiku-20241022';
|
|
361
|
+
case 2: return 'claude-sonnet-4-20250514';
|
|
362
|
+
case 3: return 'claude-sonnet-4-20250514';
|
|
363
|
+
case 4: return 'claude-opus-4-5-20251101';
|
|
364
|
+
default: return 'claude-opus-4-5-20251101'; // Default to Opus for security
|
|
365
|
+
}
|
|
366
|
+
}
|
|
367
|
+
/**
|
|
368
|
+
* Analyze vulnerability with LLM for deeper insights
|
|
369
|
+
*/
|
|
370
|
+
async analyzeVulnerabilityWithLLM(vuln, codeContext) {
|
|
371
|
+
if (!this.llmRouter) {
|
|
372
|
+
return this.getDefaultRemediation(vuln);
|
|
373
|
+
}
|
|
374
|
+
try {
|
|
375
|
+
const modelId = this.getModelForTier(this.config.llmModelTier);
|
|
376
|
+
const response = await this.llmRouter.chat({
|
|
377
|
+
messages: [
|
|
378
|
+
{
|
|
379
|
+
role: 'system',
|
|
380
|
+
content: `You are a senior security engineer. Analyze the vulnerability and provide:
|
|
381
|
+
1. Detailed explanation of the risk
|
|
382
|
+
2. Code example showing the fix
|
|
383
|
+
3. Effort estimate (trivial/minor/moderate/major)
|
|
384
|
+
4. Whether it's automatable
|
|
385
|
+
Be specific to the code context provided. Return JSON with: { "description": "", "fixExample": "", "estimatedEffort": "minor", "automatable": false }`,
|
|
386
|
+
},
|
|
387
|
+
{
|
|
388
|
+
role: 'user',
|
|
389
|
+
content: `Vulnerability: ${vuln.title} (${vuln.category})
|
|
390
|
+
Severity: ${vuln.severity}
|
|
391
|
+
Description: ${vuln.description}
|
|
392
|
+
|
|
393
|
+
Code context:
|
|
394
|
+
\`\`\`
|
|
395
|
+
${codeContext}
|
|
396
|
+
\`\`\`
|
|
397
|
+
|
|
398
|
+
Provide detailed remediation advice specific to this code.`,
|
|
399
|
+
},
|
|
400
|
+
],
|
|
401
|
+
model: modelId,
|
|
402
|
+
maxTokens: 1500,
|
|
403
|
+
temperature: 0.2,
|
|
404
|
+
});
|
|
405
|
+
if (response.content) {
|
|
406
|
+
try {
|
|
407
|
+
const jsonMatch = response.content.match(/\{[\s\S]*\}/);
|
|
408
|
+
if (jsonMatch) {
|
|
409
|
+
const analysis = JSON.parse(jsonMatch[0]);
|
|
410
|
+
return {
|
|
411
|
+
description: analysis.description || vuln.remediation?.description || 'Review and fix the vulnerability',
|
|
412
|
+
fixExample: analysis.fixExample || vuln.remediation?.fixExample,
|
|
413
|
+
estimatedEffort: analysis.estimatedEffort || vuln.remediation?.estimatedEffort || 'moderate',
|
|
414
|
+
automatable: analysis.automatable ?? vuln.remediation?.automatable ?? false,
|
|
415
|
+
llmEnhanced: true,
|
|
416
|
+
};
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
catch {
|
|
420
|
+
// JSON parse failed - use default
|
|
421
|
+
}
|
|
422
|
+
}
|
|
423
|
+
}
|
|
424
|
+
catch (error) {
|
|
425
|
+
console.warn('[SASTScanner] LLM analysis failed:', error);
|
|
426
|
+
}
|
|
427
|
+
return this.getDefaultRemediation(vuln);
|
|
428
|
+
}
|
|
429
|
+
/**
|
|
430
|
+
* Get default remediation advice without LLM
|
|
431
|
+
*/
|
|
432
|
+
getDefaultRemediation(vuln) {
|
|
433
|
+
return vuln.remediation || {
|
|
434
|
+
description: 'Review and fix the vulnerability following security best practices',
|
|
435
|
+
estimatedEffort: 'moderate',
|
|
436
|
+
automatable: false,
|
|
437
|
+
};
|
|
438
|
+
}
|
|
439
|
+
}
|
|
440
|
+
//# sourceMappingURL=sast-scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sast-scanner.js","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/sast-scanner.ts"],"names":[],"mappings":"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"}
|