codeslick-cli 1.0.0

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 (455) hide show
  1. package/README.md +458 -0
  2. package/__tests__/cli-reporter.test.ts +86 -0
  3. package/__tests__/config-loader.test.ts +247 -0
  4. package/__tests__/local-scanner.test.ts +245 -0
  5. package/bin/codeslick.cjs +153 -0
  6. package/dist/packages/cli/src/commands/auth.d.ts +36 -0
  7. package/dist/packages/cli/src/commands/auth.d.ts.map +1 -0
  8. package/dist/packages/cli/src/commands/auth.js +226 -0
  9. package/dist/packages/cli/src/commands/auth.js.map +1 -0
  10. package/dist/packages/cli/src/commands/config.d.ts +37 -0
  11. package/dist/packages/cli/src/commands/config.d.ts.map +1 -0
  12. package/dist/packages/cli/src/commands/config.js +196 -0
  13. package/dist/packages/cli/src/commands/config.js.map +1 -0
  14. package/dist/packages/cli/src/commands/init.d.ts +32 -0
  15. package/dist/packages/cli/src/commands/init.d.ts.map +1 -0
  16. package/dist/packages/cli/src/commands/init.js +171 -0
  17. package/dist/packages/cli/src/commands/init.js.map +1 -0
  18. package/dist/packages/cli/src/commands/scan.d.ts +40 -0
  19. package/dist/packages/cli/src/commands/scan.d.ts.map +1 -0
  20. package/dist/packages/cli/src/commands/scan.js +204 -0
  21. package/dist/packages/cli/src/commands/scan.js.map +1 -0
  22. package/dist/packages/cli/src/config/config-loader.d.ts +67 -0
  23. package/dist/packages/cli/src/config/config-loader.d.ts.map +1 -0
  24. package/dist/packages/cli/src/config/config-loader.js +146 -0
  25. package/dist/packages/cli/src/config/config-loader.js.map +1 -0
  26. package/dist/packages/cli/src/reporters/cli-reporter.d.ts +69 -0
  27. package/dist/packages/cli/src/reporters/cli-reporter.d.ts.map +1 -0
  28. package/dist/packages/cli/src/reporters/cli-reporter.js +244 -0
  29. package/dist/packages/cli/src/reporters/cli-reporter.js.map +1 -0
  30. package/dist/packages/cli/src/scanner/local-scanner.d.ts +92 -0
  31. package/dist/packages/cli/src/scanner/local-scanner.d.ts.map +1 -0
  32. package/dist/packages/cli/src/scanner/local-scanner.js +221 -0
  33. package/dist/packages/cli/src/scanner/local-scanner.js.map +1 -0
  34. package/dist/src/lib/analyzers/helpers/ai-code-detection-utils.d.ts +88 -0
  35. package/dist/src/lib/analyzers/helpers/ai-code-detection-utils.d.ts.map +1 -0
  36. package/dist/src/lib/analyzers/helpers/ai-code-detection-utils.js +371 -0
  37. package/dist/src/lib/analyzers/helpers/ai-code-detection-utils.js.map +1 -0
  38. package/dist/src/lib/analyzers/helpers/jsx-helpers.d.ts +63 -0
  39. package/dist/src/lib/analyzers/helpers/jsx-helpers.d.ts.map +1 -0
  40. package/dist/src/lib/analyzers/helpers/jsx-helpers.js +95 -0
  41. package/dist/src/lib/analyzers/helpers/jsx-helpers.js.map +1 -0
  42. package/dist/src/lib/analyzers/helpers/variable-tracker.d.ts +59 -0
  43. package/dist/src/lib/analyzers/helpers/variable-tracker.d.ts.map +1 -0
  44. package/dist/src/lib/analyzers/helpers/variable-tracker.js +231 -0
  45. package/dist/src/lib/analyzers/helpers/variable-tracker.js.map +1 -0
  46. package/dist/src/lib/analyzers/java/security-checks/access-control.d.ts +20 -0
  47. package/dist/src/lib/analyzers/java/security-checks/access-control.d.ts.map +1 -0
  48. package/dist/src/lib/analyzers/java/security-checks/access-control.js +129 -0
  49. package/dist/src/lib/analyzers/java/security-checks/access-control.js.map +1 -0
  50. package/dist/src/lib/analyzers/java/security-checks/ai-generated-code.d.ts +25 -0
  51. package/dist/src/lib/analyzers/java/security-checks/ai-generated-code.d.ts.map +1 -0
  52. package/dist/src/lib/analyzers/java/security-checks/ai-generated-code.js +221 -0
  53. package/dist/src/lib/analyzers/java/security-checks/ai-generated-code.js.map +1 -0
  54. package/dist/src/lib/analyzers/java/security-checks/code-quality.d.ts +18 -0
  55. package/dist/src/lib/analyzers/java/security-checks/code-quality.d.ts.map +1 -0
  56. package/dist/src/lib/analyzers/java/security-checks/code-quality.js +84 -0
  57. package/dist/src/lib/analyzers/java/security-checks/code-quality.js.map +1 -0
  58. package/dist/src/lib/analyzers/java/security-checks/crypto-validation.d.ts +18 -0
  59. package/dist/src/lib/analyzers/java/security-checks/crypto-validation.d.ts.map +1 -0
  60. package/dist/src/lib/analyzers/java/security-checks/crypto-validation.js +161 -0
  61. package/dist/src/lib/analyzers/java/security-checks/crypto-validation.js.map +1 -0
  62. package/dist/src/lib/analyzers/java/security-checks/deserialization-xxe.d.ts +20 -0
  63. package/dist/src/lib/analyzers/java/security-checks/deserialization-xxe.d.ts.map +1 -0
  64. package/dist/src/lib/analyzers/java/security-checks/deserialization-xxe.js +163 -0
  65. package/dist/src/lib/analyzers/java/security-checks/deserialization-xxe.js.map +1 -0
  66. package/dist/src/lib/analyzers/java/security-checks/enhanced-supply-chain.d.ts +24 -0
  67. package/dist/src/lib/analyzers/java/security-checks/enhanced-supply-chain.d.ts.map +1 -0
  68. package/dist/src/lib/analyzers/java/security-checks/enhanced-supply-chain.js +178 -0
  69. package/dist/src/lib/analyzers/java/security-checks/enhanced-supply-chain.js.map +1 -0
  70. package/dist/src/lib/analyzers/java/security-checks/exception-handling.d.ts +25 -0
  71. package/dist/src/lib/analyzers/java/security-checks/exception-handling.d.ts.map +1 -0
  72. package/dist/src/lib/analyzers/java/security-checks/exception-handling.js +179 -0
  73. package/dist/src/lib/analyzers/java/security-checks/exception-handling.js.map +1 -0
  74. package/dist/src/lib/analyzers/java/security-checks/file-operations.d.ts +17 -0
  75. package/dist/src/lib/analyzers/java/security-checks/file-operations.d.ts.map +1 -0
  76. package/dist/src/lib/analyzers/java/security-checks/file-operations.js +67 -0
  77. package/dist/src/lib/analyzers/java/security-checks/file-operations.js.map +1 -0
  78. package/dist/src/lib/analyzers/java/security-checks/framework-security.d.ts +25 -0
  79. package/dist/src/lib/analyzers/java/security-checks/framework-security.d.ts.map +1 -0
  80. package/dist/src/lib/analyzers/java/security-checks/framework-security.js +396 -0
  81. package/dist/src/lib/analyzers/java/security-checks/framework-security.js.map +1 -0
  82. package/dist/src/lib/analyzers/java/security-checks/hardcoded-credentials.d.ts +20 -0
  83. package/dist/src/lib/analyzers/java/security-checks/hardcoded-credentials.d.ts.map +1 -0
  84. package/dist/src/lib/analyzers/java/security-checks/hardcoded-credentials.js +123 -0
  85. package/dist/src/lib/analyzers/java/security-checks/hardcoded-credentials.js.map +1 -0
  86. package/dist/src/lib/analyzers/java/security-checks/injection-attacks.d.ts +23 -0
  87. package/dist/src/lib/analyzers/java/security-checks/injection-attacks.d.ts.map +1 -0
  88. package/dist/src/lib/analyzers/java/security-checks/injection-attacks.js +201 -0
  89. package/dist/src/lib/analyzers/java/security-checks/injection-attacks.js.map +1 -0
  90. package/dist/src/lib/analyzers/java/security-checks/insecure-design.d.ts +20 -0
  91. package/dist/src/lib/analyzers/java/security-checks/insecure-design.d.ts.map +1 -0
  92. package/dist/src/lib/analyzers/java/security-checks/insecure-design.js +121 -0
  93. package/dist/src/lib/analyzers/java/security-checks/insecure-design.js.map +1 -0
  94. package/dist/src/lib/analyzers/java/security-checks/logging-failures.d.ts +20 -0
  95. package/dist/src/lib/analyzers/java/security-checks/logging-failures.d.ts.map +1 -0
  96. package/dist/src/lib/analyzers/java/security-checks/logging-failures.js +89 -0
  97. package/dist/src/lib/analyzers/java/security-checks/logging-failures.js.map +1 -0
  98. package/dist/src/lib/analyzers/java/security-checks/security-misconfiguration.d.ts +26 -0
  99. package/dist/src/lib/analyzers/java/security-checks/security-misconfiguration.d.ts.map +1 -0
  100. package/dist/src/lib/analyzers/java/security-checks/security-misconfiguration.js +309 -0
  101. package/dist/src/lib/analyzers/java/security-checks/security-misconfiguration.js.map +1 -0
  102. package/dist/src/lib/analyzers/java/security-checks/unsafe-patterns.d.ts +18 -0
  103. package/dist/src/lib/analyzers/java/security-checks/unsafe-patterns.d.ts.map +1 -0
  104. package/dist/src/lib/analyzers/java/security-checks/unsafe-patterns.js +114 -0
  105. package/dist/src/lib/analyzers/java/security-checks/unsafe-patterns.js.map +1 -0
  106. package/dist/src/lib/analyzers/java/utils/createVulnerability.d.ts +58 -0
  107. package/dist/src/lib/analyzers/java/utils/createVulnerability.d.ts.map +1 -0
  108. package/dist/src/lib/analyzers/java/utils/createVulnerability.js +71 -0
  109. package/dist/src/lib/analyzers/java/utils/createVulnerability.js.map +1 -0
  110. package/dist/src/lib/analyzers/java-analyzer.d.ts +209 -0
  111. package/dist/src/lib/analyzers/java-analyzer.d.ts.map +1 -0
  112. package/dist/src/lib/analyzers/java-analyzer.js +1720 -0
  113. package/dist/src/lib/analyzers/java-analyzer.js.map +1 -0
  114. package/dist/src/lib/analyzers/javascript/quality-checks/ai-hallucinations.d.ts +27 -0
  115. package/dist/src/lib/analyzers/javascript/quality-checks/ai-hallucinations.d.ts.map +1 -0
  116. package/dist/src/lib/analyzers/javascript/quality-checks/ai-hallucinations.js +123 -0
  117. package/dist/src/lib/analyzers/javascript/quality-checks/ai-hallucinations.js.map +1 -0
  118. package/dist/src/lib/analyzers/javascript/quality-checks/async-patterns.d.ts +44 -0
  119. package/dist/src/lib/analyzers/javascript/quality-checks/async-patterns.d.ts.map +1 -0
  120. package/dist/src/lib/analyzers/javascript/quality-checks/async-patterns.js +224 -0
  121. package/dist/src/lib/analyzers/javascript/quality-checks/async-patterns.js.map +1 -0
  122. package/dist/src/lib/analyzers/javascript/quality-checks/code-patterns.d.ts +50 -0
  123. package/dist/src/lib/analyzers/javascript/quality-checks/code-patterns.d.ts.map +1 -0
  124. package/dist/src/lib/analyzers/javascript/quality-checks/code-patterns.js +284 -0
  125. package/dist/src/lib/analyzers/javascript/quality-checks/code-patterns.js.map +1 -0
  126. package/dist/src/lib/analyzers/javascript/quality-checks/comparison-issues.d.ts +27 -0
  127. package/dist/src/lib/analyzers/javascript/quality-checks/comparison-issues.d.ts.map +1 -0
  128. package/dist/src/lib/analyzers/javascript/quality-checks/comparison-issues.js +86 -0
  129. package/dist/src/lib/analyzers/javascript/quality-checks/comparison-issues.js.map +1 -0
  130. package/dist/src/lib/analyzers/javascript/quality-checks/reference-errors.d.ts +32 -0
  131. package/dist/src/lib/analyzers/javascript/quality-checks/reference-errors.d.ts.map +1 -0
  132. package/dist/src/lib/analyzers/javascript/quality-checks/reference-errors.js +44 -0
  133. package/dist/src/lib/analyzers/javascript/quality-checks/reference-errors.js.map +1 -0
  134. package/dist/src/lib/analyzers/javascript/security-checks/access-control.d.ts +22 -0
  135. package/dist/src/lib/analyzers/javascript/security-checks/access-control.d.ts.map +1 -0
  136. package/dist/src/lib/analyzers/javascript/security-checks/access-control.js +168 -0
  137. package/dist/src/lib/analyzers/javascript/security-checks/access-control.js.map +1 -0
  138. package/dist/src/lib/analyzers/javascript/security-checks/ai-generated-code.d.ts +25 -0
  139. package/dist/src/lib/analyzers/javascript/security-checks/ai-generated-code.d.ts.map +1 -0
  140. package/dist/src/lib/analyzers/javascript/security-checks/ai-generated-code.js +232 -0
  141. package/dist/src/lib/analyzers/javascript/security-checks/ai-generated-code.js.map +1 -0
  142. package/dist/src/lib/analyzers/javascript/security-checks/authentication-failures.d.ts +27 -0
  143. package/dist/src/lib/analyzers/javascript/security-checks/authentication-failures.d.ts.map +1 -0
  144. package/dist/src/lib/analyzers/javascript/security-checks/authentication-failures.js +222 -0
  145. package/dist/src/lib/analyzers/javascript/security-checks/authentication-failures.js.map +1 -0
  146. package/dist/src/lib/analyzers/javascript/security-checks/credential-crypto.d.ts +28 -0
  147. package/dist/src/lib/analyzers/javascript/security-checks/credential-crypto.d.ts.map +1 -0
  148. package/dist/src/lib/analyzers/javascript/security-checks/credential-crypto.js +176 -0
  149. package/dist/src/lib/analyzers/javascript/security-checks/credential-crypto.js.map +1 -0
  150. package/dist/src/lib/analyzers/javascript/security-checks/enhanced-supply-chain.d.ts +23 -0
  151. package/dist/src/lib/analyzers/javascript/security-checks/enhanced-supply-chain.d.ts.map +1 -0
  152. package/dist/src/lib/analyzers/javascript/security-checks/enhanced-supply-chain.js +113 -0
  153. package/dist/src/lib/analyzers/javascript/security-checks/enhanced-supply-chain.js.map +1 -0
  154. package/dist/src/lib/analyzers/javascript/security-checks/exception-handling.d.ts +28 -0
  155. package/dist/src/lib/analyzers/javascript/security-checks/exception-handling.d.ts.map +1 -0
  156. package/dist/src/lib/analyzers/javascript/security-checks/exception-handling.js +227 -0
  157. package/dist/src/lib/analyzers/javascript/security-checks/exception-handling.js.map +1 -0
  158. package/dist/src/lib/analyzers/javascript/security-checks/injection-attacks.d.ts +32 -0
  159. package/dist/src/lib/analyzers/javascript/security-checks/injection-attacks.d.ts.map +1 -0
  160. package/dist/src/lib/analyzers/javascript/security-checks/injection-attacks.js +260 -0
  161. package/dist/src/lib/analyzers/javascript/security-checks/injection-attacks.js.map +1 -0
  162. package/dist/src/lib/analyzers/javascript/security-checks/insecure-design.d.ts +26 -0
  163. package/dist/src/lib/analyzers/javascript/security-checks/insecure-design.d.ts.map +1 -0
  164. package/dist/src/lib/analyzers/javascript/security-checks/insecure-design.js +164 -0
  165. package/dist/src/lib/analyzers/javascript/security-checks/insecure-design.js.map +1 -0
  166. package/dist/src/lib/analyzers/javascript/security-checks/security-misconfiguration.d.ts +26 -0
  167. package/dist/src/lib/analyzers/javascript/security-checks/security-misconfiguration.d.ts.map +1 -0
  168. package/dist/src/lib/analyzers/javascript/security-checks/security-misconfiguration.js +775 -0
  169. package/dist/src/lib/analyzers/javascript/security-checks/security-misconfiguration.js.map +1 -0
  170. package/dist/src/lib/analyzers/javascript/security-checks/software-integrity.d.ts +25 -0
  171. package/dist/src/lib/analyzers/javascript/security-checks/software-integrity.d.ts.map +1 -0
  172. package/dist/src/lib/analyzers/javascript/security-checks/software-integrity.js +168 -0
  173. package/dist/src/lib/analyzers/javascript/security-checks/software-integrity.js.map +1 -0
  174. package/dist/src/lib/analyzers/javascript/security-checks/storage-security.d.ts +27 -0
  175. package/dist/src/lib/analyzers/javascript/security-checks/storage-security.d.ts.map +1 -0
  176. package/dist/src/lib/analyzers/javascript/security-checks/storage-security.js +108 -0
  177. package/dist/src/lib/analyzers/javascript/security-checks/storage-security.js.map +1 -0
  178. package/dist/src/lib/analyzers/javascript/security-checks/xss-dom-security.d.ts +28 -0
  179. package/dist/src/lib/analyzers/javascript/security-checks/xss-dom-security.d.ts.map +1 -0
  180. package/dist/src/lib/analyzers/javascript/security-checks/xss-dom-security.js +143 -0
  181. package/dist/src/lib/analyzers/javascript/security-checks/xss-dom-security.js.map +1 -0
  182. package/dist/src/lib/analyzers/javascript/syntax/syntax-helpers.d.ts +53 -0
  183. package/dist/src/lib/analyzers/javascript/syntax/syntax-helpers.d.ts.map +1 -0
  184. package/dist/src/lib/analyzers/javascript/syntax/syntax-helpers.js +144 -0
  185. package/dist/src/lib/analyzers/javascript/syntax/syntax-helpers.js.map +1 -0
  186. package/dist/src/lib/analyzers/javascript/syntax/typescript-syntax.d.ts +72 -0
  187. package/dist/src/lib/analyzers/javascript/syntax/typescript-syntax.d.ts.map +1 -0
  188. package/dist/src/lib/analyzers/javascript/syntax/typescript-syntax.js +314 -0
  189. package/dist/src/lib/analyzers/javascript/syntax/typescript-syntax.js.map +1 -0
  190. package/dist/src/lib/analyzers/javascript/utils/createVulnerability.d.ts +58 -0
  191. package/dist/src/lib/analyzers/javascript/utils/createVulnerability.d.ts.map +1 -0
  192. package/dist/src/lib/analyzers/javascript/utils/createVulnerability.js +71 -0
  193. package/dist/src/lib/analyzers/javascript/utils/createVulnerability.js.map +1 -0
  194. package/dist/src/lib/analyzers/javascript/utils/metrics-calculator.d.ts +36 -0
  195. package/dist/src/lib/analyzers/javascript/utils/metrics-calculator.d.ts.map +1 -0
  196. package/dist/src/lib/analyzers/javascript/utils/metrics-calculator.js +70 -0
  197. package/dist/src/lib/analyzers/javascript/utils/metrics-calculator.js.map +1 -0
  198. package/dist/src/lib/analyzers/javascript/utils/performance-analyzer.d.ts +29 -0
  199. package/dist/src/lib/analyzers/javascript/utils/performance-analyzer.d.ts.map +1 -0
  200. package/dist/src/lib/analyzers/javascript/utils/performance-analyzer.js +55 -0
  201. package/dist/src/lib/analyzers/javascript/utils/performance-analyzer.js.map +1 -0
  202. package/dist/src/lib/analyzers/javascript-analyzer.d.ts +95 -0
  203. package/dist/src/lib/analyzers/javascript-analyzer.d.ts.map +1 -0
  204. package/dist/src/lib/analyzers/javascript-analyzer.js +2141 -0
  205. package/dist/src/lib/analyzers/javascript-analyzer.js.map +1 -0
  206. package/dist/src/lib/analyzers/python/security-checks/access-control.d.ts +21 -0
  207. package/dist/src/lib/analyzers/python/security-checks/access-control.d.ts.map +1 -0
  208. package/dist/src/lib/analyzers/python/security-checks/access-control.js +305 -0
  209. package/dist/src/lib/analyzers/python/security-checks/access-control.js.map +1 -0
  210. package/dist/src/lib/analyzers/python/security-checks/ai-generated-code.d.ts +25 -0
  211. package/dist/src/lib/analyzers/python/security-checks/ai-generated-code.d.ts.map +1 -0
  212. package/dist/src/lib/analyzers/python/security-checks/ai-generated-code.js +242 -0
  213. package/dist/src/lib/analyzers/python/security-checks/ai-generated-code.js.map +1 -0
  214. package/dist/src/lib/analyzers/python/security-checks/authentication-flaws.d.ts +24 -0
  215. package/dist/src/lib/analyzers/python/security-checks/authentication-flaws.d.ts.map +1 -0
  216. package/dist/src/lib/analyzers/python/security-checks/authentication-flaws.js +207 -0
  217. package/dist/src/lib/analyzers/python/security-checks/authentication-flaws.js.map +1 -0
  218. package/dist/src/lib/analyzers/python/security-checks/code-quality.d.ts +27 -0
  219. package/dist/src/lib/analyzers/python/security-checks/code-quality.d.ts.map +1 -0
  220. package/dist/src/lib/analyzers/python/security-checks/code-quality.js +206 -0
  221. package/dist/src/lib/analyzers/python/security-checks/code-quality.js.map +1 -0
  222. package/dist/src/lib/analyzers/python/security-checks/credentials-crypto.d.ts +24 -0
  223. package/dist/src/lib/analyzers/python/security-checks/credentials-crypto.d.ts.map +1 -0
  224. package/dist/src/lib/analyzers/python/security-checks/credentials-crypto.js +113 -0
  225. package/dist/src/lib/analyzers/python/security-checks/credentials-crypto.js.map +1 -0
  226. package/dist/src/lib/analyzers/python/security-checks/crypto-failures.d.ts +20 -0
  227. package/dist/src/lib/analyzers/python/security-checks/crypto-failures.d.ts.map +1 -0
  228. package/dist/src/lib/analyzers/python/security-checks/crypto-failures.js +129 -0
  229. package/dist/src/lib/analyzers/python/security-checks/crypto-failures.js.map +1 -0
  230. package/dist/src/lib/analyzers/python/security-checks/data-integrity.d.ts +19 -0
  231. package/dist/src/lib/analyzers/python/security-checks/data-integrity.d.ts.map +1 -0
  232. package/dist/src/lib/analyzers/python/security-checks/data-integrity.js +90 -0
  233. package/dist/src/lib/analyzers/python/security-checks/data-integrity.js.map +1 -0
  234. package/dist/src/lib/analyzers/python/security-checks/deserialization.d.ts +20 -0
  235. package/dist/src/lib/analyzers/python/security-checks/deserialization.d.ts.map +1 -0
  236. package/dist/src/lib/analyzers/python/security-checks/deserialization.js +68 -0
  237. package/dist/src/lib/analyzers/python/security-checks/deserialization.js.map +1 -0
  238. package/dist/src/lib/analyzers/python/security-checks/django-security.d.ts +25 -0
  239. package/dist/src/lib/analyzers/python/security-checks/django-security.d.ts.map +1 -0
  240. package/dist/src/lib/analyzers/python/security-checks/django-security.js +180 -0
  241. package/dist/src/lib/analyzers/python/security-checks/django-security.js.map +1 -0
  242. package/dist/src/lib/analyzers/python/security-checks/enhanced-supply-chain.d.ts +23 -0
  243. package/dist/src/lib/analyzers/python/security-checks/enhanced-supply-chain.d.ts.map +1 -0
  244. package/dist/src/lib/analyzers/python/security-checks/enhanced-supply-chain.js +127 -0
  245. package/dist/src/lib/analyzers/python/security-checks/enhanced-supply-chain.js.map +1 -0
  246. package/dist/src/lib/analyzers/python/security-checks/exception-handling.d.ts +23 -0
  247. package/dist/src/lib/analyzers/python/security-checks/exception-handling.d.ts.map +1 -0
  248. package/dist/src/lib/analyzers/python/security-checks/exception-handling.js +120 -0
  249. package/dist/src/lib/analyzers/python/security-checks/exception-handling.js.map +1 -0
  250. package/dist/src/lib/analyzers/python/security-checks/flask-security.d.ts +24 -0
  251. package/dist/src/lib/analyzers/python/security-checks/flask-security.d.ts.map +1 -0
  252. package/dist/src/lib/analyzers/python/security-checks/flask-security.js +143 -0
  253. package/dist/src/lib/analyzers/python/security-checks/flask-security.js.map +1 -0
  254. package/dist/src/lib/analyzers/python/security-checks/injection-attacks.d.ts +28 -0
  255. package/dist/src/lib/analyzers/python/security-checks/injection-attacks.d.ts.map +1 -0
  256. package/dist/src/lib/analyzers/python/security-checks/injection-attacks.js +174 -0
  257. package/dist/src/lib/analyzers/python/security-checks/injection-attacks.js.map +1 -0
  258. package/dist/src/lib/analyzers/python/security-checks/insecure-design.d.ts +20 -0
  259. package/dist/src/lib/analyzers/python/security-checks/insecure-design.d.ts.map +1 -0
  260. package/dist/src/lib/analyzers/python/security-checks/insecure-design.js +160 -0
  261. package/dist/src/lib/analyzers/python/security-checks/insecure-design.js.map +1 -0
  262. package/dist/src/lib/analyzers/python/security-checks/logging-failures.d.ts +20 -0
  263. package/dist/src/lib/analyzers/python/security-checks/logging-failures.d.ts.map +1 -0
  264. package/dist/src/lib/analyzers/python/security-checks/logging-failures.js +121 -0
  265. package/dist/src/lib/analyzers/python/security-checks/logging-failures.js.map +1 -0
  266. package/dist/src/lib/analyzers/python/security-checks/nosql-injection.d.ts +26 -0
  267. package/dist/src/lib/analyzers/python/security-checks/nosql-injection.d.ts.map +1 -0
  268. package/dist/src/lib/analyzers/python/security-checks/nosql-injection.js +248 -0
  269. package/dist/src/lib/analyzers/python/security-checks/nosql-injection.js.map +1 -0
  270. package/dist/src/lib/analyzers/python/security-checks/security-misconfiguration.d.ts +26 -0
  271. package/dist/src/lib/analyzers/python/security-checks/security-misconfiguration.d.ts.map +1 -0
  272. package/dist/src/lib/analyzers/python/security-checks/security-misconfiguration.js +375 -0
  273. package/dist/src/lib/analyzers/python/security-checks/security-misconfiguration.js.map +1 -0
  274. package/dist/src/lib/analyzers/python/security-checks/ssrf-detection.d.ts +26 -0
  275. package/dist/src/lib/analyzers/python/security-checks/ssrf-detection.d.ts.map +1 -0
  276. package/dist/src/lib/analyzers/python/security-checks/ssrf-detection.js +160 -0
  277. package/dist/src/lib/analyzers/python/security-checks/ssrf-detection.js.map +1 -0
  278. package/dist/src/lib/analyzers/python/security-checks/web-security.d.ts +23 -0
  279. package/dist/src/lib/analyzers/python/security-checks/web-security.d.ts.map +1 -0
  280. package/dist/src/lib/analyzers/python/security-checks/web-security.js +117 -0
  281. package/dist/src/lib/analyzers/python/security-checks/web-security.js.map +1 -0
  282. package/dist/src/lib/analyzers/python/utils/createVulnerability.d.ts +58 -0
  283. package/dist/src/lib/analyzers/python/utils/createVulnerability.d.ts.map +1 -0
  284. package/dist/src/lib/analyzers/python/utils/createVulnerability.js +71 -0
  285. package/dist/src/lib/analyzers/python/utils/createVulnerability.js.map +1 -0
  286. package/dist/src/lib/analyzers/python-analyzer.d.ts +111 -0
  287. package/dist/src/lib/analyzers/python-analyzer.d.ts.map +1 -0
  288. package/dist/src/lib/analyzers/python-analyzer.js +1600 -0
  289. package/dist/src/lib/analyzers/python-analyzer.js.map +1 -0
  290. package/dist/src/lib/analyzers/secrets/patterns/api-keys/ai-providers.d.ts +14 -0
  291. package/dist/src/lib/analyzers/secrets/patterns/api-keys/ai-providers.d.ts.map +1 -0
  292. package/dist/src/lib/analyzers/secrets/patterns/api-keys/ai-providers.js +47 -0
  293. package/dist/src/lib/analyzers/secrets/patterns/api-keys/ai-providers.js.map +1 -0
  294. package/dist/src/lib/analyzers/secrets/patterns/api-keys/aws.d.ts +13 -0
  295. package/dist/src/lib/analyzers/secrets/patterns/api-keys/aws.d.ts.map +1 -0
  296. package/dist/src/lib/analyzers/secrets/patterns/api-keys/aws.js +36 -0
  297. package/dist/src/lib/analyzers/secrets/patterns/api-keys/aws.js.map +1 -0
  298. package/dist/src/lib/analyzers/secrets/patterns/api-keys/cloud-providers.d.ts +15 -0
  299. package/dist/src/lib/analyzers/secrets/patterns/api-keys/cloud-providers.d.ts.map +1 -0
  300. package/dist/src/lib/analyzers/secrets/patterns/api-keys/cloud-providers.js +68 -0
  301. package/dist/src/lib/analyzers/secrets/patterns/api-keys/cloud-providers.js.map +1 -0
  302. package/dist/src/lib/analyzers/secrets/patterns/api-keys/communication.d.ts +15 -0
  303. package/dist/src/lib/analyzers/secrets/patterns/api-keys/communication.d.ts.map +1 -0
  304. package/dist/src/lib/analyzers/secrets/patterns/api-keys/communication.js +68 -0
  305. package/dist/src/lib/analyzers/secrets/patterns/api-keys/communication.js.map +1 -0
  306. package/dist/src/lib/analyzers/secrets/patterns/api-keys/generic.d.ts +12 -0
  307. package/dist/src/lib/analyzers/secrets/patterns/api-keys/generic.d.ts.map +1 -0
  308. package/dist/src/lib/analyzers/secrets/patterns/api-keys/generic.js +45 -0
  309. package/dist/src/lib/analyzers/secrets/patterns/api-keys/generic.js.map +1 -0
  310. package/dist/src/lib/analyzers/secrets/patterns/api-keys/github.d.ts +14 -0
  311. package/dist/src/lib/analyzers/secrets/patterns/api-keys/github.d.ts.map +1 -0
  312. package/dist/src/lib/analyzers/secrets/patterns/api-keys/github.js +47 -0
  313. package/dist/src/lib/analyzers/secrets/patterns/api-keys/github.js.map +1 -0
  314. package/dist/src/lib/analyzers/secrets/patterns/api-keys/stripe.d.ts +13 -0
  315. package/dist/src/lib/analyzers/secrets/patterns/api-keys/stripe.d.ts.map +1 -0
  316. package/dist/src/lib/analyzers/secrets/patterns/api-keys/stripe.js +36 -0
  317. package/dist/src/lib/analyzers/secrets/patterns/api-keys/stripe.js.map +1 -0
  318. package/dist/src/lib/analyzers/secrets/patterns/api-keys.d.ts +15 -0
  319. package/dist/src/lib/analyzers/secrets/patterns/api-keys.d.ts.map +1 -0
  320. package/dist/src/lib/analyzers/secrets/patterns/api-keys.js +32 -0
  321. package/dist/src/lib/analyzers/secrets/patterns/api-keys.js.map +1 -0
  322. package/dist/src/lib/analyzers/secrets/patterns/credentials.d.ts +15 -0
  323. package/dist/src/lib/analyzers/secrets/patterns/credentials.d.ts.map +1 -0
  324. package/dist/src/lib/analyzers/secrets/patterns/credentials.js +68 -0
  325. package/dist/src/lib/analyzers/secrets/patterns/credentials.js.map +1 -0
  326. package/dist/src/lib/analyzers/secrets/patterns/private-keys.d.ts +16 -0
  327. package/dist/src/lib/analyzers/secrets/patterns/private-keys.d.ts.map +1 -0
  328. package/dist/src/lib/analyzers/secrets/patterns/private-keys.js +79 -0
  329. package/dist/src/lib/analyzers/secrets/patterns/private-keys.js.map +1 -0
  330. package/dist/src/lib/analyzers/secrets/patterns/tokens.d.ts +15 -0
  331. package/dist/src/lib/analyzers/secrets/patterns/tokens.d.ts.map +1 -0
  332. package/dist/src/lib/analyzers/secrets/patterns/tokens.js +58 -0
  333. package/dist/src/lib/analyzers/secrets/patterns/tokens.js.map +1 -0
  334. package/dist/src/lib/analyzers/secrets/secrets-analyzer.d.ts +88 -0
  335. package/dist/src/lib/analyzers/secrets/secrets-analyzer.d.ts.map +1 -0
  336. package/dist/src/lib/analyzers/secrets/secrets-analyzer.js +162 -0
  337. package/dist/src/lib/analyzers/secrets/secrets-analyzer.js.map +1 -0
  338. package/dist/src/lib/analyzers/secrets/validators/context-checker.d.ts +56 -0
  339. package/dist/src/lib/analyzers/secrets/validators/context-checker.d.ts.map +1 -0
  340. package/dist/src/lib/analyzers/secrets/validators/context-checker.js +199 -0
  341. package/dist/src/lib/analyzers/secrets/validators/context-checker.js.map +1 -0
  342. package/dist/src/lib/analyzers/secrets/validators/entropy-checker.d.ts +56 -0
  343. package/dist/src/lib/analyzers/secrets/validators/entropy-checker.d.ts.map +1 -0
  344. package/dist/src/lib/analyzers/secrets/validators/entropy-checker.js +102 -0
  345. package/dist/src/lib/analyzers/secrets/validators/entropy-checker.js.map +1 -0
  346. package/dist/src/lib/analyzers/security-checks/es6-security.d.ts +38 -0
  347. package/dist/src/lib/analyzers/security-checks/es6-security.d.ts.map +1 -0
  348. package/dist/src/lib/analyzers/security-checks/es6-security.js +125 -0
  349. package/dist/src/lib/analyzers/security-checks/es6-security.js.map +1 -0
  350. package/dist/src/lib/analyzers/security-checks/python-async-security.d.ts +46 -0
  351. package/dist/src/lib/analyzers/security-checks/python-async-security.d.ts.map +1 -0
  352. package/dist/src/lib/analyzers/security-checks/python-async-security.js +92 -0
  353. package/dist/src/lib/analyzers/security-checks/python-async-security.js.map +1 -0
  354. package/dist/src/lib/analyzers/security-checks/react-security.d.ts +49 -0
  355. package/dist/src/lib/analyzers/security-checks/react-security.d.ts.map +1 -0
  356. package/dist/src/lib/analyzers/security-checks/react-security.js +125 -0
  357. package/dist/src/lib/analyzers/security-checks/react-security.js.map +1 -0
  358. package/dist/src/lib/analyzers/types.d.ts +92 -0
  359. package/dist/src/lib/analyzers/types.d.ts.map +1 -0
  360. package/dist/src/lib/analyzers/types.js +3 -0
  361. package/dist/src/lib/analyzers/types.js.map +1 -0
  362. package/dist/src/lib/analyzers/typescript/security-checks/access-control.d.ts +19 -0
  363. package/dist/src/lib/analyzers/typescript/security-checks/access-control.d.ts.map +1 -0
  364. package/dist/src/lib/analyzers/typescript/security-checks/access-control.js +210 -0
  365. package/dist/src/lib/analyzers/typescript/security-checks/access-control.js.map +1 -0
  366. package/dist/src/lib/analyzers/typescript/security-checks/ai-generated-code.d.ts +25 -0
  367. package/dist/src/lib/analyzers/typescript/security-checks/ai-generated-code.d.ts.map +1 -0
  368. package/dist/src/lib/analyzers/typescript/security-checks/ai-generated-code.js +242 -0
  369. package/dist/src/lib/analyzers/typescript/security-checks/ai-generated-code.js.map +1 -0
  370. package/dist/src/lib/analyzers/typescript/security-checks/authentication.d.ts +28 -0
  371. package/dist/src/lib/analyzers/typescript/security-checks/authentication.d.ts.map +1 -0
  372. package/dist/src/lib/analyzers/typescript/security-checks/authentication.js +357 -0
  373. package/dist/src/lib/analyzers/typescript/security-checks/authentication.js.map +1 -0
  374. package/dist/src/lib/analyzers/typescript/security-checks/code-injection.d.ts +26 -0
  375. package/dist/src/lib/analyzers/typescript/security-checks/code-injection.d.ts.map +1 -0
  376. package/dist/src/lib/analyzers/typescript/security-checks/code-injection.js +380 -0
  377. package/dist/src/lib/analyzers/typescript/security-checks/code-injection.js.map +1 -0
  378. package/dist/src/lib/analyzers/typescript/security-checks/code-quality.d.ts +23 -0
  379. package/dist/src/lib/analyzers/typescript/security-checks/code-quality.d.ts.map +1 -0
  380. package/dist/src/lib/analyzers/typescript/security-checks/code-quality.js +109 -0
  381. package/dist/src/lib/analyzers/typescript/security-checks/code-quality.js.map +1 -0
  382. package/dist/src/lib/analyzers/typescript/security-checks/credentials-crypto.d.ts +21 -0
  383. package/dist/src/lib/analyzers/typescript/security-checks/credentials-crypto.d.ts.map +1 -0
  384. package/dist/src/lib/analyzers/typescript/security-checks/credentials-crypto.js +153 -0
  385. package/dist/src/lib/analyzers/typescript/security-checks/credentials-crypto.js.map +1 -0
  386. package/dist/src/lib/analyzers/typescript/security-checks/enhanced-supply-chain.d.ts +23 -0
  387. package/dist/src/lib/analyzers/typescript/security-checks/enhanced-supply-chain.d.ts.map +1 -0
  388. package/dist/src/lib/analyzers/typescript/security-checks/enhanced-supply-chain.js +146 -0
  389. package/dist/src/lib/analyzers/typescript/security-checks/enhanced-supply-chain.js.map +1 -0
  390. package/dist/src/lib/analyzers/typescript/security-checks/exception-handling.d.ts +23 -0
  391. package/dist/src/lib/analyzers/typescript/security-checks/exception-handling.d.ts.map +1 -0
  392. package/dist/src/lib/analyzers/typescript/security-checks/exception-handling.js +187 -0
  393. package/dist/src/lib/analyzers/typescript/security-checks/exception-handling.js.map +1 -0
  394. package/dist/src/lib/analyzers/typescript/security-checks/information-disclosure.d.ts +19 -0
  395. package/dist/src/lib/analyzers/typescript/security-checks/information-disclosure.d.ts.map +1 -0
  396. package/dist/src/lib/analyzers/typescript/security-checks/information-disclosure.js +97 -0
  397. package/dist/src/lib/analyzers/typescript/security-checks/information-disclosure.js.map +1 -0
  398. package/dist/src/lib/analyzers/typescript/security-checks/injection-attacks.d.ts +29 -0
  399. package/dist/src/lib/analyzers/typescript/security-checks/injection-attacks.d.ts.map +1 -0
  400. package/dist/src/lib/analyzers/typescript/security-checks/injection-attacks.js +319 -0
  401. package/dist/src/lib/analyzers/typescript/security-checks/injection-attacks.js.map +1 -0
  402. package/dist/src/lib/analyzers/typescript/security-checks/logging-failures.d.ts +21 -0
  403. package/dist/src/lib/analyzers/typescript/security-checks/logging-failures.d.ts.map +1 -0
  404. package/dist/src/lib/analyzers/typescript/security-checks/logging-failures.js +121 -0
  405. package/dist/src/lib/analyzers/typescript/security-checks/logging-failures.js.map +1 -0
  406. package/dist/src/lib/analyzers/typescript/security-checks/security-misconfiguration.d.ts +27 -0
  407. package/dist/src/lib/analyzers/typescript/security-checks/security-misconfiguration.d.ts.map +1 -0
  408. package/dist/src/lib/analyzers/typescript/security-checks/security-misconfiguration.js +213 -0
  409. package/dist/src/lib/analyzers/typescript/security-checks/security-misconfiguration.js.map +1 -0
  410. package/dist/src/lib/analyzers/typescript/security-checks/type-security.d.ts +19 -0
  411. package/dist/src/lib/analyzers/typescript/security-checks/type-security.d.ts.map +1 -0
  412. package/dist/src/lib/analyzers/typescript/security-checks/type-security.js +59 -0
  413. package/dist/src/lib/analyzers/typescript/security-checks/type-security.js.map +1 -0
  414. package/dist/src/lib/analyzers/typescript/type-checker.d.ts +17 -0
  415. package/dist/src/lib/analyzers/typescript/type-checker.d.ts.map +1 -0
  416. package/dist/src/lib/analyzers/typescript/type-checker.js +515 -0
  417. package/dist/src/lib/analyzers/typescript/type-checker.js.map +1 -0
  418. package/dist/src/lib/analyzers/typescript/utils/createVulnerability.d.ts +58 -0
  419. package/dist/src/lib/analyzers/typescript/utils/createVulnerability.d.ts.map +1 -0
  420. package/dist/src/lib/analyzers/typescript/utils/createVulnerability.js +71 -0
  421. package/dist/src/lib/analyzers/typescript/utils/createVulnerability.js.map +1 -0
  422. package/dist/src/lib/analyzers/typescript-analyzer.d.ts +116 -0
  423. package/dist/src/lib/analyzers/typescript-analyzer.d.ts.map +1 -0
  424. package/dist/src/lib/analyzers/typescript-analyzer.js +1660 -0
  425. package/dist/src/lib/analyzers/typescript-analyzer.js.map +1 -0
  426. package/dist/src/lib/security/compliance-mapping.d.ts +29 -0
  427. package/dist/src/lib/security/compliance-mapping.d.ts.map +1 -0
  428. package/dist/src/lib/security/compliance-mapping.js +1342 -0
  429. package/dist/src/lib/security/compliance-mapping.js.map +1 -0
  430. package/dist/src/lib/security/severity-scoring.d.ts +47 -0
  431. package/dist/src/lib/security/severity-scoring.d.ts.map +1 -0
  432. package/dist/src/lib/security/severity-scoring.js +965 -0
  433. package/dist/src/lib/security/severity-scoring.js.map +1 -0
  434. package/dist/src/lib/standards/references.d.ts +16 -0
  435. package/dist/src/lib/standards/references.d.ts.map +1 -0
  436. package/dist/src/lib/standards/references.js +1161 -0
  437. package/dist/src/lib/standards/references.js.map +1 -0
  438. package/dist/src/lib/types/index.d.ts +167 -0
  439. package/dist/src/lib/types/index.d.ts.map +1 -0
  440. package/dist/src/lib/types/index.js +3 -0
  441. package/dist/src/lib/types/index.js.map +1 -0
  442. package/dist/src/lib/utils/code-cleaner.d.ts +59 -0
  443. package/dist/src/lib/utils/code-cleaner.d.ts.map +1 -0
  444. package/dist/src/lib/utils/code-cleaner.js +283 -0
  445. package/dist/src/lib/utils/code-cleaner.js.map +1 -0
  446. package/package.json +51 -0
  447. package/src/commands/auth.ts +308 -0
  448. package/src/commands/config.ts +226 -0
  449. package/src/commands/init.ts +202 -0
  450. package/src/commands/scan.ts +238 -0
  451. package/src/config/config-loader.ts +175 -0
  452. package/src/reporters/cli-reporter.ts +282 -0
  453. package/src/scanner/local-scanner.ts +250 -0
  454. package/tsconfig.json +24 -0
  455. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,965 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.calculateSeverityScore = calculateSeverityScore;
4
+ exports.getSeverityLabel = getSeverityLabel;
5
+ exports.getSeverityColor = getSeverityColor;
6
+ exports.sortBySeverity = sortBySeverity;
7
+ /**
8
+ * Calculate CVSS-like score and severity level
9
+ *
10
+ * Score Ranges:
11
+ * - CRITICAL: 9.0-10.0 (Immediate exploit risk, data breach potential)
12
+ * - HIGH: 7.0-8.9 (Exploitable with moderate effort, significant impact)
13
+ * - MEDIUM: 4.0-6.9 (Requires specific conditions, moderate impact)
14
+ * - LOW: 1.0-3.9 (Limited impact, information disclosure)
15
+ */
16
+ function calculateSeverityScore(vulnerabilityType, context) {
17
+ const baseScores = getBaseScore(vulnerabilityType);
18
+ // Adjust score based on context
19
+ let adjustedScore = baseScores.cvssScore;
20
+ if (context?.hasUserInput) {
21
+ adjustedScore += 0.5;
22
+ }
23
+ if (context?.isPublicFacing) {
24
+ adjustedScore += 0.5;
25
+ }
26
+ if (context?.containsSensitiveData) {
27
+ adjustedScore += 1.0;
28
+ }
29
+ // Cap at 10.0
30
+ adjustedScore = Math.min(adjustedScore, 10.0);
31
+ // Recalculate severity based on adjusted score
32
+ const severity = getSeverityFromScore(adjustedScore);
33
+ return {
34
+ ...baseScores,
35
+ cvssScore: adjustedScore,
36
+ severity,
37
+ };
38
+ }
39
+ /**
40
+ * Get base severity score for vulnerability type
41
+ */
42
+ function getBaseScore(vulnerabilityType) {
43
+ const scoreMap = {
44
+ // CRITICAL (9.0-10.0) - Immediate exploitation, RCE, data breach
45
+ 'sql-injection': {
46
+ severity: 'critical',
47
+ cvssScore: 9.8,
48
+ exploitLikelihood: 'high',
49
+ impact: 'data-breach',
50
+ },
51
+ 'nosql-injection': {
52
+ severity: 'critical',
53
+ cvssScore: 9.8,
54
+ exploitLikelihood: 'high',
55
+ impact: 'data-breach',
56
+ },
57
+ 'ssrf': {
58
+ severity: 'critical',
59
+ cvssScore: 9.1,
60
+ exploitLikelihood: 'high',
61
+ impact: 'data-breach',
62
+ },
63
+ 'command-injection': {
64
+ severity: 'critical',
65
+ cvssScore: 9.8,
66
+ exploitLikelihood: 'high',
67
+ impact: 'rce',
68
+ },
69
+ 'deserialization': {
70
+ severity: 'critical',
71
+ cvssScore: 9.8,
72
+ exploitLikelihood: 'high',
73
+ impact: 'rce',
74
+ },
75
+ 'eval-usage': {
76
+ severity: 'critical',
77
+ cvssScore: 9.3,
78
+ exploitLikelihood: 'high',
79
+ impact: 'rce',
80
+ },
81
+ 'hardcoded-credentials': {
82
+ severity: 'critical',
83
+ cvssScore: 9.1,
84
+ exploitLikelihood: 'high',
85
+ impact: 'authentication-bypass',
86
+ },
87
+ 'hardcoded-database-credentials': {
88
+ severity: 'high',
89
+ cvssScore: 7.5,
90
+ exploitLikelihood: 'high',
91
+ impact: 'data-breach',
92
+ },
93
+ 'hardcoded-aws-credentials': {
94
+ severity: 'critical',
95
+ cvssScore: 9.8,
96
+ exploitLikelihood: 'high',
97
+ impact: 'authentication-bypass',
98
+ },
99
+ 'log4j-vulnerable-version': {
100
+ severity: 'critical',
101
+ cvssScore: 10.0,
102
+ exploitLikelihood: 'high',
103
+ impact: 'rce',
104
+ },
105
+ 'log4j-unsafe-logging': {
106
+ severity: 'critical',
107
+ cvssScore: 10.0,
108
+ exploitLikelihood: 'high',
109
+ impact: 'rce',
110
+ },
111
+ // PHASE 6 (2025-11-21): Node.js/Express Security Checks
112
+ 'nodejs-require-injection': {
113
+ severity: 'critical',
114
+ cvssScore: 9.8,
115
+ exploitLikelihood: 'high',
116
+ impact: 'rce',
117
+ },
118
+ 'nodejs-command-injection': {
119
+ severity: 'critical',
120
+ cvssScore: 9.8,
121
+ exploitLikelihood: 'high',
122
+ impact: 'rce',
123
+ },
124
+ 'log4j-jndi-pattern': {
125
+ severity: 'critical',
126
+ cvssScore: 10.0,
127
+ exploitLikelihood: 'high',
128
+ impact: 'rce',
129
+ },
130
+ // DEC 16, 2025: Supply Chain - Dynamic require() (Check #87)
131
+ 'dynamic-require-env-var': {
132
+ severity: 'critical',
133
+ cvssScore: 9.0,
134
+ exploitLikelihood: 'high',
135
+ impact: 'rce',
136
+ },
137
+ // DEC 16, 2025 (Phase 11): Authentication Failures (Checks #88, #89, #90)
138
+ 'plaintext-password-comparison': {
139
+ severity: 'critical',
140
+ cvssScore: 9.8,
141
+ exploitLikelihood: 'high',
142
+ impact: 'authentication-bypass',
143
+ },
144
+ 'weak-token-generation': {
145
+ severity: 'high',
146
+ cvssScore: 8.1,
147
+ exploitLikelihood: 'high',
148
+ impact: 'authentication-bypass',
149
+ },
150
+ 'master-password-backdoor': {
151
+ severity: 'high',
152
+ cvssScore: 7.5,
153
+ exploitLikelihood: 'high',
154
+ impact: 'authentication-bypass',
155
+ },
156
+ 'fail-open-authorization': {
157
+ severity: 'critical',
158
+ cvssScore: 9.1,
159
+ exploitLikelihood: 'high',
160
+ impact: 'privilege-escalation',
161
+ },
162
+ 'fail-open-authentication': {
163
+ severity: 'critical',
164
+ cvssScore: 9.1,
165
+ exploitLikelihood: 'high',
166
+ impact: 'privilege-escalation',
167
+ },
168
+ // DEC 20, 2025 (Phase A P0): JWT Vulnerabilities (Checks #3, #4)
169
+ 'jwt-none-algorithm': {
170
+ severity: 'critical',
171
+ cvssScore: 9.1,
172
+ exploitLikelihood: 'high',
173
+ impact: 'authentication-bypass',
174
+ },
175
+ 'jwt-decode-authentication': {
176
+ severity: 'critical',
177
+ cvssScore: 9.1,
178
+ exploitLikelihood: 'high',
179
+ impact: 'authentication-bypass',
180
+ },
181
+ 'jwt-weak-secret': {
182
+ severity: 'critical',
183
+ cvssScore: 9.1,
184
+ exploitLikelihood: 'high',
185
+ impact: 'authentication-bypass',
186
+ },
187
+ // DEC 20, 2025 (Phase B): Template Injection (Check #11)
188
+ 'ssti': {
189
+ severity: 'critical',
190
+ cvssScore: 9.0,
191
+ exploitLikelihood: 'high',
192
+ impact: 'rce',
193
+ },
194
+ // DEC 16, 2025: Information Disclosure - Direct stack exposure (Check #86 variant)
195
+ 'direct-stack-exposure': {
196
+ severity: 'high',
197
+ cvssScore: 7.0,
198
+ exploitLikelihood: 'medium',
199
+ impact: 'info-disclosure',
200
+ },
201
+ // PHASE 6 (2025-11-23): Django/Flask Security Checks - CRITICAL
202
+ 'django-orm-sql-injection': {
203
+ severity: 'critical',
204
+ cvssScore: 9.8,
205
+ exploitLikelihood: 'high',
206
+ impact: 'data-breach',
207
+ },
208
+ 'django-debug-true': {
209
+ severity: 'critical',
210
+ cvssScore: 9.3,
211
+ exploitLikelihood: 'high',
212
+ impact: 'info-disclosure',
213
+ },
214
+ 'django-weak-secret-key': {
215
+ severity: 'critical',
216
+ cvssScore: 9.1,
217
+ exploitLikelihood: 'high',
218
+ impact: 'authentication-bypass',
219
+ },
220
+ 'flask-debug-mode': {
221
+ severity: 'critical',
222
+ cvssScore: 9.8,
223
+ exploitLikelihood: 'high',
224
+ impact: 'rce',
225
+ },
226
+ 'ai-generated-code-high': {
227
+ severity: 'critical',
228
+ cvssScore: 8.5,
229
+ exploitLikelihood: 'high',
230
+ impact: 'code-integrity',
231
+ },
232
+ // HIGH (7.0-8.9) - Exploitable with moderate effort
233
+ 'xss': {
234
+ severity: 'high',
235
+ cvssScore: 8.2,
236
+ exploitLikelihood: 'high',
237
+ impact: 'xss',
238
+ },
239
+ 'xxe': {
240
+ severity: 'high',
241
+ cvssScore: 8.5,
242
+ exploitLikelihood: 'high',
243
+ impact: 'data-breach',
244
+ },
245
+ 'path-traversal': {
246
+ severity: 'high',
247
+ cvssScore: 7.5,
248
+ exploitLikelihood: 'high',
249
+ impact: 'info-disclosure',
250
+ },
251
+ 'ldap-injection': {
252
+ severity: 'high',
253
+ cvssScore: 8.8,
254
+ exploitLikelihood: 'high',
255
+ impact: 'authentication-bypass',
256
+ },
257
+ 'redis-injection': {
258
+ severity: 'high',
259
+ cvssScore: 7.5,
260
+ exploitLikelihood: 'high',
261
+ impact: 'info-disclosure',
262
+ },
263
+ 'xpath-injection': {
264
+ severity: 'high',
265
+ cvssScore: 8.1,
266
+ exploitLikelihood: 'medium',
267
+ impact: 'data-breach',
268
+ },
269
+ 'prototype-pollution': {
270
+ severity: 'high',
271
+ cvssScore: 7.5,
272
+ exploitLikelihood: 'medium',
273
+ impact: 'privilege-escalation',
274
+ },
275
+ 'unsafe-yaml-load': {
276
+ severity: 'high',
277
+ cvssScore: 7.5,
278
+ exploitLikelihood: 'medium',
279
+ impact: 'rce',
280
+ },
281
+ 'unsafe-pickle': {
282
+ severity: 'high',
283
+ cvssScore: 7.5,
284
+ exploitLikelihood: 'medium',
285
+ impact: 'rce',
286
+ },
287
+ 'unsafe-reflection': {
288
+ severity: 'high',
289
+ cvssScore: 7.5,
290
+ exploitLikelihood: 'medium',
291
+ impact: 'rce',
292
+ },
293
+ 'file-upload-no-validation': {
294
+ severity: 'high',
295
+ cvssScore: 7.5,
296
+ exploitLikelihood: 'high',
297
+ impact: 'rce',
298
+ },
299
+ 'log4j-missing-protection': {
300
+ severity: 'high',
301
+ cvssScore: 8.1,
302
+ exploitLikelihood: 'high',
303
+ impact: 'rce',
304
+ },
305
+ // PHASE 6 (2025-11-21): Node.js/Express Security Checks - HIGH
306
+ 'nodejs-path-traversal': {
307
+ severity: 'high',
308
+ cvssScore: 7.5,
309
+ exploitLikelihood: 'medium',
310
+ impact: 'data-breach',
311
+ },
312
+ 'nodejs-unsafe-request-params': {
313
+ severity: 'high',
314
+ cvssScore: 7.3,
315
+ exploitLikelihood: 'high',
316
+ impact: 'data-breach',
317
+ },
318
+ // PHASE 6 (2025-11-23): Django/Flask Security Checks - HIGH
319
+ 'django-csrf-exempt': {
320
+ severity: 'high',
321
+ cvssScore: 8.1,
322
+ exploitLikelihood: 'high',
323
+ impact: 'privilege-escalation',
324
+ },
325
+ 'django-mark-safe-xss': {
326
+ severity: 'high',
327
+ cvssScore: 7.4,
328
+ exploitLikelihood: 'high',
329
+ impact: 'xss',
330
+ },
331
+ // DEC 16, 2025: TypeScript Security Checks (Check #85, #86)
332
+ 'idor-no-authorization': {
333
+ severity: 'high',
334
+ cvssScore: 7.5,
335
+ exploitLikelihood: 'high',
336
+ impact: 'privilege-escalation',
337
+ },
338
+ 'stack-trace-exposure': {
339
+ severity: 'high',
340
+ cvssScore: 7.0,
341
+ exploitLikelihood: 'medium',
342
+ impact: 'info-disclosure',
343
+ },
344
+ 'ai-generated-code-medium': {
345
+ severity: 'high',
346
+ cvssScore: 7.5,
347
+ exploitLikelihood: 'medium',
348
+ impact: 'code-integrity',
349
+ },
350
+ // MEDIUM (4.0-6.9) - Moderate impact, requires specific conditions
351
+ 'spring-missing-method-security': {
352
+ severity: 'medium',
353
+ cvssScore: 6.5,
354
+ exploitLikelihood: 'high',
355
+ impact: 'privilege-escalation',
356
+ },
357
+ // PHASE 6 (2025-11-21): Node.js/Express Security Checks - MEDIUM
358
+ 'nodejs-missing-helmet': {
359
+ severity: 'medium',
360
+ cvssScore: 5.0,
361
+ exploitLikelihood: 'medium',
362
+ impact: 'info-disclosure',
363
+ },
364
+ // DEC 20, 2025 (Phase B): Helmet Misconfiguration (Check #10)
365
+ 'helmet-misconfiguration': {
366
+ severity: 'high',
367
+ cvssScore: 7.5,
368
+ exploitLikelihood: 'high',
369
+ impact: 'xss',
370
+ },
371
+ // DEC 20, 2025 (Phase B): Missing CSRF Protection (Check #11)
372
+ 'missing-csrf-protection': {
373
+ severity: 'high',
374
+ cvssScore: 8.1,
375
+ exploitLikelihood: 'high',
376
+ impact: 'authentication-bypass',
377
+ },
378
+ // DEC 20, 2025 (Phase B): Missing SameSite Cookie Attribute (Check #11)
379
+ 'missing-samesite-cookie': {
380
+ severity: 'high',
381
+ cvssScore: 8.1,
382
+ exploitLikelihood: 'high',
383
+ impact: 'authentication-bypass',
384
+ },
385
+ // DEC 20, 2025 (Phase B): Weak Encryption - AES-ECB Mode (Check #12)
386
+ 'weak-encryption-ecb': {
387
+ severity: 'high',
388
+ cvssScore: 8.5,
389
+ exploitLikelihood: 'high',
390
+ impact: 'data-breach',
391
+ },
392
+ // DEC 20, 2025 (Phase B): Deprecated crypto.createCipher (Check #12)
393
+ 'deprecated-createcipher': {
394
+ severity: 'high',
395
+ cvssScore: 8.5,
396
+ exploitLikelihood: 'high',
397
+ impact: 'data-breach',
398
+ },
399
+ // DEC 20, 2025 (Phase B): Insecure TLS - rejectUnauthorized: false (Check #13)
400
+ 'insecure-tls-reject-unauthorized': {
401
+ severity: 'high',
402
+ cvssScore: 7.5,
403
+ exploitLikelihood: 'high',
404
+ impact: 'data-breach',
405
+ },
406
+ // DEC 20, 2025 (Phase B): Insecure TLS Version (Check #13)
407
+ 'insecure-tls-version': {
408
+ severity: 'high',
409
+ cvssScore: 7.5,
410
+ exploitLikelihood: 'high',
411
+ impact: 'data-breach',
412
+ },
413
+ // DEC 20, 2025 (Phase B): NODE_TLS_REJECT_UNAUTHORIZED=0 (Check #13)
414
+ 'node-tls-reject-unauthorized': {
415
+ severity: 'high',
416
+ cvssScore: 7.5,
417
+ exploitLikelihood: 'high',
418
+ impact: 'data-breach',
419
+ },
420
+ // DEC 25, 2025: OWASP A10:2025 - Exception Handling (Phase 7B Day 9)
421
+ 'unhandled-promise-rejection': {
422
+ severity: 'high',
423
+ cvssScore: 7.5,
424
+ exploitLikelihood: 'high',
425
+ impact: 'dos',
426
+ },
427
+ 'error-object-exposure': {
428
+ severity: 'high',
429
+ cvssScore: 7.5,
430
+ exploitLikelihood: 'high',
431
+ impact: 'info-disclosure',
432
+ },
433
+ 'error-details-exposed': {
434
+ severity: 'medium',
435
+ cvssScore: 5.5,
436
+ exploitLikelihood: 'medium',
437
+ impact: 'info-disclosure',
438
+ },
439
+ 'async-without-try-catch': {
440
+ severity: 'medium',
441
+ cvssScore: 5.3,
442
+ exploitLikelihood: 'medium',
443
+ impact: 'dos',
444
+ },
445
+ // DEC 25, 2025: Java A06:2025 - Insecure Design (Phase 7B Day 9)
446
+ 'missing-input-validation': {
447
+ severity: 'high',
448
+ cvssScore: 8.1,
449
+ exploitLikelihood: 'high',
450
+ impact: 'data-breach',
451
+ },
452
+ 'direct-database-query': {
453
+ severity: 'medium',
454
+ cvssScore: 6.1,
455
+ exploitLikelihood: 'medium',
456
+ impact: 'privilege-escalation',
457
+ },
458
+ // DEC 25, 2025: Java A09:2025 - Logging Failures (Phase 7B Day 9)
459
+ 'missing-security-logging': {
460
+ severity: 'medium',
461
+ cvssScore: 5.9,
462
+ exploitLikelihood: 'medium',
463
+ impact: 'info-disclosure',
464
+ },
465
+ 'system-out-println': {
466
+ severity: 'low',
467
+ cvssScore: 3.1,
468
+ exploitLikelihood: 'low',
469
+ impact: 'info-disclosure',
470
+ },
471
+ // DEC 23, 2025: OWASP A03:2025 - Supply Chain (HIGH)
472
+ 'dynamic-import-no-integrity': {
473
+ severity: 'high',
474
+ cvssScore: 7.5,
475
+ exploitLikelihood: 'high',
476
+ impact: 'rce',
477
+ },
478
+ 'suspicious-package-pattern': {
479
+ severity: 'high',
480
+ cvssScore: 7.5,
481
+ exploitLikelihood: 'high',
482
+ impact: 'rce',
483
+ },
484
+ // HIGH (7.0-8.9) - Significant risk
485
+ 'weak-random': {
486
+ severity: 'high',
487
+ cvssScore: 7.2,
488
+ exploitLikelihood: 'high',
489
+ impact: 'privilege-escalation',
490
+ },
491
+ 'weak-encryption-des': {
492
+ severity: 'high',
493
+ cvssScore: 7.5,
494
+ exploitLikelihood: 'high',
495
+ impact: 'data-breach',
496
+ },
497
+ 'weak-hash-md5': {
498
+ severity: 'medium',
499
+ cvssScore: 5.9,
500
+ exploitLikelihood: 'low',
501
+ impact: 'data-breach',
502
+ },
503
+ 'weak-hash-sha1': {
504
+ severity: 'medium',
505
+ cvssScore: 5.9,
506
+ exploitLikelihood: 'low',
507
+ impact: 'data-breach',
508
+ },
509
+ 'ecb-mode-encryption': {
510
+ severity: 'medium',
511
+ cvssScore: 5.3,
512
+ exploitLikelihood: 'low',
513
+ impact: 'data-breach',
514
+ },
515
+ 'insecure-storage': {
516
+ severity: 'medium',
517
+ cvssScore: 4.3,
518
+ exploitLikelihood: 'low',
519
+ impact: 'info-disclosure',
520
+ },
521
+ 'regex-dos': {
522
+ severity: 'medium',
523
+ cvssScore: 5.3,
524
+ exploitLikelihood: 'medium',
525
+ impact: 'dos',
526
+ },
527
+ 'document-write': {
528
+ severity: 'medium',
529
+ cvssScore: 4.3,
530
+ exploitLikelihood: 'low',
531
+ impact: 'xss',
532
+ },
533
+ 'function-constructor': {
534
+ severity: 'medium',
535
+ cvssScore: 6.1,
536
+ exploitLikelihood: 'medium',
537
+ impact: 'rce',
538
+ },
539
+ 'settimeout-string': {
540
+ severity: 'medium',
541
+ cvssScore: 4.3,
542
+ exploitLikelihood: 'low',
543
+ impact: 'xss',
544
+ },
545
+ // DEC 23, 2025: OWASP A10:2025 - Exception Handling (MEDIUM)
546
+ 'empty-catch-block': {
547
+ severity: 'medium',
548
+ cvssScore: 5.0,
549
+ exploitLikelihood: 'medium',
550
+ impact: 'info-disclosure',
551
+ },
552
+ 'ignored-exception': {
553
+ severity: 'medium',
554
+ cvssScore: 5.0,
555
+ exploitLikelihood: 'medium',
556
+ impact: 'info-disclosure',
557
+ },
558
+ 'missing-resource-cleanup': {
559
+ severity: 'medium',
560
+ cvssScore: 5.0,
561
+ exploitLikelihood: 'medium',
562
+ impact: 'dos',
563
+ },
564
+ // DEC 23, 2025: OWASP A03:2025 - Supply Chain (MEDIUM)
565
+ 'runtime-dependency-loading': {
566
+ severity: 'high',
567
+ cvssScore: 7.5,
568
+ exploitLikelihood: 'high',
569
+ impact: 'rce',
570
+ },
571
+ 'unrestricted-cdn-usage': {
572
+ severity: 'medium',
573
+ cvssScore: 5.0,
574
+ exploitLikelihood: 'medium',
575
+ impact: 'rce',
576
+ },
577
+ // DEC 24, 2025: Python A10:2025 - Exception Handling (HIGH)
578
+ 'bare-except-clause': {
579
+ severity: 'high',
580
+ cvssScore: 7.0,
581
+ exploitLikelihood: 'high',
582
+ impact: 'info-disclosure',
583
+ },
584
+ 'exception-details-exposed': {
585
+ severity: 'high',
586
+ cvssScore: 7.5,
587
+ exploitLikelihood: 'high',
588
+ impact: 'info-disclosure',
589
+ },
590
+ // DEC 24, 2025: Python A10:2025 - Exception Handling (MEDIUM)
591
+ 'silent-exception-suppression': {
592
+ severity: 'medium',
593
+ cvssScore: 5.5,
594
+ exploitLikelihood: 'medium',
595
+ impact: 'info-disclosure',
596
+ },
597
+ 'incorrect-exception-pattern': {
598
+ severity: 'medium',
599
+ cvssScore: 5.0,
600
+ exploitLikelihood: 'medium',
601
+ impact: 'info-disclosure',
602
+ },
603
+ // DEC 24, 2025: Python A03:2025 - Supply Chain (HIGH)
604
+ 'dynamic-import-no-validation': {
605
+ severity: 'high',
606
+ cvssScore: 8.0,
607
+ exploitLikelihood: 'high',
608
+ impact: 'rce',
609
+ },
610
+ 'runtime-package-installation': {
611
+ severity: 'high',
612
+ cvssScore: 8.5,
613
+ exploitLikelihood: 'high',
614
+ impact: 'rce',
615
+ },
616
+ 'untrusted-package-source': {
617
+ severity: 'high',
618
+ cvssScore: 7.5,
619
+ exploitLikelihood: 'high',
620
+ impact: 'rce',
621
+ },
622
+ // DEC 24, 2025: Python A03:2025 - Supply Chain (MEDIUM)
623
+ 'package-typosquatting-pattern': {
624
+ severity: 'medium',
625
+ cvssScore: 6.0,
626
+ exploitLikelihood: 'medium',
627
+ impact: 'rce',
628
+ },
629
+ // DEC 24, 2025: Python A01:2025 - Broken Access Control (HIGH)
630
+ 'missing-authentication-decorator': {
631
+ severity: 'high',
632
+ cvssScore: 8.1,
633
+ exploitLikelihood: 'high',
634
+ impact: 'privilege-escalation',
635
+ },
636
+ 'insecure-direct-object-reference': {
637
+ severity: 'high',
638
+ cvssScore: 8.2,
639
+ exploitLikelihood: 'high',
640
+ impact: 'data-breach',
641
+ },
642
+ // DEC 24, 2025: Python A04:2025 - Cryptographic Failures (HIGH)
643
+ 'weak-crypto-algorithm': {
644
+ severity: 'high',
645
+ cvssScore: 7.5,
646
+ exploitLikelihood: 'high',
647
+ impact: 'data-breach',
648
+ },
649
+ 'insecure-random': {
650
+ severity: 'high',
651
+ cvssScore: 7.8,
652
+ exploitLikelihood: 'high',
653
+ impact: 'privilege-escalation',
654
+ },
655
+ // DEC 24, 2025: Python A06:2025 - Insecure Design (HIGH)
656
+ 'missing-rate-limiting': {
657
+ severity: 'high',
658
+ cvssScore: 7.3,
659
+ exploitLikelihood: 'high',
660
+ impact: 'dos',
661
+ },
662
+ 'mass-assignment': {
663
+ severity: 'high',
664
+ cvssScore: 8.0,
665
+ exploitLikelihood: 'high',
666
+ impact: 'privilege-escalation',
667
+ },
668
+ // DEC 24, 2025: Python A09:2025 - Logging Failures
669
+ 'sensitive-data-logging': {
670
+ severity: 'high',
671
+ cvssScore: 7.5,
672
+ exploitLikelihood: 'high',
673
+ impact: 'info-disclosure',
674
+ },
675
+ // DEC 24, 2025: Python A08:2025 - Software and Data Integrity Failures (CRITICAL)
676
+ 'insecure-deserialization': {
677
+ severity: 'critical',
678
+ cvssScore: 9.8,
679
+ exploitLikelihood: 'high',
680
+ impact: 'rce',
681
+ },
682
+ // DEC 25, 2025: Java A10:2025 - Exception Handling (Phase 7B Day 6)
683
+ 'broad-exception-catching': {
684
+ severity: 'high',
685
+ cvssScore: 7.2,
686
+ exploitLikelihood: 'medium',
687
+ impact: 'info-disclosure',
688
+ },
689
+ 'printstacktrace-usage': {
690
+ severity: 'high',
691
+ cvssScore: 7.0,
692
+ exploitLikelihood: 'high',
693
+ impact: 'info-disclosure',
694
+ },
695
+ 'swallowed-interrupted-exception': {
696
+ severity: 'medium',
697
+ cvssScore: 5.8,
698
+ exploitLikelihood: 'medium',
699
+ impact: 'dos',
700
+ },
701
+ // DEC 25, 2025: Java A03:2025 - Supply Chain Security (Phase 7B Day 7)
702
+ 'dynamic-class-loading': {
703
+ severity: 'critical',
704
+ cvssScore: 9.8,
705
+ exploitLikelihood: 'high',
706
+ impact: 'rce',
707
+ },
708
+ 'insecure-maven-repository': {
709
+ severity: 'high',
710
+ cvssScore: 7.5,
711
+ exploitLikelihood: 'high',
712
+ impact: 'data-breach',
713
+ },
714
+ 'package-typosquatting': {
715
+ severity: 'critical',
716
+ cvssScore: 9.0,
717
+ exploitLikelihood: 'high',
718
+ impact: 'rce',
719
+ },
720
+ 'unsigned-jar-usage': {
721
+ severity: 'high',
722
+ cvssScore: 7.2,
723
+ exploitLikelihood: 'high',
724
+ impact: 'rce',
725
+ },
726
+ 'dependency-confusion': {
727
+ severity: 'high',
728
+ cvssScore: 7.8,
729
+ exploitLikelihood: 'high',
730
+ impact: 'rce',
731
+ },
732
+ 'runtime-bytecode-loading': {
733
+ severity: 'critical',
734
+ cvssScore: 9.5,
735
+ exploitLikelihood: 'high',
736
+ impact: 'rce',
737
+ },
738
+ // DEC 25, 2025: Java A01:2025 - Access Control (Phase 7B Day 8)
739
+ 'missing-authorization': {
740
+ severity: 'high',
741
+ cvssScore: 8.1,
742
+ exploitLikelihood: 'high',
743
+ impact: 'privilege-escalation',
744
+ },
745
+ 'hardcoded-roles': {
746
+ severity: 'medium',
747
+ cvssScore: 5.3,
748
+ exploitLikelihood: 'low',
749
+ impact: 'info-disclosure',
750
+ },
751
+ // DEC 25, 2025: JavaScript/TypeScript A01:2025 - Access Control (Phase 7B Day 11)
752
+ 'missing-authentication-middleware': {
753
+ severity: 'high',
754
+ cvssScore: 8.1,
755
+ exploitLikelihood: 'high',
756
+ impact: 'authentication-bypass',
757
+ },
758
+ 'client-side-authorization': {
759
+ severity: 'high',
760
+ cvssScore: 7.5,
761
+ exploitLikelihood: 'high',
762
+ impact: 'privilege-escalation',
763
+ },
764
+ // DEC 25, 2025: JavaScript/TypeScript A07:2025 - Authentication Failures (Phase 7B Day 11)
765
+ 'missing-mfa': {
766
+ severity: 'medium',
767
+ cvssScore: 6.5,
768
+ exploitLikelihood: 'high',
769
+ impact: 'authentication-bypass',
770
+ },
771
+ 'no-rate-limiting': {
772
+ severity: 'medium',
773
+ cvssScore: 5.3,
774
+ exploitLikelihood: 'high',
775
+ impact: 'dos',
776
+ },
777
+ // DEC 25, 2025: Java A04:2025 - Cryptographic Failures (Phase 7B Day 8)
778
+ 'weak-cipher-rc4': {
779
+ severity: 'high',
780
+ cvssScore: 7.4,
781
+ exploitLikelihood: 'high',
782
+ impact: 'data-breach',
783
+ },
784
+ 'assert-security': {
785
+ severity: 'medium',
786
+ cvssScore: 4.3,
787
+ exploitLikelihood: 'low',
788
+ impact: 'privilege-escalation',
789
+ },
790
+ 'input-no-validation': {
791
+ severity: 'medium',
792
+ cvssScore: 5.3,
793
+ exploitLikelihood: 'medium',
794
+ impact: 'info-disclosure',
795
+ },
796
+ // PHASE 6 (2025-11-23): Django/Flask Security Checks - MEDIUM
797
+ 'django-missing-login-required': {
798
+ severity: 'medium',
799
+ cvssScore: 6.5,
800
+ exploitLikelihood: 'high',
801
+ impact: 'privilege-escalation',
802
+ },
803
+ 'flask-missing-csrf': {
804
+ severity: 'medium',
805
+ cvssScore: 6.1,
806
+ exploitLikelihood: 'high',
807
+ impact: 'privilege-escalation',
808
+ },
809
+ 'flask-ssti': {
810
+ severity: 'medium',
811
+ cvssScore: 6.5,
812
+ exploitLikelihood: 'medium',
813
+ impact: 'rce',
814
+ },
815
+ 'flask-markup-xss': {
816
+ severity: 'medium',
817
+ cvssScore: 5.4,
818
+ exploitLikelihood: 'medium',
819
+ impact: 'xss',
820
+ },
821
+ 'flask-weak-secret-key': {
822
+ severity: 'medium',
823
+ cvssScore: 5.3,
824
+ exploitLikelihood: 'medium',
825
+ impact: 'authentication-bypass',
826
+ },
827
+ 'ai-generated-code-low': {
828
+ severity: 'medium',
829
+ cvssScore: 5.5,
830
+ exploitLikelihood: 'low',
831
+ impact: 'code-quality',
832
+ },
833
+ // LOW (1.0-3.9) - Limited impact, information disclosure
834
+ // CODE QUALITY (0.0) - Not security vulnerabilities (Dec 16, 2025 - Phase 11)
835
+ 'any-type-usage': {
836
+ severity: 'low',
837
+ cvssScore: 0.0,
838
+ exploitLikelihood: 'low',
839
+ impact: 'info-disclosure',
840
+ },
841
+ 'console-log': {
842
+ severity: 'low',
843
+ cvssScore: 2.6,
844
+ exploitLikelihood: 'low',
845
+ impact: 'info-disclosure',
846
+ },
847
+ 'print-statement': {
848
+ severity: 'low',
849
+ cvssScore: 2.6,
850
+ exploitLikelihood: 'low',
851
+ impact: 'info-disclosure',
852
+ },
853
+ 'printstacktrace': {
854
+ severity: 'low',
855
+ cvssScore: 3.7,
856
+ exploitLikelihood: 'low',
857
+ impact: 'info-disclosure',
858
+ },
859
+ 'empty-except': {
860
+ severity: 'low',
861
+ cvssScore: 3.1,
862
+ exploitLikelihood: 'low',
863
+ impact: 'info-disclosure',
864
+ },
865
+ 'missing-error-handling': {
866
+ severity: 'low',
867
+ cvssScore: 3.1,
868
+ exploitLikelihood: 'low',
869
+ impact: 'info-disclosure',
870
+ },
871
+ 'generic-exception-catch': {
872
+ severity: 'low',
873
+ cvssScore: 3.1,
874
+ exploitLikelihood: 'low',
875
+ impact: 'info-disclosure',
876
+ },
877
+ 'null-pointer-unhandled': {
878
+ severity: 'low',
879
+ cvssScore: 2.6,
880
+ exploitLikelihood: 'low',
881
+ impact: 'dos',
882
+ },
883
+ };
884
+ return scoreMap[vulnerabilityType] || {
885
+ severity: 'medium',
886
+ cvssScore: 5.0,
887
+ exploitLikelihood: 'medium',
888
+ impact: 'info-disclosure',
889
+ };
890
+ }
891
+ /**
892
+ * Get severity level from CVSS score
893
+ */
894
+ function getSeverityFromScore(score) {
895
+ if (score >= 9.0)
896
+ return 'critical';
897
+ if (score >= 7.0)
898
+ return 'high';
899
+ if (score >= 4.0)
900
+ return 'medium';
901
+ return 'low';
902
+ }
903
+ /**
904
+ * Get severity label for display
905
+ */
906
+ function getSeverityLabel(severity) {
907
+ const labels = {
908
+ critical: 'CRITICAL',
909
+ high: 'HIGH',
910
+ medium: 'MEDIUM',
911
+ low: 'LOW',
912
+ };
913
+ return labels[severity];
914
+ }
915
+ /**
916
+ * Get severity color for UI
917
+ */
918
+ function getSeverityColor(severity) {
919
+ const colors = {
920
+ critical: {
921
+ bg: 'bg-red-100',
922
+ text: 'text-red-900',
923
+ border: 'border-red-500',
924
+ },
925
+ high: {
926
+ bg: 'bg-orange-100',
927
+ text: 'text-orange-900',
928
+ border: 'border-orange-500',
929
+ },
930
+ medium: {
931
+ bg: 'bg-yellow-100',
932
+ text: 'text-yellow-900',
933
+ border: 'border-yellow-500',
934
+ },
935
+ low: {
936
+ bg: 'bg-gray-100',
937
+ text: 'text-gray-700',
938
+ border: 'border-gray-400',
939
+ },
940
+ };
941
+ return colors[severity];
942
+ }
943
+ /**
944
+ * Sort security issues by severity (critical first)
945
+ */
946
+ function sortBySeverity(issues) {
947
+ const severityOrder = {
948
+ critical: 4,
949
+ high: 3,
950
+ medium: 2,
951
+ low: 1,
952
+ };
953
+ return [...issues].sort((a, b) => {
954
+ // First sort by severity level
955
+ const severityDiff = severityOrder[b.severity] - severityOrder[a.severity];
956
+ if (severityDiff !== 0)
957
+ return severityDiff;
958
+ // Then by CVSS score if available
959
+ if (a.cvssScore && b.cvssScore) {
960
+ return b.cvssScore - a.cvssScore;
961
+ }
962
+ return 0;
963
+ });
964
+ }
965
+ //# sourceMappingURL=severity-scoring.js.map