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.
Files changed (522) hide show
  1. package/.claude/agents/v3/README.md +100 -0
  2. package/.claude/agents/v3/qe-accessibility-auditor.md +112 -11
  3. package/.claude/agents/v3/qe-bdd-generator.md +40 -0
  4. package/.claude/agents/v3/qe-coverage-specialist.md +39 -0
  5. package/.claude/agents/v3/qe-defect-predictor.md +36 -0
  6. package/.claude/agents/v3/qe-gap-detector.md +39 -0
  7. package/.claude/agents/v3/qe-pattern-learner.md +31 -0
  8. package/.claude/agents/v3/qe-product-factors-assessor.md +34 -0
  9. package/.claude/agents/v3/qe-quality-criteria-recommender.md +32 -0
  10. package/.claude/agents/v3/qe-quality-gate.md +39 -0
  11. package/.claude/agents/v3/qe-requirements-validator.md +37 -0
  12. package/.claude/agents/v3/qe-risk-assessor.md +33 -0
  13. package/.claude/agents/v3/qe-tdd-specialist.md +33 -0
  14. package/.claude/agents/v3/qe-test-architect.md +36 -0
  15. package/.claude/skills/README.md +30 -104
  16. package/.claude/skills/a11y-ally/SKILL.md +1658 -0
  17. package/.claude/skills/qcsd-ideation-swarm/SKILL.md +1750 -0
  18. package/.claude/skills/skills-manifest.json +78 -8
  19. package/README.md +18 -4
  20. package/package.json +1 -1
  21. package/scripts/demo-warmup.sh +45 -0
  22. package/scripts/fetch-content.js +460 -0
  23. package/v3/CHANGELOG.md +101 -0
  24. package/v3/README.md +11 -6
  25. package/v3/assets/agents/v3/README.md +100 -0
  26. package/v3/assets/agents/v3/qe-accessibility-auditor.md +112 -11
  27. package/v3/assets/agents/v3/qe-bdd-generator.md +40 -0
  28. package/v3/assets/agents/v3/qe-coverage-specialist.md +39 -0
  29. package/v3/assets/agents/v3/qe-defect-predictor.md +36 -0
  30. package/v3/assets/agents/v3/qe-gap-detector.md +39 -0
  31. package/v3/assets/agents/v3/qe-pattern-learner.md +31 -0
  32. package/v3/assets/agents/v3/qe-product-factors-assessor.md +34 -0
  33. package/v3/assets/agents/v3/qe-quality-criteria-recommender.md +32 -0
  34. package/v3/assets/agents/v3/qe-quality-gate.md +39 -0
  35. package/v3/assets/agents/v3/qe-requirements-validator.md +37 -0
  36. package/v3/assets/agents/v3/qe-risk-assessor.md +33 -0
  37. package/v3/assets/agents/v3/qe-tdd-specialist.md +33 -0
  38. package/v3/assets/agents/v3/qe-test-architect.md +36 -0
  39. package/v3/assets/hooks/cross-phase-memory.yaml +253 -0
  40. package/v3/assets/skills/a11y-ally/SKILL.md +1658 -0
  41. package/v3/assets/skills/qcsd-ideation-swarm/SKILL.md +1750 -0
  42. package/v3/assets/skills/skills-manifest.json +753 -0
  43. package/v3/dist/adapters/claude-flow/model-router-bridge.d.ts.map +1 -1
  44. package/v3/dist/adapters/claude-flow/model-router-bridge.js +6 -4
  45. package/v3/dist/adapters/claude-flow/model-router-bridge.js.map +1 -1
  46. package/v3/dist/adapters/claude-flow/pretrain-bridge.d.ts.map +1 -1
  47. package/v3/dist/adapters/claude-flow/pretrain-bridge.js +13 -8
  48. package/v3/dist/adapters/claude-flow/pretrain-bridge.js.map +1 -1
  49. package/v3/dist/adapters/claude-flow/trajectory-bridge.d.ts.map +1 -1
  50. package/v3/dist/adapters/claude-flow/trajectory-bridge.js +9 -6
  51. package/v3/dist/adapters/claude-flow/trajectory-bridge.js.map +1 -1
  52. package/v3/dist/benchmarks/performance-benchmarks.d.ts.map +1 -1
  53. package/v3/dist/benchmarks/performance-benchmarks.js +5 -3
  54. package/v3/dist/benchmarks/performance-benchmarks.js.map +1 -1
  55. package/v3/dist/cli/bundle.js +27611 -23175
  56. package/v3/dist/cli/commands/hooks.d.ts.map +1 -1
  57. package/v3/dist/cli/commands/hooks.js +288 -0
  58. package/v3/dist/cli/commands/hooks.js.map +1 -1
  59. package/v3/dist/cli/commands/sync.d.ts.map +1 -1
  60. package/v3/dist/cli/commands/sync.js +0 -6
  61. package/v3/dist/cli/commands/sync.js.map +1 -1
  62. package/v3/dist/cli/handlers/init-handler.d.ts.map +1 -1
  63. package/v3/dist/cli/handlers/init-handler.js +11 -0
  64. package/v3/dist/cli/handlers/init-handler.js.map +1 -1
  65. package/v3/dist/cli/index.js +14 -2
  66. package/v3/dist/cli/index.js.map +1 -1
  67. package/v3/dist/cli/scheduler/persistent-scheduler.d.ts.map +1 -1
  68. package/v3/dist/cli/scheduler/persistent-scheduler.js +3 -2
  69. package/v3/dist/cli/scheduler/persistent-scheduler.js.map +1 -1
  70. package/v3/dist/cli/wizards/test-wizard.d.ts.map +1 -1
  71. package/v3/dist/cli/wizards/test-wizard.js +6 -4
  72. package/v3/dist/cli/wizards/test-wizard.js.map +1 -1
  73. package/v3/dist/coordination/consensus/providers/native-learning-provider.d.ts.map +1 -1
  74. package/v3/dist/coordination/consensus/providers/native-learning-provider.js +10 -8
  75. package/v3/dist/coordination/consensus/providers/native-learning-provider.js.map +1 -1
  76. package/v3/dist/coordination/consensus/providers/ollama-provider.d.ts.map +1 -1
  77. package/v3/dist/coordination/consensus/providers/ollama-provider.js +5 -4
  78. package/v3/dist/coordination/consensus/providers/ollama-provider.js.map +1 -1
  79. package/v3/dist/coordination/consensus/providers/openai-provider.d.ts.map +1 -1
  80. package/v3/dist/coordination/consensus/providers/openai-provider.js +5 -4
  81. package/v3/dist/coordination/consensus/providers/openai-provider.js.map +1 -1
  82. package/v3/dist/coordination/constants.d.ts +198 -0
  83. package/v3/dist/coordination/constants.d.ts.map +1 -0
  84. package/v3/dist/coordination/constants.js +210 -0
  85. package/v3/dist/coordination/constants.js.map +1 -0
  86. package/v3/dist/coordination/mincut/dream-integration.d.ts.map +1 -1
  87. package/v3/dist/coordination/mincut/dream-integration.js +5 -1
  88. package/v3/dist/coordination/mincut/dream-integration.js.map +1 -1
  89. package/v3/dist/coordination/queen-coordinator.d.ts +9 -1
  90. package/v3/dist/coordination/queen-coordinator.d.ts.map +1 -1
  91. package/v3/dist/coordination/queen-coordinator.js +49 -9
  92. package/v3/dist/coordination/queen-coordinator.js.map +1 -1
  93. package/v3/dist/coordination/task-executor.d.ts.map +1 -1
  94. package/v3/dist/coordination/task-executor.js +7 -8
  95. package/v3/dist/coordination/task-executor.js.map +1 -1
  96. package/v3/dist/coordination/workflow-orchestrator.d.ts.map +1 -1
  97. package/v3/dist/coordination/workflow-orchestrator.js +261 -0
  98. package/v3/dist/coordination/workflow-orchestrator.js.map +1 -1
  99. package/v3/dist/domains/chaos-resilience/plugin.d.ts +14 -3
  100. package/v3/dist/domains/chaos-resilience/plugin.d.ts.map +1 -1
  101. package/v3/dist/domains/chaos-resilience/plugin.js +96 -0
  102. package/v3/dist/domains/chaos-resilience/plugin.js.map +1 -1
  103. package/v3/dist/domains/chaos-resilience/services/performance-profiler.d.ts.map +1 -1
  104. package/v3/dist/domains/chaos-resilience/services/performance-profiler.js +12 -8
  105. package/v3/dist/domains/chaos-resilience/services/performance-profiler.js.map +1 -1
  106. package/v3/dist/domains/code-intelligence/plugin.d.ts +13 -3
  107. package/v3/dist/domains/code-intelligence/plugin.d.ts.map +1 -1
  108. package/v3/dist/domains/code-intelligence/plugin.js +85 -0
  109. package/v3/dist/domains/code-intelligence/plugin.js.map +1 -1
  110. package/v3/dist/domains/code-intelligence/services/product-factors-bridge.d.ts.map +1 -1
  111. package/v3/dist/domains/code-intelligence/services/product-factors-bridge.js +3 -2
  112. package/v3/dist/domains/code-intelligence/services/product-factors-bridge.js.map +1 -1
  113. package/v3/dist/domains/constants.d.ts +481 -0
  114. package/v3/dist/domains/constants.d.ts.map +1 -0
  115. package/v3/dist/domains/constants.js +503 -0
  116. package/v3/dist/domains/constants.js.map +1 -0
  117. package/v3/dist/domains/contract-testing/plugin.d.ts +6 -1
  118. package/v3/dist/domains/contract-testing/plugin.d.ts.map +1 -1
  119. package/v3/dist/domains/contract-testing/plugin.js +80 -1
  120. package/v3/dist/domains/contract-testing/plugin.js.map +1 -1
  121. package/v3/dist/domains/contract-testing/services/contract-validator.d.ts.map +1 -1
  122. package/v3/dist/domains/contract-testing/services/contract-validator.js +5 -4
  123. package/v3/dist/domains/contract-testing/services/contract-validator.js.map +1 -1
  124. package/v3/dist/domains/coverage-analysis/services/hnsw-index.d.ts.map +1 -1
  125. package/v3/dist/domains/coverage-analysis/services/hnsw-index.js +1 -0
  126. package/v3/dist/domains/coverage-analysis/services/hnsw-index.js.map +1 -1
  127. package/v3/dist/domains/defect-intelligence/coordinator.d.ts +2 -2
  128. package/v3/dist/domains/defect-intelligence/coordinator.d.ts.map +1 -1
  129. package/v3/dist/domains/defect-intelligence/coordinator.js.map +1 -1
  130. package/v3/dist/domains/defect-intelligence/plugin.d.ts +6 -1
  131. package/v3/dist/domains/defect-intelligence/plugin.d.ts.map +1 -1
  132. package/v3/dist/domains/defect-intelligence/plugin.js +101 -0
  133. package/v3/dist/domains/defect-intelligence/plugin.js.map +1 -1
  134. package/v3/dist/domains/defect-intelligence/services/defect-predictor.d.ts.map +1 -1
  135. package/v3/dist/domains/defect-intelligence/services/defect-predictor.js +3 -2
  136. package/v3/dist/domains/defect-intelligence/services/defect-predictor.js.map +1 -1
  137. package/v3/dist/domains/domain-interface.d.ts.map +1 -1
  138. package/v3/dist/domains/domain-interface.js +24 -9
  139. package/v3/dist/domains/domain-interface.js.map +1 -1
  140. package/v3/dist/domains/learning-optimization/plugin.d.ts +2 -1
  141. package/v3/dist/domains/learning-optimization/plugin.d.ts.map +1 -1
  142. package/v3/dist/domains/learning-optimization/plugin.js +49 -0
  143. package/v3/dist/domains/learning-optimization/plugin.js.map +1 -1
  144. package/v3/dist/domains/quality-assessment/coordinator.d.ts +90 -1
  145. package/v3/dist/domains/quality-assessment/coordinator.d.ts.map +1 -1
  146. package/v3/dist/domains/quality-assessment/coordinator.js +310 -0
  147. package/v3/dist/domains/quality-assessment/coordinator.js.map +1 -1
  148. package/v3/dist/domains/requirements-validation/index.d.ts +1 -0
  149. package/v3/dist/domains/requirements-validation/index.d.ts.map +1 -1
  150. package/v3/dist/domains/requirements-validation/index.js +2 -0
  151. package/v3/dist/domains/requirements-validation/index.js.map +1 -1
  152. package/v3/dist/domains/requirements-validation/plugin.d.ts +13 -1
  153. package/v3/dist/domains/requirements-validation/plugin.d.ts.map +1 -1
  154. package/v3/dist/domains/requirements-validation/plugin.js +94 -0
  155. package/v3/dist/domains/requirements-validation/plugin.js.map +1 -1
  156. package/v3/dist/domains/requirements-validation/qcsd-ideation-plugin.d.ts +245 -0
  157. package/v3/dist/domains/requirements-validation/qcsd-ideation-plugin.d.ts.map +1 -0
  158. package/v3/dist/domains/requirements-validation/qcsd-ideation-plugin.js +1143 -0
  159. package/v3/dist/domains/requirements-validation/qcsd-ideation-plugin.js.map +1 -0
  160. package/v3/dist/domains/requirements-validation/services/product-factors-assessment/code-intelligence/codebase-analyzer.d.ts.map +1 -1
  161. package/v3/dist/domains/requirements-validation/services/product-factors-assessment/code-intelligence/codebase-analyzer.js +3 -2
  162. package/v3/dist/domains/requirements-validation/services/product-factors-assessment/code-intelligence/codebase-analyzer.js.map +1 -1
  163. package/v3/dist/domains/security-compliance/plugin.d.ts +3 -2
  164. package/v3/dist/domains/security-compliance/plugin.d.ts.map +1 -1
  165. package/v3/dist/domains/security-compliance/plugin.js +64 -0
  166. package/v3/dist/domains/security-compliance/plugin.js.map +1 -1
  167. package/v3/dist/domains/security-compliance/services/scanners/dast-auth-testing.d.ts +25 -0
  168. package/v3/dist/domains/security-compliance/services/scanners/dast-auth-testing.d.ts.map +1 -0
  169. package/v3/dist/domains/security-compliance/services/scanners/dast-auth-testing.js +160 -0
  170. package/v3/dist/domains/security-compliance/services/scanners/dast-auth-testing.js.map +1 -0
  171. package/v3/dist/domains/security-compliance/services/scanners/dast-helpers.d.ts +48 -0
  172. package/v3/dist/domains/security-compliance/services/scanners/dast-helpers.d.ts.map +1 -0
  173. package/v3/dist/domains/security-compliance/services/scanners/dast-helpers.js +385 -0
  174. package/v3/dist/domains/security-compliance/services/scanners/dast-helpers.js.map +1 -0
  175. package/v3/dist/domains/security-compliance/services/scanners/dast-injection-testing.d.ts +20 -0
  176. package/v3/dist/domains/security-compliance/services/scanners/dast-injection-testing.d.ts.map +1 -0
  177. package/v3/dist/domains/security-compliance/services/scanners/dast-injection-testing.js +99 -0
  178. package/v3/dist/domains/security-compliance/services/scanners/dast-injection-testing.js.map +1 -0
  179. package/v3/dist/domains/security-compliance/services/scanners/dast-scanner.d.ts +62 -0
  180. package/v3/dist/domains/security-compliance/services/scanners/dast-scanner.d.ts.map +1 -0
  181. package/v3/dist/domains/security-compliance/services/scanners/dast-scanner.js +329 -0
  182. package/v3/dist/domains/security-compliance/services/scanners/dast-scanner.js.map +1 -0
  183. package/v3/dist/domains/security-compliance/services/scanners/dependency-scanner.d.ts +46 -0
  184. package/v3/dist/domains/security-compliance/services/scanners/dependency-scanner.d.ts.map +1 -0
  185. package/v3/dist/domains/security-compliance/services/scanners/dependency-scanner.js +180 -0
  186. package/v3/dist/domains/security-compliance/services/scanners/dependency-scanner.js.map +1 -0
  187. package/v3/dist/domains/security-compliance/services/scanners/index.d.ts +14 -0
  188. package/v3/dist/domains/security-compliance/services/scanners/index.d.ts.map +1 -0
  189. package/v3/dist/domains/security-compliance/services/scanners/index.js +16 -0
  190. package/v3/dist/domains/security-compliance/services/scanners/index.js.map +1 -0
  191. package/v3/dist/domains/security-compliance/services/scanners/sast-scanner.d.ts +92 -0
  192. package/v3/dist/domains/security-compliance/services/scanners/sast-scanner.d.ts.map +1 -0
  193. package/v3/dist/domains/security-compliance/services/scanners/sast-scanner.js +440 -0
  194. package/v3/dist/domains/security-compliance/services/scanners/sast-scanner.js.map +1 -0
  195. package/v3/dist/domains/security-compliance/services/scanners/scanner-orchestrator.d.ts +78 -0
  196. package/v3/dist/domains/security-compliance/services/scanners/scanner-orchestrator.d.ts.map +1 -0
  197. package/v3/dist/domains/security-compliance/services/scanners/scanner-orchestrator.js +179 -0
  198. package/v3/dist/domains/security-compliance/services/scanners/scanner-orchestrator.js.map +1 -0
  199. package/v3/dist/domains/security-compliance/services/scanners/scanner-types.d.ts +91 -0
  200. package/v3/dist/domains/security-compliance/services/scanners/scanner-types.d.ts.map +1 -0
  201. package/v3/dist/domains/security-compliance/services/scanners/scanner-types.js +15 -0
  202. package/v3/dist/domains/security-compliance/services/scanners/scanner-types.js.map +1 -0
  203. package/v3/dist/domains/security-compliance/services/scanners/security-patterns.d.ts +16 -0
  204. package/v3/dist/domains/security-compliance/services/scanners/security-patterns.d.ts.map +1 -0
  205. package/v3/dist/domains/security-compliance/services/scanners/security-patterns.js +507 -0
  206. package/v3/dist/domains/security-compliance/services/scanners/security-patterns.js.map +1 -0
  207. package/v3/dist/domains/security-compliance/services/security-auditor.d.ts.map +1 -1
  208. package/v3/dist/domains/security-compliance/services/security-auditor.js +2 -1
  209. package/v3/dist/domains/security-compliance/services/security-auditor.js.map +1 -1
  210. package/v3/dist/domains/security-compliance/services/security-scanner.d.ts +20 -213
  211. package/v3/dist/domains/security-compliance/services/security-scanner.d.ts.map +1 -1
  212. package/v3/dist/domains/security-compliance/services/security-scanner.js +37 -2013
  213. package/v3/dist/domains/security-compliance/services/security-scanner.js.map +1 -1
  214. package/v3/dist/domains/security-compliance/services/semgrep-integration.d.ts.map +1 -1
  215. package/v3/dist/domains/security-compliance/services/semgrep-integration.js +7 -6
  216. package/v3/dist/domains/security-compliance/services/semgrep-integration.js.map +1 -1
  217. package/v3/dist/domains/test-execution/services/auth-state-manager.d.ts.map +1 -1
  218. package/v3/dist/domains/test-execution/services/auth-state-manager.js +6 -4
  219. package/v3/dist/domains/test-execution/services/auth-state-manager.js.map +1 -1
  220. package/v3/dist/domains/test-execution/services/e2e/assertion-handlers.d.ts +55 -0
  221. package/v3/dist/domains/test-execution/services/e2e/assertion-handlers.d.ts.map +1 -0
  222. package/v3/dist/domains/test-execution/services/e2e/assertion-handlers.js +407 -0
  223. package/v3/dist/domains/test-execution/services/e2e/assertion-handlers.js.map +1 -0
  224. package/v3/dist/domains/test-execution/services/e2e/browser-orchestrator.d.ts +122 -0
  225. package/v3/dist/domains/test-execution/services/e2e/browser-orchestrator.d.ts.map +1 -0
  226. package/v3/dist/domains/test-execution/services/e2e/browser-orchestrator.js +325 -0
  227. package/v3/dist/domains/test-execution/services/e2e/browser-orchestrator.js.map +1 -0
  228. package/v3/dist/domains/test-execution/services/e2e/e2e-coordinator.d.ts +97 -0
  229. package/v3/dist/domains/test-execution/services/e2e/e2e-coordinator.d.ts.map +1 -0
  230. package/v3/dist/domains/test-execution/services/e2e/e2e-coordinator.js +297 -0
  231. package/v3/dist/domains/test-execution/services/e2e/e2e-coordinator.js.map +1 -0
  232. package/v3/dist/domains/test-execution/services/e2e/index.d.ts +22 -0
  233. package/v3/dist/domains/test-execution/services/e2e/index.d.ts.map +1 -0
  234. package/v3/dist/domains/test-execution/services/e2e/index.js +52 -0
  235. package/v3/dist/domains/test-execution/services/e2e/index.js.map +1 -0
  236. package/v3/dist/domains/test-execution/services/e2e/result-collector.d.ts +51 -0
  237. package/v3/dist/domains/test-execution/services/e2e/result-collector.d.ts.map +1 -0
  238. package/v3/dist/domains/test-execution/services/e2e/result-collector.js +133 -0
  239. package/v3/dist/domains/test-execution/services/e2e/result-collector.js.map +1 -0
  240. package/v3/dist/domains/test-execution/services/e2e/step-executors.d.ts +48 -0
  241. package/v3/dist/domains/test-execution/services/e2e/step-executors.d.ts.map +1 -0
  242. package/v3/dist/domains/test-execution/services/e2e/step-executors.js +422 -0
  243. package/v3/dist/domains/test-execution/services/e2e/step-executors.js.map +1 -0
  244. package/v3/dist/domains/test-execution/services/e2e/step-retry-handler.d.ts +49 -0
  245. package/v3/dist/domains/test-execution/services/e2e/step-retry-handler.d.ts.map +1 -0
  246. package/v3/dist/domains/test-execution/services/e2e/step-retry-handler.js +146 -0
  247. package/v3/dist/domains/test-execution/services/e2e/step-retry-handler.js.map +1 -0
  248. package/v3/dist/domains/test-execution/services/e2e/types.d.ts +138 -0
  249. package/v3/dist/domains/test-execution/services/e2e/types.d.ts.map +1 -0
  250. package/v3/dist/domains/test-execution/services/e2e/types.js +65 -0
  251. package/v3/dist/domains/test-execution/services/e2e/types.js.map +1 -0
  252. package/v3/dist/domains/test-execution/services/e2e/wait-condition-handler.d.ts +33 -0
  253. package/v3/dist/domains/test-execution/services/e2e/wait-condition-handler.d.ts.map +1 -0
  254. package/v3/dist/domains/test-execution/services/e2e/wait-condition-handler.js +114 -0
  255. package/v3/dist/domains/test-execution/services/e2e/wait-condition-handler.js.map +1 -0
  256. package/v3/dist/domains/test-execution/services/e2e-runner.d.ts +18 -392
  257. package/v3/dist/domains/test-execution/services/e2e-runner.d.ts.map +1 -1
  258. package/v3/dist/domains/test-execution/services/e2e-runner.js +25 -1757
  259. package/v3/dist/domains/test-execution/services/e2e-runner.js.map +1 -1
  260. package/v3/dist/domains/test-execution/services/flaky-detector.d.ts.map +1 -1
  261. package/v3/dist/domains/test-execution/services/flaky-detector.js +12 -9
  262. package/v3/dist/domains/test-execution/services/flaky-detector.js.map +1 -1
  263. package/v3/dist/domains/test-execution/services/retry-handler.d.ts.map +1 -1
  264. package/v3/dist/domains/test-execution/services/retry-handler.js +7 -5
  265. package/v3/dist/domains/test-execution/services/retry-handler.js.map +1 -1
  266. package/v3/dist/domains/test-execution/services/test-executor.d.ts.map +1 -1
  267. package/v3/dist/domains/test-execution/services/test-executor.js +4 -3
  268. package/v3/dist/domains/test-execution/services/test-executor.js.map +1 -1
  269. package/v3/dist/domains/visual-accessibility/coordinator.d.ts +70 -0
  270. package/v3/dist/domains/visual-accessibility/coordinator.d.ts.map +1 -1
  271. package/v3/dist/domains/visual-accessibility/coordinator.js +172 -0
  272. package/v3/dist/domains/visual-accessibility/coordinator.js.map +1 -1
  273. package/v3/dist/domains/visual-accessibility/plugin.d.ts +2 -1
  274. package/v3/dist/domains/visual-accessibility/plugin.d.ts.map +1 -1
  275. package/v3/dist/domains/visual-accessibility/plugin.js +63 -0
  276. package/v3/dist/domains/visual-accessibility/plugin.js.map +1 -1
  277. package/v3/dist/domains/visual-accessibility/services/accessibility-tester.d.ts.map +1 -1
  278. package/v3/dist/domains/visual-accessibility/services/accessibility-tester.js +3 -2
  279. package/v3/dist/domains/visual-accessibility/services/accessibility-tester.js.map +1 -1
  280. package/v3/dist/domains/visual-accessibility/services/browser-security-scanner.d.ts.map +1 -1
  281. package/v3/dist/domains/visual-accessibility/services/browser-security-scanner.js +22 -12
  282. package/v3/dist/domains/visual-accessibility/services/browser-security-scanner.js.map +1 -1
  283. package/v3/dist/domains/visual-accessibility/services/viewport-capture.d.ts.map +1 -1
  284. package/v3/dist/domains/visual-accessibility/services/viewport-capture.js +3 -2
  285. package/v3/dist/domains/visual-accessibility/services/viewport-capture.js.map +1 -1
  286. package/v3/dist/domains/visual-accessibility/services/visual-regression.d.ts.map +1 -1
  287. package/v3/dist/domains/visual-accessibility/services/visual-regression.js +3 -2
  288. package/v3/dist/domains/visual-accessibility/services/visual-regression.js.map +1 -1
  289. package/v3/dist/hooks/cross-phase-hooks.d.ts +42 -0
  290. package/v3/dist/hooks/cross-phase-hooks.d.ts.map +1 -0
  291. package/v3/dist/hooks/cross-phase-hooks.js +338 -0
  292. package/v3/dist/hooks/cross-phase-hooks.js.map +1 -0
  293. package/v3/dist/hooks/index.d.ts +9 -0
  294. package/v3/dist/hooks/index.d.ts.map +1 -0
  295. package/v3/dist/hooks/index.js +9 -0
  296. package/v3/dist/hooks/index.js.map +1 -0
  297. package/v3/dist/init/agents-installer.d.ts.map +1 -1
  298. package/v3/dist/init/agents-installer.js +6 -4
  299. package/v3/dist/init/agents-installer.js.map +1 -1
  300. package/v3/dist/init/enhancements/claude-flow-adapter.d.ts.map +1 -1
  301. package/v3/dist/init/enhancements/claude-flow-adapter.js +15 -9
  302. package/v3/dist/init/enhancements/claude-flow-adapter.js.map +1 -1
  303. package/v3/dist/init/enhancements/detector.js +6 -4
  304. package/v3/dist/init/enhancements/detector.js.map +1 -1
  305. package/v3/dist/init/init-wizard.d.ts +5 -0
  306. package/v3/dist/init/init-wizard.d.ts.map +1 -1
  307. package/v3/dist/init/init-wizard.js +74 -11
  308. package/v3/dist/init/init-wizard.js.map +1 -1
  309. package/v3/dist/init/migration/data-migrator.d.ts.map +1 -1
  310. package/v3/dist/init/migration/data-migrator.js +6 -4
  311. package/v3/dist/init/migration/data-migrator.js.map +1 -1
  312. package/v3/dist/init/phases/02-analysis.js +2 -2
  313. package/v3/dist/init/phases/02-analysis.js.map +1 -1
  314. package/v3/dist/init/phases/04-database.d.ts.map +1 -1
  315. package/v3/dist/init/phases/04-database.js +0 -1
  316. package/v3/dist/init/phases/04-database.js.map +1 -1
  317. package/v3/dist/init/phases/11-claude-md.d.ts.map +1 -1
  318. package/v3/dist/init/phases/11-claude-md.js +25 -0
  319. package/v3/dist/init/phases/11-claude-md.js.map +1 -1
  320. package/v3/dist/init/phases/12-verification.d.ts.map +1 -1
  321. package/v3/dist/init/phases/12-verification.js +2 -1
  322. package/v3/dist/init/phases/12-verification.js.map +1 -1
  323. package/v3/dist/init/project-analyzer.d.ts.map +1 -1
  324. package/v3/dist/init/project-analyzer.js +12 -8
  325. package/v3/dist/init/project-analyzer.js.map +1 -1
  326. package/v3/dist/init/skills-installer.d.ts.map +1 -1
  327. package/v3/dist/init/skills-installer.js +6 -4
  328. package/v3/dist/init/skills-installer.js.map +1 -1
  329. package/v3/dist/init/token-bootstrap.d.ts.map +1 -1
  330. package/v3/dist/init/token-bootstrap.js +2 -1
  331. package/v3/dist/init/token-bootstrap.js.map +1 -1
  332. package/v3/dist/integrations/agent-booster-wasm/index.d.ts.map +1 -1
  333. package/v3/dist/integrations/agent-booster-wasm/index.js +8 -4
  334. package/v3/dist/integrations/agent-booster-wasm/index.js.map +1 -1
  335. package/v3/dist/integrations/agentic-flow/model-router/signal-collector.d.ts.map +1 -1
  336. package/v3/dist/integrations/agentic-flow/model-router/signal-collector.js +3 -2
  337. package/v3/dist/integrations/agentic-flow/model-router/signal-collector.js.map +1 -1
  338. package/v3/dist/integrations/agentic-flow/reasoning-bank/experience-replay.d.ts.map +1 -1
  339. package/v3/dist/integrations/agentic-flow/reasoning-bank/experience-replay.js.map +1 -1
  340. package/v3/dist/integrations/agentic-flow/reasoning-bank/trajectory-tracker.d.ts.map +1 -1
  341. package/v3/dist/integrations/agentic-flow/reasoning-bank/trajectory-tracker.js.map +1 -1
  342. package/v3/dist/integrations/browser/agent-browser/client.d.ts.map +1 -1
  343. package/v3/dist/integrations/browser/agent-browser/client.js +9 -6
  344. package/v3/dist/integrations/browser/agent-browser/client.js.map +1 -1
  345. package/v3/dist/integrations/browser/agent-browser/command-executor.d.ts.map +1 -1
  346. package/v3/dist/integrations/browser/agent-browser/command-executor.js +3 -2
  347. package/v3/dist/integrations/browser/agent-browser/command-executor.js.map +1 -1
  348. package/v3/dist/integrations/browser/index.d.ts +1 -0
  349. package/v3/dist/integrations/browser/index.d.ts.map +1 -1
  350. package/v3/dist/integrations/browser/index.js +6 -0
  351. package/v3/dist/integrations/browser/index.js.map +1 -1
  352. package/v3/dist/integrations/browser/web-content-fetcher.d.ts +154 -0
  353. package/v3/dist/integrations/browser/web-content-fetcher.d.ts.map +1 -0
  354. package/v3/dist/integrations/browser/web-content-fetcher.js +529 -0
  355. package/v3/dist/integrations/browser/web-content-fetcher.js.map +1 -0
  356. package/v3/dist/integrations/coherence/threshold-tuner.d.ts.map +1 -1
  357. package/v3/dist/integrations/coherence/threshold-tuner.js +3 -2
  358. package/v3/dist/integrations/coherence/threshold-tuner.js.map +1 -1
  359. package/v3/dist/integrations/coherence/wasm-loader.d.ts.map +1 -1
  360. package/v3/dist/integrations/coherence/wasm-loader.js +3 -2
  361. package/v3/dist/integrations/coherence/wasm-loader.js.map +1 -1
  362. package/v3/dist/integrations/n8n/agent-factory.d.ts.map +1 -1
  363. package/v3/dist/integrations/n8n/agent-factory.js +6 -4
  364. package/v3/dist/integrations/n8n/agent-factory.js.map +1 -1
  365. package/v3/dist/integrations/rl-suite/persistence/q-value-store.d.ts.map +1 -1
  366. package/v3/dist/integrations/rl-suite/persistence/q-value-store.js.map +1 -1
  367. package/v3/dist/integrations/ruvector/sona-persistence.d.ts.map +1 -1
  368. package/v3/dist/integrations/ruvector/sona-persistence.js +6 -4
  369. package/v3/dist/integrations/ruvector/sona-persistence.js.map +1 -1
  370. package/v3/dist/integrations/vibium/client.d.ts.map +1 -1
  371. package/v3/dist/integrations/vibium/client.js +3 -2
  372. package/v3/dist/integrations/vibium/client.js.map +1 -1
  373. package/v3/dist/kernel/agent-coordinator.d.ts +1 -1
  374. package/v3/dist/kernel/agent-coordinator.d.ts.map +1 -1
  375. package/v3/dist/kernel/agent-coordinator.js +4 -4
  376. package/v3/dist/kernel/agent-coordinator.js.map +1 -1
  377. package/v3/dist/kernel/constants.d.ts +155 -0
  378. package/v3/dist/kernel/constants.d.ts.map +1 -0
  379. package/v3/dist/kernel/constants.js +169 -0
  380. package/v3/dist/kernel/constants.js.map +1 -0
  381. package/v3/dist/kernel/event-bus.d.ts +8 -0
  382. package/v3/dist/kernel/event-bus.d.ts.map +1 -1
  383. package/v3/dist/kernel/event-bus.js +79 -17
  384. package/v3/dist/kernel/event-bus.js.map +1 -1
  385. package/v3/dist/kernel/hybrid-backend.d.ts.map +1 -1
  386. package/v3/dist/kernel/hybrid-backend.js +4 -3
  387. package/v3/dist/kernel/hybrid-backend.js.map +1 -1
  388. package/v3/dist/kernel/kernel.d.ts.map +1 -1
  389. package/v3/dist/kernel/kernel.js +3 -2
  390. package/v3/dist/kernel/kernel.js.map +1 -1
  391. package/v3/dist/kernel/memory-backend.d.ts.map +1 -1
  392. package/v3/dist/kernel/memory-backend.js +4 -3
  393. package/v3/dist/kernel/memory-backend.js.map +1 -1
  394. package/v3/dist/kernel/unified-memory.d.ts.map +1 -1
  395. package/v3/dist/kernel/unified-memory.js +14 -11
  396. package/v3/dist/kernel/unified-memory.js.map +1 -1
  397. package/v3/dist/kernel/unified-persistence.js +3 -2
  398. package/v3/dist/kernel/unified-persistence.js.map +1 -1
  399. package/v3/dist/learning/aqe-learning-engine.d.ts.map +1 -1
  400. package/v3/dist/learning/aqe-learning-engine.js +12 -8
  401. package/v3/dist/learning/aqe-learning-engine.js.map +1 -1
  402. package/v3/dist/learning/dream/index.d.ts +1 -1
  403. package/v3/dist/learning/dream/index.d.ts.map +1 -1
  404. package/v3/dist/learning/dream/index.js +3 -1
  405. package/v3/dist/learning/dream/index.js.map +1 -1
  406. package/v3/dist/learning/dream/spreading-activation.d.ts +41 -0
  407. package/v3/dist/learning/dream/spreading-activation.d.ts.map +1 -1
  408. package/v3/dist/learning/dream/spreading-activation.js +79 -0
  409. package/v3/dist/learning/dream/spreading-activation.js.map +1 -1
  410. package/v3/dist/learning/pattern-store.d.ts.map +1 -1
  411. package/v3/dist/learning/pattern-store.js +16 -6
  412. package/v3/dist/learning/pattern-store.js.map +1 -1
  413. package/v3/dist/learning/real-embeddings.d.ts.map +1 -1
  414. package/v3/dist/learning/real-embeddings.js +7 -1
  415. package/v3/dist/learning/real-embeddings.js.map +1 -1
  416. package/v3/dist/learning/sqlite-persistence.d.ts +1 -1
  417. package/v3/dist/learning/sqlite-persistence.d.ts.map +1 -1
  418. package/v3/dist/learning/sqlite-persistence.js.map +1 -1
  419. package/v3/dist/logging/console-logger.d.ts +96 -0
  420. package/v3/dist/logging/console-logger.d.ts.map +1 -0
  421. package/v3/dist/logging/console-logger.js +247 -0
  422. package/v3/dist/logging/console-logger.js.map +1 -0
  423. package/v3/dist/logging/index.d.ts +42 -0
  424. package/v3/dist/logging/index.d.ts.map +1 -0
  425. package/v3/dist/logging/index.js +39 -0
  426. package/v3/dist/logging/index.js.map +1 -0
  427. package/v3/dist/logging/logger-factory.d.ts +145 -0
  428. package/v3/dist/logging/logger-factory.d.ts.map +1 -0
  429. package/v3/dist/logging/logger-factory.js +218 -0
  430. package/v3/dist/logging/logger-factory.js.map +1 -0
  431. package/v3/dist/logging/logger.d.ts +89 -0
  432. package/v3/dist/logging/logger.d.ts.map +1 -0
  433. package/v3/dist/logging/logger.js +74 -0
  434. package/v3/dist/logging/logger.js.map +1 -0
  435. package/v3/dist/mcp/bundle.js +11334 -7497
  436. package/v3/dist/mcp/handlers/agent-handlers.js +2 -2
  437. package/v3/dist/mcp/handlers/agent-handlers.js.map +1 -1
  438. package/v3/dist/mcp/handlers/core-handlers.d.ts +2 -0
  439. package/v3/dist/mcp/handlers/core-handlers.d.ts.map +1 -1
  440. package/v3/dist/mcp/handlers/core-handlers.js +33 -0
  441. package/v3/dist/mcp/handlers/core-handlers.js.map +1 -1
  442. package/v3/dist/mcp/handlers/cross-phase-handlers.d.ts +110 -0
  443. package/v3/dist/mcp/handlers/cross-phase-handlers.d.ts.map +1 -0
  444. package/v3/dist/mcp/handlers/cross-phase-handlers.js +216 -0
  445. package/v3/dist/mcp/handlers/cross-phase-handlers.js.map +1 -0
  446. package/v3/dist/mcp/handlers/domain-handler-configs.d.ts +151 -0
  447. package/v3/dist/mcp/handlers/domain-handler-configs.d.ts.map +1 -0
  448. package/v3/dist/mcp/handlers/domain-handler-configs.js +486 -0
  449. package/v3/dist/mcp/handlers/domain-handler-configs.js.map +1 -0
  450. package/v3/dist/mcp/handlers/domain-handlers.d.ts +174 -120
  451. package/v3/dist/mcp/handlers/domain-handlers.d.ts.map +1 -1
  452. package/v3/dist/mcp/handlers/domain-handlers.js +178 -1049
  453. package/v3/dist/mcp/handlers/domain-handlers.js.map +1 -1
  454. package/v3/dist/mcp/handlers/handler-factory.d.ts +182 -0
  455. package/v3/dist/mcp/handlers/handler-factory.d.ts.map +1 -0
  456. package/v3/dist/mcp/handlers/handler-factory.js +327 -0
  457. package/v3/dist/mcp/handlers/handler-factory.js.map +1 -0
  458. package/v3/dist/mcp/handlers/index.d.ts +1 -0
  459. package/v3/dist/mcp/handlers/index.d.ts.map +1 -1
  460. package/v3/dist/mcp/handlers/index.js +2 -0
  461. package/v3/dist/mcp/handlers/index.js.map +1 -1
  462. package/v3/dist/mcp/handlers/task-handlers.d.ts +1 -0
  463. package/v3/dist/mcp/handlers/task-handlers.d.ts.map +1 -1
  464. package/v3/dist/mcp/handlers/task-handlers.js +91 -7
  465. package/v3/dist/mcp/handlers/task-handlers.js.map +1 -1
  466. package/v3/dist/mcp/server.d.ts.map +1 -1
  467. package/v3/dist/mcp/server.js +107 -1
  468. package/v3/dist/mcp/server.js.map +1 -1
  469. package/v3/dist/mcp/types.d.ts +5 -3
  470. package/v3/dist/mcp/types.d.ts.map +1 -1
  471. package/v3/dist/memory/cross-phase-memory.d.ts +55 -0
  472. package/v3/dist/memory/cross-phase-memory.d.ts.map +1 -0
  473. package/v3/dist/memory/cross-phase-memory.js +265 -0
  474. package/v3/dist/memory/cross-phase-memory.js.map +1 -0
  475. package/v3/dist/memory/index.d.ts +9 -0
  476. package/v3/dist/memory/index.d.ts.map +1 -0
  477. package/v3/dist/memory/index.js +9 -0
  478. package/v3/dist/memory/index.js.map +1 -0
  479. package/v3/dist/shared/io/file-reader.d.ts.map +1 -1
  480. package/v3/dist/shared/io/file-reader.js +3 -2
  481. package/v3/dist/shared/io/file-reader.js.map +1 -1
  482. package/v3/dist/shared/utils/binary-insert.d.ts +85 -0
  483. package/v3/dist/shared/utils/binary-insert.d.ts.map +1 -0
  484. package/v3/dist/shared/utils/binary-insert.js +122 -0
  485. package/v3/dist/shared/utils/binary-insert.js.map +1 -0
  486. package/v3/dist/shared/utils/index.d.ts +1 -0
  487. package/v3/dist/shared/utils/index.d.ts.map +1 -1
  488. package/v3/dist/shared/utils/index.js +1 -0
  489. package/v3/dist/shared/utils/index.js.map +1 -1
  490. package/v3/dist/strange-loop/belief-reconciler.d.ts.map +1 -1
  491. package/v3/dist/strange-loop/belief-reconciler.js +3 -2
  492. package/v3/dist/strange-loop/belief-reconciler.js.map +1 -1
  493. package/v3/dist/sync/claude-flow-bridge.d.ts.map +1 -1
  494. package/v3/dist/sync/claude-flow-bridge.js +6 -4
  495. package/v3/dist/sync/claude-flow-bridge.js.map +1 -1
  496. package/v3/dist/sync/cloud/postgres-writer.d.ts.map +1 -1
  497. package/v3/dist/sync/cloud/postgres-writer.js +0 -1
  498. package/v3/dist/sync/cloud/postgres-writer.js.map +1 -1
  499. package/v3/dist/sync/readers/sqlite-reader.d.ts.map +1 -1
  500. package/v3/dist/sync/readers/sqlite-reader.js +3 -2
  501. package/v3/dist/sync/readers/sqlite-reader.js.map +1 -1
  502. package/v3/dist/test-scheduling/flaky-tracking/flaky-tracker.d.ts.map +1 -1
  503. package/v3/dist/test-scheduling/flaky-tracking/flaky-tracker.js +3 -2
  504. package/v3/dist/test-scheduling/flaky-tracking/flaky-tracker.js.map +1 -1
  505. package/v3/dist/test-scheduling/git-aware/test-selector.d.ts.map +1 -1
  506. package/v3/dist/test-scheduling/git-aware/test-selector.js +3 -2
  507. package/v3/dist/test-scheduling/git-aware/test-selector.js.map +1 -1
  508. package/v3/dist/types/cross-phase-signals.d.ts +119 -0
  509. package/v3/dist/types/cross-phase-signals.d.ts.map +1 -0
  510. package/v3/dist/types/cross-phase-signals.js +33 -0
  511. package/v3/dist/types/cross-phase-signals.js.map +1 -0
  512. package/v3/dist/types/index.d.ts +9 -0
  513. package/v3/dist/types/index.d.ts.map +1 -0
  514. package/v3/dist/types/index.js +9 -0
  515. package/v3/dist/types/index.js.map +1 -0
  516. package/v3/dist/workers/worker-manager.d.ts.map +1 -1
  517. package/v3/dist/workers/worker-manager.js +3 -2
  518. package/v3/dist/workers/worker-manager.js.map +1 -1
  519. package/v3/dist/workflows/browser/workflow-loader.d.ts +3 -3
  520. package/v3/dist/workflows/browser/workflow-loader.d.ts.map +1 -1
  521. package/v3/dist/workflows/browser/workflow-loader.js.map +1 -1
  522. 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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"}