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,717 @@
1
+ /**
2
+ * Dependency Report Generator
3
+ * Generates HTML report section for dependency analysis
4
+ */
5
+
6
+ import {
7
+ DependencyAnalysisResult,
8
+ DependencyVulnerability,
9
+ DependencyRiskCategory,
10
+ DependencyRecommendation,
11
+ Dependency,
12
+ PackageEcosystem
13
+ } from '../dependencies/types';
14
+ import { Severity } from '../types';
15
+ import { escapeHtml, formatDuration } from '../utils';
16
+ import { Language, getTranslations, Translations } from '../i18n';
17
+
18
+ /**
19
+ * Dependency Report Translations
20
+ */
21
+ const dependencyTranslations = {
22
+ es: {
23
+ dependencyAnalysis: 'Análisis de Dependencias',
24
+ dependencySubtitle: 'Software Composition Analysis (SCA)',
25
+ totalDependencies: 'Total Dependencias',
26
+ directDependencies: 'Directas',
27
+ transitiveDependencies: 'Transitivas',
28
+ vulnerableDependencies: 'Vulnerables',
29
+ ecosystems: 'Ecosistemas',
30
+ vulnerabilities: 'Vulnerabilidades',
31
+ supplyChainRisks: 'Riesgos Supply Chain',
32
+ maliciousPackages: 'Paquetes Maliciosos',
33
+ outdatedPackages: 'Paquetes Obsoletos',
34
+ package: 'Paquete',
35
+ version: 'Versión',
36
+ ecosystem: 'Ecosistema',
37
+ type: 'Tipo',
38
+ severity: 'Severidad',
39
+ category: 'Categoría',
40
+ recommendation: 'Recomendación',
41
+ references: 'Referencias',
42
+ affectedVersion: 'Versión Afectada',
43
+ fixedVersion: 'Versión Corregida',
44
+ cve: 'CVE',
45
+ cvss: 'CVSS',
46
+ upgrade: 'Actualizar',
47
+ replace: 'Reemplazar',
48
+ remove: 'Eliminar',
49
+ review: 'Revisar',
50
+ monitor: 'Monitorear',
51
+ direct: 'Directa',
52
+ transitive: 'Transitiva',
53
+ dev: 'Desarrollo',
54
+ optional: 'Opcional',
55
+ peer: 'Peer',
56
+ noVulnerabilities: 'No se detectaron vulnerabilidades en las dependencias',
57
+ dependencyDetails: 'Detalles de Dependencia',
58
+ riskIndicators: 'Indicadores de Riesgo',
59
+ securityStandards: 'Estándares de Seguridad',
60
+ aiAnalysis: 'Análisis IA'
61
+ },
62
+ en: {
63
+ dependencyAnalysis: 'Dependency Analysis',
64
+ dependencySubtitle: 'Software Composition Analysis (SCA)',
65
+ totalDependencies: 'Total Dependencies',
66
+ directDependencies: 'Direct',
67
+ transitiveDependencies: 'Transitive',
68
+ vulnerableDependencies: 'Vulnerable',
69
+ ecosystems: 'Ecosystems',
70
+ vulnerabilities: 'Vulnerabilities',
71
+ supplyChainRisks: 'Supply Chain Risks',
72
+ maliciousPackages: 'Malicious Packages',
73
+ outdatedPackages: 'Outdated Packages',
74
+ package: 'Package',
75
+ version: 'Version',
76
+ ecosystem: 'Ecosystem',
77
+ type: 'Type',
78
+ severity: 'Severity',
79
+ category: 'Category',
80
+ recommendation: 'Recommendation',
81
+ references: 'References',
82
+ affectedVersion: 'Affected Version',
83
+ fixedVersion: 'Fixed Version',
84
+ cve: 'CVE',
85
+ cvss: 'CVSS',
86
+ upgrade: 'Upgrade',
87
+ replace: 'Replace',
88
+ remove: 'Remove',
89
+ review: 'Review',
90
+ monitor: 'Monitor',
91
+ direct: 'Direct',
92
+ transitive: 'Transitive',
93
+ dev: 'Development',
94
+ optional: 'Optional',
95
+ peer: 'Peer',
96
+ noVulnerabilities: 'No vulnerabilities detected in dependencies',
97
+ dependencyDetails: 'Dependency Details',
98
+ riskIndicators: 'Risk Indicators',
99
+ securityStandards: 'Security Standards',
100
+ aiAnalysis: 'AI Analysis'
101
+ }
102
+ };
103
+
104
+ /**
105
+ * Get dependency translations
106
+ */
107
+ function getDependencyTranslations(language: Language) {
108
+ return dependencyTranslations[language] || dependencyTranslations.en;
109
+ }
110
+
111
+ /**
112
+ * Get ecosystem icon
113
+ */
114
+ function getEcosystemIcon(ecosystem: PackageEcosystem): string {
115
+ const icons: Record<PackageEcosystem, string> = {
116
+ npm: '📦',
117
+ pip: '🐍',
118
+ composer: '🐘',
119
+ maven: '☕',
120
+ gradle: '🐘',
121
+ nuget: '🔷',
122
+ vcpkg: '⚙️',
123
+ conan: '🔧',
124
+ cmake: '🔨'
125
+ };
126
+ return icons[ecosystem] || '📦';
127
+ }
128
+
129
+ /**
130
+ * Get recommendation icon
131
+ */
132
+ function getRecommendationIcon(recommendation: DependencyRecommendation): string {
133
+ const icons: Record<DependencyRecommendation, string> = {
134
+ [DependencyRecommendation.UPGRADE]: '⬆️',
135
+ [DependencyRecommendation.REPLACE]: '🔄',
136
+ [DependencyRecommendation.REMOVE]: '❌',
137
+ [DependencyRecommendation.REVIEW]: '🔍',
138
+ [DependencyRecommendation.MONITOR]: '👁️'
139
+ };
140
+ return icons[recommendation] || '📋';
141
+ }
142
+
143
+ /**
144
+ * Get category icon
145
+ */
146
+ function getCategoryIcon(category: DependencyRiskCategory): string {
147
+ const icons: Record<DependencyRiskCategory, string> = {
148
+ [DependencyRiskCategory.VULNERABILITY]: '🔓',
149
+ [DependencyRiskCategory.SUPPLY_CHAIN]: '🔗',
150
+ [DependencyRiskCategory.MALICIOUS]: '🦠',
151
+ [DependencyRiskCategory.OUTDATED]: '📅',
152
+ [DependencyRiskCategory.LICENSE]: '📄',
153
+ [DependencyRiskCategory.MAINTENANCE]: '🔧'
154
+ };
155
+ return icons[category] || '⚠️';
156
+ }
157
+
158
+ /**
159
+ * Generate dependency analysis HTML section
160
+ */
161
+ export function generateDependencyReportSection(
162
+ result: DependencyAnalysisResult,
163
+ language: Language = 'es'
164
+ ): string {
165
+ const t = getDependencyTranslations(language);
166
+ const stats = result.stats;
167
+
168
+ // Count by category
169
+ const vulnCount = result.vulnerabilities.filter(
170
+ v => v.category === DependencyRiskCategory.VULNERABILITY
171
+ ).length;
172
+ const supplyChainCount = result.vulnerabilities.filter(
173
+ v => v.category === DependencyRiskCategory.SUPPLY_CHAIN
174
+ ).length;
175
+ const maliciousCount = result.vulnerabilities.filter(
176
+ v => v.category === DependencyRiskCategory.MALICIOUS
177
+ ).length;
178
+ const outdatedCount = result.vulnerabilities.filter(
179
+ v => v.category === DependencyRiskCategory.OUTDATED
180
+ ).length;
181
+
182
+ return `
183
+ <!-- Dependency Analysis Section -->
184
+ <div class="section dependency-section">
185
+ <div class="section-header">
186
+ <h2 class="section-title">📦 ${t.dependencyAnalysis}</h2>
187
+ <span class="section-subtitle">${t.dependencySubtitle}</span>
188
+ </div>
189
+ <div class="section-content">
190
+ <!-- Dependency Stats -->
191
+ <div class="dep-stats-grid">
192
+ <div class="dep-stat-card">
193
+ <div class="dep-stat-icon">📊</div>
194
+ <div class="dep-stat-value">${stats.totalDependencies}</div>
195
+ <div class="dep-stat-label">${t.totalDependencies}</div>
196
+ </div>
197
+ <div class="dep-stat-card">
198
+ <div class="dep-stat-icon">📎</div>
199
+ <div class="dep-stat-value">${stats.directDependencies}</div>
200
+ <div class="dep-stat-label">${t.directDependencies}</div>
201
+ </div>
202
+ <div class="dep-stat-card">
203
+ <div class="dep-stat-icon">🔗</div>
204
+ <div class="dep-stat-value">${stats.transitiveDependencies}</div>
205
+ <div class="dep-stat-label">${t.transitiveDependencies}</div>
206
+ </div>
207
+ <div class="dep-stat-card vulnerable">
208
+ <div class="dep-stat-icon">⚠️</div>
209
+ <div class="dep-stat-value">${stats.vulnerableDependencies}</div>
210
+ <div class="dep-stat-label">${t.vulnerableDependencies}</div>
211
+ </div>
212
+ </div>
213
+
214
+ <!-- Ecosystems -->
215
+ <div class="ecosystems-bar">
216
+ ${result.ecosystems.map(eco => `
217
+ <span class="ecosystem-badge">
218
+ ${getEcosystemIcon(eco)} ${eco}
219
+ </span>
220
+ `).join('')}
221
+ </div>
222
+
223
+ <!-- Category Summary -->
224
+ <div class="dep-category-summary">
225
+ ${vulnCount > 0 ? `
226
+ <div class="category-pill vulnerability">
227
+ 🔓 ${vulnCount} ${t.vulnerabilities}
228
+ </div>
229
+ ` : ''}
230
+ ${supplyChainCount > 0 ? `
231
+ <div class="category-pill supply-chain">
232
+ 🔗 ${supplyChainCount} ${t.supplyChainRisks}
233
+ </div>
234
+ ` : ''}
235
+ ${maliciousCount > 0 ? `
236
+ <div class="category-pill malicious">
237
+ 🦠 ${maliciousCount} ${t.maliciousPackages}
238
+ </div>
239
+ ` : ''}
240
+ ${outdatedCount > 0 ? `
241
+ <div class="category-pill outdated">
242
+ 📅 ${outdatedCount} ${t.outdatedPackages}
243
+ </div>
244
+ ` : ''}
245
+ </div>
246
+
247
+ <!-- Vulnerability List -->
248
+ ${result.vulnerabilities.length > 0 ? `
249
+ <div class="dep-vulnerabilities">
250
+ ${result.vulnerabilities.map(vuln => generateVulnerabilityCard(vuln, t)).join('')}
251
+ </div>
252
+ ` : `
253
+ <div class="no-vulnerabilities">
254
+ <span class="success-icon">✅</span>
255
+ <p>${t.noVulnerabilities}</p>
256
+ </div>
257
+ `}
258
+ </div>
259
+ </div>
260
+ `;
261
+ }
262
+
263
+ /**
264
+ * Generate vulnerability card HTML
265
+ */
266
+ function generateVulnerabilityCard(vuln: DependencyVulnerability, t: any): string {
267
+ const dep = vuln.dependency;
268
+
269
+ return `
270
+ <div class="dep-finding" onclick="this.classList.toggle('expanded')">
271
+ <div class="dep-finding-header">
272
+ <div class="dep-finding-info">
273
+ <div class="dep-finding-title">
274
+ ${getCategoryIcon(vuln.category)} ${escapeHtml(vuln.title)}
275
+ </div>
276
+ <div class="dep-finding-meta">
277
+ <span class="dep-name">${getEcosystemIcon(dep.ecosystem)} ${escapeHtml(dep.name)}</span>
278
+ <span class="dep-version">@${escapeHtml(dep.resolvedVersion || dep.version)}</span>
279
+ <span class="dep-type badge-${dep.dependencyType}">${dep.dependencyType}</span>
280
+ </div>
281
+ </div>
282
+ <div class="dep-finding-badges">
283
+ <span class="badge badge-${vuln.severity}">${vuln.severity.toUpperCase()}</span>
284
+ <span class="recommendation-badge">
285
+ ${getRecommendationIcon(vuln.recommendation)} ${vuln.recommendation}
286
+ </span>
287
+ </div>
288
+ </div>
289
+ <div class="dep-finding-body">
290
+ <p class="dep-description">${escapeHtml(vuln.description)}</p>
291
+
292
+ ${vuln.cve ? `
293
+ <div class="cve-info">
294
+ <div class="cve-header">
295
+ <span class="cve-id">${vuln.cve.id}</span>
296
+ <span class="cvss-score cvss-${getCVSSLevel(vuln.cve.cvssScore)}">
297
+ CVSS: ${vuln.cve.cvssScore}
298
+ </span>
299
+ ${vuln.cve.exploitAvailable ? '<span class="exploit-badge">⚠️ Exploit Available</span>' : ''}
300
+ </div>
301
+ ${vuln.cve.fixedVersion ? `
302
+ <div class="fix-version">
303
+ <strong>${t.fixedVersion}:</strong> ${vuln.cve.fixedVersion}
304
+ </div>
305
+ ` : ''}
306
+ ${vuln.cve.references.length > 0 ? `
307
+ <div class="cve-references">
308
+ <strong>${t.references}:</strong>
309
+ ${vuln.cve.references.slice(0, 3).map(ref => `
310
+ <a href="${escapeHtml(ref)}" target="_blank" rel="noopener">${getDomain(ref)}</a>
311
+ `).join(' ')}
312
+ </div>
313
+ ` : ''}
314
+ </div>
315
+ ` : ''}
316
+
317
+ ${vuln.supplyChainRisks && vuln.supplyChainRisks.length > 0 ? `
318
+ <div class="risk-indicators">
319
+ <strong>${t.riskIndicators}:</strong>
320
+ ${vuln.supplyChainRisks.map(risk => `
321
+ <span class="risk-badge">${formatRiskName(risk)}</span>
322
+ `).join('')}
323
+ </div>
324
+ ` : ''}
325
+
326
+ ${vuln.malwareIndicators && vuln.malwareIndicators.length > 0 ? `
327
+ <div class="malware-indicators">
328
+ <strong>🦠 Malware Indicators:</strong>
329
+ ${vuln.malwareIndicators.map(ind => `
330
+ <span class="malware-badge">${formatMalwareName(ind)}</span>
331
+ `).join('')}
332
+ </div>
333
+ ` : ''}
334
+
335
+ <div class="standards-list">
336
+ ${vuln.standards.slice(0, 4).map(std => `
337
+ <span class="standard-badge">${std.name}: ${std.id}</span>
338
+ `).join('')}
339
+ </div>
340
+
341
+ <div class="dep-remediation">
342
+ <div class="remediation-title">
343
+ ${getRecommendationIcon(vuln.recommendation)} ${t.recommendation}
344
+ </div>
345
+ <p>${escapeHtml(vuln.recommendationDetails)}</p>
346
+ </div>
347
+
348
+ ${vuln.aiExplanation ? `
349
+ <div class="ai-explanation">
350
+ <div class="ai-title">🤖 ${t.aiAnalysis}</div>
351
+ <p>${escapeHtml(vuln.aiExplanation)}</p>
352
+ </div>
353
+ ` : ''}
354
+ </div>
355
+ </div>
356
+ `;
357
+ }
358
+
359
+ /**
360
+ * Get CVSS level for styling
361
+ */
362
+ function getCVSSLevel(score: number): string {
363
+ if (score >= 9.0) return 'critical';
364
+ if (score >= 7.0) return 'high';
365
+ if (score >= 4.0) return 'medium';
366
+ if (score >= 0.1) return 'low';
367
+ return 'info';
368
+ }
369
+
370
+ /**
371
+ * Get domain from URL
372
+ */
373
+ function getDomain(url: string): string {
374
+ try {
375
+ return new URL(url).hostname.replace('www.', '');
376
+ } catch {
377
+ return url.substring(0, 30);
378
+ }
379
+ }
380
+
381
+ /**
382
+ * Format risk name
383
+ */
384
+ function formatRiskName(risk: string): string {
385
+ return risk.replace(/_/g, ' ').toLowerCase().replace(/\b\w/g, l => l.toUpperCase());
386
+ }
387
+
388
+ /**
389
+ * Format malware name
390
+ */
391
+ function formatMalwareName(indicator: string): string {
392
+ return indicator.replace(/_/g, ' ').toLowerCase().replace(/\b\w/g, l => l.toUpperCase());
393
+ }
394
+
395
+ /**
396
+ * Generate dependency CSS styles
397
+ */
398
+ export function generateDependencyStyles(): string {
399
+ return `
400
+ /* Dependency Analysis Styles */
401
+ .dependency-section .section-subtitle {
402
+ font-size: 12px;
403
+ color: var(--text-secondary);
404
+ margin-left: 12px;
405
+ }
406
+
407
+ .dep-stats-grid {
408
+ display: grid;
409
+ grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
410
+ gap: 16px;
411
+ margin-bottom: 20px;
412
+ }
413
+
414
+ .dep-stat-card {
415
+ background: var(--bg-tertiary);
416
+ border: 1px solid var(--border-color);
417
+ border-radius: 8px;
418
+ padding: 16px;
419
+ text-align: center;
420
+ }
421
+
422
+ .dep-stat-card.vulnerable {
423
+ border-color: var(--high-color);
424
+ background: rgba(219, 109, 40, 0.1);
425
+ }
426
+
427
+ .dep-stat-icon {
428
+ font-size: 24px;
429
+ margin-bottom: 8px;
430
+ }
431
+
432
+ .dep-stat-value {
433
+ font-size: 28px;
434
+ font-weight: 600;
435
+ color: var(--text-primary);
436
+ }
437
+
438
+ .dep-stat-card.vulnerable .dep-stat-value {
439
+ color: var(--high-color);
440
+ }
441
+
442
+ .dep-stat-label {
443
+ font-size: 12px;
444
+ color: var(--text-secondary);
445
+ margin-top: 4px;
446
+ }
447
+
448
+ .ecosystems-bar {
449
+ display: flex;
450
+ flex-wrap: wrap;
451
+ gap: 8px;
452
+ margin-bottom: 16px;
453
+ }
454
+
455
+ .ecosystem-badge {
456
+ background: var(--bg-tertiary);
457
+ border: 1px solid var(--border-color);
458
+ border-radius: 20px;
459
+ padding: 6px 12px;
460
+ font-size: 13px;
461
+ }
462
+
463
+ .dep-category-summary {
464
+ display: flex;
465
+ flex-wrap: wrap;
466
+ gap: 10px;
467
+ margin-bottom: 20px;
468
+ }
469
+
470
+ .category-pill {
471
+ padding: 8px 16px;
472
+ border-radius: 20px;
473
+ font-size: 13px;
474
+ font-weight: 500;
475
+ }
476
+
477
+ .category-pill.vulnerability {
478
+ background: rgba(219, 109, 40, 0.2);
479
+ border: 1px solid var(--high-color);
480
+ color: var(--high-color);
481
+ }
482
+
483
+ .category-pill.supply-chain {
484
+ background: rgba(210, 153, 34, 0.2);
485
+ border: 1px solid var(--medium-color);
486
+ color: var(--medium-color);
487
+ }
488
+
489
+ .category-pill.malicious {
490
+ background: rgba(248, 81, 73, 0.2);
491
+ border: 1px solid var(--critical-color);
492
+ color: var(--critical-color);
493
+ }
494
+
495
+ .category-pill.outdated {
496
+ background: rgba(88, 166, 255, 0.2);
497
+ border: 1px solid var(--info-color);
498
+ color: var(--info-color);
499
+ }
500
+
501
+ .dep-vulnerabilities {
502
+ display: flex;
503
+ flex-direction: column;
504
+ gap: 16px;
505
+ }
506
+
507
+ .dep-finding {
508
+ background: var(--bg-tertiary);
509
+ border: 1px solid var(--border-color);
510
+ border-radius: 8px;
511
+ overflow: hidden;
512
+ }
513
+
514
+ .dep-finding-header {
515
+ padding: 16px;
516
+ display: flex;
517
+ justify-content: space-between;
518
+ align-items: flex-start;
519
+ gap: 16px;
520
+ cursor: pointer;
521
+ }
522
+
523
+ .dep-finding-header:hover {
524
+ background: rgba(255, 255, 255, 0.02);
525
+ }
526
+
527
+ .dep-finding-title {
528
+ font-weight: 600;
529
+ margin-bottom: 8px;
530
+ }
531
+
532
+ .dep-finding-meta {
533
+ display: flex;
534
+ flex-wrap: wrap;
535
+ gap: 8px;
536
+ font-size: 13px;
537
+ color: var(--text-secondary);
538
+ }
539
+
540
+ .dep-name {
541
+ font-family: 'SFMono-Regular', Consolas, monospace;
542
+ color: var(--info-color);
543
+ }
544
+
545
+ .dep-version {
546
+ font-family: 'SFMono-Regular', Consolas, monospace;
547
+ }
548
+
549
+ .dep-type {
550
+ padding: 2px 8px;
551
+ border-radius: 4px;
552
+ font-size: 11px;
553
+ text-transform: uppercase;
554
+ }
555
+
556
+ .badge-direct { background: var(--accent-color); color: white; }
557
+ .badge-transitive { background: var(--bg-primary); border: 1px solid var(--border-color); }
558
+ .badge-dev { background: rgba(88, 166, 255, 0.2); color: var(--info-color); }
559
+ .badge-optional { background: rgba(210, 153, 34, 0.2); color: var(--medium-color); }
560
+ .badge-peer { background: rgba(63, 185, 80, 0.2); color: var(--low-color); }
561
+
562
+ .dep-finding-badges {
563
+ display: flex;
564
+ flex-direction: column;
565
+ align-items: flex-end;
566
+ gap: 8px;
567
+ }
568
+
569
+ .recommendation-badge {
570
+ font-size: 12px;
571
+ color: var(--text-secondary);
572
+ }
573
+
574
+ .dep-finding-body {
575
+ padding: 0 16px 16px;
576
+ display: none;
577
+ border-top: 1px solid var(--border-color);
578
+ }
579
+
580
+ .dep-finding.expanded .dep-finding-body {
581
+ display: block;
582
+ padding-top: 16px;
583
+ }
584
+
585
+ .dep-description {
586
+ color: var(--text-secondary);
587
+ margin-bottom: 16px;
588
+ line-height: 1.6;
589
+ }
590
+
591
+ .cve-info {
592
+ background: var(--bg-primary);
593
+ border: 1px solid var(--border-color);
594
+ border-radius: 6px;
595
+ padding: 12px 16px;
596
+ margin-bottom: 16px;
597
+ }
598
+
599
+ .cve-header {
600
+ display: flex;
601
+ align-items: center;
602
+ gap: 12px;
603
+ margin-bottom: 8px;
604
+ }
605
+
606
+ .cve-id {
607
+ font-weight: 600;
608
+ font-family: 'SFMono-Regular', Consolas, monospace;
609
+ color: var(--critical-color);
610
+ }
611
+
612
+ .cvss-score {
613
+ padding: 4px 8px;
614
+ border-radius: 4px;
615
+ font-size: 12px;
616
+ font-weight: 600;
617
+ }
618
+
619
+ .cvss-critical { background: var(--critical-color); color: white; }
620
+ .cvss-high { background: var(--high-color); color: white; }
621
+ .cvss-medium { background: var(--medium-color); color: black; }
622
+ .cvss-low { background: var(--low-color); color: black; }
623
+ .cvss-info { background: var(--info-color); color: black; }
624
+
625
+ .exploit-badge {
626
+ background: rgba(248, 81, 73, 0.2);
627
+ color: var(--critical-color);
628
+ padding: 4px 8px;
629
+ border-radius: 4px;
630
+ font-size: 12px;
631
+ }
632
+
633
+ .fix-version {
634
+ font-size: 13px;
635
+ margin-bottom: 8px;
636
+ }
637
+
638
+ .cve-references {
639
+ font-size: 13px;
640
+ }
641
+
642
+ .cve-references a {
643
+ color: var(--info-color);
644
+ text-decoration: none;
645
+ margin-left: 8px;
646
+ }
647
+
648
+ .cve-references a:hover {
649
+ text-decoration: underline;
650
+ }
651
+
652
+ .risk-indicators, .malware-indicators {
653
+ margin-bottom: 16px;
654
+ }
655
+
656
+ .risk-badge, .malware-badge {
657
+ display: inline-block;
658
+ background: rgba(210, 153, 34, 0.2);
659
+ border: 1px solid var(--medium-color);
660
+ color: var(--medium-color);
661
+ padding: 4px 8px;
662
+ border-radius: 4px;
663
+ font-size: 12px;
664
+ margin: 4px 4px 0 0;
665
+ }
666
+
667
+ .malware-badge {
668
+ background: rgba(248, 81, 73, 0.2);
669
+ border-color: var(--critical-color);
670
+ color: var(--critical-color);
671
+ }
672
+
673
+ .dep-remediation {
674
+ background: rgba(35, 134, 54, 0.1);
675
+ border: 1px solid var(--accent-color);
676
+ border-radius: 6px;
677
+ padding: 12px 16px;
678
+ margin-bottom: 16px;
679
+ }
680
+
681
+ .dep-remediation .remediation-title {
682
+ font-weight: 600;
683
+ color: var(--accent-color);
684
+ margin-bottom: 8px;
685
+ }
686
+
687
+ .ai-explanation {
688
+ background: rgba(88, 166, 255, 0.1);
689
+ border: 1px solid var(--info-color);
690
+ border-radius: 6px;
691
+ padding: 12px 16px;
692
+ }
693
+
694
+ .ai-explanation .ai-title {
695
+ font-weight: 600;
696
+ color: var(--info-color);
697
+ margin-bottom: 8px;
698
+ }
699
+
700
+ .no-vulnerabilities {
701
+ text-align: center;
702
+ padding: 40px;
703
+ color: var(--text-secondary);
704
+ }
705
+
706
+ .no-vulnerabilities .success-icon {
707
+ font-size: 48px;
708
+ display: block;
709
+ margin-bottom: 16px;
710
+ }
711
+ `;
712
+ }
713
+
714
+ export default {
715
+ generateDependencyReportSection,
716
+ generateDependencyStyles
717
+ };