@contrast/contrast 2.0.2-beta.1 → 2.0.2-beta.11

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 (397) hide show
  1. package/README.md +2 -1
  2. package/dist/assess/assessConfig.js +9 -0
  3. package/dist/assess/assessConfig.js.map +1 -0
  4. package/dist/assess/help.js +36 -0
  5. package/dist/assess/help.js.map +1 -0
  6. package/dist/assess/http/index.js +39 -0
  7. package/dist/assess/http/index.js.map +1 -0
  8. package/dist/assess/index.js +69 -0
  9. package/dist/assess/index.js.map +1 -0
  10. package/dist/assess/metadata/findYamlFile.js +59 -0
  11. package/dist/assess/metadata/findYamlFile.js.map +1 -0
  12. package/dist/assess/metadata/index.js +37 -0
  13. package/dist/assess/metadata/index.js.map +1 -0
  14. package/dist/assess/metadata/utils.js +159 -0
  15. package/dist/assess/metadata/utils.js.map +1 -0
  16. package/dist/assess/printing/index.js +11 -0
  17. package/dist/assess/printing/index.js.map +1 -0
  18. package/dist/assess/printing/utils.js +119 -0
  19. package/dist/assess/printing/utils.js.map +1 -0
  20. package/dist/audit/auditConfig.js +9 -0
  21. package/dist/audit/auditConfig.js.map +1 -0
  22. package/dist/{commands/audit → audit}/auditController.js +12 -15
  23. package/dist/audit/auditController.js.map +1 -0
  24. package/dist/audit/auditRequests.js +178 -0
  25. package/dist/audit/auditRequests.js.map +1 -0
  26. package/dist/audit/auditRequestsLegacy.js +63 -0
  27. package/dist/audit/auditRequestsLegacy.js.map +1 -0
  28. package/dist/audit/catalogueApplication/catalogueApplication.js +16 -29
  29. package/dist/audit/catalogueApplication/catalogueApplication.js.map +1 -0
  30. package/dist/audit/help.js +67 -0
  31. package/dist/audit/help.js.map +1 -0
  32. package/dist/audit/languageAnalysisEngine/commonApi.js +12 -14
  33. package/dist/audit/languageAnalysisEngine/commonApi.js.map +1 -0
  34. package/dist/audit/languageAnalysisEngine/filterProjectPath.js +2 -1
  35. package/dist/audit/languageAnalysisEngine/filterProjectPath.js.map +1 -0
  36. package/dist/audit/languageAnalysisEngine/getProjectRootFilenames.js +9 -12
  37. package/dist/audit/languageAnalysisEngine/getProjectRootFilenames.js.map +1 -0
  38. package/dist/audit/languageAnalysisEngine/sendSnapshot.js +21 -32
  39. package/dist/audit/languageAnalysisEngine/sendSnapshot.js.map +1 -0
  40. package/dist/audit/nodeAnalysisEngine/parseYarn2LockFileContents.js +9 -9
  41. package/dist/audit/nodeAnalysisEngine/parseYarn2LockFileContents.js.map +1 -0
  42. package/dist/audit/processAudit.js +22 -0
  43. package/dist/audit/processAudit.js.map +1 -0
  44. package/dist/audit/report/commonReportingFunctions.js +51 -77
  45. package/dist/audit/report/commonReportingFunctions.js.map +1 -0
  46. package/dist/audit/report/models/reportGuidanceModel.js +2 -5
  47. package/dist/audit/report/models/reportGuidanceModel.js.map +1 -0
  48. package/dist/audit/report/models/reportLibraryModel.js +3 -7
  49. package/dist/audit/report/models/reportLibraryModel.js.map +1 -0
  50. package/dist/audit/report/models/reportListModel.js +4 -9
  51. package/dist/audit/report/models/reportListModel.js.map +1 -0
  52. package/dist/audit/report/models/reportOutputModel.js +4 -9
  53. package/dist/audit/report/models/reportOutputModel.js.map +1 -0
  54. package/dist/audit/report/models/reportSeverityModel.js +2 -5
  55. package/dist/audit/report/models/reportSeverityModel.js.map +1 -0
  56. package/dist/audit/report/models/severityCountModel.js +3 -5
  57. package/dist/audit/report/models/severityCountModel.js.map +1 -0
  58. package/dist/audit/report/reportingFeature.js +30 -57
  59. package/dist/audit/report/reportingFeature.js.map +1 -0
  60. package/dist/audit/report/utils/reportUtils.js +28 -59
  61. package/dist/audit/report/utils/reportUtils.js.map +1 -0
  62. package/dist/audit/save.js +18 -19
  63. package/dist/audit/save.js.map +1 -0
  64. package/dist/{commands/audit → audit}/saveFile.js +3 -6
  65. package/dist/audit/saveFile.js.map +1 -0
  66. package/dist/auth/auth.js +103 -0
  67. package/dist/auth/auth.js.map +1 -0
  68. package/dist/auth/authRequests.js +18 -0
  69. package/dist/auth/authRequests.js.map +1 -0
  70. package/dist/cliConstants.js +57 -37
  71. package/dist/cliConstants.js.map +1 -0
  72. package/dist/commands/config/config.js +12 -13
  73. package/dist/commands/config/config.js.map +1 -0
  74. package/dist/commands/learn/learn.js +3 -6
  75. package/dist/commands/learn/learn.js.map +1 -0
  76. package/dist/commands/learn/processLearn.js +3 -6
  77. package/dist/commands/learn/processLearn.js.map +1 -0
  78. package/dist/common/HTTPClient.js +200 -101
  79. package/dist/common/HTTPClient.js.map +1 -0
  80. package/dist/{scan → common}/autoDetection.js +53 -36
  81. package/dist/common/autoDetection.js.map +1 -0
  82. package/dist/common/baseRequest.js +59 -23
  83. package/dist/common/baseRequest.js.map +1 -0
  84. package/dist/common/commonHelp.js +13 -13
  85. package/dist/common/commonHelp.js.map +1 -0
  86. package/dist/common/errorHandling.js +49 -63
  87. package/dist/common/errorHandling.js.map +1 -0
  88. package/dist/common/fail.js +6 -12
  89. package/dist/common/fail.js.map +1 -0
  90. package/dist/common/logging.js +26 -0
  91. package/dist/common/logging.js.map +1 -0
  92. package/dist/common/stringManipulations.js +8 -0
  93. package/dist/common/stringManipulations.js.map +1 -0
  94. package/dist/common/versionChecker.js +16 -19
  95. package/dist/common/versionChecker.js.map +1 -0
  96. package/dist/constants/constants.js +46 -65
  97. package/dist/constants/constants.js.map +1 -0
  98. package/dist/constants/lambda.js +8 -5
  99. package/dist/constants/lambda.js.map +1 -0
  100. package/dist/constants/locales.js +15 -10
  101. package/dist/constants/locales.js.map +1 -0
  102. package/dist/github/fingerprintConfig.js +10 -0
  103. package/dist/github/fingerprintConfig.js.map +1 -0
  104. package/dist/github/processFingerprint.js +26 -0
  105. package/dist/github/processFingerprint.js.map +1 -0
  106. package/dist/github/projectGroup.js +202 -0
  107. package/dist/github/projectGroup.js.map +1 -0
  108. package/dist/github/repoServices.js +73 -0
  109. package/dist/github/repoServices.js.map +1 -0
  110. package/dist/index.js +42 -39
  111. package/dist/index.js.map +1 -0
  112. package/dist/lambda/analytics.js +6 -9
  113. package/dist/lambda/analytics.js.map +1 -0
  114. package/dist/lambda/arn.js +6 -9
  115. package/dist/lambda/arn.js.map +1 -0
  116. package/dist/lambda/aws.js +29 -34
  117. package/dist/lambda/aws.js.map +1 -0
  118. package/dist/lambda/cliError.js +13 -41
  119. package/dist/lambda/cliError.js.map +1 -0
  120. package/dist/lambda/constants.js +3 -4
  121. package/dist/lambda/constants.js.map +1 -0
  122. package/dist/lambda/help.js +39 -44
  123. package/dist/lambda/help.js.map +1 -0
  124. package/dist/lambda/lambda.js +61 -65
  125. package/dist/lambda/lambda.js.map +1 -0
  126. package/dist/lambda/lambdaUtils.js +38 -32
  127. package/dist/lambda/lambdaUtils.js.map +1 -0
  128. package/dist/lambda/logUtils.js +21 -17
  129. package/dist/lambda/logUtils.js.map +1 -0
  130. package/dist/lambda/scanDetailCompletion.js +19 -25
  131. package/dist/lambda/scanDetailCompletion.js.map +1 -0
  132. package/dist/lambda/scanRequest.js +34 -41
  133. package/dist/lambda/scanRequest.js.map +1 -0
  134. package/dist/lambda/scanResults.js +8 -10
  135. package/dist/lambda/scanResults.js.map +1 -0
  136. package/dist/lambda/types.js +5 -7
  137. package/dist/lambda/types.js.map +1 -0
  138. package/dist/lambda/utils.js +33 -35
  139. package/dist/lambda/utils.js.map +1 -0
  140. package/dist/sbom/generateSbom.js +6 -10
  141. package/dist/sbom/generateSbom.js.map +1 -0
  142. package/dist/scaAnalysis/common/auditReport.js +10 -13
  143. package/dist/scaAnalysis/common/auditReport.js.map +1 -0
  144. package/dist/scaAnalysis/common/commonReportingFunctionsSca.js +35 -40
  145. package/dist/scaAnalysis/common/commonReportingFunctionsSca.js.map +1 -0
  146. package/dist/scaAnalysis/common/formatMessage.js +8 -17
  147. package/dist/scaAnalysis/common/formatMessage.js.map +1 -0
  148. package/dist/scaAnalysis/common/models/ScaReportModel.js +4 -9
  149. package/dist/scaAnalysis/common/models/ScaReportModel.js.map +1 -0
  150. package/dist/scaAnalysis/common/scaParserForGoAndJava.js +10 -9
  151. package/dist/scaAnalysis/common/scaParserForGoAndJava.js.map +1 -0
  152. package/dist/scaAnalysis/common/scaServicesUpload.js +53 -96
  153. package/dist/scaAnalysis/common/scaServicesUpload.js.map +1 -0
  154. package/dist/scaAnalysis/common/treeUpload.js +15 -25
  155. package/dist/scaAnalysis/common/treeUpload.js.map +1 -0
  156. package/dist/scaAnalysis/common/utils/reportUtilsSca.js +21 -29
  157. package/dist/scaAnalysis/common/utils/reportUtilsSca.js.map +1 -0
  158. package/dist/scaAnalysis/dotnet/analysis.js +15 -20
  159. package/dist/scaAnalysis/dotnet/analysis.js.map +1 -0
  160. package/dist/scaAnalysis/dotnet/index.js +4 -7
  161. package/dist/scaAnalysis/dotnet/index.js.map +1 -0
  162. package/dist/scaAnalysis/go/goAnalysis.js +10 -12
  163. package/dist/scaAnalysis/go/goAnalysis.js.map +1 -0
  164. package/dist/scaAnalysis/go/goParseDeps.js +9 -7
  165. package/dist/scaAnalysis/go/goParseDeps.js.map +1 -0
  166. package/dist/scaAnalysis/go/goReadDepFile.js +12 -9
  167. package/dist/scaAnalysis/go/goReadDepFile.js.map +1 -0
  168. package/dist/scaAnalysis/java/analysis.js +26 -22
  169. package/dist/scaAnalysis/java/analysis.js.map +1 -0
  170. package/dist/scaAnalysis/java/index.js +7 -10
  171. package/dist/scaAnalysis/java/index.js.map +1 -0
  172. package/dist/scaAnalysis/java/javaBuildDepsParser.js +41 -43
  173. package/dist/scaAnalysis/java/javaBuildDepsParser.js.map +1 -0
  174. package/dist/scaAnalysis/javascript/analysis.js +16 -20
  175. package/dist/scaAnalysis/javascript/analysis.js.map +1 -0
  176. package/dist/scaAnalysis/javascript/index.js +17 -19
  177. package/dist/scaAnalysis/javascript/index.js.map +1 -0
  178. package/dist/scaAnalysis/javascript/scaServiceParser.js +8 -15
  179. package/dist/scaAnalysis/javascript/scaServiceParser.js.map +1 -0
  180. package/dist/scaAnalysis/legacy/legacyFlow.js +15 -16
  181. package/dist/scaAnalysis/legacy/legacyFlow.js.map +1 -0
  182. package/dist/scaAnalysis/php/analysis.js +18 -18
  183. package/dist/scaAnalysis/php/analysis.js.map +1 -0
  184. package/dist/scaAnalysis/php/index.js +5 -8
  185. package/dist/scaAnalysis/php/index.js.map +1 -0
  186. package/dist/scaAnalysis/php/phpNewServicesMapper.js +9 -12
  187. package/dist/scaAnalysis/php/phpNewServicesMapper.js.map +1 -0
  188. package/dist/scaAnalysis/processServicesFlow.js +92 -37
  189. package/dist/scaAnalysis/processServicesFlow.js.map +1 -0
  190. package/dist/scaAnalysis/python/analysis.js +18 -24
  191. package/dist/scaAnalysis/python/analysis.js.map +1 -0
  192. package/dist/scaAnalysis/python/index.js +4 -7
  193. package/dist/scaAnalysis/python/index.js.map +1 -0
  194. package/dist/scaAnalysis/repoMode/gradleParser.js +9 -14
  195. package/dist/scaAnalysis/repoMode/gradleParser.js.map +1 -0
  196. package/dist/scaAnalysis/repoMode/index.js +11 -13
  197. package/dist/scaAnalysis/repoMode/index.js.map +1 -0
  198. package/dist/scaAnalysis/repoMode/mavenParser.js +26 -14
  199. package/dist/scaAnalysis/repoMode/mavenParser.js.map +1 -0
  200. package/dist/scaAnalysis/ruby/analysis.js +32 -46
  201. package/dist/scaAnalysis/ruby/analysis.js.map +1 -0
  202. package/dist/scaAnalysis/ruby/index.js +5 -8
  203. package/dist/scaAnalysis/ruby/index.js.map +1 -0
  204. package/dist/scaAnalysis/scaAnalysis.js +54 -55
  205. package/dist/scaAnalysis/scaAnalysis.js.map +1 -0
  206. package/dist/scan/fileUtils.js +36 -40
  207. package/dist/scan/fileUtils.js.map +1 -0
  208. package/dist/scan/formatScanOutput.js +47 -61
  209. package/dist/scan/formatScanOutput.js.map +1 -0
  210. package/dist/scan/help.js +8 -11
  211. package/dist/scan/help.js.map +1 -0
  212. package/dist/scan/models/groupedResultsModel.js +2 -5
  213. package/dist/scan/models/groupedResultsModel.js.map +1 -0
  214. package/dist/scan/models/resultContentModel.js +2 -2
  215. package/dist/scan/models/resultContentModel.js.map +1 -0
  216. package/dist/scan/models/scanResultsModel.js +2 -5
  217. package/dist/scan/models/scanResultsModel.js.map +1 -0
  218. package/dist/scan/populateProjectIdAndProjectName.js +24 -62
  219. package/dist/scan/populateProjectIdAndProjectName.js.map +1 -0
  220. package/dist/scan/processScan.js +28 -0
  221. package/dist/scan/processScan.js.map +1 -0
  222. package/dist/scan/saveResults.js +3 -6
  223. package/dist/scan/saveResults.js.map +1 -0
  224. package/dist/scan/scan.js +33 -53
  225. package/dist/scan/scan.js.map +1 -0
  226. package/dist/scan/scanConfig.js +14 -12
  227. package/dist/scan/scanConfig.js.map +1 -0
  228. package/dist/scan/scanController.js +20 -22
  229. package/dist/scan/scanController.js.map +1 -0
  230. package/dist/scan/scanRequests.js +86 -0
  231. package/dist/scan/scanRequests.js.map +1 -0
  232. package/dist/scan/scanResults.js +26 -72
  233. package/dist/scan/scanResults.js.map +1 -0
  234. package/dist/telemetry/telemetry.js +29 -59
  235. package/dist/telemetry/telemetry.js.map +1 -0
  236. package/dist/utils/capabilities.js +2 -1
  237. package/dist/utils/capabilities.js.map +1 -0
  238. package/dist/utils/commonApi.js +61 -52
  239. package/dist/utils/commonApi.js.map +1 -0
  240. package/dist/utils/filterProjectPath.js +2 -1
  241. package/dist/utils/filterProjectPath.js.map +1 -0
  242. package/dist/utils/generalAPI.js +11 -33
  243. package/dist/utils/generalAPI.js.map +1 -0
  244. package/dist/utils/getConfig.js +8 -13
  245. package/dist/utils/getConfig.js.map +1 -0
  246. package/dist/utils/oraWrapper.js +7 -14
  247. package/dist/utils/oraWrapper.js.map +1 -0
  248. package/dist/utils/paramsUtil/commandlineParams.js +2 -5
  249. package/dist/utils/paramsUtil/commandlineParams.js.map +1 -0
  250. package/dist/utils/paramsUtil/configStoreParams.js +9 -10
  251. package/dist/utils/paramsUtil/configStoreParams.js.map +1 -0
  252. package/dist/utils/paramsUtil/envVariableParams.js +2 -3
  253. package/dist/utils/paramsUtil/envVariableParams.js.map +1 -0
  254. package/dist/utils/paramsUtil/paramHandler.js +12 -13
  255. package/dist/utils/paramsUtil/paramHandler.js.map +1 -0
  256. package/dist/utils/parsedCLIOptions.js +4 -7
  257. package/dist/utils/parsedCLIOptions.js.map +1 -0
  258. package/dist/utils/requestUtils.js +7 -13
  259. package/dist/utils/requestUtils.js.map +1 -0
  260. package/dist/utils/saveFile.js +8 -11
  261. package/dist/utils/saveFile.js.map +1 -0
  262. package/dist/utils/validationCheck.js +5 -11
  263. package/dist/utils/validationCheck.js.map +1 -0
  264. package/package.json +39 -48
  265. package/.prettierignore +0 -1
  266. package/bin/contrast.js +0 -2
  267. package/dist/audit/languageAnalysisEngine/util/requestUtils.js +0 -14
  268. package/dist/commands/audit/auditConfig.js +0 -12
  269. package/dist/commands/audit/help.js +0 -70
  270. package/dist/commands/audit/processAudit.js +0 -24
  271. package/dist/commands/auth/auth.js +0 -120
  272. package/dist/commands/github/fingerprintConfig.js +0 -13
  273. package/dist/commands/github/processFingerprint.js +0 -28
  274. package/dist/commands/github/projectGroup.js +0 -254
  275. package/dist/commands/github/repoServices.js +0 -108
  276. package/dist/commands/scan/processScan.js +0 -31
  277. package/dist/lambda/__mocks__/aws.js +0 -21
  278. package/dist/lambda/__mocks__/lambdaConfig.json +0 -42
  279. package/src/audit/catalogueApplication/catalogueApplication.js +0 -51
  280. package/src/audit/languageAnalysisEngine/commonApi.js +0 -20
  281. package/src/audit/languageAnalysisEngine/filterProjectPath.js +0 -21
  282. package/src/audit/languageAnalysisEngine/getProjectRootFilenames.js +0 -36
  283. package/src/audit/languageAnalysisEngine/sendSnapshot.js +0 -57
  284. package/src/audit/languageAnalysisEngine/util/requestUtils.js +0 -17
  285. package/src/audit/nodeAnalysisEngine/parseYarn2LockFileContents.js +0 -63
  286. package/src/audit/report/commonReportingFunctions.js +0 -412
  287. package/src/audit/report/models/reportGuidanceModel.ts +0 -5
  288. package/src/audit/report/models/reportLibraryModel.ts +0 -30
  289. package/src/audit/report/models/reportListModel.ts +0 -49
  290. package/src/audit/report/models/reportOutputModel.ts +0 -29
  291. package/src/audit/report/models/reportSeverityModel.ts +0 -18
  292. package/src/audit/report/models/severityCountModel.ts +0 -22
  293. package/src/audit/report/reportingFeature.ts +0 -110
  294. package/src/audit/report/utils/reportUtils.ts +0 -165
  295. package/src/audit/save.js +0 -67
  296. package/src/cliConstants.js +0 -522
  297. package/src/commands/audit/auditConfig.js +0 -18
  298. package/src/commands/audit/auditController.js +0 -50
  299. package/src/commands/audit/help.js +0 -72
  300. package/src/commands/audit/processAudit.js +0 -34
  301. package/src/commands/audit/saveFile.js +0 -15
  302. package/src/commands/auth/auth.js +0 -146
  303. package/src/commands/config/config.js +0 -41
  304. package/src/commands/github/fingerprintConfig.js +0 -19
  305. package/src/commands/github/processFingerprint.js +0 -37
  306. package/src/commands/github/projectGroup.js +0 -294
  307. package/src/commands/github/repoServices.js +0 -122
  308. package/src/commands/learn/learn.js +0 -10
  309. package/src/commands/learn/processLearn.js +0 -13
  310. package/src/commands/scan/processScan.js +0 -42
  311. package/src/common/HTTPClient.js +0 -775
  312. package/src/common/baseRequest.ts +0 -83
  313. package/src/common/commonHelp.js +0 -53
  314. package/src/common/errorHandling.js +0 -157
  315. package/src/common/fail.js +0 -79
  316. package/src/common/versionChecker.js +0 -75
  317. package/src/constants/constants.js +0 -71
  318. package/src/constants/lambda.js +0 -85
  319. package/src/constants/locales.js +0 -365
  320. package/src/index.ts +0 -142
  321. package/src/lambda/__mocks__/aws.ts +0 -32
  322. package/src/lambda/__mocks__/lambdaConfig.json +0 -42
  323. package/src/lambda/analytics.ts +0 -9
  324. package/src/lambda/arn.ts +0 -33
  325. package/src/lambda/aws.ts +0 -248
  326. package/src/lambda/cliError.ts +0 -72
  327. package/src/lambda/constants.ts +0 -11
  328. package/src/lambda/help.ts +0 -92
  329. package/src/lambda/lambda.ts +0 -230
  330. package/src/lambda/lambdaUtils.ts +0 -111
  331. package/src/lambda/logUtils.ts +0 -64
  332. package/src/lambda/scanDetailCompletion.ts +0 -78
  333. package/src/lambda/scanRequest.ts +0 -169
  334. package/src/lambda/scanResults.ts +0 -29
  335. package/src/lambda/types.ts +0 -36
  336. package/src/lambda/utils.ts +0 -188
  337. package/src/sbom/generateSbom.ts +0 -45
  338. package/src/scaAnalysis/common/auditReport.js +0 -59
  339. package/src/scaAnalysis/common/commonReportingFunctionsSca.js +0 -276
  340. package/src/scaAnalysis/common/formatMessage.js +0 -67
  341. package/src/scaAnalysis/common/models/ScaReportModel.ts +0 -81
  342. package/src/scaAnalysis/common/scaParserForGoAndJava.js +0 -41
  343. package/src/scaAnalysis/common/scaServicesUpload.js +0 -155
  344. package/src/scaAnalysis/common/treeUpload.js +0 -51
  345. package/src/scaAnalysis/common/utils/reportUtilsSca.ts +0 -123
  346. package/src/scaAnalysis/dotnet/analysis.js +0 -72
  347. package/src/scaAnalysis/dotnet/index.js +0 -11
  348. package/src/scaAnalysis/go/goAnalysis.js +0 -26
  349. package/src/scaAnalysis/go/goParseDeps.js +0 -203
  350. package/src/scaAnalysis/go/goReadDepFile.js +0 -34
  351. package/src/scaAnalysis/java/analysis.js +0 -148
  352. package/src/scaAnalysis/java/index.js +0 -29
  353. package/src/scaAnalysis/java/javaBuildDepsParser.js +0 -439
  354. package/src/scaAnalysis/javascript/analysis.js +0 -111
  355. package/src/scaAnalysis/javascript/index.js +0 -104
  356. package/src/scaAnalysis/javascript/scaServiceParser.js +0 -151
  357. package/src/scaAnalysis/legacy/legacyFlow.js +0 -43
  358. package/src/scaAnalysis/php/analysis.js +0 -78
  359. package/src/scaAnalysis/php/index.js +0 -28
  360. package/src/scaAnalysis/php/phpNewServicesMapper.js +0 -77
  361. package/src/scaAnalysis/processServicesFlow.js +0 -119
  362. package/src/scaAnalysis/python/analysis.js +0 -93
  363. package/src/scaAnalysis/python/index.js +0 -16
  364. package/src/scaAnalysis/repoMode/gradleParser.js +0 -88
  365. package/src/scaAnalysis/repoMode/index.js +0 -21
  366. package/src/scaAnalysis/repoMode/mavenParser.js +0 -139
  367. package/src/scaAnalysis/ruby/analysis.js +0 -413
  368. package/src/scaAnalysis/ruby/index.js +0 -16
  369. package/src/scaAnalysis/scaAnalysis.js +0 -171
  370. package/src/scan/autoDetection.js +0 -175
  371. package/src/scan/fileUtils.js +0 -206
  372. package/src/scan/formatScanOutput.ts +0 -225
  373. package/src/scan/help.js +0 -56
  374. package/src/scan/models/groupedResultsModel.ts +0 -20
  375. package/src/scan/models/resultContentModel.ts +0 -86
  376. package/src/scan/models/scanResultsModel.ts +0 -55
  377. package/src/scan/populateProjectIdAndProjectName.js +0 -73
  378. package/src/scan/saveResults.js +0 -14
  379. package/src/scan/scan.ts +0 -68
  380. package/src/scan/scanConfig.js +0 -58
  381. package/src/scan/scanController.js +0 -98
  382. package/src/scan/scanResults.js +0 -171
  383. package/src/telemetry/telemetry.ts +0 -154
  384. package/src/utils/capabilities.js +0 -12
  385. package/src/utils/commonApi.js +0 -103
  386. package/src/utils/filterProjectPath.js +0 -25
  387. package/src/utils/generalAPI.js +0 -52
  388. package/src/utils/getConfig.ts +0 -34
  389. package/src/utils/oraWrapper.js +0 -29
  390. package/src/utils/paramsUtil/commandlineParams.js +0 -12
  391. package/src/utils/paramsUtil/configStoreParams.js +0 -19
  392. package/src/utils/paramsUtil/envVariableParams.js +0 -10
  393. package/src/utils/paramsUtil/paramHandler.js +0 -38
  394. package/src/utils/parsedCLIOptions.js +0 -32
  395. package/src/utils/requestUtils.js +0 -29
  396. package/src/utils/saveFile.js +0 -20
  397. package/src/utils/validationCheck.js +0 -39
@@ -1,31 +1,25 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createFunctionEvent = exports.requestScanFunctionPost = exports.sendScanPostRequest = void 0;
7
- const i18n_1 = __importDefault(require("i18n"));
8
- const log_symbols_1 = __importDefault(require("log-symbols"));
9
- const chalk_1 = __importDefault(require("chalk"));
10
- const arn_1 = require("./arn");
11
- const aws_1 = require("./aws");
12
- const utils_1 = require("./utils");
13
- const commonApi_1 = require("../utils/commonApi");
14
- const logUtils_1 = require("./logUtils");
15
- const cliError_1 = require("./cliError");
16
- const constants_1 = require("./constants");
17
- const requestUtils_1 = require("../utils/requestUtils");
1
+ import i18n from 'i18n';
2
+ import logSymbols from 'log-symbols';
3
+ import chalk from 'chalk';
4
+ import { parseARN } from './arn.js';
5
+ import { getLambdaClient, getLambdaFunctionConfiguration, getLambdaPolicies, getLayersLinks } from './aws.js';
6
+ import { toLowerKeys } from './utils.js';
7
+ import { getHttpClient } from '../utils/commonApi.js';
8
+ import { log, prettyPrintJson } from './logUtils.js';
9
+ import { CliError } from './cliError.js';
10
+ import { ERRORS } from './constants.js';
11
+ import { sleep } from '../utils/requestUtils.js';
18
12
  const MAX_RETRIES = 2;
19
13
  const sendScanPostRequest = async (config, params, functionsEvent, showProgress = false, retryNumber = 0) => {
20
- const client = (0, commonApi_1.getHttpClient)(config);
14
+ const client = getHttpClient(config);
21
15
  if (showProgress) {
22
- (0, logUtils_1.log)(i18n_1.default.__('sendingScanRequest', { icon: log_symbols_1.default.success }));
16
+ log(i18n.__('sendingScanRequest', { icon: logSymbols.success }));
23
17
  }
24
- const res = await client.postFunctionScan(config, params, functionsEvent);
18
+ const res = (await client.postFunctionScan(config, params, functionsEvent));
25
19
  const { statusCode, body } = res;
26
20
  if (statusCode === 201) {
27
21
  if (showProgress) {
28
- (0, logUtils_1.log)(i18n_1.default.__('scanRequestedSuccessfully', { icon: log_symbols_1.default.success }));
22
+ log(i18n.__('scanRequestedSuccessfully', { icon: logSymbols.success }));
29
23
  }
30
24
  return body?.data?.scanId;
31
25
  }
@@ -34,33 +28,32 @@ const sendScanPostRequest = async (config, params, functionsEvent, showProgress
34
28
  let description = '';
35
29
  switch (errorCode) {
36
30
  case 'not_supported_runtime':
37
- description = i18n_1.default.__(errorCode, {
31
+ description = i18n.__(errorCode, {
38
32
  runtime: data?.runtime,
39
33
  supportedRuntimes: data?.supportedRuntimes.sort().join(' | ')
40
34
  });
41
35
  errorCode = false;
42
36
  break;
43
37
  case 'not_supported_lambda':
44
- description = i18n_1.default.__(errorCode);
38
+ description = i18n.__(errorCode);
45
39
  errorCode = false;
46
40
  break;
47
41
  default:
48
42
  if (retryNumber < MAX_RETRIES) {
49
- await (0, requestUtils_1.sleep)(3 * 1000);
43
+ await sleep(3 * 1000);
50
44
  return sendScanPostRequest(config, params, functionsEvent, showProgress, retryNumber + 1);
51
45
  }
52
46
  }
53
- throw new cliError_1.CliError(constants_1.ERRORS.FAILED_TO_START_SCAN, {
47
+ throw new CliError(ERRORS.FAILED_TO_START_SCAN, {
54
48
  statusCode,
55
49
  errorCode,
56
50
  data,
57
51
  description
58
52
  });
59
53
  };
60
- exports.sendScanPostRequest = sendScanPostRequest;
61
54
  const createFunctionEvent = (lambdaConfig, layersLinks, lambdaPolicies) => {
62
55
  delete lambdaConfig.$metadata;
63
- const functionEvent = (0, utils_1.toLowerKeys)(lambdaConfig.Configuration);
56
+ const functionEvent = toLowerKeys(lambdaConfig.Configuration);
64
57
  functionEvent['code'] = lambdaConfig.Code;
65
58
  functionEvent['rolePolicies'] = lambdaPolicies;
66
59
  if (layersLinks) {
@@ -68,43 +61,43 @@ const createFunctionEvent = (lambdaConfig, layersLinks, lambdaPolicies) => {
68
61
  }
69
62
  return { function: functionEvent };
70
63
  };
71
- exports.createFunctionEvent = createFunctionEvent;
72
64
  const requestScanFunctionPost = async (config, lambdaOptions) => {
73
65
  const { verbose, jsonOutput, functionName } = lambdaOptions;
74
- const lambdaClient = (0, aws_1.getLambdaClient)(lambdaOptions);
66
+ const lambdaClient = getLambdaClient(lambdaOptions);
75
67
  if (!jsonOutput) {
76
- (0, logUtils_1.log)(i18n_1.default.__('fetchingConfiguration', {
77
- icon: log_symbols_1.default.success,
78
- functionName: chalk_1.default.bold(functionName)
68
+ log(i18n.__('fetchingConfiguration', {
69
+ icon: logSymbols.success,
70
+ functionName: chalk.bold(functionName)
79
71
  }));
80
72
  }
81
- const lambdaConfig = await (0, aws_1.getLambdaFunctionConfiguration)(lambdaClient, lambdaOptions);
73
+ const lambdaConfig = await getLambdaFunctionConfiguration(lambdaClient, lambdaOptions);
82
74
  if (!lambdaConfig?.Configuration) {
83
- throw new cliError_1.CliError(constants_1.ERRORS.FAILED_TO_START_SCAN, {
75
+ throw new CliError(ERRORS.FAILED_TO_START_SCAN, {
84
76
  errorCode: 'missingLambdaConfig'
85
77
  });
86
78
  }
87
79
  const { Configuration } = lambdaConfig;
88
- const layersLinks = await (0, aws_1.getLayersLinks)(lambdaClient, Configuration);
89
- const lambdaPolicies = await (0, aws_1.getLambdaPolicies)(Configuration, lambdaOptions);
80
+ const layersLinks = await getLayersLinks(lambdaClient, Configuration);
81
+ const lambdaPolicies = await getLambdaPolicies(Configuration, lambdaOptions);
90
82
  const functionEvent = createFunctionEvent(lambdaConfig, layersLinks, lambdaPolicies);
91
83
  const { FunctionArn: functionArn } = Configuration;
92
84
  if (!functionArn) {
93
- throw new cliError_1.CliError(constants_1.ERRORS.FAILED_TO_START_SCAN, {
85
+ throw new CliError(ERRORS.FAILED_TO_START_SCAN, {
94
86
  errorCode: 'missingLambdaArn'
95
87
  });
96
88
  }
97
- const parsedARN = (0, arn_1.parseARN)(functionArn);
89
+ const parsedARN = parseARN(functionArn);
98
90
  const params = {
99
91
  organizationId: config.organizationId,
100
92
  provider: 'aws',
101
93
  accountId: parsedARN.accountId
102
94
  };
103
95
  if (verbose) {
104
- (0, logUtils_1.log)(i18n_1.default.__('fetchedConfiguration', { icon: log_symbols_1.default.success }));
105
- (0, logUtils_1.prettyPrintJson)(functionEvent);
96
+ log(i18n.__('fetchedConfiguration', { icon: logSymbols.success }));
97
+ prettyPrintJson(functionEvent);
106
98
  }
107
99
  const scanId = await sendScanPostRequest(config, params, functionEvent, !jsonOutput);
108
100
  return { scanId, params, functionArn };
109
101
  };
110
- exports.requestScanFunctionPost = requestScanFunctionPost;
102
+ export { sendScanPostRequest, requestScanFunctionPost, createFunctionEvent };
103
+ //# sourceMappingURL=scanRequest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanRequest.js","sourceRoot":"","sources":["../../src/lambda/scanRequest.ts"],"names":[],"mappings":"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"}
@@ -1,16 +1,14 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getScanResults = void 0;
4
- const commonApi_1 = require("../utils/commonApi");
5
- const cliError_1 = require("./cliError");
6
- const constants_1 = require("./constants");
1
+ import { getHttpClient } from '../utils/commonApi.js';
2
+ import { CliError } from './cliError.js';
3
+ import { ERRORS } from './constants.js';
7
4
  const getScanResults = async (config, params, scanId, functionArn) => {
8
- const client = (0, commonApi_1.getHttpClient)(config);
9
- const { statusCode, body } = await client.getFunctionScanResults(config, params, scanId, functionArn);
5
+ const client = getHttpClient(config);
6
+ const { statusCode, body } = (await client.getFunctionScanResults(config, params, scanId, functionArn));
10
7
  if (statusCode === 200) {
11
8
  return body;
12
9
  }
13
10
  const { errorCode } = body || {};
14
- throw new cliError_1.CliError(constants_1.ERRORS.FAILED_TO_GET_RESULTS, { statusCode, errorCode });
11
+ throw new CliError(ERRORS.FAILED_TO_GET_RESULTS, { statusCode, errorCode });
15
12
  };
16
- exports.getScanResults = getScanResults;
13
+ export { getScanResults };
14
+ //# sourceMappingURL=scanResults.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scanResults.js","sourceRoot":"","sources":["../../src/lambda/scanResults.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAGvC,MAAM,cAAc,GAAG,KAAK,EAC1B,MAAW,EACX,MAAiB,EACjB,MAAc,EACd,WAAmB,EACnB,EAAE;IACF,MAAM,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC,CAAA;IAEpC,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,GAAG,CAAC,MAAM,MAAM,CAAC,sBAAsB,CAC/D,MAAM,EACN,MAAM,EACN,MAAM,EACN,WAAW,CACZ,CAAQ,CAAA;IAET,IAAI,UAAU,KAAK,GAAG,EAAE;QACtB,OAAO,IAAI,CAAA;KACZ;IAED,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,IAAI,EAAE,CAAA;IAChC,MAAM,IAAI,QAAQ,CAAC,MAAM,CAAC,qBAAqB,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAA;AAC7E,CAAC,CAAA;AAED,OAAO,EAAE,cAAc,EAAE,CAAA"}
@@ -1,13 +1,11 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EventType = exports.StatusType = void 0;
4
- var StatusType;
1
+ export var StatusType;
5
2
  (function (StatusType) {
6
3
  StatusType["FAILED"] = "failed";
7
4
  StatusType["SUCCESS"] = "success";
8
- })(StatusType = exports.StatusType || (exports.StatusType = {}));
9
- var EventType;
5
+ })(StatusType || (StatusType = {}));
6
+ export var EventType;
10
7
  (function (EventType) {
11
8
  EventType["START"] = "start_command_session";
12
9
  EventType["END"] = "end_command_session";
13
- })(EventType = exports.EventType || (exports.EventType = {}));
10
+ })(EventType || (EventType = {}));
11
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/lambda/types.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,UAGX;AAHD,WAAY,UAAU;IACpB,+BAAiB,CAAA;IACjB,iCAAmB,CAAA;AACrB,CAAC,EAHW,UAAU,KAAV,UAAU,QAGrB;AAED,MAAM,CAAN,IAAY,SAGX;AAHD,WAAY,SAAS;IACnB,4CAA+B,CAAA;IAC/B,wCAA2B,CAAA;AAC7B,CAAC,EAHW,SAAS,KAAT,SAAS,QAGpB"}
@@ -1,14 +1,10 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.exportedForTesting = exports.printResults = exports.toLowerKeys = void 0;
7
- const chalk_1 = __importDefault(require("chalk"));
8
- const lodash_1 = require("lodash");
9
- const i18n_1 = __importDefault(require("i18n"));
10
- const logUtils_1 = require("./logUtils");
11
- i18n_1.default.setLocale('en');
1
+ import chalk from 'chalk';
2
+ import { groupBy, sortBy, capitalize, minBy } from 'lodash-es';
3
+ import i18n from 'i18n';
4
+ import { log } from './logUtils.js';
5
+ // fix for using `plural`
6
+ // https://github.com/mashpie/i18n-node/issues/429
7
+ i18n.setLocale('en');
12
8
  class PrintVulnerability {
13
9
  constructor(index, vulnerability, group) {
14
10
  const { severityText, title, description, remediation, categoryText } = vulnerability;
@@ -16,7 +12,7 @@ class PrintVulnerability {
16
12
  this.vulnerability = vulnerability;
17
13
  this.index = index;
18
14
  this.title = title;
19
- this.severity = (0, lodash_1.capitalize)(severityText);
15
+ this.severity = capitalize(severityText);
20
16
  this.description = underlineLinks(description);
21
17
  this.remediation = remediation?.description;
22
18
  this.recommendation = '';
@@ -52,13 +48,13 @@ class PrintVulnerability {
52
48
  const [policy, description] = comment.split(':').map(c => c.trim());
53
49
  return { policy, description };
54
50
  };
55
- const groupByPolicy = (0, lodash_1.groupBy)(comment, c => splitComment(c).policy);
51
+ const groupByPolicy = groupBy(comment, c => splitComment(c).policy);
56
52
  Object.entries(groupByPolicy).forEach(([policy, commentArr]) => {
57
53
  const comments = commentArr
58
54
  .map(splitComment)
59
55
  .map(({ description }) => ` - ${description}`)
60
56
  .join('\n');
61
- this.whatHappened += i18n_1.default.__('whatHappenedItem', { policy, comments });
57
+ this.whatHappened += i18n.__('whatHappenedItem', { policy, comments });
62
58
  });
63
59
  }
64
60
  }
@@ -67,14 +63,14 @@ class PrintVulnerability {
67
63
  this.recommendation = this.vulnerability?.remediation?.description;
68
64
  return;
69
65
  }
70
- const maxSeverity = (0, lodash_1.minBy)(this.group, 'severity');
71
- this.title = i18n_1.default.__('vulnerableDependency');
72
- this.severity = (0, lodash_1.capitalize)(maxSeverity.severityText);
66
+ const maxSeverity = minBy(this.group, 'severity');
67
+ this.title = i18n.__('vulnerableDependency');
68
+ this.severity = capitalize(maxSeverity.severityText);
73
69
  this.recommendation = maxSeverity.remediation?.description;
74
70
  const library = groupByDependency({ title: this.vulnerability.title });
75
71
  const [packageName, version] = library.split(':');
76
72
  const allCves = this.group.map(groupByCVE);
77
- this.description = i18n_1.default.__mf('vulnerableDependencyDescriptions', {
73
+ this.description = i18n.__mf('vulnerableDependencyDescriptions', {
78
74
  NUM: this.group.length,
79
75
  packageName,
80
76
  version,
@@ -82,26 +78,28 @@ class PrintVulnerability {
82
78
  });
83
79
  }
84
80
  print() {
85
- (0, logUtils_1.log)(`${this.index}.`);
86
- (0, logUtils_1.log)(`${chalk_1.default.bold(this.severity)} | ${chalk_1.default.bold(this.title)} ${this.description}`);
81
+ log(`${this.index}.`);
82
+ // prettier-ignore
83
+ log(`${chalk.bold(this.severity)} | ${chalk.bold(this.title)} ${this.description}`);
87
84
  if (this.whatHappened) {
88
- (0, logUtils_1.log)(`\n${chalk_1.default.bold(i18n_1.default.__('whatHappenedTitle'))}\n${this.whatHappened}`);
85
+ log(`\n${chalk.bold(i18n.__('whatHappenedTitle'))}\n${this.whatHappened}`);
89
86
  }
90
87
  if (this.recommendation) {
91
- (0, logUtils_1.log)(`${chalk_1.default.bold(i18n_1.default.__('recommendation'))}\n${this.recommendation}`);
88
+ log(`${chalk.bold(i18n.__('recommendation'))}\n${this.recommendation}`);
92
89
  }
93
- (0, logUtils_1.log)('');
90
+ log('');
94
91
  }
95
92
  }
96
93
  const groupByCVE = ({ title }) => title.substring(0, title.indexOf('[') - 1);
97
94
  const groupByDependency = ({ title }) => title.substring(title.indexOf('[') + 1, title.indexOf(']'));
98
95
  const printResults = (results) => {
96
+ //filter out any vulnerabs which is not least privilege or dependencies- cli does not handle other vulnerabs yet
99
97
  const vulnerabs = results.filter(r => r.category === 1 || r.category === 4);
100
- const sortBySeverity = (0, lodash_1.sortBy)(vulnerabs, ['severity', 'title']);
98
+ const sortBySeverity = sortBy(vulnerabs, ['severity', 'title']);
101
99
  const notDependencies = sortBySeverity.filter(r => r.category !== 1);
102
100
  const dependencies = sortBySeverity.filter(r => r.category === 1);
103
- const dependenciesByLibrary = (0, lodash_1.groupBy)(dependencies, groupByDependency);
104
- (0, logUtils_1.log)('');
101
+ const dependenciesByLibrary = groupBy(dependencies, groupByDependency);
102
+ log('');
105
103
  notDependencies.forEach((vulnerability, index) => {
106
104
  const printVulnerab = new PrintVulnerability(index + 1, vulnerability);
107
105
  printVulnerab.print();
@@ -113,24 +111,23 @@ const printResults = (results) => {
113
111
  });
114
112
  const dependenciesCount = Object.keys(dependenciesByLibrary).length;
115
113
  const resultCount = notDependencies.length + dependenciesCount;
116
- (0, logUtils_1.log)(i18n_1.default.__n('foundVulnerabilities', resultCount), { bold: true });
114
+ log(i18n.__n('foundVulnerabilities', resultCount), { bold: true });
117
115
  const counters = getNotDependenciesCounters(notDependencies);
118
116
  if (dependenciesCount) {
119
- counters.push(i18n_1.default.__n('dependenciesCount', dependenciesCount));
117
+ counters.push(i18n.__n('dependenciesCount', dependenciesCount));
120
118
  }
121
- (0, logUtils_1.log)(counters.join(' | '), { bold: true });
119
+ log(counters.join(' | '), { bold: true });
122
120
  };
123
- exports.printResults = printResults;
124
121
  const getNotDependenciesCounters = (notDependencies) => {
125
- const groupByType = (0, lodash_1.groupBy)(notDependencies, ['categoryText']);
126
- return Object.values(groupByType).map(group => `${group.length} ${(0, lodash_1.capitalize)(group[0].categoryText)}`);
122
+ const groupByType = groupBy(notDependencies, ['categoryText']);
123
+ return Object.values(groupByType).map(group => `${group.length} ${capitalize(group[0].categoryText)}`);
127
124
  };
128
125
  const underlineLinks = (text) => {
129
126
  if (!text) {
130
127
  return text;
131
128
  }
132
129
  const urlRegex = /(https?:\/\/[^\s]+)/g;
133
- return text.replace(urlRegex, chalk_1.default.underline('$1'));
130
+ return text.replace(urlRegex, chalk.underline('$1'));
134
131
  };
135
132
  function toLowerKeys(obj) {
136
133
  return Object.keys(obj).reduce((accumulator, key) => {
@@ -139,9 +136,10 @@ function toLowerKeys(obj) {
139
136
  return accumulator;
140
137
  }, {});
141
138
  }
142
- exports.toLowerKeys = toLowerKeys;
143
- exports.exportedForTesting = {
139
+ export { toLowerKeys, printResults };
140
+ export const exportedForTesting = {
144
141
  underlineLinks,
145
142
  printResults,
146
143
  PrintVulnerability
147
144
  };
145
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/lambda/utils.ts"],"names":[],"mappings":"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"}
@@ -1,9 +1,6 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.generateSCASbom = exports.generateSbom = void 0;
4
- const commonApi_1 = require("../utils/commonApi");
5
- const generateSbom = (config, type) => {
6
- const client = (0, commonApi_1.getHttpClient)(config);
1
+ import { getHttpClient } from '../utils/commonApi.js';
2
+ export const generateSbom = (config, type) => {
3
+ const client = getHttpClient(config);
7
4
  return client
8
5
  .getSbom(config, type)
9
6
  .then((res) => {
@@ -24,9 +21,8 @@ const generateSbom = (config, type) => {
24
21
  console.log(err);
25
22
  });
26
23
  };
27
- exports.generateSbom = generateSbom;
28
- const generateSCASbom = (config, type, reportId) => {
29
- const client = (0, commonApi_1.getHttpClient)(config);
24
+ export const generateSCASbom = (config, type, reportId) => {
25
+ const client = getHttpClient(config);
30
26
  return client
31
27
  .getSCASbom(config, type, reportId)
32
28
  .then((res) => {
@@ -42,4 +38,4 @@ const generateSCASbom = (config, type, reportId) => {
42
38
  console.log(err);
43
39
  });
44
40
  };
45
- exports.generateSCASbom = generateSCASbom;
41
+ //# sourceMappingURL=generateSbom.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generateSbom.js","sourceRoot":"","sources":["../../src/sbom/generateSbom.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AAErD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,MAAW,EAAE,IAAY,EAAE,EAAE;IACxD,MAAM,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC,CAAA;IACpC,OAAO,MAAM;SACV,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC;SACrB,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE;QACjB,IAAI,GAAG,CAAC,UAAU,KAAK,GAAG,EAAE;YAC1B,OAAO,GAAG,CAAC,IAAI,CAAA;SAChB;aAAM,IAAI,GAAG,CAAC,UAAU,KAAK,GAAG,EAAE;YACjC,OAAO,CAAC,GAAG,CAAC,wDAAwD,CAAC,CAAA;YACrE,OAAO,CAAC,GAAG,CACT,+DAA+D,MAAM,CAAC,cAAc,YAAY,MAAM,CAAC,aAAa,EAAE,CACvH,CAAA;YACD,OAAO,SAAS,CAAA;SACjB;aAAM;YACL,OAAO,CAAC,GAAG,CAAC,sDAAsD,CAAC,CAAA;YACnE,OAAO,SAAS,CAAA;SACjB;IACH,CAAC,CAAC;SACD,KAAK,CAAC,CAAC,GAAQ,EAAE,EAAE;QAClB,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;IAClB,CAAC,CAAC,CAAA;AACN,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,MAAW,EACX,IAAY,EACZ,QAAgB,EAChB,EAAE;IACF,MAAM,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC,CAAA;IACpC,OAAO,MAAM;SACV,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,CAAC;SAClC,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE;QACjB,IAAI,GAAG,CAAC,UAAU,KAAK,GAAG,EAAE;YAC1B,OAAO,GAAG,CAAC,IAAI,CAAA;SAChB;aAAM;YACL,OAAO,CAAC,GAAG,CAAC,sDAAsD,CAAC,CAAA;YACnE,OAAO,SAAS,CAAA;SACjB;IACH,CAAC,CAAC;SACD,KAAK,CAAC,CAAC,GAAQ,EAAE,EAAE;QAClB,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAA;IAClB,CAAC,CAAC,CAAA;AACN,CAAC,CAAA"}
@@ -1,9 +1,9 @@
1
- "use strict";
2
- const { getSeverityCounts, printNoVulnFoundMsg } = require('../../audit/report/commonReportingFunctions');
3
- const common = require('../../common/fail');
4
- const { printFormattedOutputSca } = require('./commonReportingFunctionsSca');
5
- const { auditSave } = require('../../audit/save');
6
- const processAuditReport = async (config, reportModelList, reportId) => {
1
+ import { auditSave } from '../../audit/save.js';
2
+ import { processFail } from '../../common/fail.js';
3
+ import { getSeverityCounts, printNoVulnFoundMsg } from '../../audit/report/commonReportingFunctions.js';
4
+ import { printFormattedOutputSca } from './commonReportingFunctionsSca.js';
5
+ import { logInfo } from '../../common/logging.js';
6
+ export const processAuditReport = async (config, reportModelList, reportId) => {
7
7
  let severityCounts = {};
8
8
  if (reportModelList !== undefined) {
9
9
  severityCounts = formatScaServicesReport(config, reportModelList);
@@ -12,13 +12,13 @@ const processAuditReport = async (config, reportModelList, reportId) => {
12
12
  await auditSave(config, reportId);
13
13
  }
14
14
  else {
15
- console.log('Use contrast audit --save to generate an SBOM');
15
+ logInfo('Use contrast audit --save to generate an SBOM');
16
16
  }
17
17
  if (config.fail) {
18
- common.processFail(config, severityCounts);
18
+ processFail(config, severityCounts);
19
19
  }
20
20
  };
21
- const formatScaServicesReport = (config, reportModelList) => {
21
+ export const formatScaServicesReport = (config, reportModelList) => {
22
22
  const projectOverviewCount = getSeverityCounts(reportModelList);
23
23
  if (projectOverviewCount.total === 0) {
24
24
  printNoVulnFoundMsg();
@@ -36,7 +36,4 @@ const formatScaServicesReport = (config, reportModelList) => {
36
36
  }
37
37
  return projectOverviewCount;
38
38
  };
39
- module.exports = {
40
- formatScaServicesReport,
41
- processAuditReport
42
- };
39
+ //# sourceMappingURL=auditReport.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auditReport.js","sourceRoot":"","sources":["../../../src/scaAnalysis/common/auditReport.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAA;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAA;AAClD,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACpB,MAAM,gDAAgD,CAAA;AACvD,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAA;AAC1E,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAA;AAEjD,MAAM,CAAC,MAAM,kBAAkB,GAAG,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,QAAQ,EAAE,EAAE;IAC5E,IAAI,cAAc,GAAG,EAAE,CAAA;IACvB,IAAI,eAAe,KAAK,SAAS,EAAE;QACjC,cAAc,GAAG,uBAAuB,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;KAClE;IAED,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE;QAC7B,MAAM,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAA;KAClC;SAAM;QACL,OAAO,CAAC,+CAA+C,CAAC,CAAA;KACzD;IAED,IAAI,MAAM,CAAC,IAAI,EAAE;QACf,WAAW,CAAC,MAAM,EAAE,cAAc,CAAC,CAAA;KACpC;AACH,CAAC,CAAA;AACD,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,MAAM,EAAE,eAAe,EAAE,EAAE;IACjE,MAAM,oBAAoB,GAAG,iBAAiB,CAAC,eAAe,CAAC,CAAA;IAE/D,IAAI,oBAAoB,CAAC,KAAK,KAAK,CAAC,EAAE;QACpC,mBAAmB,EAAE,CAAA;KACtB;SAAM;QACL,MAAM,2BAA2B,GAAG,eAAe,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;YAChE,IAAI,KAAK,GAAG,CAAC,CAAA;YAEb,IAAI,OAAO,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;gBACtC,KAAK,EAAE,CAAA;aACR;YAED,OAAO,KAAK,CAAA;QACd,CAAC,CAAC,CAAC,MAAM,CAAA;QAET,IAAI,YAAY,GAAG,eAAe,CAAC,MAAM,CACvC,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE,CAAC,KAAK,GAAG,OAAO,CAAC,eAAe,CAAC,MAAM,EAC1D,CAAC,CACF,CAAA;QAED,uBAAuB,CACrB,MAAM,EACN,eAAe,EACf,2BAA2B,EAC3B,YAAY,CACb,CAAA;KACF;IAED,OAAO,oBAAoB,CAAA;AAC7B,CAAC,CAAA"}
@@ -1,27 +1,27 @@
1
- "use strict";
2
- const { ReportList, ReportModelStructure, ReportCompositeKey } = require('../../audit/report/models/reportListModel');
3
- const { countVulnerableLibrariesBySeverity } = require('../../audit/report/utils/reportUtils');
4
- const { SeverityCountModel } = require('../../audit/report/models/severityCountModel');
5
- const { orderBy } = require('lodash');
6
- const { ReportOutputModel, ReportOutputHeaderModel, ReportOutputBodyModel } = require('../../audit/report/models/reportOutputModel');
7
- const { CE_URL, CRITICAL_COLOUR, HIGH_COLOUR, MEDIUM_COLOUR, LOW_COLOUR, NOTE_COLOUR } = require('../../constants/constants');
8
- const chalk = require('chalk');
9
- const Table = require('cli-table3');
10
- const { findHighestSeverityCVESca, severityCountAllCVEsSca, findCVESeveritySca, orderByHighestPrioritySca } = require('./utils/reportUtilsSca');
11
- const { buildFormattedHeaderNum } = require('../../audit/report/commonReportingFunctions');
12
- const createSummaryMessageTop = (numberOfVulnerableLibraries, numberOfCves) => {
1
+ import { ReportList, ReportModelStructure, ReportCompositeKey } from '../../audit/report/models/reportListModel.js';
2
+ import { countVulnerableLibrariesBySeverity } from '../../audit/report/utils/reportUtils.js';
3
+ import { SeverityCountModel } from '../../audit/report/models/severityCountModel.js';
4
+ import { orderBy } from 'lodash-es';
5
+ import { ReportOutputModel, ReportOutputHeaderModel, ReportOutputBodyModel } from '../../audit/report/models/reportOutputModel.js';
6
+ import { CE_URL, CRITICAL_COLOUR, HIGH_COLOUR, MEDIUM_COLOUR, LOW_COLOUR, NOTE_COLOUR } from '../../constants/constants.js';
7
+ import Table from 'cli-table3';
8
+ import { findHighestSeverityCVESca, severityCountAllCVEsSca, findCVESeveritySca, orderByHighestPrioritySca } from './utils/reportUtilsSca.js';
9
+ import chalk from 'chalk';
10
+ import { buildFormattedHeaderNum } from '../../audit/report/commonReportingFunctions.js';
11
+ import { logInfo } from '../../common/logging.js';
12
+ export const createSummaryMessageTop = (numberOfVulnerableLibraries, numberOfCves) => {
13
13
  numberOfVulnerableLibraries === 1
14
- ? console.log(`\n\nFound 1 vulnerable library containing ${numberOfCves} CVE`)
15
- : console.log(`\n\nFound ${numberOfVulnerableLibraries} vulnerable libraries containing ${numberOfCves} CVEs`);
14
+ ? logInfo(`\n\nFound 1 vulnerable library containing ${numberOfCves} CVE`)
15
+ : logInfo(`\n\nFound ${numberOfVulnerableLibraries} vulnerable libraries containing ${numberOfCves} CVEs`);
16
16
  };
17
- const createSummaryMessageBottom = numberOfVulnerableLibraries => {
17
+ export const createSummaryMessageBottom = numberOfVulnerableLibraries => {
18
18
  numberOfVulnerableLibraries === 1
19
- ? console.log(`Found 1 vulnerability`)
20
- : console.log(`Found ${numberOfVulnerableLibraries} vulnerabilities`);
19
+ ? logInfo(`Found 1 vulnerability`)
20
+ : logInfo(`Found ${numberOfVulnerableLibraries} vulnerabilities`);
21
21
  };
22
- const printFormattedOutputSca = (config, reportModelList, numberOfVulnerableLibraries, numberOfCves) => {
22
+ export const printFormattedOutputSca = (config, reportModelList, numberOfVulnerableLibraries, numberOfCves) => {
23
23
  createSummaryMessageTop(numberOfVulnerableLibraries, numberOfCves);
24
- console.log();
24
+ logInfo('');
25
25
  const report = new ReportList();
26
26
  for (const library of reportModelList) {
27
27
  const { artifactName, version, vulnerabilities, remediationAdvice } = library;
@@ -47,18 +47,23 @@ const printFormattedOutputSca = (config, reportModelList, numberOfVulnerableLibr
47
47
  const body = buildBody(cveArray, remediationAdvice);
48
48
  const reportOutputModel = new ReportOutputModel(header, body);
49
49
  table.push(reportOutputModel.body.issueMessage, reportOutputModel.body.adviceMessage);
50
- console.log(reportOutputModel.header.vulnMessage, reportOutputModel.header.introducesMessage);
51
- console.log(table.toString() + '\n');
50
+ logInfo(`${reportOutputModel.header.vulnMessage} ${reportOutputModel.header.introducesMessage}`);
51
+ logInfo(`${table.toString()} \n`);
52
52
  }
53
53
  createSummaryMessageBottom(numberOfVulnerableLibraries);
54
54
  const { criticalMessage, highMessage, mediumMessage, lowMessage, noteMessage } = buildFooter(outputOrderedByLowestSeverityAndLowestNumOfCvesFirst);
55
- console.log(`${criticalMessage} | ${highMessage} | ${mediumMessage} | ${lowMessage} | ${noteMessage}`);
55
+ logInfo(`${criticalMessage} | ${highMessage} | ${mediumMessage} | ${lowMessage} | ${noteMessage}`);
56
56
  if (config.host !== CE_URL && config.projectId) {
57
- console.log('\n' + chalk.bold("Check out your project's results in Contrast"));
58
- console.log(`${config.host}/Contrast/static/ng/index.html#/${config.organizationId}/libraries?view=static&projects=${config.name}`);
57
+ logInfo('\n' + chalk.bold('Check out your projects SCA risk in Contrast.'));
58
+ if (config.repo && config.shortenedFilePath) {
59
+ logInfo(`${config.host}/Contrast/static/ng/index.html#/${config.organizationId}/libraries?view=static&projects=${config.shortenedFilePath}`);
60
+ }
61
+ else {
62
+ logInfo(`${config.host}/Contrast/static/ng/index.html#/${config.organizationId}/libraries?view=static&projects=${config.name}`);
63
+ }
59
64
  }
60
65
  };
61
- function getReportTable() {
66
+ export function getReportTable() {
62
67
  return new Table({
63
68
  chars: {
64
69
  top: '',
@@ -83,7 +88,7 @@ function getReportTable() {
83
88
  colWidths: [12, 1, 100]
84
89
  });
85
90
  }
86
- function buildHeader(highestSeverity, contrastHeaderNum, libraryName, version, numOfCVEs) {
91
+ export function buildHeader(highestSeverity, contrastHeaderNum, libraryName, version, numOfCVEs) {
87
92
  const vulnerabilityPluralised = numOfCVEs > 1 ? 'vulnerabilities' : 'vulnerability';
88
93
  const formattedHeaderNum = buildFormattedHeaderNum(contrastHeaderNum);
89
94
  const headerColour = chalk.hex(highestSeverity.colour);
@@ -93,13 +98,13 @@ function buildHeader(highestSeverity, contrastHeaderNum, libraryName, version, n
93
98
  const introducesMessage = `introduces ${numOfCVEs} ${vulnerabilityPluralised}`;
94
99
  return new ReportOutputHeaderModel(vulnMessage, introducesMessage);
95
100
  }
96
- function buildBody(cveArray, advice) {
101
+ export function buildBody(cveArray, advice) {
97
102
  const orderedCvesWithSeverityAssigned = orderByHighestPrioritySca(cveArray.map(cve => findCVESeveritySca(cve)));
98
103
  const issueMessage = getIssueRow(orderedCvesWithSeverityAssigned);
99
104
  const adviceMessage = getAdviceRow(advice);
100
105
  return new ReportOutputBodyModel(issueMessage, adviceMessage);
101
106
  }
102
- function getIssueRow(cveArray) {
107
+ export function getIssueRow(cveArray) {
103
108
  const cveMessagesList = getIssueCveMsgList(cveArray);
104
109
  return [chalk.bold('Issue'), ':', `${cveMessagesList.join(', ')}`];
105
110
  }
@@ -129,7 +134,7 @@ const buildFooter = reportModelStructure => {
129
134
  noteMessage
130
135
  };
131
136
  };
132
- const getIssueCveMsgList = reportSeverityModels => {
137
+ export const getIssueCveMsgList = reportSeverityModels => {
133
138
  const cveMessages = [];
134
139
  reportSeverityModels.forEach(reportSeverityModel => {
135
140
  const { colour, severity, name } = reportSeverityModel;
@@ -141,14 +146,4 @@ const getIssueCveMsgList = reportSeverityModels => {
141
146
  });
142
147
  return cveMessages;
143
148
  };
144
- module.exports = {
145
- createSummaryMessageTop,
146
- createSummaryMessageBottom,
147
- printFormattedOutputSca,
148
- getReportTable,
149
- buildHeader,
150
- buildBody,
151
- getIssueRow,
152
- buildFormattedHeaderNum,
153
- getIssueCveMsgList
154
- };
149
+ //# sourceMappingURL=commonReportingFunctionsSca.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"commonReportingFunctionsSca.js","sourceRoot":"","sources":["../../../src/scaAnalysis/common/commonReportingFunctionsSca.js"],"names":[],"mappings":"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"}