agentic-qe 3.3.3 → 3.3.4
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-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/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/demo-warmup.sh +45 -0
- package/scripts/fetch-content.js +460 -0
- package/v3/CHANGELOG.md +101 -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-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 +27611 -23175
- 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/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 +74 -11
- 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/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/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/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.map +1 -1
- package/v3/dist/kernel/unified-memory.js +14 -11
- 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/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/sqlite-persistence.d.ts +1 -1
- package/v3/dist/learning/sqlite-persistence.d.ts.map +1 -1
- package/v3/dist/learning/sqlite-persistence.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 +11334 -7497
- 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.map +1 -1
- package/v3/dist/sync/claude-flow-bridge.js +6 -4
- 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/readers/sqlite-reader.d.ts.map +1 -1
- package/v3/dist/sync/readers/sqlite-reader.js +3 -2
- 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,62 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - DAST (Dynamic Application Security Testing) Scanner
|
|
3
|
+
* Performs dynamic analysis of running applications to detect security vulnerabilities
|
|
4
|
+
*/
|
|
5
|
+
import { Result } from '../../../../shared/types/index.js';
|
|
6
|
+
import type { SecurityScannerConfig, DASTResult, DASTOptions, AuthCredentials, MemoryBackend, ScanStatus } from './scanner-types.js';
|
|
7
|
+
/**
|
|
8
|
+
* DAST Scanner - Dynamic Application Security Testing
|
|
9
|
+
* Scans running applications for security vulnerabilities
|
|
10
|
+
*
|
|
11
|
+
* **Capabilities:**
|
|
12
|
+
* - Security header analysis (HSTS, CSP, X-Frame-Options, etc.)
|
|
13
|
+
* - Cookie security (Secure, HttpOnly, SameSite flags)
|
|
14
|
+
* - CORS misconfiguration detection
|
|
15
|
+
* - Sensitive file exposure (/.git, /.env, etc.)
|
|
16
|
+
* - Link crawling with same-origin scope
|
|
17
|
+
* - XSS reflection testing (GET parameters)
|
|
18
|
+
* - SQL injection error-based detection (GET parameters)
|
|
19
|
+
* - Form security analysis (CSRF tokens, autocomplete, action URLs)
|
|
20
|
+
*
|
|
21
|
+
* **Limitations:**
|
|
22
|
+
* - Injection testing: GET parameters only (POST form submission not implemented)
|
|
23
|
+
* - Crawling: Same-origin only, max 10 links per page, single depth
|
|
24
|
+
* - Auth flows: Header-based only, no login form automation
|
|
25
|
+
* - No JavaScript execution (static response analysis only)
|
|
26
|
+
* - No session management testing beyond cookie attributes
|
|
27
|
+
*/
|
|
28
|
+
export declare class DASTScanner {
|
|
29
|
+
private readonly config;
|
|
30
|
+
private readonly memory;
|
|
31
|
+
private readonly activeScans;
|
|
32
|
+
constructor(config: SecurityScannerConfig, memory: MemoryBackend, activeScans?: Map<string, ScanStatus>);
|
|
33
|
+
/**
|
|
34
|
+
* Scan running application using dynamic analysis
|
|
35
|
+
*/
|
|
36
|
+
scanUrl(targetUrl: string, options?: DASTOptions): Promise<Result<DASTResult>>;
|
|
37
|
+
/**
|
|
38
|
+
* Scan authenticated endpoints
|
|
39
|
+
*/
|
|
40
|
+
scanAuthenticated(targetUrl: string, credentials: AuthCredentials, options?: DASTOptions): Promise<Result<DASTResult>>;
|
|
41
|
+
/**
|
|
42
|
+
* Get scan status
|
|
43
|
+
*/
|
|
44
|
+
getScanStatus(scanId: string): Promise<ScanStatus>;
|
|
45
|
+
/**
|
|
46
|
+
* Perform dynamic (DAST) scanning on a target URL
|
|
47
|
+
*/
|
|
48
|
+
private performDynamicScan;
|
|
49
|
+
/**
|
|
50
|
+
* Perform authenticated dynamic scanning
|
|
51
|
+
*/
|
|
52
|
+
private performAuthenticatedScan;
|
|
53
|
+
private createInvalidUrlVuln;
|
|
54
|
+
private createInsecureProtocolVuln;
|
|
55
|
+
private createAuthFailedVuln;
|
|
56
|
+
private createTokenInUrlVuln;
|
|
57
|
+
/**
|
|
58
|
+
* Test URL parameters for injection vulnerabilities
|
|
59
|
+
*/
|
|
60
|
+
private testInjectionVulnerabilities;
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=dast-scanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dast-scanner.d.ts","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/dast-scanner.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,MAAM,EAAW,MAAM,mCAAmC,CAAC;AACpE,OAAO,KAAK,EACV,qBAAqB,EAErB,UAAU,EACV,WAAW,EACX,eAAe,EACf,aAAa,EACb,UAAU,EACX,MAAM,oBAAoB,CAAC;AAwB5B;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAwB;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAgB;IACvC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAA0B;gBAGpD,MAAM,EAAE,qBAAqB,EAC7B,MAAM,EAAE,aAAa,EACrB,WAAW,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC;IAWvC;;OAEG;IACG,OAAO,CACX,SAAS,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE,WAAW,GACpB,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IA2C9B;;OAEG;IACG,iBAAiB,CACrB,SAAS,EAAE,MAAM,EACjB,WAAW,EAAE,eAAe,EAC5B,OAAO,CAAC,EAAE,WAAW,GACpB,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAqD9B;;OAEG;IACG,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAQxD;;OAEG;YACW,kBAAkB;IAuFhC;;OAEG;YACW,wBAAwB;IA8EtC,OAAO,CAAC,oBAAoB;IAa5B,OAAO,CAAC,0BAA0B;IAalC,OAAO,CAAC,oBAAoB;IAa5B,OAAO,CAAC,oBAAoB;IAiB5B;;OAEG;YACW,4BAA4B;CAyB3C"}
|
|
@@ -0,0 +1,329 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - DAST (Dynamic Application Security Testing) Scanner
|
|
3
|
+
* Performs dynamic analysis of running applications to detect security vulnerabilities
|
|
4
|
+
*/
|
|
5
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
6
|
+
import { ok, err } from '../../../../shared/types/index.js';
|
|
7
|
+
import { analyzeSecurityHeaders, analyzeCookieSecurity, analyzeServerHeaders, scanSensitiveFiles, analyzeCORS, extractAndCrawlLinks, testXSS, testSQLi, analyzeFormsForSecurityIssues, testAuthorizationBypass, testIDOR, validateCredentials, buildAuthHeaders, handleFetchError, calculateSummary, storeScanResults, } from './dast-helpers.js';
|
|
8
|
+
// ============================================================================
|
|
9
|
+
// DAST Scanner Service
|
|
10
|
+
// ============================================================================
|
|
11
|
+
/**
|
|
12
|
+
* DAST Scanner - Dynamic Application Security Testing
|
|
13
|
+
* Scans running applications for security vulnerabilities
|
|
14
|
+
*
|
|
15
|
+
* **Capabilities:**
|
|
16
|
+
* - Security header analysis (HSTS, CSP, X-Frame-Options, etc.)
|
|
17
|
+
* - Cookie security (Secure, HttpOnly, SameSite flags)
|
|
18
|
+
* - CORS misconfiguration detection
|
|
19
|
+
* - Sensitive file exposure (/.git, /.env, etc.)
|
|
20
|
+
* - Link crawling with same-origin scope
|
|
21
|
+
* - XSS reflection testing (GET parameters)
|
|
22
|
+
* - SQL injection error-based detection (GET parameters)
|
|
23
|
+
* - Form security analysis (CSRF tokens, autocomplete, action URLs)
|
|
24
|
+
*
|
|
25
|
+
* **Limitations:**
|
|
26
|
+
* - Injection testing: GET parameters only (POST form submission not implemented)
|
|
27
|
+
* - Crawling: Same-origin only, max 10 links per page, single depth
|
|
28
|
+
* - Auth flows: Header-based only, no login form automation
|
|
29
|
+
* - No JavaScript execution (static response analysis only)
|
|
30
|
+
* - No session management testing beyond cookie attributes
|
|
31
|
+
*/
|
|
32
|
+
export class DASTScanner {
|
|
33
|
+
config;
|
|
34
|
+
memory;
|
|
35
|
+
activeScans;
|
|
36
|
+
constructor(config, memory, activeScans) {
|
|
37
|
+
this.config = config;
|
|
38
|
+
this.memory = memory;
|
|
39
|
+
this.activeScans = activeScans || new Map();
|
|
40
|
+
}
|
|
41
|
+
// ==========================================================================
|
|
42
|
+
// Public Methods
|
|
43
|
+
// ==========================================================================
|
|
44
|
+
/**
|
|
45
|
+
* Scan running application using dynamic analysis
|
|
46
|
+
*/
|
|
47
|
+
async scanUrl(targetUrl, options) {
|
|
48
|
+
const scanId = uuidv4();
|
|
49
|
+
try {
|
|
50
|
+
this.activeScans.set(scanId, 'running');
|
|
51
|
+
const startTime = Date.now();
|
|
52
|
+
const mergedOptions = {
|
|
53
|
+
maxDepth: options?.maxDepth ?? this.config.dastMaxDepth,
|
|
54
|
+
activeScanning: options?.activeScanning ?? this.config.dastActiveScanning,
|
|
55
|
+
timeout: options?.timeout ?? this.config.timeout,
|
|
56
|
+
excludePatterns: options?.excludePatterns ?? [],
|
|
57
|
+
};
|
|
58
|
+
// Perform dynamic analysis
|
|
59
|
+
const result = await this.performDynamicScan(targetUrl, mergedOptions);
|
|
60
|
+
const scanDurationMs = Date.now() - startTime;
|
|
61
|
+
const summary = calculateSummary(result.vulnerabilities, 1, scanDurationMs);
|
|
62
|
+
// Store results
|
|
63
|
+
await storeScanResults(this.memory, scanId, 'dast', result.vulnerabilities, summary);
|
|
64
|
+
this.activeScans.set(scanId, 'completed');
|
|
65
|
+
return ok({
|
|
66
|
+
scanId,
|
|
67
|
+
targetUrl,
|
|
68
|
+
vulnerabilities: result.vulnerabilities,
|
|
69
|
+
summary,
|
|
70
|
+
crawledUrls: result.crawledUrls,
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
catch (error) {
|
|
74
|
+
this.activeScans.set(scanId, 'failed');
|
|
75
|
+
return err(error instanceof Error ? error : new Error(String(error)));
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Scan authenticated endpoints
|
|
80
|
+
*/
|
|
81
|
+
async scanAuthenticated(targetUrl, credentials, options) {
|
|
82
|
+
const scanId = uuidv4();
|
|
83
|
+
try {
|
|
84
|
+
this.activeScans.set(scanId, 'running');
|
|
85
|
+
const startTime = Date.now();
|
|
86
|
+
// Validate credentials
|
|
87
|
+
const credValidation = validateCredentials(credentials);
|
|
88
|
+
if (!credValidation.valid) {
|
|
89
|
+
return err(new Error(credValidation.reason));
|
|
90
|
+
}
|
|
91
|
+
const mergedOptions = {
|
|
92
|
+
maxDepth: options?.maxDepth ?? this.config.dastMaxDepth,
|
|
93
|
+
activeScanning: options?.activeScanning ?? this.config.dastActiveScanning,
|
|
94
|
+
timeout: options?.timeout ?? this.config.timeout,
|
|
95
|
+
excludePatterns: options?.excludePatterns ?? [],
|
|
96
|
+
};
|
|
97
|
+
// Perform authenticated dynamic analysis
|
|
98
|
+
const result = await this.performAuthenticatedScan(targetUrl, credentials, mergedOptions);
|
|
99
|
+
const scanDurationMs = Date.now() - startTime;
|
|
100
|
+
const summary = calculateSummary(result.vulnerabilities, 1, scanDurationMs);
|
|
101
|
+
// Store results (without credentials)
|
|
102
|
+
await storeScanResults(this.memory, scanId, 'dast-auth', result.vulnerabilities, summary);
|
|
103
|
+
this.activeScans.set(scanId, 'completed');
|
|
104
|
+
return ok({
|
|
105
|
+
scanId,
|
|
106
|
+
targetUrl,
|
|
107
|
+
vulnerabilities: result.vulnerabilities,
|
|
108
|
+
summary,
|
|
109
|
+
crawledUrls: result.crawledUrls,
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
catch (error) {
|
|
113
|
+
this.activeScans.set(scanId, 'failed');
|
|
114
|
+
return err(error instanceof Error ? error : new Error(String(error)));
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Get scan status
|
|
119
|
+
*/
|
|
120
|
+
async getScanStatus(scanId) {
|
|
121
|
+
return this.activeScans.get(scanId) ?? 'pending';
|
|
122
|
+
}
|
|
123
|
+
// ==========================================================================
|
|
124
|
+
// Private Methods - Dynamic Scanning
|
|
125
|
+
// ==========================================================================
|
|
126
|
+
/**
|
|
127
|
+
* Perform dynamic (DAST) scanning on a target URL
|
|
128
|
+
*/
|
|
129
|
+
async performDynamicScan(targetUrl, options) {
|
|
130
|
+
const vulnerabilities = [];
|
|
131
|
+
let crawledUrls = 0;
|
|
132
|
+
try {
|
|
133
|
+
// Validate and parse URL
|
|
134
|
+
let parsedUrl;
|
|
135
|
+
try {
|
|
136
|
+
parsedUrl = new URL(targetUrl);
|
|
137
|
+
}
|
|
138
|
+
catch {
|
|
139
|
+
vulnerabilities.push(this.createInvalidUrlVuln(targetUrl));
|
|
140
|
+
return { vulnerabilities, crawledUrls: 0 };
|
|
141
|
+
}
|
|
142
|
+
const timeout = options.timeout ?? this.config.timeout;
|
|
143
|
+
const maxDepth = options.maxDepth ?? this.config.dastMaxDepth;
|
|
144
|
+
// Perform main page scan
|
|
145
|
+
const controller = new AbortController();
|
|
146
|
+
const timeoutId = setTimeout(() => controller.abort(), Math.min(timeout, 30000));
|
|
147
|
+
try {
|
|
148
|
+
const response = await fetch(targetUrl, {
|
|
149
|
+
method: 'GET',
|
|
150
|
+
headers: {
|
|
151
|
+
'User-Agent': 'AgenticQE-DAST-Scanner/3.0',
|
|
152
|
+
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
|
|
153
|
+
},
|
|
154
|
+
signal: controller.signal,
|
|
155
|
+
redirect: 'follow',
|
|
156
|
+
});
|
|
157
|
+
clearTimeout(timeoutId);
|
|
158
|
+
crawledUrls++;
|
|
159
|
+
// Security header analysis
|
|
160
|
+
analyzeSecurityHeaders(response.headers, targetUrl, vulnerabilities);
|
|
161
|
+
// Check for insecure protocol
|
|
162
|
+
if (parsedUrl.protocol === 'http:') {
|
|
163
|
+
vulnerabilities.push(this.createInsecureProtocolVuln(targetUrl));
|
|
164
|
+
}
|
|
165
|
+
// Check for cookie security
|
|
166
|
+
analyzeCookieSecurity(response.headers, targetUrl, vulnerabilities);
|
|
167
|
+
// Check for server version disclosure
|
|
168
|
+
analyzeServerHeaders(response.headers, targetUrl, vulnerabilities);
|
|
169
|
+
// Active scanning features
|
|
170
|
+
if (options.activeScanning ?? this.config.dastActiveScanning) {
|
|
171
|
+
crawledUrls = await scanSensitiveFiles(parsedUrl, crawledUrls, maxDepth, vulnerabilities);
|
|
172
|
+
await analyzeCORS(targetUrl, vulnerabilities);
|
|
173
|
+
// Enhanced DAST: Link crawling, injection testing, form analysis
|
|
174
|
+
const responseText = await response.clone().text();
|
|
175
|
+
crawledUrls = await extractAndCrawlLinks(responseText, parsedUrl, crawledUrls, maxDepth, vulnerabilities);
|
|
176
|
+
if (parsedUrl.search) {
|
|
177
|
+
await this.testInjectionVulnerabilities(targetUrl, parsedUrl, vulnerabilities);
|
|
178
|
+
}
|
|
179
|
+
analyzeFormsForSecurityIssues(responseText, targetUrl, vulnerabilities);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
catch (fetchError) {
|
|
183
|
+
clearTimeout(timeoutId);
|
|
184
|
+
handleFetchError(fetchError, targetUrl, vulnerabilities);
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
catch (error) {
|
|
188
|
+
console.error('DAST scan error:', error);
|
|
189
|
+
}
|
|
190
|
+
return { vulnerabilities, crawledUrls };
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Perform authenticated dynamic scanning
|
|
194
|
+
*/
|
|
195
|
+
async performAuthenticatedScan(targetUrl, credentials, options) {
|
|
196
|
+
const vulnerabilities = [];
|
|
197
|
+
let crawledUrls = 0;
|
|
198
|
+
try {
|
|
199
|
+
const authHeaders = buildAuthHeaders(credentials);
|
|
200
|
+
let parsedUrl;
|
|
201
|
+
try {
|
|
202
|
+
parsedUrl = new URL(targetUrl);
|
|
203
|
+
}
|
|
204
|
+
catch {
|
|
205
|
+
vulnerabilities.push(this.createInvalidUrlVuln(targetUrl));
|
|
206
|
+
return { vulnerabilities, crawledUrls: 0 };
|
|
207
|
+
}
|
|
208
|
+
const timeout = options.timeout ?? this.config.timeout;
|
|
209
|
+
const maxDepth = options.maxDepth ?? this.config.dastMaxDepth;
|
|
210
|
+
const controller = new AbortController();
|
|
211
|
+
const timeoutId = setTimeout(() => controller.abort(), Math.min(timeout, 30000));
|
|
212
|
+
try {
|
|
213
|
+
const response = await fetch(targetUrl, {
|
|
214
|
+
method: 'GET',
|
|
215
|
+
headers: {
|
|
216
|
+
'User-Agent': 'AgenticQE-DAST-Scanner/3.0',
|
|
217
|
+
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
|
|
218
|
+
...authHeaders,
|
|
219
|
+
},
|
|
220
|
+
signal: controller.signal,
|
|
221
|
+
redirect: 'follow',
|
|
222
|
+
});
|
|
223
|
+
clearTimeout(timeoutId);
|
|
224
|
+
crawledUrls++;
|
|
225
|
+
// Check if authentication was successful
|
|
226
|
+
if (response.status === 401 || response.status === 403) {
|
|
227
|
+
vulnerabilities.push(this.createAuthFailedVuln(targetUrl, response.status));
|
|
228
|
+
}
|
|
229
|
+
// Standard security header checks
|
|
230
|
+
analyzeSecurityHeaders(response.headers, targetUrl, vulnerabilities, true);
|
|
231
|
+
// Check for session token in URL
|
|
232
|
+
if (parsedUrl.search.includes('token=') || parsedUrl.search.includes('session=') || parsedUrl.search.includes('auth=')) {
|
|
233
|
+
vulnerabilities.push(this.createTokenInUrlVuln(targetUrl, parsedUrl.search));
|
|
234
|
+
}
|
|
235
|
+
// Active scanning for authenticated endpoints
|
|
236
|
+
if (options.activeScanning ?? this.config.dastActiveScanning) {
|
|
237
|
+
crawledUrls = await testAuthorizationBypass(parsedUrl, authHeaders, crawledUrls, maxDepth, vulnerabilities);
|
|
238
|
+
crawledUrls = await testIDOR(parsedUrl, authHeaders, crawledUrls, maxDepth, vulnerabilities);
|
|
239
|
+
}
|
|
240
|
+
// Enhanced cookie security for authenticated sessions
|
|
241
|
+
analyzeCookieSecurity(response.headers, targetUrl, vulnerabilities, true);
|
|
242
|
+
}
|
|
243
|
+
catch (fetchError) {
|
|
244
|
+
clearTimeout(timeoutId);
|
|
245
|
+
handleFetchError(fetchError, targetUrl, vulnerabilities);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
catch (error) {
|
|
249
|
+
console.error('Authenticated DAST scan error:', error);
|
|
250
|
+
}
|
|
251
|
+
return { vulnerabilities, crawledUrls };
|
|
252
|
+
}
|
|
253
|
+
// ==========================================================================
|
|
254
|
+
// Private Methods - Vulnerability Factories
|
|
255
|
+
// ==========================================================================
|
|
256
|
+
createInvalidUrlVuln(targetUrl) {
|
|
257
|
+
return {
|
|
258
|
+
id: uuidv4(),
|
|
259
|
+
title: 'Invalid Target URL',
|
|
260
|
+
description: 'The provided target URL is not valid',
|
|
261
|
+
severity: 'informational',
|
|
262
|
+
category: 'security-misconfiguration',
|
|
263
|
+
location: { file: targetUrl },
|
|
264
|
+
remediation: { description: 'Provide a valid URL', estimatedEffort: 'trivial', automatable: false },
|
|
265
|
+
references: [],
|
|
266
|
+
};
|
|
267
|
+
}
|
|
268
|
+
createInsecureProtocolVuln(targetUrl) {
|
|
269
|
+
return {
|
|
270
|
+
id: uuidv4(),
|
|
271
|
+
title: 'Insecure HTTP Protocol',
|
|
272
|
+
description: 'Application is accessible over unencrypted HTTP',
|
|
273
|
+
severity: 'high',
|
|
274
|
+
category: 'sensitive-data',
|
|
275
|
+
location: { file: targetUrl },
|
|
276
|
+
remediation: { description: 'Redirect all HTTP traffic to HTTPS', estimatedEffort: 'moderate', automatable: false },
|
|
277
|
+
references: ['https://owasp.org/www-project-web-security-testing-guide/'],
|
|
278
|
+
};
|
|
279
|
+
}
|
|
280
|
+
createAuthFailedVuln(targetUrl, status) {
|
|
281
|
+
return {
|
|
282
|
+
id: uuidv4(),
|
|
283
|
+
title: 'Authentication Failed',
|
|
284
|
+
description: `Authentication returned ${status} status`,
|
|
285
|
+
severity: 'informational',
|
|
286
|
+
category: 'broken-auth',
|
|
287
|
+
location: { file: targetUrl },
|
|
288
|
+
remediation: { description: 'Verify credentials are correct', estimatedEffort: 'trivial', automatable: false },
|
|
289
|
+
references: [],
|
|
290
|
+
};
|
|
291
|
+
}
|
|
292
|
+
createTokenInUrlVuln(targetUrl, search) {
|
|
293
|
+
return {
|
|
294
|
+
id: uuidv4(),
|
|
295
|
+
title: 'Session Token in URL',
|
|
296
|
+
description: 'Authentication token appears in URL query string',
|
|
297
|
+
severity: 'high',
|
|
298
|
+
category: 'sensitive-data',
|
|
299
|
+
location: { file: targetUrl, snippet: search.substring(0, 50) },
|
|
300
|
+
remediation: { description: 'Send tokens in headers or request body, not URL', estimatedEffort: 'moderate', automatable: false },
|
|
301
|
+
references: ['https://owasp.org/www-community/vulnerabilities/Information_exposure_through_query_strings_in_url'],
|
|
302
|
+
};
|
|
303
|
+
}
|
|
304
|
+
// ==========================================================================
|
|
305
|
+
// Private Methods - Injection Testing
|
|
306
|
+
// ==========================================================================
|
|
307
|
+
/**
|
|
308
|
+
* Test URL parameters for injection vulnerabilities
|
|
309
|
+
*/
|
|
310
|
+
async testInjectionVulnerabilities(targetUrl, parsedUrl, vulnerabilities) {
|
|
311
|
+
const params = new URLSearchParams(parsedUrl.search);
|
|
312
|
+
const paramNames = Array.from(params.keys());
|
|
313
|
+
const xssPayloads = [
|
|
314
|
+
{ payload: '<script>alert(1)</script>', name: 'Basic XSS' },
|
|
315
|
+
{ payload: '"><img src=x onerror=alert(1)>', name: 'Attribute Injection' },
|
|
316
|
+
{ payload: "'-alert(1)-'", name: 'JavaScript Injection' },
|
|
317
|
+
];
|
|
318
|
+
const sqliPayloads = [
|
|
319
|
+
{ payload: "' OR '1'='1", name: 'SQL OR Injection' },
|
|
320
|
+
{ payload: "1; DROP TABLE test--", name: 'SQL Statement Injection' },
|
|
321
|
+
{ payload: "1' AND '1'='1", name: 'SQL AND Injection' },
|
|
322
|
+
];
|
|
323
|
+
for (const paramName of paramNames.slice(0, 3)) {
|
|
324
|
+
await testXSS(targetUrl, parsedUrl, paramName, xssPayloads, vulnerabilities);
|
|
325
|
+
await testSQLi(targetUrl, parsedUrl, paramName, sqliPayloads, vulnerabilities);
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
//# sourceMappingURL=dast-scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dast-scanner.js","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/dast-scanner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - Dependency Scanner
|
|
3
|
+
* Scans npm dependencies for known vulnerabilities using OSV API
|
|
4
|
+
*/
|
|
5
|
+
import { Result } from '../../../../shared/types/index.js';
|
|
6
|
+
import type { SecurityScannerConfig, DependencyScanResult, MemoryBackend, ScanStatus } from './scanner-types.js';
|
|
7
|
+
/**
|
|
8
|
+
* Dependency Scanner - OSV-based Vulnerability Detection
|
|
9
|
+
* Scans npm dependencies for known vulnerabilities using the OSV API
|
|
10
|
+
*/
|
|
11
|
+
export declare class DependencyScanner {
|
|
12
|
+
private readonly config;
|
|
13
|
+
private readonly memory;
|
|
14
|
+
private readonly osvClient;
|
|
15
|
+
private readonly activeScans;
|
|
16
|
+
constructor(config: SecurityScannerConfig, memory: MemoryBackend, activeScans?: Map<string, ScanStatus>);
|
|
17
|
+
/**
|
|
18
|
+
* Scan npm dependencies for known vulnerabilities using OSV API
|
|
19
|
+
*/
|
|
20
|
+
scanDependencies(dependencies: Record<string, string>): Promise<Result<DependencyScanResult>>;
|
|
21
|
+
/**
|
|
22
|
+
* Scan a package.json file for dependency vulnerabilities
|
|
23
|
+
*/
|
|
24
|
+
scanPackageJson(packageJsonPath: string): Promise<Result<DependencyScanResult>>;
|
|
25
|
+
/**
|
|
26
|
+
* Get scan status
|
|
27
|
+
*/
|
|
28
|
+
getScanStatus(scanId: string): Promise<ScanStatus>;
|
|
29
|
+
/**
|
|
30
|
+
* Convert OSV vulnerabilities to our internal format
|
|
31
|
+
*/
|
|
32
|
+
private convertOSVVulnerabilities;
|
|
33
|
+
/**
|
|
34
|
+
* Map OSV severity to our severity type
|
|
35
|
+
*/
|
|
36
|
+
private mapOSVSeverity;
|
|
37
|
+
/**
|
|
38
|
+
* Calculate scan summary
|
|
39
|
+
*/
|
|
40
|
+
private calculateSummary;
|
|
41
|
+
/**
|
|
42
|
+
* Store scan results
|
|
43
|
+
*/
|
|
44
|
+
private storeScanResults;
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=dependency-scanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dependency-scanner.d.ts","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/dependency-scanner.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,MAAM,EAAW,MAAM,mCAAmC,CAAC;AAEpE,OAAO,KAAK,EACV,qBAAqB,EACrB,oBAAoB,EAMpB,aAAa,EAEb,UAAU,EACX,MAAM,oBAAoB,CAAC;AAM5B;;;GAGG;AACH,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAwB;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAgB;IACvC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAY;IACtC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAA0B;gBAGpD,MAAM,EAAE,qBAAqB,EAC7B,MAAM,EAAE,aAAa,EACrB,WAAW,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC;IAYvC;;OAEG;IACG,gBAAgB,CACpB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACnC,OAAO,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAiDxC;;OAEG;IACG,eAAe,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;IA2BrF;;OAEG;IACG,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IAQxD;;OAEG;IACH,OAAO,CAAC,yBAAyB;IAoCjC;;OAEG;IACH,OAAO,CAAC,cAAc;IAatB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAsBxB;;OAEG;YACW,gBAAgB;CAkB/B"}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - Dependency Scanner
|
|
3
|
+
* Scans npm dependencies for known vulnerabilities using OSV API
|
|
4
|
+
*/
|
|
5
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
6
|
+
import { ok, err } from '../../../../shared/types/index.js';
|
|
7
|
+
import { OSVClient } from '../../../../shared/security/index.js';
|
|
8
|
+
// ============================================================================
|
|
9
|
+
// Dependency Scanner Service
|
|
10
|
+
// ============================================================================
|
|
11
|
+
/**
|
|
12
|
+
* Dependency Scanner - OSV-based Vulnerability Detection
|
|
13
|
+
* Scans npm dependencies for known vulnerabilities using the OSV API
|
|
14
|
+
*/
|
|
15
|
+
export class DependencyScanner {
|
|
16
|
+
config;
|
|
17
|
+
memory;
|
|
18
|
+
osvClient;
|
|
19
|
+
activeScans;
|
|
20
|
+
constructor(config, memory, activeScans) {
|
|
21
|
+
this.config = config;
|
|
22
|
+
this.memory = memory;
|
|
23
|
+
this.osvClient = new OSVClient({ enableCache: true });
|
|
24
|
+
this.activeScans = activeScans || new Map();
|
|
25
|
+
}
|
|
26
|
+
// ==========================================================================
|
|
27
|
+
// Public Methods
|
|
28
|
+
// ==========================================================================
|
|
29
|
+
/**
|
|
30
|
+
* Scan npm dependencies for known vulnerabilities using OSV API
|
|
31
|
+
*/
|
|
32
|
+
async scanDependencies(dependencies) {
|
|
33
|
+
const scanId = uuidv4();
|
|
34
|
+
const startTime = Date.now();
|
|
35
|
+
try {
|
|
36
|
+
if (Object.keys(dependencies).length === 0) {
|
|
37
|
+
return err(new Error('No dependencies provided for scanning'));
|
|
38
|
+
}
|
|
39
|
+
this.activeScans.set(scanId, 'running');
|
|
40
|
+
// Query OSV for vulnerabilities
|
|
41
|
+
const osvVulns = await this.osvClient.scanNpmDependencies(dependencies);
|
|
42
|
+
// Convert OSV vulnerabilities to our format
|
|
43
|
+
const vulnerabilities = this.convertOSVVulnerabilities(osvVulns);
|
|
44
|
+
const scanDurationMs = Date.now() - startTime;
|
|
45
|
+
// Calculate unique vulnerable packages
|
|
46
|
+
const vulnerablePackageNames = new Set(osvVulns.map((v) => v.affectedPackage));
|
|
47
|
+
// Calculate summary
|
|
48
|
+
const summary = this.calculateSummary(vulnerabilities, Object.keys(dependencies).length, scanDurationMs);
|
|
49
|
+
// Store scan results
|
|
50
|
+
await this.storeScanResults(scanId, 'dependency', vulnerabilities, summary);
|
|
51
|
+
this.activeScans.set(scanId, 'completed');
|
|
52
|
+
return ok({
|
|
53
|
+
scanId,
|
|
54
|
+
vulnerabilities,
|
|
55
|
+
packagesScanned: Object.keys(dependencies).length,
|
|
56
|
+
vulnerablePackages: vulnerablePackageNames.size,
|
|
57
|
+
summary,
|
|
58
|
+
scanDurationMs,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
this.activeScans.set(scanId, 'failed');
|
|
63
|
+
return err(error instanceof Error ? error : new Error(String(error)));
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Scan a package.json file for dependency vulnerabilities
|
|
68
|
+
*/
|
|
69
|
+
async scanPackageJson(packageJsonPath) {
|
|
70
|
+
try {
|
|
71
|
+
const fs = await import('fs/promises');
|
|
72
|
+
const content = await fs.readFile(packageJsonPath, 'utf-8');
|
|
73
|
+
const packageJson = JSON.parse(content);
|
|
74
|
+
// Combine all dependency types
|
|
75
|
+
const allDependencies = {
|
|
76
|
+
...(packageJson.dependencies || {}),
|
|
77
|
+
...(packageJson.devDependencies || {}),
|
|
78
|
+
...(packageJson.peerDependencies || {}),
|
|
79
|
+
...(packageJson.optionalDependencies || {}),
|
|
80
|
+
};
|
|
81
|
+
if (Object.keys(allDependencies).length === 0) {
|
|
82
|
+
return err(new Error('No dependencies found in package.json'));
|
|
83
|
+
}
|
|
84
|
+
return this.scanDependencies(allDependencies);
|
|
85
|
+
}
|
|
86
|
+
catch (error) {
|
|
87
|
+
if (error instanceof SyntaxError) {
|
|
88
|
+
return err(new Error(`Invalid JSON in package.json: ${error.message}`));
|
|
89
|
+
}
|
|
90
|
+
return err(error instanceof Error ? error : new Error(String(error)));
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Get scan status
|
|
95
|
+
*/
|
|
96
|
+
async getScanStatus(scanId) {
|
|
97
|
+
return this.activeScans.get(scanId) ?? 'pending';
|
|
98
|
+
}
|
|
99
|
+
// ==========================================================================
|
|
100
|
+
// Private Methods
|
|
101
|
+
// ==========================================================================
|
|
102
|
+
/**
|
|
103
|
+
* Convert OSV vulnerabilities to our internal format
|
|
104
|
+
*/
|
|
105
|
+
convertOSVVulnerabilities(osvVulns) {
|
|
106
|
+
return osvVulns.map((osv) => {
|
|
107
|
+
const location = {
|
|
108
|
+
file: 'package.json',
|
|
109
|
+
line: 1,
|
|
110
|
+
column: 1,
|
|
111
|
+
snippet: `"${osv.affectedPackage}": "..."`,
|
|
112
|
+
};
|
|
113
|
+
const remediation = {
|
|
114
|
+
description: osv.fixedVersions.length > 0
|
|
115
|
+
? `Update to version ${osv.fixedVersions[0]} or later`
|
|
116
|
+
: 'No fixed version available; consider alternative packages',
|
|
117
|
+
fixExample: osv.fixedVersions.length > 0
|
|
118
|
+
? `npm install ${osv.affectedPackage}@${osv.fixedVersions[0]}`
|
|
119
|
+
: undefined,
|
|
120
|
+
estimatedEffort: 'minor',
|
|
121
|
+
automatable: true,
|
|
122
|
+
};
|
|
123
|
+
return {
|
|
124
|
+
id: uuidv4(),
|
|
125
|
+
cveId: osv.cveIds[0],
|
|
126
|
+
title: `${osv.affectedPackage}: ${osv.summary.substring(0, 80)}`,
|
|
127
|
+
description: osv.details || osv.summary,
|
|
128
|
+
severity: this.mapOSVSeverity(osv.severity),
|
|
129
|
+
category: 'vulnerable-components',
|
|
130
|
+
location,
|
|
131
|
+
remediation,
|
|
132
|
+
references: osv.references.slice(0, 5),
|
|
133
|
+
};
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Map OSV severity to our severity type
|
|
138
|
+
*/
|
|
139
|
+
mapOSVSeverity(osvSeverity) {
|
|
140
|
+
const mapping = {
|
|
141
|
+
critical: 'critical',
|
|
142
|
+
high: 'high',
|
|
143
|
+
medium: 'medium',
|
|
144
|
+
low: 'low',
|
|
145
|
+
unknown: 'medium',
|
|
146
|
+
};
|
|
147
|
+
return mapping[osvSeverity];
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* Calculate scan summary
|
|
151
|
+
*/
|
|
152
|
+
calculateSummary(vulnerabilities, totalFiles, scanDurationMs) {
|
|
153
|
+
const summary = {
|
|
154
|
+
critical: 0,
|
|
155
|
+
high: 0,
|
|
156
|
+
medium: 0,
|
|
157
|
+
low: 0,
|
|
158
|
+
informational: 0,
|
|
159
|
+
totalFiles,
|
|
160
|
+
scanDurationMs,
|
|
161
|
+
};
|
|
162
|
+
for (const vuln of vulnerabilities) {
|
|
163
|
+
summary[vuln.severity]++;
|
|
164
|
+
}
|
|
165
|
+
return summary;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Store scan results
|
|
169
|
+
*/
|
|
170
|
+
async storeScanResults(scanId, scanType, vulnerabilities, summary) {
|
|
171
|
+
await this.memory.set(`security:scan:${scanId}`, {
|
|
172
|
+
scanId,
|
|
173
|
+
scanType,
|
|
174
|
+
vulnerabilities,
|
|
175
|
+
summary,
|
|
176
|
+
timestamp: new Date().toISOString(),
|
|
177
|
+
}, { namespace: 'security-compliance', ttl: 86400 * 7 });
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
//# sourceMappingURL=dependency-scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dependency-scanner.js","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/dependency-scanner.ts"],"names":[],"mappings":"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"}
|