secure-scan 1.2.2

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 (569) hide show
  1. package/README.md +564 -0
  2. package/dist/ai/aiAnalyzer.d.ts +99 -0
  3. package/dist/ai/aiAnalyzer.d.ts.map +1 -0
  4. package/dist/ai/aiAnalyzer.js +669 -0
  5. package/dist/ai/aiAnalyzer.js.map +1 -0
  6. package/dist/ai/index.d.ts +5 -0
  7. package/dist/ai/index.d.ts.map +1 -0
  8. package/dist/ai/index.js +21 -0
  9. package/dist/ai/index.js.map +1 -0
  10. package/dist/analyzers/base/baseAnalyzer.d.ts +44 -0
  11. package/dist/analyzers/base/baseAnalyzer.d.ts.map +1 -0
  12. package/dist/analyzers/base/baseAnalyzer.js +53 -0
  13. package/dist/analyzers/base/baseAnalyzer.js.map +1 -0
  14. package/dist/analyzers/base/index.d.ts +5 -0
  15. package/dist/analyzers/base/index.d.ts.map +1 -0
  16. package/dist/analyzers/base/index.js +21 -0
  17. package/dist/analyzers/base/index.js.map +1 -0
  18. package/dist/analyzers/c-cpp/cppAnalyzer.d.ts +60 -0
  19. package/dist/analyzers/c-cpp/cppAnalyzer.d.ts.map +1 -0
  20. package/dist/analyzers/c-cpp/cppAnalyzer.js +218 -0
  21. package/dist/analyzers/c-cpp/cppAnalyzer.js.map +1 -0
  22. package/dist/analyzers/c-cpp/index.d.ts +5 -0
  23. package/dist/analyzers/c-cpp/index.d.ts.map +1 -0
  24. package/dist/analyzers/c-cpp/index.js +21 -0
  25. package/dist/analyzers/c-cpp/index.js.map +1 -0
  26. package/dist/analyzers/core/engine/index.d.ts +5 -0
  27. package/dist/analyzers/core/engine/index.d.ts.map +1 -0
  28. package/dist/analyzers/core/engine/index.js +21 -0
  29. package/dist/analyzers/core/engine/index.js.map +1 -0
  30. package/dist/analyzers/core/engine/ruleEngine.d.ts +46 -0
  31. package/dist/analyzers/core/engine/ruleEngine.d.ts.map +1 -0
  32. package/dist/analyzers/core/engine/ruleEngine.js +173 -0
  33. package/dist/analyzers/core/engine/ruleEngine.js.map +1 -0
  34. package/dist/analyzers/core/index.d.ts +8 -0
  35. package/dist/analyzers/core/index.d.ts.map +1 -0
  36. package/dist/analyzers/core/index.js +24 -0
  37. package/dist/analyzers/core/index.js.map +1 -0
  38. package/dist/analyzers/core/scanner/fileScanner.d.ts +31 -0
  39. package/dist/analyzers/core/scanner/fileScanner.d.ts.map +1 -0
  40. package/dist/analyzers/core/scanner/fileScanner.js +199 -0
  41. package/dist/analyzers/core/scanner/fileScanner.js.map +1 -0
  42. package/dist/analyzers/core/scanner/index.d.ts +5 -0
  43. package/dist/analyzers/core/scanner/index.d.ts.map +1 -0
  44. package/dist/analyzers/core/scanner/index.js +21 -0
  45. package/dist/analyzers/core/scanner/index.js.map +1 -0
  46. package/dist/analyzers/core/scoring/index.d.ts +5 -0
  47. package/dist/analyzers/core/scoring/index.d.ts.map +1 -0
  48. package/dist/analyzers/core/scoring/index.js +21 -0
  49. package/dist/analyzers/core/scoring/index.js.map +1 -0
  50. package/dist/analyzers/core/scoring/riskScoring.d.ts +49 -0
  51. package/dist/analyzers/core/scoring/riskScoring.d.ts.map +1 -0
  52. package/dist/analyzers/core/scoring/riskScoring.js +180 -0
  53. package/dist/analyzers/core/scoring/riskScoring.js.map +1 -0
  54. package/dist/analyzers/core/securityScanner.d.ts +47 -0
  55. package/dist/analyzers/core/securityScanner.d.ts.map +1 -0
  56. package/dist/analyzers/core/securityScanner.js +298 -0
  57. package/dist/analyzers/core/securityScanner.js.map +1 -0
  58. package/dist/analyzers/csharp/csharpAnalyzer.d.ts +64 -0
  59. package/dist/analyzers/csharp/csharpAnalyzer.d.ts.map +1 -0
  60. package/dist/analyzers/csharp/csharpAnalyzer.js +232 -0
  61. package/dist/analyzers/csharp/csharpAnalyzer.js.map +1 -0
  62. package/dist/analyzers/csharp/index.d.ts +5 -0
  63. package/dist/analyzers/csharp/index.d.ts.map +1 -0
  64. package/dist/analyzers/csharp/index.js +21 -0
  65. package/dist/analyzers/csharp/index.js.map +1 -0
  66. package/dist/analyzers/iac/iacAnalyzer.d.ts +36 -0
  67. package/dist/analyzers/iac/iacAnalyzer.d.ts.map +1 -0
  68. package/dist/analyzers/iac/iacAnalyzer.js +182 -0
  69. package/dist/analyzers/iac/iacAnalyzer.js.map +1 -0
  70. package/dist/analyzers/iac/index.d.ts +5 -0
  71. package/dist/analyzers/iac/index.d.ts.map +1 -0
  72. package/dist/analyzers/iac/index.js +21 -0
  73. package/dist/analyzers/iac/index.js.map +1 -0
  74. package/dist/analyzers/index.d.ts +30 -0
  75. package/dist/analyzers/index.d.ts.map +1 -0
  76. package/dist/analyzers/index.js +80 -0
  77. package/dist/analyzers/index.js.map +1 -0
  78. package/dist/analyzers/java/index.d.ts +5 -0
  79. package/dist/analyzers/java/index.d.ts.map +1 -0
  80. package/dist/analyzers/java/index.js +21 -0
  81. package/dist/analyzers/java/index.js.map +1 -0
  82. package/dist/analyzers/java/javaAnalyzer.d.ts +64 -0
  83. package/dist/analyzers/java/javaAnalyzer.d.ts.map +1 -0
  84. package/dist/analyzers/java/javaAnalyzer.js +224 -0
  85. package/dist/analyzers/java/javaAnalyzer.js.map +1 -0
  86. package/dist/analyzers/javascript/astUtils.d.ts +170 -0
  87. package/dist/analyzers/javascript/astUtils.d.ts.map +1 -0
  88. package/dist/analyzers/javascript/astUtils.js +700 -0
  89. package/dist/analyzers/javascript/astUtils.js.map +1 -0
  90. package/dist/analyzers/javascript/index.d.ts +18 -0
  91. package/dist/analyzers/javascript/index.d.ts.map +1 -0
  92. package/dist/analyzers/javascript/index.js +50 -0
  93. package/dist/analyzers/javascript/index.js.map +1 -0
  94. package/dist/analyzers/javascript/javascriptAnalyzer.d.ts +111 -0
  95. package/dist/analyzers/javascript/javascriptAnalyzer.d.ts.map +1 -0
  96. package/dist/analyzers/javascript/javascriptAnalyzer.js +860 -0
  97. package/dist/analyzers/javascript/javascriptAnalyzer.js.map +1 -0
  98. package/dist/analyzers/javascript/malwareDetector.d.ts +102 -0
  99. package/dist/analyzers/javascript/malwareDetector.d.ts.map +1 -0
  100. package/dist/analyzers/javascript/malwareDetector.js +616 -0
  101. package/dist/analyzers/javascript/malwareDetector.js.map +1 -0
  102. package/dist/analyzers/javascript/packageJsonAnalyzer.d.ts +87 -0
  103. package/dist/analyzers/javascript/packageJsonAnalyzer.d.ts.map +1 -0
  104. package/dist/analyzers/javascript/packageJsonAnalyzer.js +553 -0
  105. package/dist/analyzers/javascript/packageJsonAnalyzer.js.map +1 -0
  106. package/dist/analyzers/javascript/taintAnalyzer.d.ts +120 -0
  107. package/dist/analyzers/javascript/taintAnalyzer.d.ts.map +1 -0
  108. package/dist/analyzers/javascript/taintAnalyzer.js +526 -0
  109. package/dist/analyzers/javascript/taintAnalyzer.js.map +1 -0
  110. package/dist/analyzers/php/index.d.ts +5 -0
  111. package/dist/analyzers/php/index.d.ts.map +1 -0
  112. package/dist/analyzers/php/index.js +21 -0
  113. package/dist/analyzers/php/index.js.map +1 -0
  114. package/dist/analyzers/php/phpAnalyzer.d.ts +56 -0
  115. package/dist/analyzers/php/phpAnalyzer.d.ts.map +1 -0
  116. package/dist/analyzers/php/phpAnalyzer.js +202 -0
  117. package/dist/analyzers/php/phpAnalyzer.js.map +1 -0
  118. package/dist/analyzers/python/index.d.ts +5 -0
  119. package/dist/analyzers/python/index.d.ts.map +1 -0
  120. package/dist/analyzers/python/index.js +21 -0
  121. package/dist/analyzers/python/index.js.map +1 -0
  122. package/dist/analyzers/python/pythonAnalyzer.d.ts +64 -0
  123. package/dist/analyzers/python/pythonAnalyzer.d.ts.map +1 -0
  124. package/dist/analyzers/python/pythonAnalyzer.js +226 -0
  125. package/dist/analyzers/python/pythonAnalyzer.js.map +1 -0
  126. package/dist/cli/index.d.ts +7 -0
  127. package/dist/cli/index.d.ts.map +1 -0
  128. package/dist/cli/index.js +281 -0
  129. package/dist/cli/index.js.map +1 -0
  130. package/dist/core/engine/index.d.ts +5 -0
  131. package/dist/core/engine/index.d.ts.map +1 -0
  132. package/dist/core/engine/index.js +21 -0
  133. package/dist/core/engine/index.js.map +1 -0
  134. package/dist/core/engine/ruleEngine.d.ts +46 -0
  135. package/dist/core/engine/ruleEngine.d.ts.map +1 -0
  136. package/dist/core/engine/ruleEngine.js +173 -0
  137. package/dist/core/engine/ruleEngine.js.map +1 -0
  138. package/dist/core/index.d.ts +8 -0
  139. package/dist/core/index.d.ts.map +1 -0
  140. package/dist/core/index.js +24 -0
  141. package/dist/core/index.js.map +1 -0
  142. package/dist/core/scanner/fileScanner.d.ts +31 -0
  143. package/dist/core/scanner/fileScanner.d.ts.map +1 -0
  144. package/dist/core/scanner/fileScanner.js +199 -0
  145. package/dist/core/scanner/fileScanner.js.map +1 -0
  146. package/dist/core/scanner/index.d.ts +5 -0
  147. package/dist/core/scanner/index.d.ts.map +1 -0
  148. package/dist/core/scanner/index.js +21 -0
  149. package/dist/core/scanner/index.js.map +1 -0
  150. package/dist/core/scoring/index.d.ts +5 -0
  151. package/dist/core/scoring/index.d.ts.map +1 -0
  152. package/dist/core/scoring/index.js +21 -0
  153. package/dist/core/scoring/index.js.map +1 -0
  154. package/dist/core/scoring/riskScoring.d.ts +49 -0
  155. package/dist/core/scoring/riskScoring.d.ts.map +1 -0
  156. package/dist/core/scoring/riskScoring.js +180 -0
  157. package/dist/core/scoring/riskScoring.js.map +1 -0
  158. package/dist/core/securityScanner.d.ts +47 -0
  159. package/dist/core/securityScanner.d.ts.map +1 -0
  160. package/dist/core/securityScanner.js +298 -0
  161. package/dist/core/securityScanner.js.map +1 -0
  162. package/dist/dependencies/aiDependencyAnalyzer.d.ts +96 -0
  163. package/dist/dependencies/aiDependencyAnalyzer.d.ts.map +1 -0
  164. package/dist/dependencies/aiDependencyAnalyzer.js +435 -0
  165. package/dist/dependencies/aiDependencyAnalyzer.js.map +1 -0
  166. package/dist/dependencies/database/cveDatabase.d.ts +32 -0
  167. package/dist/dependencies/database/cveDatabase.d.ts.map +1 -0
  168. package/dist/dependencies/database/cveDatabase.js +393 -0
  169. package/dist/dependencies/database/cveDatabase.js.map +1 -0
  170. package/dist/dependencies/database/index.d.ts +6 -0
  171. package/dist/dependencies/database/index.d.ts.map +1 -0
  172. package/dist/dependencies/database/index.js +22 -0
  173. package/dist/dependencies/database/index.js.map +1 -0
  174. package/dist/dependencies/database/maliciousPackages.d.ts +43 -0
  175. package/dist/dependencies/database/maliciousPackages.d.ts.map +1 -0
  176. package/dist/dependencies/database/maliciousPackages.js +279 -0
  177. package/dist/dependencies/database/maliciousPackages.js.map +1 -0
  178. package/dist/dependencies/dependencyAnalyzer.d.ts +74 -0
  179. package/dist/dependencies/dependencyAnalyzer.d.ts.map +1 -0
  180. package/dist/dependencies/dependencyAnalyzer.js +349 -0
  181. package/dist/dependencies/dependencyAnalyzer.js.map +1 -0
  182. package/dist/dependencies/detectors/index.d.ts +7 -0
  183. package/dist/dependencies/detectors/index.d.ts.map +1 -0
  184. package/dist/dependencies/detectors/index.js +28 -0
  185. package/dist/dependencies/detectors/index.js.map +1 -0
  186. package/dist/dependencies/detectors/securityStandards.d.ts +15 -0
  187. package/dist/dependencies/detectors/securityStandards.d.ts.map +1 -0
  188. package/dist/dependencies/detectors/securityStandards.js +178 -0
  189. package/dist/dependencies/detectors/securityStandards.js.map +1 -0
  190. package/dist/dependencies/detectors/vulnerabilityDetector.d.ts +53 -0
  191. package/dist/dependencies/detectors/vulnerabilityDetector.d.ts.map +1 -0
  192. package/dist/dependencies/detectors/vulnerabilityDetector.js +289 -0
  193. package/dist/dependencies/detectors/vulnerabilityDetector.js.map +1 -0
  194. package/dist/dependencies/index.d.ts +14 -0
  195. package/dist/dependencies/index.d.ts.map +1 -0
  196. package/dist/dependencies/index.js +43 -0
  197. package/dist/dependencies/index.js.map +1 -0
  198. package/dist/dependencies/installed/index.d.ts +8 -0
  199. package/dist/dependencies/installed/index.d.ts.map +1 -0
  200. package/dist/dependencies/installed/index.js +24 -0
  201. package/dist/dependencies/installed/index.js.map +1 -0
  202. package/dist/dependencies/installed/installedScanner.d.ts +91 -0
  203. package/dist/dependencies/installed/installedScanner.d.ts.map +1 -0
  204. package/dist/dependencies/installed/installedScanner.js +766 -0
  205. package/dist/dependencies/installed/installedScanner.js.map +1 -0
  206. package/dist/dependencies/installed/malwarePatterns.d.ts +32 -0
  207. package/dist/dependencies/installed/malwarePatterns.d.ts.map +1 -0
  208. package/dist/dependencies/installed/malwarePatterns.js +480 -0
  209. package/dist/dependencies/installed/malwarePatterns.js.map +1 -0
  210. package/dist/dependencies/installed/types.d.ts +274 -0
  211. package/dist/dependencies/installed/types.d.ts.map +1 -0
  212. package/dist/dependencies/installed/types.js +7 -0
  213. package/dist/dependencies/installed/types.js.map +1 -0
  214. package/dist/dependencies/parsers/base/baseParser.d.ts +44 -0
  215. package/dist/dependencies/parsers/base/baseParser.d.ts.map +1 -0
  216. package/dist/dependencies/parsers/base/baseParser.js +80 -0
  217. package/dist/dependencies/parsers/base/baseParser.js.map +1 -0
  218. package/dist/dependencies/parsers/base/index.d.ts +6 -0
  219. package/dist/dependencies/parsers/base/index.d.ts.map +1 -0
  220. package/dist/dependencies/parsers/base/index.js +27 -0
  221. package/dist/dependencies/parsers/base/index.js.map +1 -0
  222. package/dist/dependencies/parsers/cpp/cppParser.d.ts +36 -0
  223. package/dist/dependencies/parsers/cpp/cppParser.d.ts.map +1 -0
  224. package/dist/dependencies/parsers/cpp/cppParser.js +196 -0
  225. package/dist/dependencies/parsers/cpp/cppParser.js.map +1 -0
  226. package/dist/dependencies/parsers/cpp/index.d.ts +6 -0
  227. package/dist/dependencies/parsers/cpp/index.d.ts.map +1 -0
  228. package/dist/dependencies/parsers/cpp/index.js +27 -0
  229. package/dist/dependencies/parsers/cpp/index.js.map +1 -0
  230. package/dist/dependencies/parsers/csharp/csharpParser.d.ts +32 -0
  231. package/dist/dependencies/parsers/csharp/csharpParser.d.ts.map +1 -0
  232. package/dist/dependencies/parsers/csharp/csharpParser.js +125 -0
  233. package/dist/dependencies/parsers/csharp/csharpParser.js.map +1 -0
  234. package/dist/dependencies/parsers/csharp/index.d.ts +6 -0
  235. package/dist/dependencies/parsers/csharp/index.d.ts.map +1 -0
  236. package/dist/dependencies/parsers/csharp/index.js +27 -0
  237. package/dist/dependencies/parsers/csharp/index.js.map +1 -0
  238. package/dist/dependencies/parsers/index.d.ts +24 -0
  239. package/dist/dependencies/parsers/index.d.ts.map +1 -0
  240. package/dist/dependencies/parsers/index.js +69 -0
  241. package/dist/dependencies/parsers/index.js.map +1 -0
  242. package/dist/dependencies/parsers/java/index.d.ts +6 -0
  243. package/dist/dependencies/parsers/java/index.d.ts.map +1 -0
  244. package/dist/dependencies/parsers/java/index.js +27 -0
  245. package/dist/dependencies/parsers/java/index.js.map +1 -0
  246. package/dist/dependencies/parsers/java/javaParser.d.ts +32 -0
  247. package/dist/dependencies/parsers/java/javaParser.d.ts.map +1 -0
  248. package/dist/dependencies/parsers/java/javaParser.js +168 -0
  249. package/dist/dependencies/parsers/java/javaParser.js.map +1 -0
  250. package/dist/dependencies/parsers/javascript/index.d.ts +6 -0
  251. package/dist/dependencies/parsers/javascript/index.d.ts.map +1 -0
  252. package/dist/dependencies/parsers/javascript/index.js +27 -0
  253. package/dist/dependencies/parsers/javascript/index.js.map +1 -0
  254. package/dist/dependencies/parsers/javascript/javascriptParser.d.ts +55 -0
  255. package/dist/dependencies/parsers/javascript/javascriptParser.d.ts.map +1 -0
  256. package/dist/dependencies/parsers/javascript/javascriptParser.js +266 -0
  257. package/dist/dependencies/parsers/javascript/javascriptParser.js.map +1 -0
  258. package/dist/dependencies/parsers/php/index.d.ts +6 -0
  259. package/dist/dependencies/parsers/php/index.d.ts.map +1 -0
  260. package/dist/dependencies/parsers/php/index.js +27 -0
  261. package/dist/dependencies/parsers/php/index.js.map +1 -0
  262. package/dist/dependencies/parsers/php/phpParser.d.ts +35 -0
  263. package/dist/dependencies/parsers/php/phpParser.d.ts.map +1 -0
  264. package/dist/dependencies/parsers/php/phpParser.js +162 -0
  265. package/dist/dependencies/parsers/php/phpParser.js.map +1 -0
  266. package/dist/dependencies/parsers/python/index.d.ts +6 -0
  267. package/dist/dependencies/parsers/python/index.d.ts.map +1 -0
  268. package/dist/dependencies/parsers/python/index.js +27 -0
  269. package/dist/dependencies/parsers/python/index.js.map +1 -0
  270. package/dist/dependencies/parsers/python/pythonParser.d.ts +60 -0
  271. package/dist/dependencies/parsers/python/pythonParser.d.ts.map +1 -0
  272. package/dist/dependencies/parsers/python/pythonParser.js +336 -0
  273. package/dist/dependencies/parsers/python/pythonParser.js.map +1 -0
  274. package/dist/dependencies/types.d.ts +280 -0
  275. package/dist/dependencies/types.d.ts.map +1 -0
  276. package/dist/dependencies/types.js +59 -0
  277. package/dist/dependencies/types.js.map +1 -0
  278. package/dist/i18n/index.d.ts +2 -0
  279. package/dist/i18n/index.d.ts.map +1 -0
  280. package/dist/i18n/index.js +18 -0
  281. package/dist/i18n/index.js.map +1 -0
  282. package/dist/i18n/translations.d.ts +55 -0
  283. package/dist/i18n/translations.d.ts.map +1 -0
  284. package/dist/i18n/translations.js +119 -0
  285. package/dist/i18n/translations.js.map +1 -0
  286. package/dist/index.d.ts +14 -0
  287. package/dist/index.d.ts.map +1 -0
  288. package/dist/index.js +36 -0
  289. package/dist/index.js.map +1 -0
  290. package/dist/reports/dependencyReportGenerator.d.ts +20 -0
  291. package/dist/reports/dependencyReportGenerator.d.ts.map +1 -0
  292. package/dist/reports/dependencyReportGenerator.js +690 -0
  293. package/dist/reports/dependencyReportGenerator.js.map +1 -0
  294. package/dist/reports/htmlReportGenerator.d.ts +43 -0
  295. package/dist/reports/htmlReportGenerator.d.ts.map +1 -0
  296. package/dist/reports/htmlReportGenerator.js +793 -0
  297. package/dist/reports/htmlReportGenerator.js.map +1 -0
  298. package/dist/reports/index.d.ts +7 -0
  299. package/dist/reports/index.d.ts.map +1 -0
  300. package/dist/reports/index.js +23 -0
  301. package/dist/reports/index.js.map +1 -0
  302. package/dist/reports/installedDepsReportGenerator.d.ts +14 -0
  303. package/dist/reports/installedDepsReportGenerator.d.ts.map +1 -0
  304. package/dist/reports/installedDepsReportGenerator.js +872 -0
  305. package/dist/reports/installedDepsReportGenerator.js.map +1 -0
  306. package/dist/rules/index.d.ts +31 -0
  307. package/dist/rules/index.d.ts.map +1 -0
  308. package/dist/rules/index.js +95 -0
  309. package/dist/rules/index.js.map +1 -0
  310. package/dist/rules/malware/categories/backdoors.d.ts +12 -0
  311. package/dist/rules/malware/categories/backdoors.d.ts.map +1 -0
  312. package/dist/rules/malware/categories/backdoors.js +163 -0
  313. package/dist/rules/malware/categories/backdoors.js.map +1 -0
  314. package/dist/rules/malware/categories/cryptominers.d.ts +13 -0
  315. package/dist/rules/malware/categories/cryptominers.d.ts.map +1 -0
  316. package/dist/rules/malware/categories/cryptominers.js +415 -0
  317. package/dist/rules/malware/categories/cryptominers.js.map +1 -0
  318. package/dist/rules/malware/categories/exfiltration.d.ts +20 -0
  319. package/dist/rules/malware/categories/exfiltration.d.ts.map +1 -0
  320. package/dist/rules/malware/categories/exfiltration.js +658 -0
  321. package/dist/rules/malware/categories/exfiltration.js.map +1 -0
  322. package/dist/rules/malware/categories/keyloggers.d.ts +19 -0
  323. package/dist/rules/malware/categories/keyloggers.d.ts.map +1 -0
  324. package/dist/rules/malware/categories/keyloggers.js +763 -0
  325. package/dist/rules/malware/categories/keyloggers.js.map +1 -0
  326. package/dist/rules/malware/categories/loaders.d.ts +20 -0
  327. package/dist/rules/malware/categories/loaders.d.ts.map +1 -0
  328. package/dist/rules/malware/categories/loaders.js +702 -0
  329. package/dist/rules/malware/categories/loaders.js.map +1 -0
  330. package/dist/rules/malware/categories/network.d.ts +19 -0
  331. package/dist/rules/malware/categories/network.d.ts.map +1 -0
  332. package/dist/rules/malware/categories/network.js +622 -0
  333. package/dist/rules/malware/categories/network.js.map +1 -0
  334. package/dist/rules/malware/categories/obfuscation.d.ts +22 -0
  335. package/dist/rules/malware/categories/obfuscation.d.ts.map +1 -0
  336. package/dist/rules/malware/categories/obfuscation.js +766 -0
  337. package/dist/rules/malware/categories/obfuscation.js.map +1 -0
  338. package/dist/rules/malware/constants/index.d.ts +281 -0
  339. package/dist/rules/malware/constants/index.d.ts.map +1 -0
  340. package/dist/rules/malware/constants/index.js +327 -0
  341. package/dist/rules/malware/constants/index.js.map +1 -0
  342. package/dist/rules/malware/engine/index.d.ts +178 -0
  343. package/dist/rules/malware/engine/index.d.ts.map +1 -0
  344. package/dist/rules/malware/engine/index.js +552 -0
  345. package/dist/rules/malware/engine/index.js.map +1 -0
  346. package/dist/rules/malware/index.d.ts +205 -0
  347. package/dist/rules/malware/index.d.ts.map +1 -0
  348. package/dist/rules/malware/index.js +837 -0
  349. package/dist/rules/malware/index.js.map +1 -0
  350. package/dist/rules/malware/scoring/index.d.ts +84 -0
  351. package/dist/rules/malware/scoring/index.d.ts.map +1 -0
  352. package/dist/rules/malware/scoring/index.js +441 -0
  353. package/dist/rules/malware/scoring/index.js.map +1 -0
  354. package/dist/rules/malware/types/index.d.ts +616 -0
  355. package/dist/rules/malware/types/index.d.ts.map +1 -0
  356. package/dist/rules/malware/types/index.js +155 -0
  357. package/dist/rules/malware/types/index.js.map +1 -0
  358. package/dist/rules/malware/utils/index.d.ts +117 -0
  359. package/dist/rules/malware/utils/index.d.ts.map +1 -0
  360. package/dist/rules/malware/utils/index.js +514 -0
  361. package/dist/rules/malware/utils/index.js.map +1 -0
  362. package/dist/rules/standards.d.ts +26 -0
  363. package/dist/rules/standards.d.ts.map +1 -0
  364. package/dist/rules/standards.js +352 -0
  365. package/dist/rules/standards.js.map +1 -0
  366. package/dist/rules/vulnerabilities/constants/index.d.ts +835 -0
  367. package/dist/rules/vulnerabilities/constants/index.d.ts.map +1 -0
  368. package/dist/rules/vulnerabilities/constants/index.js +544 -0
  369. package/dist/rules/vulnerabilities/constants/index.js.map +1 -0
  370. package/dist/rules/vulnerabilities/engine/index.d.ts +145 -0
  371. package/dist/rules/vulnerabilities/engine/index.d.ts.map +1 -0
  372. package/dist/rules/vulnerabilities/engine/index.js +581 -0
  373. package/dist/rules/vulnerabilities/engine/index.js.map +1 -0
  374. package/dist/rules/vulnerabilities/index.d.ts +148 -0
  375. package/dist/rules/vulnerabilities/index.d.ts.map +1 -0
  376. package/dist/rules/vulnerabilities/index.js +252 -0
  377. package/dist/rules/vulnerabilities/index.js.map +1 -0
  378. package/dist/rules/vulnerabilities/rules/authentication.d.ts +8 -0
  379. package/dist/rules/vulnerabilities/rules/authentication.d.ts.map +1 -0
  380. package/dist/rules/vulnerabilities/rules/authentication.js +419 -0
  381. package/dist/rules/vulnerabilities/rules/authentication.js.map +1 -0
  382. package/dist/rules/vulnerabilities/rules/commandInjection.d.ts +8 -0
  383. package/dist/rules/vulnerabilities/rules/commandInjection.d.ts.map +1 -0
  384. package/dist/rules/vulnerabilities/rules/commandInjection.js +300 -0
  385. package/dist/rules/vulnerabilities/rules/commandInjection.js.map +1 -0
  386. package/dist/rules/vulnerabilities/rules/csrf.d.ts +8 -0
  387. package/dist/rules/vulnerabilities/rules/csrf.d.ts.map +1 -0
  388. package/dist/rules/vulnerabilities/rules/csrf.js +261 -0
  389. package/dist/rules/vulnerabilities/rules/csrf.js.map +1 -0
  390. package/dist/rules/vulnerabilities/rules/deserialization.d.ts +8 -0
  391. package/dist/rules/vulnerabilities/rules/deserialization.d.ts.map +1 -0
  392. package/dist/rules/vulnerabilities/rules/deserialization.js +336 -0
  393. package/dist/rules/vulnerabilities/rules/deserialization.js.map +1 -0
  394. package/dist/rules/vulnerabilities/rules/fileUpload.d.ts +8 -0
  395. package/dist/rules/vulnerabilities/rules/fileUpload.d.ts.map +1 -0
  396. package/dist/rules/vulnerabilities/rules/fileUpload.js +325 -0
  397. package/dist/rules/vulnerabilities/rules/fileUpload.js.map +1 -0
  398. package/dist/rules/vulnerabilities/rules/hardcodedSecrets.d.ts +8 -0
  399. package/dist/rules/vulnerabilities/rules/hardcodedSecrets.d.ts.map +1 -0
  400. package/dist/rules/vulnerabilities/rules/hardcodedSecrets.js +446 -0
  401. package/dist/rules/vulnerabilities/rules/hardcodedSecrets.js.map +1 -0
  402. package/dist/rules/vulnerabilities/rules/index.d.ts +17 -0
  403. package/dist/rules/vulnerabilities/rules/index.d.ts.map +1 -0
  404. package/dist/rules/vulnerabilities/rules/index.js +47 -0
  405. package/dist/rules/vulnerabilities/rules/index.js.map +1 -0
  406. package/dist/rules/vulnerabilities/rules/pathTraversal.d.ts +8 -0
  407. package/dist/rules/vulnerabilities/rules/pathTraversal.d.ts.map +1 -0
  408. package/dist/rules/vulnerabilities/rules/pathTraversal.js +351 -0
  409. package/dist/rules/vulnerabilities/rules/pathTraversal.js.map +1 -0
  410. package/dist/rules/vulnerabilities/rules/prototypePollution.d.ts +8 -0
  411. package/dist/rules/vulnerabilities/rules/prototypePollution.d.ts.map +1 -0
  412. package/dist/rules/vulnerabilities/rules/prototypePollution.js +272 -0
  413. package/dist/rules/vulnerabilities/rules/prototypePollution.js.map +1 -0
  414. package/dist/rules/vulnerabilities/rules/securityMisconfiguration.d.ts +8 -0
  415. package/dist/rules/vulnerabilities/rules/securityMisconfiguration.d.ts.map +1 -0
  416. package/dist/rules/vulnerabilities/rules/securityMisconfiguration.js +438 -0
  417. package/dist/rules/vulnerabilities/rules/securityMisconfiguration.js.map +1 -0
  418. package/dist/rules/vulnerabilities/rules/sqlInjection.d.ts +12 -0
  419. package/dist/rules/vulnerabilities/rules/sqlInjection.d.ts.map +1 -0
  420. package/dist/rules/vulnerabilities/rules/sqlInjection.js +636 -0
  421. package/dist/rules/vulnerabilities/rules/sqlInjection.js.map +1 -0
  422. package/dist/rules/vulnerabilities/rules/ssrf.d.ts +8 -0
  423. package/dist/rules/vulnerabilities/rules/ssrf.d.ts.map +1 -0
  424. package/dist/rules/vulnerabilities/rules/ssrf.js +401 -0
  425. package/dist/rules/vulnerabilities/rules/ssrf.js.map +1 -0
  426. package/dist/rules/vulnerabilities/rules/xss.d.ts +11 -0
  427. package/dist/rules/vulnerabilities/rules/xss.d.ts.map +1 -0
  428. package/dist/rules/vulnerabilities/rules/xss.js +724 -0
  429. package/dist/rules/vulnerabilities/rules/xss.js.map +1 -0
  430. package/dist/rules/vulnerabilities/scoring/index.d.ts +80 -0
  431. package/dist/rules/vulnerabilities/scoring/index.d.ts.map +1 -0
  432. package/dist/rules/vulnerabilities/scoring/index.js +414 -0
  433. package/dist/rules/vulnerabilities/scoring/index.js.map +1 -0
  434. package/dist/rules/vulnerabilities/types/index.d.ts +830 -0
  435. package/dist/rules/vulnerabilities/types/index.d.ts.map +1 -0
  436. package/dist/rules/vulnerabilities/types/index.js +164 -0
  437. package/dist/rules/vulnerabilities/types/index.js.map +1 -0
  438. package/dist/rules/vulnerabilities/utils/index.d.ts +206 -0
  439. package/dist/rules/vulnerabilities/utils/index.d.ts.map +1 -0
  440. package/dist/rules/vulnerabilities/utils/index.js +615 -0
  441. package/dist/rules/vulnerabilities/utils/index.js.map +1 -0
  442. package/dist/types/index.d.ts +359 -0
  443. package/dist/types/index.d.ts.map +1 -0
  444. package/dist/types/index.js +61 -0
  445. package/dist/types/index.js.map +1 -0
  446. package/dist/utils/index.d.ts +82 -0
  447. package/dist/utils/index.d.ts.map +1 -0
  448. package/dist/utils/index.js +326 -0
  449. package/dist/utils/index.js.map +1 -0
  450. package/dist/utils/logger.d.ts +40 -0
  451. package/dist/utils/logger.d.ts.map +1 -0
  452. package/dist/utils/logger.js +139 -0
  453. package/dist/utils/logger.js.map +1 -0
  454. package/docs/ARCHITECTURE.md +320 -0
  455. package/docs/V1.2.1-IA_Performances.md +116 -0
  456. package/docs/images/WIN_Defender.png +0 -0
  457. package/package.json +68 -0
  458. package/secure-scan.config.json +134 -0
  459. package/secure-scan.sln +29 -0
  460. package/src/ai/aiAnalyzer.ts +714 -0
  461. package/src/ai/index.ts +5 -0
  462. package/src/analyzers/base/baseAnalyzer.ts +66 -0
  463. package/src/analyzers/base/index.ts +5 -0
  464. package/src/analyzers/c-cpp/cppAnalyzer.ts +308 -0
  465. package/src/analyzers/c-cpp/index.ts +5 -0
  466. package/src/analyzers/core/engine/index.ts +5 -0
  467. package/src/analyzers/core/engine/ruleEngine.ts +221 -0
  468. package/src/analyzers/core/index.ts +8 -0
  469. package/src/analyzers/core/scanner/fileScanner.ts +204 -0
  470. package/src/analyzers/core/scanner/index.ts +5 -0
  471. package/src/analyzers/core/scoring/index.ts +5 -0
  472. package/src/analyzers/core/scoring/riskScoring.ts +198 -0
  473. package/src/analyzers/core/securityScanner.ts +321 -0
  474. package/src/analyzers/csharp/csharpAnalyzer.ts +328 -0
  475. package/src/analyzers/csharp/index.ts +5 -0
  476. package/src/analyzers/iac/iacAnalyzer.ts +318 -0
  477. package/src/analyzers/iac/index.ts +5 -0
  478. package/src/analyzers/index.ts +67 -0
  479. package/src/analyzers/java/index.ts +5 -0
  480. package/src/analyzers/java/javaAnalyzer.ts +320 -0
  481. package/src/analyzers/javascript/PROMPT_JS_ANALYZER.md +267 -0
  482. package/src/analyzers/javascript/astUtils.ts +789 -0
  483. package/src/analyzers/javascript/index.ts +50 -0
  484. package/src/analyzers/javascript/javascriptAnalyzer.ts +984 -0
  485. package/src/analyzers/javascript/malwareDetector.ts +697 -0
  486. package/src/analyzers/javascript/packageJsonAnalyzer.ts +626 -0
  487. package/src/analyzers/javascript/taintAnalyzer.ts +630 -0
  488. package/src/analyzers/php/index.ts +5 -0
  489. package/src/analyzers/php/phpAnalyzer.ts +280 -0
  490. package/src/analyzers/python/index.ts +5 -0
  491. package/src/analyzers/python/pythonAnalyzer.ts +319 -0
  492. package/src/cli/index.ts +276 -0
  493. package/src/dependencies/aiDependencyAnalyzer.ts +496 -0
  494. package/src/dependencies/database/cveDatabase.ts +426 -0
  495. package/src/dependencies/database/index.ts +6 -0
  496. package/src/dependencies/database/maliciousPackages.ts +286 -0
  497. package/src/dependencies/dependencyAnalyzer.ts +394 -0
  498. package/src/dependencies/detectors/index.ts +7 -0
  499. package/src/dependencies/detectors/securityStandards.ts +200 -0
  500. package/src/dependencies/detectors/vulnerabilityDetector.ts +343 -0
  501. package/src/dependencies/index.ts +27 -0
  502. package/src/dependencies/installed/index.ts +8 -0
  503. package/src/dependencies/installed/installedScanner.ts +821 -0
  504. package/src/dependencies/installed/malwarePatterns.ts +492 -0
  505. package/src/dependencies/installed/types.ts +287 -0
  506. package/src/dependencies/parsers/base/baseParser.ts +108 -0
  507. package/src/dependencies/parsers/base/index.ts +6 -0
  508. package/src/dependencies/parsers/cpp/cppParser.ts +245 -0
  509. package/src/dependencies/parsers/cpp/index.ts +6 -0
  510. package/src/dependencies/parsers/csharp/csharpParser.ts +151 -0
  511. package/src/dependencies/parsers/csharp/index.ts +6 -0
  512. package/src/dependencies/parsers/index.ts +56 -0
  513. package/src/dependencies/parsers/java/index.ts +6 -0
  514. package/src/dependencies/parsers/java/javaParser.ts +203 -0
  515. package/src/dependencies/parsers/javascript/index.ts +6 -0
  516. package/src/dependencies/parsers/javascript/javascriptParser.ts +362 -0
  517. package/src/dependencies/parsers/php/index.ts +6 -0
  518. package/src/dependencies/parsers/php/phpParser.ts +208 -0
  519. package/src/dependencies/parsers/python/index.ts +6 -0
  520. package/src/dependencies/parsers/python/pythonParser.ts +437 -0
  521. package/src/dependencies/types.ts +330 -0
  522. package/src/i18n/index.ts +1 -0
  523. package/src/i18n/translations.ts +194 -0
  524. package/src/index.ts +16 -0
  525. package/src/reports/dependencyReportGenerator.ts +717 -0
  526. package/src/reports/htmlReportGenerator.ts +781 -0
  527. package/src/reports/index.ts +7 -0
  528. package/src/reports/installedDepsReportGenerator.ts +899 -0
  529. package/src/rules/index.ts +58 -0
  530. package/src/rules/malware/INFO.md +287 -0
  531. package/src/rules/malware/categories/backdoors.ts +174 -0
  532. package/src/rules/malware/categories/cryptominers.ts +434 -0
  533. package/src/rules/malware/categories/exfiltration.ts +677 -0
  534. package/src/rules/malware/categories/keyloggers.ts +780 -0
  535. package/src/rules/malware/categories/loaders.ts +721 -0
  536. package/src/rules/malware/categories/network.ts +639 -0
  537. package/src/rules/malware/categories/obfuscation.ts +788 -0
  538. package/src/rules/malware/constants/index.ts +358 -0
  539. package/src/rules/malware/engine/index.ts +758 -0
  540. package/src/rules/malware/index.ts +928 -0
  541. package/src/rules/malware/scoring/index.ts +549 -0
  542. package/src/rules/malware/types/index.ts +752 -0
  543. package/src/rules/malware/utils/index.ts +643 -0
  544. package/src/rules/standards.ts +372 -0
  545. package/src/rules/vulnerabilities/PROMPT_VULNERABILITIES.md +226 -0
  546. package/src/rules/vulnerabilities/constants/index.ts +625 -0
  547. package/src/rules/vulnerabilities/engine/index.ts +831 -0
  548. package/src/rules/vulnerabilities/index.ts +312 -0
  549. package/src/rules/vulnerabilities/rules/authentication.ts +426 -0
  550. package/src/rules/vulnerabilities/rules/commandInjection.ts +307 -0
  551. package/src/rules/vulnerabilities/rules/csrf.ts +268 -0
  552. package/src/rules/vulnerabilities/rules/deserialization.ts +343 -0
  553. package/src/rules/vulnerabilities/rules/fileUpload.ts +332 -0
  554. package/src/rules/vulnerabilities/rules/hardcodedSecrets.ts +453 -0
  555. package/src/rules/vulnerabilities/rules/index.ts +17 -0
  556. package/src/rules/vulnerabilities/rules/pathTraversal.ts +358 -0
  557. package/src/rules/vulnerabilities/rules/prototypePollution.ts +279 -0
  558. package/src/rules/vulnerabilities/rules/securityMisconfiguration.ts +445 -0
  559. package/src/rules/vulnerabilities/rules/sqlInjection.ts +669 -0
  560. package/src/rules/vulnerabilities/rules/ssrf.ts +408 -0
  561. package/src/rules/vulnerabilities/rules/xss.ts +753 -0
  562. package/src/rules/vulnerabilities/scoring/index.ts +543 -0
  563. package/src/rules/vulnerabilities/types/index.ts +1004 -0
  564. package/src/rules/vulnerabilities/utils/index.ts +709 -0
  565. package/src/types/index.ts +391 -0
  566. package/src/utils/index.ts +306 -0
  567. package/src/utils/logger.ts +150 -0
  568. package/test-installed-scanner.ts +136 -0
  569. package/tsconfig.json +30 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"xss.js","sourceRoot":"","sources":["../../../../src/rules/vulnerabilities/rules/xss.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,80 @@
1
+ /**
2
+ * @fileoverview Vulnerability Score Calculator
3
+ * @module rules/vulnerabilities/scoring
4
+ *
5
+ * Dynamic scoring system for vulnerability detection that calculates risk scores
6
+ * based on multiple factors including pattern matches, taint analysis,
7
+ * exploitability, impact, and context.
8
+ */
9
+ import { VulnerabilityRule, VulnerabilityScore, PatternMatch, AnalysisContext, TaintFlow, IScoreCalculator, ImpactAssessment, ExploitabilityAssessment } from '../types';
10
+ import { DEFAULT_SCORING_WEIGHTS } from '../constants';
11
+ /**
12
+ * Vulnerability Score Calculator
13
+ * Implements dynamic scoring based on multiple risk factors
14
+ */
15
+ export declare class VulnerabilityScoreCalculator implements IScoreCalculator {
16
+ private weights;
17
+ constructor(customWeights?: Partial<typeof DEFAULT_SCORING_WEIGHTS>);
18
+ /**
19
+ * Calculate vulnerability score for a finding
20
+ */
21
+ calculateScore(rule: VulnerabilityRule, matches: PatternMatch[], context: AnalysisContext, taintFlow?: TaintFlow): VulnerabilityScore;
22
+ /**
23
+ * Calculate score breakdown
24
+ */
25
+ private calculateBreakdown;
26
+ /**
27
+ * Calculate total score from breakdown
28
+ */
29
+ private calculateTotalScore;
30
+ /**
31
+ * Get default base score from severity
32
+ */
33
+ private getDefaultBaseScore;
34
+ /**
35
+ * Calculate score from pattern matches
36
+ */
37
+ private calculatePatternScore;
38
+ /**
39
+ * Calculate taint analysis score
40
+ */
41
+ private calculateTaintScore;
42
+ /**
43
+ * Calculate exploitability score based on CVSS-like factors
44
+ */
45
+ private calculateExploitabilityScore;
46
+ /**
47
+ * Calculate impact score based on CIA triad
48
+ */
49
+ private calculateImpactScore;
50
+ /**
51
+ * Calculate context-based score adjustments
52
+ */
53
+ private calculateContextScore;
54
+ /**
55
+ * Calculate correlation boost from related findings
56
+ */
57
+ private calculateCorrelationBoost;
58
+ /**
59
+ * Calculate false positive penalty
60
+ */
61
+ private calculateFalsePositivePenalty;
62
+ /**
63
+ * Convert score to severity level
64
+ */
65
+ private scoreToSeverity;
66
+ /**
67
+ * Convert score to risk level description
68
+ */
69
+ private scoreToRiskLevel;
70
+ /**
71
+ * Generate human-readable explanation of the score
72
+ */
73
+ private generateExplanation;
74
+ /**
75
+ * Calculate CVSS-like base score
76
+ */
77
+ calculateCvssBaseScore(impact: ImpactAssessment, exploitability: ExploitabilityAssessment): number;
78
+ }
79
+ export default VulnerabilityScoreCalculator;
80
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/rules/vulnerabilities/scoring/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAGlB,YAAY,EACZ,eAAe,EACf,SAAS,EACT,gBAAgB,EAEhB,gBAAgB,EAChB,wBAAwB,EACzB,MAAM,UAAU,CAAC;AAClB,OAAO,EAGL,uBAAuB,EAExB,MAAM,cAAc,CAAC;AAMtB;;;GAGG;AACH,qBAAa,4BAA6B,YAAW,gBAAgB;IACnE,OAAO,CAAC,OAAO,CAAiC;gBAEpC,aAAa,CAAC,EAAE,OAAO,CAAC,OAAO,uBAAuB,CAAC;IAInE;;OAEG;IACH,cAAc,CACZ,IAAI,EAAE,iBAAiB,EACvB,OAAO,EAAE,YAAY,EAAE,EACvB,OAAO,EAAE,eAAe,EACxB,SAAS,CAAC,EAAE,SAAS,GACpB,kBAAkB;IAerB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAmD1B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAoB3B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAW3B;;OAEG;IACH,OAAO,CAAC,qBAAqB;IA8B7B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IA6C3B;;OAEG;IACH,OAAO,CAAC,4BAA4B;IAgEpC;;OAEG;IACH,OAAO,CAAC,oBAAoB;IA2C5B;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAsC7B;;OAEG;IACH,OAAO,CAAC,yBAAyB;IAsBjC;;OAEG;IACH,OAAO,CAAC,6BAA6B;IA4BrC;;OAEG;IACH,OAAO,CAAC,eAAe;IAQvB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAQxB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IA4C3B;;OAEG;IACH,sBAAsB,CACpB,MAAM,EAAE,gBAAgB,EACxB,cAAc,EAAE,wBAAwB,GACvC,MAAM;CAYV;AAMD,eAAe,4BAA4B,CAAC"}
@@ -0,0 +1,414 @@
1
+ "use strict";
2
+ /**
3
+ * @fileoverview Vulnerability Score Calculator
4
+ * @module rules/vulnerabilities/scoring
5
+ *
6
+ * Dynamic scoring system for vulnerability detection that calculates risk scores
7
+ * based on multiple factors including pattern matches, taint analysis,
8
+ * exploitability, impact, and context.
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ exports.VulnerabilityScoreCalculator = void 0;
12
+ const types_1 = require("../types");
13
+ const constants_1 = require("../constants");
14
+ // ============================================================================
15
+ // SCORE CALCULATOR IMPLEMENTATION
16
+ // ============================================================================
17
+ /**
18
+ * Vulnerability Score Calculator
19
+ * Implements dynamic scoring based on multiple risk factors
20
+ */
21
+ class VulnerabilityScoreCalculator {
22
+ weights;
23
+ constructor(customWeights) {
24
+ this.weights = { ...constants_1.DEFAULT_SCORING_WEIGHTS, ...customWeights };
25
+ }
26
+ /**
27
+ * Calculate vulnerability score for a finding
28
+ */
29
+ calculateScore(rule, matches, context, taintFlow) {
30
+ const breakdown = this.calculateBreakdown(rule, matches, context, taintFlow);
31
+ const totalScore = this.calculateTotalScore(breakdown);
32
+ const severity = this.scoreToSeverity(totalScore);
33
+ const riskLevel = this.scoreToRiskLevel(totalScore);
34
+ return {
35
+ score: Math.round(totalScore),
36
+ breakdown,
37
+ calculatedSeverity: severity,
38
+ riskLevel,
39
+ explanation: this.generateExplanation(breakdown, matches.length, !!taintFlow)
40
+ };
41
+ }
42
+ /**
43
+ * Calculate score breakdown
44
+ */
45
+ calculateBreakdown(rule, matches, context, taintFlow) {
46
+ // Base score from rule definition
47
+ const baseScore = rule.baseScore ?? this.getDefaultBaseScore(rule.severity);
48
+ // Pattern match score
49
+ const patternScore = this.calculatePatternScore(matches, rule);
50
+ // Taint analysis score
51
+ const taintScore = this.calculateTaintScore(taintFlow);
52
+ // Exploitability score
53
+ const exploitabilityScore = this.calculateExploitabilityScore(rule.exploitability);
54
+ // Impact score
55
+ const impactScore = this.calculateImpactScore(rule.impact);
56
+ // Context score
57
+ const contextScore = this.calculateContextScore(context, rule);
58
+ // Correlation boost from related findings
59
+ const correlationBoost = this.calculateCorrelationBoost(rule, context.previousFindings || [], context.relatedFindings || []);
60
+ // False positive penalty
61
+ const falsePositivePenalty = this.calculateFalsePositivePenalty(rule, context, matches);
62
+ return {
63
+ baseScore,
64
+ patternScore,
65
+ taintScore,
66
+ exploitabilityScore,
67
+ impactScore,
68
+ contextScore,
69
+ correlationBoost,
70
+ falsePositivePenalty,
71
+ totalScore: 0 // Will be calculated
72
+ };
73
+ }
74
+ /**
75
+ * Calculate total score from breakdown
76
+ */
77
+ calculateTotalScore(breakdown) {
78
+ const weighted = (breakdown.baseScore * 0.25 +
79
+ breakdown.patternScore * this.weights.patternCount +
80
+ breakdown.taintScore * this.weights.taintFlow +
81
+ breakdown.exploitabilityScore * this.weights.exploitability +
82
+ breakdown.impactScore * this.weights.impact +
83
+ breakdown.contextScore * this.weights.context +
84
+ breakdown.correlationBoost);
85
+ const penalized = weighted - breakdown.falsePositivePenalty;
86
+ const total = Math.max(0, Math.min(100, penalized));
87
+ // Update breakdown with total
88
+ breakdown.totalScore = total;
89
+ return total;
90
+ }
91
+ /**
92
+ * Get default base score from severity
93
+ */
94
+ getDefaultBaseScore(severity) {
95
+ switch (severity) {
96
+ case types_1.VulnerabilitySeverity.CRITICAL: return 85;
97
+ case types_1.VulnerabilitySeverity.HIGH: return 70;
98
+ case types_1.VulnerabilitySeverity.MEDIUM: return 50;
99
+ case types_1.VulnerabilitySeverity.LOW: return 30;
100
+ case types_1.VulnerabilitySeverity.INFO: return 15;
101
+ default: return 40;
102
+ }
103
+ }
104
+ /**
105
+ * Calculate score from pattern matches
106
+ */
107
+ calculatePatternScore(matches, rule) {
108
+ if (matches.length === 0)
109
+ return 0;
110
+ // Base score for having any match
111
+ let score = 25;
112
+ // Bonus for multiple matches (diminishing returns)
113
+ const matchBonus = Math.min(matches.length * 3, 20);
114
+ score += matchBonus;
115
+ // Bonus for matches from different patterns
116
+ const uniquePatterns = new Set(matches.map(m => m.pattern.patternId || JSON.stringify(m.pattern)));
117
+ const diversityBonus = Math.min(uniquePatterns.size * 8, 15);
118
+ score += diversityBonus;
119
+ // Weight by pattern weights if defined
120
+ const weightedSum = matches.reduce((sum, match) => {
121
+ return sum + (match.pattern.weight ?? 1);
122
+ }, 0);
123
+ const avgWeight = weightedSum / matches.length;
124
+ score *= avgWeight;
125
+ return Math.min(score, 100);
126
+ }
127
+ /**
128
+ * Calculate taint analysis score
129
+ */
130
+ calculateTaintScore(taintFlow) {
131
+ if (!taintFlow)
132
+ return 0;
133
+ let score = 50; // Base score for having a taint flow
134
+ // Boost for exploitable flows
135
+ if (taintFlow.isExploitable) {
136
+ score += 30;
137
+ }
138
+ // Boost based on confidence
139
+ switch (taintFlow.confidence) {
140
+ case types_1.ConfidenceLevel.CONFIRMED:
141
+ score += 20;
142
+ break;
143
+ case types_1.ConfidenceLevel.HIGH:
144
+ score += 15;
145
+ break;
146
+ case types_1.ConfidenceLevel.MEDIUM:
147
+ score += 10;
148
+ break;
149
+ case types_1.ConfidenceLevel.LOW:
150
+ score += 5;
151
+ break;
152
+ }
153
+ // Penalty if sanitized
154
+ if (taintFlow.sanitizers.length > 0) {
155
+ // Reduce score based on sanitizer effectiveness
156
+ const avgEffectiveness = taintFlow.sanitizers.reduce((sum, s) => sum + (s.effectiveness ?? 80), 0) / taintFlow.sanitizers.length;
157
+ score -= avgEffectiveness * 0.5;
158
+ }
159
+ // Bonus for shorter paths (more direct = more likely exploitable)
160
+ if (taintFlow.path.length <= 3) {
161
+ score += 10;
162
+ }
163
+ else if (taintFlow.path.length <= 5) {
164
+ score += 5;
165
+ }
166
+ return Math.max(0, Math.min(score, 100));
167
+ }
168
+ /**
169
+ * Calculate exploitability score based on CVSS-like factors
170
+ */
171
+ calculateExploitabilityScore(exploitability) {
172
+ if (!exploitability)
173
+ return 50; // Default middle score
174
+ let score = 0;
175
+ // Attack Vector (0-40 points)
176
+ switch (exploitability.attackVector) {
177
+ case 'network':
178
+ score += 40;
179
+ break;
180
+ case 'adjacent':
181
+ score += 30;
182
+ break;
183
+ case 'local':
184
+ score += 20;
185
+ break;
186
+ case 'physical':
187
+ score += 10;
188
+ break;
189
+ }
190
+ // Attack Complexity (0-20 points)
191
+ switch (exploitability.attackComplexity) {
192
+ case 'low':
193
+ score += 20;
194
+ break;
195
+ case 'high':
196
+ score += 10;
197
+ break;
198
+ }
199
+ // Privileges Required (0-20 points)
200
+ switch (exploitability.privilegesRequired) {
201
+ case 'none':
202
+ score += 20;
203
+ break;
204
+ case 'low':
205
+ score += 15;
206
+ break;
207
+ case 'high':
208
+ score += 5;
209
+ break;
210
+ }
211
+ // User Interaction (0-20 points)
212
+ switch (exploitability.userInteraction) {
213
+ case 'none':
214
+ score += 20;
215
+ break;
216
+ case 'required':
217
+ score += 10;
218
+ break;
219
+ }
220
+ // Known exploits bonus
221
+ if (exploitability.knownExploits) {
222
+ score = Math.min(score + 10, 100);
223
+ }
224
+ return score;
225
+ }
226
+ /**
227
+ * Calculate impact score based on CIA triad
228
+ */
229
+ calculateImpactScore(impact) {
230
+ if (!impact)
231
+ return 50; // Default middle score
232
+ let score = 0;
233
+ // Confidentiality (0-33 points)
234
+ switch (impact.confidentiality) {
235
+ case 'high':
236
+ score += 33;
237
+ break;
238
+ case 'low':
239
+ score += 17;
240
+ break;
241
+ }
242
+ // Integrity (0-33 points)
243
+ switch (impact.integrity) {
244
+ case 'high':
245
+ score += 33;
246
+ break;
247
+ case 'low':
248
+ score += 17;
249
+ break;
250
+ }
251
+ // Availability (0-34 points)
252
+ switch (impact.availability) {
253
+ case 'high':
254
+ score += 34;
255
+ break;
256
+ case 'low':
257
+ score += 17;
258
+ break;
259
+ }
260
+ // Scope change bonus
261
+ if (impact.scope === 'changed') {
262
+ score = Math.min(score + 10, 100);
263
+ }
264
+ return score;
265
+ }
266
+ /**
267
+ * Calculate context-based score adjustments
268
+ */
269
+ calculateContextScore(context, rule) {
270
+ let score = 50; // Neutral base
271
+ // Production code boost
272
+ if (context.isProductionCode) {
273
+ score += rule.contextConditions?.productionBoost ?? 15;
274
+ }
275
+ // Test code penalty
276
+ if (context.isTestFile) {
277
+ score -= rule.contextConditions?.testCodePenalty ?? 30;
278
+ }
279
+ // Vendor code penalty
280
+ if (context.isVendorCode) {
281
+ score -= 20;
282
+ }
283
+ // Sensitive data boost
284
+ if (context.handlesSensitiveData) {
285
+ score += rule.contextConditions?.sensitiveDataBoost ?? 20;
286
+ }
287
+ // File pattern adjustments
288
+ if (rule.contextConditions?.filePatterns && context.filePath) {
289
+ for (const { pattern, severityAdjustment } of rule.contextConditions.filePatterns) {
290
+ if (new RegExp(pattern).test(context.filePath)) {
291
+ score += severityAdjustment;
292
+ }
293
+ }
294
+ }
295
+ return Math.max(0, Math.min(score, 100));
296
+ }
297
+ /**
298
+ * Calculate correlation boost from related findings
299
+ */
300
+ calculateCorrelationBoost(rule, previousFindings, relatedFindings) {
301
+ if (!rule.correlation?.amplifyWith)
302
+ return 0;
303
+ let boost = 0;
304
+ const allRelatedRuleIds = [
305
+ ...previousFindings.map(f => f.ruleId),
306
+ ...relatedFindings.map(f => f.ruleId)
307
+ ];
308
+ for (const amplifyRuleId of rule.correlation.amplifyWith) {
309
+ if (allRelatedRuleIds.includes(amplifyRuleId)) {
310
+ boost += rule.correlation.severityBoost ?? 10;
311
+ }
312
+ }
313
+ return Math.min(boost, 30);
314
+ }
315
+ /**
316
+ * Calculate false positive penalty
317
+ */
318
+ calculateFalsePositivePenalty(rule, context, matches) {
319
+ let penalty = 0;
320
+ // Check for false positive patterns
321
+ if (rule.falsePositivePatterns && rule.falsePositivePatterns.length > 0) {
322
+ for (const fpPattern of rule.falsePositivePatterns) {
323
+ // Simple check - in real implementation, would use pattern matching
324
+ penalty += 15;
325
+ }
326
+ }
327
+ // Test file penalty
328
+ if (context.isTestFile) {
329
+ penalty += 10;
330
+ }
331
+ // Vendor code penalty
332
+ if (context.isVendorCode) {
333
+ penalty += 20;
334
+ }
335
+ return Math.min(penalty, 50);
336
+ }
337
+ /**
338
+ * Convert score to severity level
339
+ */
340
+ scoreToSeverity(score) {
341
+ if (score >= constants_1.SCORE_THRESHOLDS.CRITICAL)
342
+ return types_1.VulnerabilitySeverity.CRITICAL;
343
+ if (score >= constants_1.SCORE_THRESHOLDS.HIGH)
344
+ return types_1.VulnerabilitySeverity.HIGH;
345
+ if (score >= constants_1.SCORE_THRESHOLDS.MEDIUM)
346
+ return types_1.VulnerabilitySeverity.MEDIUM;
347
+ if (score >= constants_1.SCORE_THRESHOLDS.LOW)
348
+ return types_1.VulnerabilitySeverity.LOW;
349
+ return types_1.VulnerabilitySeverity.INFO;
350
+ }
351
+ /**
352
+ * Convert score to risk level description
353
+ */
354
+ scoreToRiskLevel(score) {
355
+ if (score >= constants_1.SCORE_THRESHOLDS.CRITICAL)
356
+ return constants_1.RISK_LEVELS.CRITICAL;
357
+ if (score >= constants_1.SCORE_THRESHOLDS.HIGH)
358
+ return constants_1.RISK_LEVELS.HIGH;
359
+ if (score >= constants_1.SCORE_THRESHOLDS.MEDIUM)
360
+ return constants_1.RISK_LEVELS.MEDIUM;
361
+ if (score >= constants_1.SCORE_THRESHOLDS.LOW)
362
+ return constants_1.RISK_LEVELS.LOW;
363
+ return constants_1.RISK_LEVELS.MINIMAL;
364
+ }
365
+ /**
366
+ * Generate human-readable explanation of the score
367
+ */
368
+ generateExplanation(breakdown, matchCount, hasTaintFlow) {
369
+ const factors = [];
370
+ factors.push(`Base rule score: ${breakdown.baseScore.toFixed(0)}`);
371
+ if (matchCount > 0) {
372
+ factors.push(`Pattern matches (${matchCount}): +${breakdown.patternScore.toFixed(0)}`);
373
+ }
374
+ if (hasTaintFlow) {
375
+ factors.push(`Confirmed taint flow: +${breakdown.taintScore.toFixed(0)}`);
376
+ }
377
+ if (breakdown.exploitabilityScore > 50) {
378
+ factors.push(`High exploitability: +${(breakdown.exploitabilityScore - 50).toFixed(0)}`);
379
+ }
380
+ if (breakdown.impactScore > 50) {
381
+ factors.push(`High impact: +${(breakdown.impactScore - 50).toFixed(0)}`);
382
+ }
383
+ if (breakdown.contextScore > 50) {
384
+ factors.push(`Context factors: +${(breakdown.contextScore - 50).toFixed(0)}`);
385
+ }
386
+ else if (breakdown.contextScore < 50) {
387
+ factors.push(`Context factors: ${(breakdown.contextScore - 50).toFixed(0)}`);
388
+ }
389
+ if (breakdown.correlationBoost > 0) {
390
+ factors.push(`Correlated findings: +${breakdown.correlationBoost.toFixed(0)}`);
391
+ }
392
+ if (breakdown.falsePositivePenalty > 0) {
393
+ factors.push(`False positive indicators: -${breakdown.falsePositivePenalty.toFixed(0)}`);
394
+ }
395
+ factors.push(`Total score: ${breakdown.totalScore.toFixed(0)}/100`);
396
+ return factors.join('\n');
397
+ }
398
+ /**
399
+ * Calculate CVSS-like base score
400
+ */
401
+ calculateCvssBaseScore(impact, exploitability) {
402
+ const impactScore = this.calculateImpactScore(impact) / 100;
403
+ const exploitabilityScore = this.calculateExploitabilityScore(exploitability) / 100;
404
+ // Simplified CVSS-like formula
405
+ const baseScore = Math.min(10, (impactScore * 6 + exploitabilityScore * 4));
406
+ return Math.round(baseScore * 10) / 10;
407
+ }
408
+ }
409
+ exports.VulnerabilityScoreCalculator = VulnerabilityScoreCalculator;
410
+ // ============================================================================
411
+ // EXPORTS
412
+ // ============================================================================
413
+ exports.default = VulnerabilityScoreCalculator;
414
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/rules/vulnerabilities/scoring/index.ts"],"names":[],"mappings":"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"}