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,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - DAST Scanner Helper Functions
|
|
3
|
+
* Utility functions for dynamic security analysis
|
|
4
|
+
*/
|
|
5
|
+
import type { Vulnerability, ScanSummary, MemoryBackend } from './scanner-types.js';
|
|
6
|
+
export { testXSS, testSQLi } from './dast-injection-testing.js';
|
|
7
|
+
export { testAuthorizationBypass, testIDOR, validateCredentials, buildAuthHeaders, } from './dast-auth-testing.js';
|
|
8
|
+
/**
|
|
9
|
+
* Analyze security headers in HTTP response
|
|
10
|
+
*/
|
|
11
|
+
export declare function analyzeSecurityHeaders(headers: Headers, targetUrl: string, vulnerabilities: Vulnerability[], authenticated?: boolean): void;
|
|
12
|
+
/**
|
|
13
|
+
* Analyze cookie security attributes
|
|
14
|
+
*/
|
|
15
|
+
export declare function analyzeCookieSecurity(headers: Headers, targetUrl: string, vulnerabilities: Vulnerability[], authenticated?: boolean): void;
|
|
16
|
+
/**
|
|
17
|
+
* Analyze server headers for version disclosure
|
|
18
|
+
*/
|
|
19
|
+
export declare function analyzeServerHeaders(headers: Headers, targetUrl: string, vulnerabilities: Vulnerability[]): void;
|
|
20
|
+
/**
|
|
21
|
+
* Scan for sensitive file exposure
|
|
22
|
+
*/
|
|
23
|
+
export declare function scanSensitiveFiles(parsedUrl: URL, crawledUrls: number, maxDepth: number, vulnerabilities: Vulnerability[]): Promise<number>;
|
|
24
|
+
/**
|
|
25
|
+
* Analyze CORS configuration
|
|
26
|
+
*/
|
|
27
|
+
export declare function analyzeCORS(targetUrl: string, vulnerabilities: Vulnerability[]): Promise<void>;
|
|
28
|
+
/**
|
|
29
|
+
* Extract links from HTML and crawl discovered pages
|
|
30
|
+
*/
|
|
31
|
+
export declare function extractAndCrawlLinks(html: string, baseUrl: URL, currentCrawled: number, maxDepth: number, vulnerabilities: Vulnerability[]): Promise<number>;
|
|
32
|
+
/**
|
|
33
|
+
* Analyze HTML forms for security issues
|
|
34
|
+
*/
|
|
35
|
+
export declare function analyzeFormsForSecurityIssues(html: string, baseUrl: string, vulnerabilities: Vulnerability[]): void;
|
|
36
|
+
/**
|
|
37
|
+
* Handle fetch errors and add appropriate vulnerabilities
|
|
38
|
+
*/
|
|
39
|
+
export declare function handleFetchError(fetchError: unknown, targetUrl: string, vulnerabilities: Vulnerability[]): void;
|
|
40
|
+
/**
|
|
41
|
+
* Calculate scan summary from vulnerabilities
|
|
42
|
+
*/
|
|
43
|
+
export declare function calculateSummary(vulnerabilities: Vulnerability[], totalFiles: number, scanDurationMs: number): ScanSummary;
|
|
44
|
+
/**
|
|
45
|
+
* Store scan results in memory
|
|
46
|
+
*/
|
|
47
|
+
export declare function storeScanResults(memory: MemoryBackend, scanId: string, scanType: string, vulnerabilities: Vulnerability[], summary: ScanSummary): Promise<void>;
|
|
48
|
+
//# sourceMappingURL=dast-helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dast-helpers.d.ts","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/dast-helpers.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EACV,aAAa,EAEb,WAAW,EAEX,aAAa,EACd,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EACL,uBAAuB,EACvB,QAAQ,EACR,mBAAmB,EACnB,gBAAgB,GACjB,MAAM,wBAAwB,CAAC;AAMhC;;GAEG;AACH,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,MAAM,EACjB,eAAe,EAAE,aAAa,EAAE,EAChC,aAAa,UAAQ,GACpB,IAAI,CA6BN;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,MAAM,EACjB,eAAe,EAAE,aAAa,EAAE,EAChC,aAAa,UAAQ,GACpB,IAAI,CAoCN;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,OAAO,EAChB,SAAS,EAAE,MAAM,EACjB,eAAe,EAAE,aAAa,EAAE,GAC/B,IAAI,CAcN;AAMD;;GAEG;AACH,wBAAsB,kBAAkB,CACtC,SAAS,EAAE,GAAG,EACd,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,MAAM,EAChB,eAAe,EAAE,aAAa,EAAE,GAC/B,OAAO,CAAC,MAAM,CAAC,CAmDjB;AAMD;;GAEG;AACH,wBAAsB,WAAW,CAC/B,SAAS,EAAE,MAAM,EACjB,eAAe,EAAE,aAAa,EAAE,GAC/B,OAAO,CAAC,IAAI,CAAC,CA2Bf;AAMD;;GAEG;AACH,wBAAsB,oBAAoB,CACxC,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,GAAG,EACZ,cAAc,EAAE,MAAM,EACtB,QAAQ,EAAE,MAAM,EAChB,eAAe,EAAE,aAAa,EAAE,GAC/B,OAAO,CAAC,MAAM,CAAC,CAsEjB;AAMD;;GAEG;AACH,wBAAgB,6BAA6B,CAC3C,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,EACf,eAAe,EAAE,aAAa,EAAE,GAC/B,IAAI,CAsEN;AAMD;;GAEG;AACH,wBAAgB,gBAAgB,CAC9B,UAAU,EAAE,OAAO,EACnB,SAAS,EAAE,MAAM,EACjB,eAAe,EAAE,aAAa,EAAE,GAC/B,IAAI,CA0BN;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAC9B,eAAe,EAAE,aAAa,EAAE,EAChC,UAAU,EAAE,MAAM,EAClB,cAAc,EAAE,MAAM,GACrB,WAAW,CAgBb;AAED;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,aAAa,EACrB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,eAAe,EAAE,aAAa,EAAE,EAChC,OAAO,EAAE,WAAW,GACnB,OAAO,CAAC,IAAI,CAAC,CAYf"}
|
|
@@ -0,0 +1,385 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - DAST Scanner Helper Functions
|
|
3
|
+
* Utility functions for dynamic security analysis
|
|
4
|
+
*/
|
|
5
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
6
|
+
// Re-export from specialized modules for convenience
|
|
7
|
+
export { testXSS, testSQLi } from './dast-injection-testing.js';
|
|
8
|
+
export { testAuthorizationBypass, testIDOR, validateCredentials, buildAuthHeaders, } from './dast-auth-testing.js';
|
|
9
|
+
// ============================================================================
|
|
10
|
+
// Security Header Analysis
|
|
11
|
+
// ============================================================================
|
|
12
|
+
/**
|
|
13
|
+
* Analyze security headers in HTTP response
|
|
14
|
+
*/
|
|
15
|
+
export function analyzeSecurityHeaders(headers, targetUrl, vulnerabilities, authenticated = false) {
|
|
16
|
+
const headerChecks = [
|
|
17
|
+
{ header: 'strict-transport-security', title: 'Missing HSTS Header', severity: 'medium', remediation: 'Add Strict-Transport-Security header' },
|
|
18
|
+
{ header: 'x-content-type-options', title: 'Missing X-Content-Type-Options', severity: 'low', remediation: 'Add X-Content-Type-Options: nosniff' },
|
|
19
|
+
{ header: 'x-frame-options', title: 'Missing X-Frame-Options', severity: 'medium', remediation: 'Add X-Frame-Options: DENY or SAMEORIGIN' },
|
|
20
|
+
{ header: 'content-security-policy', title: 'Missing Content-Security-Policy', severity: 'medium', remediation: 'Implement a Content-Security-Policy' },
|
|
21
|
+
];
|
|
22
|
+
if (!authenticated) {
|
|
23
|
+
headerChecks.push({ header: 'referrer-policy', title: 'Missing Referrer-Policy', severity: 'low', remediation: 'Add Referrer-Policy header' }, { header: 'permissions-policy', title: 'Missing Permissions-Policy', severity: 'low', remediation: 'Add Permissions-Policy header' });
|
|
24
|
+
}
|
|
25
|
+
for (const check of headerChecks) {
|
|
26
|
+
if (!headers.get(check.header)) {
|
|
27
|
+
vulnerabilities.push({
|
|
28
|
+
id: uuidv4(),
|
|
29
|
+
title: check.title,
|
|
30
|
+
description: `Security header ${check.header} is not present in the response`,
|
|
31
|
+
severity: check.severity,
|
|
32
|
+
category: 'security-misconfiguration',
|
|
33
|
+
location: { file: targetUrl, snippet: `Missing: ${check.header}` },
|
|
34
|
+
remediation: { description: check.remediation, estimatedEffort: 'minor', automatable: true },
|
|
35
|
+
references: ['https://owasp.org/www-project-secure-headers/'],
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Analyze cookie security attributes
|
|
42
|
+
*/
|
|
43
|
+
export function analyzeCookieSecurity(headers, targetUrl, vulnerabilities, authenticated = false) {
|
|
44
|
+
const setCookie = headers.get('set-cookie');
|
|
45
|
+
if (!setCookie)
|
|
46
|
+
return;
|
|
47
|
+
const cookieLower = setCookie.toLowerCase();
|
|
48
|
+
const severity = authenticated ? 'high' : 'medium';
|
|
49
|
+
if (!cookieLower.includes('secure')) {
|
|
50
|
+
vulnerabilities.push({
|
|
51
|
+
id: uuidv4(),
|
|
52
|
+
title: authenticated ? 'Session Cookie Missing Secure Flag' : 'Cookie Missing Secure Flag',
|
|
53
|
+
description: authenticated
|
|
54
|
+
? 'Authenticated session cookie is not marked as Secure'
|
|
55
|
+
: 'Cookie is set without the Secure attribute',
|
|
56
|
+
severity,
|
|
57
|
+
category: 'sensitive-data',
|
|
58
|
+
location: { file: targetUrl, snippet: `Set-Cookie header without Secure flag` },
|
|
59
|
+
remediation: { description: 'Add Secure flag to all cookies', estimatedEffort: 'trivial', automatable: true },
|
|
60
|
+
references: ['https://owasp.org/www-community/controls/SecureCookieAttribute'],
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
if (!cookieLower.includes('httponly')) {
|
|
64
|
+
vulnerabilities.push({
|
|
65
|
+
id: uuidv4(),
|
|
66
|
+
title: authenticated ? 'Session Cookie Missing HttpOnly Flag' : 'Cookie Missing HttpOnly Flag',
|
|
67
|
+
description: authenticated
|
|
68
|
+
? 'Session cookie is accessible to JavaScript'
|
|
69
|
+
: 'Cookie is accessible to client-side JavaScript',
|
|
70
|
+
severity,
|
|
71
|
+
category: 'sensitive-data',
|
|
72
|
+
location: { file: targetUrl, snippet: `Set-Cookie header without HttpOnly flag` },
|
|
73
|
+
remediation: { description: 'Add HttpOnly flag to session cookies', estimatedEffort: 'trivial', automatable: true },
|
|
74
|
+
references: ['https://owasp.org/www-community/HttpOnly'],
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Analyze server headers for version disclosure
|
|
80
|
+
*/
|
|
81
|
+
export function analyzeServerHeaders(headers, targetUrl, vulnerabilities) {
|
|
82
|
+
const serverHeader = headers.get('server') || headers.get('x-powered-by');
|
|
83
|
+
if (serverHeader && /\d+\.\d+/.test(serverHeader)) {
|
|
84
|
+
vulnerabilities.push({
|
|
85
|
+
id: uuidv4(),
|
|
86
|
+
title: 'Server Version Disclosure',
|
|
87
|
+
description: `Server version information exposed: ${serverHeader}`,
|
|
88
|
+
severity: 'low',
|
|
89
|
+
category: 'security-misconfiguration',
|
|
90
|
+
location: { file: targetUrl, snippet: `Server: ${serverHeader}` },
|
|
91
|
+
remediation: { description: 'Remove or obfuscate server version headers', estimatedEffort: 'trivial', automatable: true },
|
|
92
|
+
references: ['https://owasp.org/www-project-web-security-testing-guide/'],
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
// ============================================================================
|
|
97
|
+
// Sensitive File Scanning
|
|
98
|
+
// ============================================================================
|
|
99
|
+
/**
|
|
100
|
+
* Scan for sensitive file exposure
|
|
101
|
+
*/
|
|
102
|
+
export async function scanSensitiveFiles(parsedUrl, crawledUrls, maxDepth, vulnerabilities) {
|
|
103
|
+
const sensitiveEndpoints = [
|
|
104
|
+
{ path: '/.git/config', name: 'Git Configuration' },
|
|
105
|
+
{ path: '/.env', name: 'Environment File' },
|
|
106
|
+
{ path: '/robots.txt', name: 'Robots.txt' },
|
|
107
|
+
{ path: '/sitemap.xml', name: 'Sitemap' },
|
|
108
|
+
{ path: '/.htaccess', name: 'htaccess File' },
|
|
109
|
+
{ path: '/web.config', name: 'IIS Configuration' },
|
|
110
|
+
];
|
|
111
|
+
for (const endpoint of sensitiveEndpoints) {
|
|
112
|
+
if (crawledUrls >= maxDepth * 10)
|
|
113
|
+
break;
|
|
114
|
+
try {
|
|
115
|
+
const testUrl = new URL(endpoint.path, parsedUrl.origin).toString();
|
|
116
|
+
const testResponse = await fetch(testUrl, {
|
|
117
|
+
method: 'GET',
|
|
118
|
+
signal: AbortSignal.timeout(5000),
|
|
119
|
+
});
|
|
120
|
+
if (testResponse.ok) {
|
|
121
|
+
crawledUrls++;
|
|
122
|
+
const text = await testResponse.text();
|
|
123
|
+
if (text.length > 20 && !text.toLowerCase().includes('not found') && !text.toLowerCase().includes('404')) {
|
|
124
|
+
const isSensitive = endpoint.path.includes('.git') ||
|
|
125
|
+
endpoint.path.includes('.env') ||
|
|
126
|
+
endpoint.path.includes('.htaccess') ||
|
|
127
|
+
endpoint.path.includes('web.config');
|
|
128
|
+
if (isSensitive) {
|
|
129
|
+
vulnerabilities.push({
|
|
130
|
+
id: uuidv4(),
|
|
131
|
+
title: `Sensitive File Exposed: ${endpoint.name}`,
|
|
132
|
+
description: `${endpoint.name} is publicly accessible`,
|
|
133
|
+
severity: endpoint.path.includes('.git') || endpoint.path.includes('.env') ? 'high' : 'medium',
|
|
134
|
+
category: 'sensitive-data',
|
|
135
|
+
location: { file: testUrl },
|
|
136
|
+
remediation: { description: `Restrict access to ${endpoint.path}`, estimatedEffort: 'trivial', automatable: true },
|
|
137
|
+
references: ['https://owasp.org/www-project-web-security-testing-guide/'],
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
catch {
|
|
144
|
+
// File not accessible - expected
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
return crawledUrls;
|
|
148
|
+
}
|
|
149
|
+
// ============================================================================
|
|
150
|
+
// CORS Analysis
|
|
151
|
+
// ============================================================================
|
|
152
|
+
/**
|
|
153
|
+
* Analyze CORS configuration
|
|
154
|
+
*/
|
|
155
|
+
export async function analyzeCORS(targetUrl, vulnerabilities) {
|
|
156
|
+
try {
|
|
157
|
+
const corsResponse = await fetch(targetUrl, {
|
|
158
|
+
method: 'OPTIONS',
|
|
159
|
+
headers: {
|
|
160
|
+
'Origin': 'https://evil-attacker.com',
|
|
161
|
+
'Access-Control-Request-Method': 'GET',
|
|
162
|
+
},
|
|
163
|
+
signal: AbortSignal.timeout(5000),
|
|
164
|
+
});
|
|
165
|
+
const allowOrigin = corsResponse.headers.get('access-control-allow-origin');
|
|
166
|
+
if (allowOrigin === '*' || allowOrigin === 'https://evil-attacker.com') {
|
|
167
|
+
vulnerabilities.push({
|
|
168
|
+
id: uuidv4(),
|
|
169
|
+
title: 'Overly Permissive CORS Policy',
|
|
170
|
+
description: allowOrigin === '*' ? 'CORS allows all origins' : 'CORS reflects arbitrary origin',
|
|
171
|
+
severity: 'medium',
|
|
172
|
+
category: 'access-control',
|
|
173
|
+
location: { file: targetUrl, snippet: `Access-Control-Allow-Origin: ${allowOrigin}` },
|
|
174
|
+
remediation: { description: 'Restrict CORS to specific trusted origins', estimatedEffort: 'minor', automatable: false },
|
|
175
|
+
references: ['https://owasp.org/www-community/attacks/CORS_OriginHeaderScrutiny'],
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
catch {
|
|
180
|
+
// OPTIONS request failed - CORS might be properly restricted
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
// ============================================================================
|
|
184
|
+
// Link Crawling
|
|
185
|
+
// ============================================================================
|
|
186
|
+
/**
|
|
187
|
+
* Extract links from HTML and crawl discovered pages
|
|
188
|
+
*/
|
|
189
|
+
export async function extractAndCrawlLinks(html, baseUrl, currentCrawled, maxDepth, vulnerabilities) {
|
|
190
|
+
let crawledUrls = currentCrawled;
|
|
191
|
+
const maxCrawl = maxDepth * 5;
|
|
192
|
+
const linkPattern = /href=["']([^"']+)["']/gi;
|
|
193
|
+
const discoveredLinks = new Set();
|
|
194
|
+
let match;
|
|
195
|
+
while ((match = linkPattern.exec(html)) !== null) {
|
|
196
|
+
const href = match[1];
|
|
197
|
+
try {
|
|
198
|
+
const linkUrl = new URL(href, baseUrl.origin);
|
|
199
|
+
if (linkUrl.origin === baseUrl.origin && !discoveredLinks.has(linkUrl.pathname)) {
|
|
200
|
+
discoveredLinks.add(linkUrl.pathname);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
catch {
|
|
204
|
+
// Invalid URL - skip
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
const linksToCrawl = Array.from(discoveredLinks).slice(0, Math.min(10, maxCrawl - crawledUrls));
|
|
208
|
+
for (const path of linksToCrawl) {
|
|
209
|
+
if (crawledUrls >= maxCrawl)
|
|
210
|
+
break;
|
|
211
|
+
try {
|
|
212
|
+
const crawlUrl = new URL(path, baseUrl.origin).toString();
|
|
213
|
+
const crawlResponse = await fetch(crawlUrl, {
|
|
214
|
+
method: 'GET',
|
|
215
|
+
headers: { 'User-Agent': 'AgenticQE-DAST-Scanner/3.0' },
|
|
216
|
+
signal: AbortSignal.timeout(5000),
|
|
217
|
+
redirect: 'follow',
|
|
218
|
+
});
|
|
219
|
+
crawledUrls++;
|
|
220
|
+
if (crawlResponse.ok) {
|
|
221
|
+
if (path.includes('password') || path.includes('token') || path.includes('api_key')) {
|
|
222
|
+
vulnerabilities.push({
|
|
223
|
+
id: uuidv4(),
|
|
224
|
+
title: 'Sensitive Data in URL Path',
|
|
225
|
+
description: `URL path may contain sensitive parameter names: ${path}`,
|
|
226
|
+
severity: 'medium',
|
|
227
|
+
category: 'sensitive-data',
|
|
228
|
+
location: { file: crawlUrl },
|
|
229
|
+
remediation: { description: 'Avoid sensitive data in URL paths', estimatedEffort: 'minor', automatable: false },
|
|
230
|
+
references: ['https://owasp.org/www-community/vulnerabilities/Information_exposure_through_query_strings_in_url'],
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
const responseText = await crawlResponse.text();
|
|
234
|
+
if (responseText.includes('Index of /') || responseText.includes('Directory listing for')) {
|
|
235
|
+
vulnerabilities.push({
|
|
236
|
+
id: uuidv4(),
|
|
237
|
+
title: 'Directory Listing Enabled',
|
|
238
|
+
description: `Directory listing is enabled at: ${crawlUrl}`,
|
|
239
|
+
severity: 'medium',
|
|
240
|
+
category: 'security-misconfiguration',
|
|
241
|
+
location: { file: crawlUrl },
|
|
242
|
+
remediation: { description: 'Disable directory listing in server configuration', estimatedEffort: 'trivial', automatable: true },
|
|
243
|
+
references: ['https://owasp.org/www-project-web-security-testing-guide/'],
|
|
244
|
+
});
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
catch {
|
|
249
|
+
// Page not accessible
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
return crawledUrls;
|
|
253
|
+
}
|
|
254
|
+
// ============================================================================
|
|
255
|
+
// Form Analysis
|
|
256
|
+
// ============================================================================
|
|
257
|
+
/**
|
|
258
|
+
* Analyze HTML forms for security issues
|
|
259
|
+
*/
|
|
260
|
+
export function analyzeFormsForSecurityIssues(html, baseUrl, vulnerabilities) {
|
|
261
|
+
const formPattern = /<form[^>]*>([\s\S]*?)<\/form>/gi;
|
|
262
|
+
let formMatch;
|
|
263
|
+
let formIndex = 0;
|
|
264
|
+
while ((formMatch = formPattern.exec(html)) !== null && formIndex < 10) {
|
|
265
|
+
formIndex++;
|
|
266
|
+
const formHtml = formMatch[0];
|
|
267
|
+
const formContent = formMatch[1];
|
|
268
|
+
// Check for CSRF token
|
|
269
|
+
const hasCsrfToken = /name=["']?csrf/i.test(formContent) ||
|
|
270
|
+
/name=["']?_token/i.test(formContent) ||
|
|
271
|
+
/name=["']?authenticity_token/i.test(formContent) ||
|
|
272
|
+
/name=["']?__RequestVerificationToken/i.test(formContent);
|
|
273
|
+
const isPostForm = /method=["']?post/i.test(formHtml);
|
|
274
|
+
if (isPostForm && !hasCsrfToken) {
|
|
275
|
+
vulnerabilities.push({
|
|
276
|
+
id: uuidv4(),
|
|
277
|
+
title: 'Missing CSRF Token',
|
|
278
|
+
description: `POST form #${formIndex} does not appear to have CSRF protection`,
|
|
279
|
+
severity: 'medium',
|
|
280
|
+
category: 'broken-auth',
|
|
281
|
+
location: { file: baseUrl, snippet: `Form #${formIndex}` },
|
|
282
|
+
remediation: { description: 'Add CSRF token to all state-changing forms', estimatedEffort: 'minor', automatable: false },
|
|
283
|
+
references: ['https://owasp.org/www-community/attacks/csrf'],
|
|
284
|
+
});
|
|
285
|
+
}
|
|
286
|
+
// Check for password fields without autocomplete=off
|
|
287
|
+
if (/type=["']?password/i.test(formContent)) {
|
|
288
|
+
const hasAutocompleteOff = /autocomplete=["']?(off|new-password)/i.test(formContent) ||
|
|
289
|
+
/autocomplete=["']?(off|new-password)/i.test(formHtml);
|
|
290
|
+
if (!hasAutocompleteOff) {
|
|
291
|
+
vulnerabilities.push({
|
|
292
|
+
id: uuidv4(),
|
|
293
|
+
title: 'Password Field Allows Autocomplete',
|
|
294
|
+
description: `Form #${formIndex} has password field that may be cached by browser`,
|
|
295
|
+
severity: 'low',
|
|
296
|
+
category: 'sensitive-data',
|
|
297
|
+
location: { file: baseUrl, snippet: `Form #${formIndex}` },
|
|
298
|
+
remediation: { description: 'Add autocomplete="new-password" to password fields', estimatedEffort: 'trivial', automatable: true },
|
|
299
|
+
references: ['https://owasp.org/www-project-web-security-testing-guide/'],
|
|
300
|
+
});
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
// Check for insecure form action
|
|
304
|
+
const actionMatch = /action=["']?([^"'\s>]+)/i.exec(formHtml);
|
|
305
|
+
if (actionMatch) {
|
|
306
|
+
const action = actionMatch[1];
|
|
307
|
+
if (action.startsWith('http://') && !action.includes('localhost') && !action.includes('127.0.0.1')) {
|
|
308
|
+
vulnerabilities.push({
|
|
309
|
+
id: uuidv4(),
|
|
310
|
+
title: 'Form Submits to Insecure HTTP',
|
|
311
|
+
description: `Form #${formIndex} submits data over insecure HTTP: ${action}`,
|
|
312
|
+
severity: 'high',
|
|
313
|
+
category: 'sensitive-data',
|
|
314
|
+
location: { file: baseUrl, snippet: `Action: ${action}` },
|
|
315
|
+
remediation: { description: 'Change form action to use HTTPS', estimatedEffort: 'trivial', automatable: true },
|
|
316
|
+
references: ['https://owasp.org/www-project-web-security-testing-guide/'],
|
|
317
|
+
});
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
// ============================================================================
|
|
323
|
+
// Utility Functions
|
|
324
|
+
// ============================================================================
|
|
325
|
+
/**
|
|
326
|
+
* Handle fetch errors and add appropriate vulnerabilities
|
|
327
|
+
*/
|
|
328
|
+
export function handleFetchError(fetchError, targetUrl, vulnerabilities) {
|
|
329
|
+
const errorMsg = fetchError instanceof Error ? fetchError.message : String(fetchError);
|
|
330
|
+
if (errorMsg.includes('CERT') || errorMsg.includes('SSL') || errorMsg.includes('TLS') || errorMsg.includes('certificate')) {
|
|
331
|
+
vulnerabilities.push({
|
|
332
|
+
id: uuidv4(),
|
|
333
|
+
title: 'TLS Certificate Error',
|
|
334
|
+
description: `SSL/TLS error: ${errorMsg}`,
|
|
335
|
+
severity: 'high',
|
|
336
|
+
category: 'security-misconfiguration',
|
|
337
|
+
location: { file: targetUrl },
|
|
338
|
+
remediation: { description: 'Fix TLS certificate configuration', estimatedEffort: 'moderate', automatable: false },
|
|
339
|
+
references: ['https://owasp.org/www-project-web-security-testing-guide/'],
|
|
340
|
+
});
|
|
341
|
+
}
|
|
342
|
+
else if (errorMsg.includes('timeout') || errorMsg.includes('abort')) {
|
|
343
|
+
vulnerabilities.push({
|
|
344
|
+
id: uuidv4(),
|
|
345
|
+
title: 'Connection Timeout',
|
|
346
|
+
description: `Target did not respond within timeout: ${errorMsg}`,
|
|
347
|
+
severity: 'informational',
|
|
348
|
+
category: 'security-misconfiguration',
|
|
349
|
+
location: { file: targetUrl },
|
|
350
|
+
remediation: { description: 'Verify target is accessible', estimatedEffort: 'trivial', automatable: false },
|
|
351
|
+
references: [],
|
|
352
|
+
});
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
/**
|
|
356
|
+
* Calculate scan summary from vulnerabilities
|
|
357
|
+
*/
|
|
358
|
+
export function calculateSummary(vulnerabilities, totalFiles, scanDurationMs) {
|
|
359
|
+
const summary = {
|
|
360
|
+
critical: 0,
|
|
361
|
+
high: 0,
|
|
362
|
+
medium: 0,
|
|
363
|
+
low: 0,
|
|
364
|
+
informational: 0,
|
|
365
|
+
totalFiles,
|
|
366
|
+
scanDurationMs,
|
|
367
|
+
};
|
|
368
|
+
for (const vuln of vulnerabilities) {
|
|
369
|
+
summary[vuln.severity]++;
|
|
370
|
+
}
|
|
371
|
+
return summary;
|
|
372
|
+
}
|
|
373
|
+
/**
|
|
374
|
+
* Store scan results in memory
|
|
375
|
+
*/
|
|
376
|
+
export async function storeScanResults(memory, scanId, scanType, vulnerabilities, summary) {
|
|
377
|
+
await memory.set(`security:scan:${scanId}`, {
|
|
378
|
+
scanId,
|
|
379
|
+
scanType,
|
|
380
|
+
vulnerabilities,
|
|
381
|
+
summary,
|
|
382
|
+
timestamp: new Date().toISOString(),
|
|
383
|
+
}, { namespace: 'security-compliance', ttl: 86400 * 7 });
|
|
384
|
+
}
|
|
385
|
+
//# sourceMappingURL=dast-helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dast-helpers.js","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/dast-helpers.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - DAST Injection Testing
|
|
3
|
+
* XSS and SQL injection testing utilities
|
|
4
|
+
*/
|
|
5
|
+
import type { Vulnerability } from './scanner-types.js';
|
|
6
|
+
/**
|
|
7
|
+
* Test for XSS vulnerabilities
|
|
8
|
+
*/
|
|
9
|
+
export declare function testXSS(targetUrl: string, parsedUrl: URL, paramName: string, payloads: Array<{
|
|
10
|
+
payload: string;
|
|
11
|
+
name: string;
|
|
12
|
+
}>, vulnerabilities: Vulnerability[]): Promise<void>;
|
|
13
|
+
/**
|
|
14
|
+
* Test for SQL injection vulnerabilities
|
|
15
|
+
*/
|
|
16
|
+
export declare function testSQLi(targetUrl: string, parsedUrl: URL, paramName: string, payloads: Array<{
|
|
17
|
+
payload: string;
|
|
18
|
+
name: string;
|
|
19
|
+
}>, vulnerabilities: Vulnerability[]): Promise<void>;
|
|
20
|
+
//# sourceMappingURL=dast-injection-testing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dast-injection-testing.d.ts","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/dast-injection-testing.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAMxD;;GAEG;AACH,wBAAsB,OAAO,CAC3B,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,GAAG,EACd,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,KAAK,CAAC;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,EAClD,eAAe,EAAE,aAAa,EAAE,GAC/B,OAAO,CAAC,IAAI,CAAC,CA2Cf;AAED;;GAEG;AACH,wBAAsB,QAAQ,CAC5B,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,GAAG,EACd,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,KAAK,CAAC;IAAE,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,CAAC,EAClD,eAAe,EAAE,aAAa,EAAE,GAC/B,OAAO,CAAC,IAAI,CAAC,CA6Cf"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agentic QE v3 - DAST Injection Testing
|
|
3
|
+
* XSS and SQL injection testing utilities
|
|
4
|
+
*/
|
|
5
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
6
|
+
// ============================================================================
|
|
7
|
+
// Injection Testing
|
|
8
|
+
// ============================================================================
|
|
9
|
+
/**
|
|
10
|
+
* Test for XSS vulnerabilities
|
|
11
|
+
*/
|
|
12
|
+
export async function testXSS(targetUrl, parsedUrl, paramName, payloads, vulnerabilities) {
|
|
13
|
+
for (const xss of payloads) {
|
|
14
|
+
try {
|
|
15
|
+
const testParams = new URLSearchParams(parsedUrl.search);
|
|
16
|
+
testParams.set(paramName, xss.payload);
|
|
17
|
+
const testUrl = `${parsedUrl.origin}${parsedUrl.pathname}?${testParams.toString()}`;
|
|
18
|
+
const response = await fetch(testUrl, {
|
|
19
|
+
method: 'GET',
|
|
20
|
+
headers: { 'User-Agent': 'AgenticQE-DAST-Scanner/3.0' },
|
|
21
|
+
signal: AbortSignal.timeout(5000),
|
|
22
|
+
});
|
|
23
|
+
if (response.ok) {
|
|
24
|
+
const text = await response.text();
|
|
25
|
+
const escapedPayload = xss.payload
|
|
26
|
+
.replace(/&/g, '&')
|
|
27
|
+
.replace(/</g, '<')
|
|
28
|
+
.replace(/>/g, '>')
|
|
29
|
+
.replace(/"/g, '"')
|
|
30
|
+
.replace(/'/g, ''');
|
|
31
|
+
const hasUnescapedPayload = text.includes(xss.payload);
|
|
32
|
+
const hasEscapedPayload = text.includes(escapedPayload);
|
|
33
|
+
if (hasUnescapedPayload && !hasEscapedPayload) {
|
|
34
|
+
vulnerabilities.push({
|
|
35
|
+
id: uuidv4(),
|
|
36
|
+
title: `Reflected XSS: ${xss.name}`,
|
|
37
|
+
description: `Parameter '${paramName}' reflects unsanitized input`,
|
|
38
|
+
severity: 'critical',
|
|
39
|
+
category: 'xss',
|
|
40
|
+
location: { file: targetUrl, snippet: `Parameter: ${paramName}, Payload: ${xss.payload.substring(0, 30)}...` },
|
|
41
|
+
remediation: { description: 'HTML-encode all user input before rendering', estimatedEffort: 'moderate', automatable: false },
|
|
42
|
+
references: ['https://owasp.org/www-community/attacks/xss/'],
|
|
43
|
+
});
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
catch {
|
|
49
|
+
// Request failed
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Test for SQL injection vulnerabilities
|
|
55
|
+
*/
|
|
56
|
+
export async function testSQLi(targetUrl, parsedUrl, paramName, payloads, vulnerabilities) {
|
|
57
|
+
const sqlErrorPatterns = [
|
|
58
|
+
/SQL syntax.*MySQL/i,
|
|
59
|
+
/Warning.*mysql/i,
|
|
60
|
+
/PostgreSQL.*ERROR/i,
|
|
61
|
+
/ORA-\d{5}/i,
|
|
62
|
+
/SQLite.*error/i,
|
|
63
|
+
/SQLITE_ERROR/i,
|
|
64
|
+
/unclosed quotation mark/i,
|
|
65
|
+
/quoted string not properly terminated/i,
|
|
66
|
+
];
|
|
67
|
+
for (const sqli of payloads) {
|
|
68
|
+
try {
|
|
69
|
+
const testParams = new URLSearchParams(parsedUrl.search);
|
|
70
|
+
testParams.set(paramName, sqli.payload);
|
|
71
|
+
const testUrl = `${parsedUrl.origin}${parsedUrl.pathname}?${testParams.toString()}`;
|
|
72
|
+
const response = await fetch(testUrl, {
|
|
73
|
+
method: 'GET',
|
|
74
|
+
headers: { 'User-Agent': 'AgenticQE-DAST-Scanner/3.0' },
|
|
75
|
+
signal: AbortSignal.timeout(5000),
|
|
76
|
+
});
|
|
77
|
+
const text = await response.text();
|
|
78
|
+
for (const pattern of sqlErrorPatterns) {
|
|
79
|
+
if (pattern.test(text)) {
|
|
80
|
+
vulnerabilities.push({
|
|
81
|
+
id: uuidv4(),
|
|
82
|
+
title: `SQL Injection: ${sqli.name}`,
|
|
83
|
+
description: `Parameter '${paramName}' appears vulnerable to SQL injection`,
|
|
84
|
+
severity: 'critical',
|
|
85
|
+
category: 'injection',
|
|
86
|
+
location: { file: targetUrl, snippet: `Parameter: ${paramName}` },
|
|
87
|
+
remediation: { description: 'Use parameterized queries or prepared statements', estimatedEffort: 'moderate', automatable: false },
|
|
88
|
+
references: ['https://owasp.org/www-community/attacks/SQL_Injection'],
|
|
89
|
+
});
|
|
90
|
+
break;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
catch {
|
|
95
|
+
// Request failed
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
//# sourceMappingURL=dast-injection-testing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dast-injection-testing.js","sourceRoot":"","sources":["../../../../../src/domains/security-compliance/services/scanners/dast-injection-testing.ts"],"names":[],"mappings":"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"}
|