@mongodb-js/sbom-tools 0.3.0 → 0.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -58,6 +58,15 @@ dependencies.json
58
58
 
59
59
  Outputs a markdown report of vulnerabilities given one or more `dependencies.json` files and the output of one or more multiple `snyk test`.
60
60
 
61
+ If `--create-jira-issues` is set then each vulnerability that is not ignored will be also reported as a jira issue.
62
+
63
+ The jira issue creation must be configured setting the following environment variables:
64
+
65
+ - `JIRA_BASE_URL` (required): The base url of the jira api (excluded the `/rest/api/...`).
66
+ - `JIRA_API_TOKEN` (required): A jira PAT.
67
+ - `JIRA_PROJECT` (required): The project used to create the ticket.
68
+ - `JIRA_VULNERABILITY_BUILD_INFO`: Additional build info added to the ticket description (for example the commit id).
69
+
61
70
  #### Usage
62
71
 
63
72
  ```
@@ -67,19 +76,19 @@ Generate vulnerabilities report
67
76
 
68
77
  Options:
69
78
  --dependencies <paths> Comma-separated list of dependency files (default: [])
70
- --snyk-reports <paths> Comma-separated list of snyk
79
+ --snyk-reports <paths> Comma-separated list of snyk
71
80
  result files (default: [])
72
- --fail-on [level] Fail on the specified severity
81
+ --fail-on [level] Fail on the specified severity
73
82
  level
74
-
75
- -h, --help display help for command
83
+ --create-jira-issues Create Jira issues for the vulnerabilities found
84
+ -h, --help display help for command
76
85
  ```
77
86
 
78
87
  **Example output:**
79
88
 
80
89
  ```md
81
- | dep@version | id | score | fixed in | origin | ignored |
82
- | ------------ | --------------------- | ------------ | -------- | -------------------- | ------- |
90
+ | dep@version | id | score | fixed in | ignored |
91
+ | ------------ | --------------------- | ------------ | -------- | -------------------- |
83
92
  | jquery@2.2.4 | SNYK-JS-JQUERY-567880 | 6.5 (Medium) | 3.5.0 | - |
84
93
  | got@10.7.0 | SNYK-JS-GOT-2932019 | 5.4 (Medium) | 11.8.5 | Ignored. Reason: ... |
85
94
  ```
@@ -1,11 +1,14 @@
1
- import type { KnownSeverity, SnykTestProjectResult } from '../snyk-vulnerability';
1
+ import type { KnownSeverity, SnykTestProjectResult, VulnerabilityInfo } from '../vulnerability';
2
2
  import { Command } from 'commander';
3
3
  export declare function loadReports(files: string[]): Promise<SnykTestProjectResult[]>;
4
+ export declare function formatIgnored(vuln: VulnerabilityInfo): string;
5
+ export declare function generateVulnerabilityTable(vulnerabilities: VulnerabilityInfo[]): string;
4
6
  export declare function generateVulnerabilityReport(options: {
5
7
  dependencyFiles: string[];
6
8
  snykReports: string[];
7
9
  snykPolicyPath?: string;
8
10
  failOn?: KnownSeverity;
11
+ createJiraIssues?: boolean;
9
12
  printResult?: (result: string) => void;
10
13
  }): Promise<void>;
11
14
  export declare const command: Command;
@@ -1 +1 @@
1
- {"version":3,"file":"generate-vulnerability-report.d.ts","sourceRoot":"","sources":["../../src/commands/generate-vulnerability-report.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EACV,aAAa,EACb,qBAAqB,EAEtB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,wBAAsB,WAAW,CAC/B,KAAK,EAAE,MAAM,EAAE,GACd,OAAO,CAAC,qBAAqB,EAAE,CAAC,CAUlC;AAiJD,wBAAsB,2BAA2B,CAAC,OAAO,EAAE;IACzD,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;CACxC,GAAG,OAAO,CAAC,IAAI,CAAC,CAuBhB;AAMD,eAAO,MAAM,OAAO,SAyBhB,CAAC"}
1
+ {"version":3,"file":"generate-vulnerability-report.d.ts","sourceRoot":"","sources":["../../src/commands/generate-vulnerability-report.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACV,aAAa,EAEb,qBAAqB,EACrB,iBAAiB,EAClB,MAAM,kBAAkB,CAAC;AAY1B,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,wBAAsB,WAAW,CAC/B,KAAK,EAAE,MAAM,EAAE,GACd,OAAO,CAAC,qBAAqB,EAAE,CAAC,CAUlC;AA6ED,wBAAgB,aAAa,CAAC,IAAI,EAAE,iBAAiB,GAAG,MAAM,CAW7D;AAED,wBAAgB,0BAA0B,CACxC,eAAe,EAAE,iBAAiB,EAAE,GACnC,MAAM,CAwBR;AAED,wBAAsB,2BAA2B,CAAC,OAAO,EAAE;IACzD,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,WAAW,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;CACxC,GAAG,OAAO,CAAC,IAAI,CAAC,CA4BhB;AAMD,eAAO,MAAM,OAAO,SA8BhB,CAAC"}
@@ -3,115 +3,94 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.command = exports.generateVulnerabilityReport = exports.loadReports = void 0;
6
+ exports.command = exports.generateVulnerabilityReport = exports.generateVulnerabilityTable = exports.formatIgnored = exports.loadReports = void 0;
7
7
  const fs_1 = require("fs");
8
- const snykPolicy = require('snyk-policy');
9
8
  const lodash_1 = __importDefault(require("lodash"));
10
9
  const load_dependency_files_1 = require("../load-dependency-files");
11
- const snyk_vulnerability_1 = require("../snyk-vulnerability");
10
+ const vulnerability_1 = require("../vulnerability");
12
11
  const commander_1 = require("commander");
12
+ const jira_1 = require("../jira");
13
13
  async function loadReports(files) {
14
14
  return (await Promise.all(files.map(async (fileName) => JSON.parse(await fs_1.promises.readFile(fileName, 'utf-8'))))).flat();
15
15
  }
16
16
  exports.loadReports = loadReports;
17
17
  function filterApplicableVulnerabilities(snykTestResults, dependencies, rules) {
18
- const affectedDependencies = [];
18
+ const uniqueVulnerabilities = new Map();
19
19
  snykTestResults.forEach((projectResult) => {
20
- projectResult.vulnerabilities.forEach((vuln) => {
21
- dependencies.forEach((dep) => {
22
- if (vuln.moduleName === dep.name &&
23
- vuln.from.includes(`${dep.name}@${dep.version}`)) {
24
- affectedDependencies.push(vuln);
20
+ projectResult.vulnerabilities.forEach((snykVulnerability) => {
21
+ if (snykVulnerability.type === 'license') {
22
+ return;
23
+ }
24
+ const newVulnerability = (0, vulnerability_1.vulnerabilityFromSnyk)(snykVulnerability, rules);
25
+ for (const dep of dependencies) {
26
+ if (newVulnerability.packageName !== dep.name ||
27
+ newVulnerability.packageVersion !== dep.version) {
28
+ continue;
29
+ }
30
+ const key = `${newVulnerability.packageName}@${newVulnerability.packageVersion}_${newVulnerability.id}`;
31
+ const previouslyAdded = uniqueVulnerabilities.get(key);
32
+ if (previouslyAdded) {
33
+ previouslyAdded.origins = Array.from(new Set([...previouslyAdded.origins, ...newVulnerability.origins]));
34
+ }
35
+ else {
36
+ uniqueVulnerabilities.set(key, newVulnerability);
25
37
  }
26
- });
27
- });
28
- });
29
- const uniqueVulnerabilities = new Map();
30
- affectedDependencies.forEach((vuln) => {
31
- const key = `${vuln.name}@${vuln.version}_${vuln.id}`;
32
- const origin = '-';
33
- if (uniqueVulnerabilities.has(key)) {
34
- const existingVuln = uniqueVulnerabilities.get(key);
35
- if (!existingVuln.origins.includes(origin)) {
36
- existingVuln.origins.push(origin);
37
38
  }
38
- }
39
- else {
40
- uniqueVulnerabilities.set(key, {
41
- name: `${vuln.name}@${vuln.version}`,
42
- id: vuln.id,
43
- score: vuln.cvssScore,
44
- severity: `${vuln.severity
45
- .charAt(0)
46
- .toUpperCase()}${vuln.severity.slice(1)}`,
47
- fixedIn: vuln.fixedIn.join(', '),
48
- origins: [origin],
49
- policy: snykPolicy.getByVuln(rules, vuln),
50
- });
51
- }
39
+ });
52
40
  });
53
- const sortedVulnerabilities = Array.from(uniqueVulnerabilities.values()).sort((a, b) => a.name.localeCompare(b.name));
41
+ const sortedVulnerabilities = Array.from(uniqueVulnerabilities.values()).sort((a, b) => `${a.packageName}@${a.packageVersion}`.localeCompare(`${b.packageName}@${b.packageVersion}`));
54
42
  return sortedVulnerabilities;
55
43
  }
44
+ function fail(failOn, bundleVulnerabilities) {
45
+ var _a;
46
+ const minScore = (_a = (0, vulnerability_1.severityToScore)(failOn)) !== null && _a !== void 0 ? _a : 0;
47
+ for (const vuln of bundleVulnerabilities) {
48
+ if ((vuln.score === undefined || vuln.score >= minScore) &&
49
+ (0, vulnerability_1.hasKnownRemediation)(vuln) &&
50
+ !(0, vulnerability_1.isIgnored)(vuln)) {
51
+ throw new Error(`Vulnerabilities check failed: found vulnerabilities >= "${failOn}"`);
52
+ }
53
+ }
54
+ }
56
55
  function formatIgnored(vuln) {
57
56
  var _a, _b;
58
- if (!hasKnownRemediation(vuln)) {
57
+ if (!(0, vulnerability_1.hasKnownRemediation)(vuln)) {
59
58
  return 'Reason: Remediation not available yet';
60
59
  }
61
- if (hasIgnorePolicy(vuln)) {
62
- const expired = hasExpiredPolicy(vuln) ? ' (Expired)' : '';
60
+ if ((0, vulnerability_1.hasIgnorePolicy)(vuln)) {
61
+ const expired = (0, vulnerability_1.hasExpiredPolicy)(vuln) ? ' (Expired)' : '';
63
62
  return `Reason: ${(_b = (_a = vuln.policy) === null || _a === void 0 ? void 0 : _a.reason) !== null && _b !== void 0 ? _b : 'unknown'}${expired}`;
64
63
  }
65
64
  return '-';
66
65
  }
67
- function generateTable(vulnerabilities) {
66
+ exports.formatIgnored = formatIgnored;
67
+ function generateVulnerabilityTable(vulnerabilities) {
68
68
  var _a;
69
69
  let output = '';
70
- output += `## Vulnerabilities Report (${vulnerabilities.length} vulnerabilities)\n`;
71
- output += '| dep@version | id | score | fixed in | origin | ignored |\n';
72
- output += '| ----------- | -- | ----- | -------- | ------ | ------- |\n';
70
+ output += '| dep@version | id | score | fixed in | ignored |\n';
71
+ output += '| ----------- | -- | ----- | -------- | ------- |\n';
73
72
  const sortedVulns = lodash_1.default.orderBy(vulnerabilities, ['score', 'name'], ['desc', 'asc']);
74
73
  for (const vuln of sortedVulns) {
75
- const severity = `${(_a = vuln.score) !== null && _a !== void 0 ? _a : '?'} (${vuln.severity})`;
74
+ const severity = `${(_a = vuln.score) !== null && _a !== void 0 ? _a : '?'} (${vuln.severity
75
+ .charAt(0)
76
+ .toUpperCase()}${vuln.severity.slice(1)})`;
76
77
  const ignored = formatIgnored(vuln);
77
- output += `| ${vuln.name} | ${vuln.id} | ${severity} | ${vuln.fixedIn || 'N/A'} | ${ignored} |\n`;
78
+ output += `| ${vuln.packageName}@${vuln.packageVersion} | ${vuln.id} | ${severity} | ${vuln.fixedIn.join(', ') || 'N/A'} | ${ignored} |\n`;
78
79
  }
79
80
  return output;
80
81
  }
81
- function isIgnored(vuln) {
82
- return hasIgnorePolicy(vuln) && !hasExpiredPolicy(vuln);
83
- }
84
- function hasIgnorePolicy(vuln) {
85
- var _a;
86
- return ((_a = vuln.policy) === null || _a === void 0 ? void 0 : _a.type) === 'ignore';
87
- }
88
- function hasExpiredPolicy(vuln) {
89
- var _a;
90
- return new Date() >= ((_a = vuln.policy) === null || _a === void 0 ? void 0 : _a.expires);
91
- }
92
- function hasKnownRemediation(vuln) {
93
- return !!vuln.fixedIn;
94
- }
95
- function fail(failOn, bundleVulnerabilities) {
96
- var _a;
97
- const minScore = (_a = (0, snyk_vulnerability_1.severityToScore)(failOn)) !== null && _a !== void 0 ? _a : 0;
98
- for (const vuln of bundleVulnerabilities) {
99
- if ((vuln.score === undefined || vuln.score >= minScore) &&
100
- hasKnownRemediation(vuln) &&
101
- !isIgnored(vuln)) {
102
- throw new Error(`Vulnerabilities check failed: found vulnerabilities >= "${failOn}"`);
103
- }
104
- }
105
- }
82
+ exports.generateVulnerabilityTable = generateVulnerabilityTable;
106
83
  async function generateVulnerabilityReport(options) {
107
- var _a, _b;
84
+ var _a;
108
85
  const productionDependencies = await (0, load_dependency_files_1.loadDependencyFiles)(options.dependencyFiles);
109
86
  const snykTestResult = await loadReports(options.snykReports);
110
- const rules = await snykPolicy.load((_a = options.snykPolicyPath) !== null && _a !== void 0 ? _a : process.cwd(), {
111
- loose: true,
112
- });
87
+ const rules = await (0, vulnerability_1.loadSnykPolicyRules)(options.snykPolicyPath);
113
88
  const applicableVulnerabilities = filterApplicableVulnerabilities(snykTestResult, productionDependencies, rules);
114
- ((_b = options.printResult) !== null && _b !== void 0 ? _b : console.info)(generateTable(applicableVulnerabilities));
89
+ ((_a = options.printResult) !== null && _a !== void 0 ? _a : console.info)(`## Vulnerabilities Report (${applicableVulnerabilities.length} vulnerabilities)
90
+ ${generateVulnerabilityTable(applicableVulnerabilities)}`);
91
+ if (options.createJiraIssues) {
92
+ await (0, jira_1.createVulnerabilityTickets)(applicableVulnerabilities);
93
+ }
115
94
  if (options.failOn) {
116
95
  fail(options.failOn, applicableVulnerabilities);
117
96
  }
@@ -126,12 +105,14 @@ exports.command = new commander_1.Command('generate-vulnerability-report')
126
105
  .option('--snyk-reports <paths>', 'Comma-separated list of snyk result files', commaSeparatedList, [])
127
106
  .option('--fail-on [level]', 'Fail on the specified severity level')
128
107
  .option('--snyk-policy-path [path]', 'Snyk policy path')
108
+ .option('--create-jira-issues', 'Create Jira issues for the vulnerabilities found')
129
109
  .action(async (options) => {
130
110
  await generateVulnerabilityReport({
131
111
  dependencyFiles: options.dependencies,
132
112
  snykReports: options.snykReports,
133
113
  failOn: options.failOn,
134
114
  snykPolicyPath: options.snykPolicyPath,
115
+ createJiraIssues: options.createJiraIssues,
135
116
  });
136
117
  });
137
118
  //# sourceMappingURL=generate-vulnerability-report.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"generate-vulnerability-report.js","sourceRoot":"","sources":["../../src/commands/generate-vulnerability-report.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"generate-vulnerability-report.js","sourceRoot":"","sources":["../../src/commands/generate-vulnerability-report.ts"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import type { SnykTestProjectResult } from '../snyk-vulnerability';
1
+ import type { SnykTestProjectResult } from '../vulnerability';
2
2
  import { Command } from 'commander';
3
3
  export declare function scanNodeJs({ version, }: {
4
4
  version: string;
@@ -1 +1 @@
1
- {"version":3,"file":"scan-node-js.d.ts","sourceRoot":"","sources":["../../src/commands/scan-node-js.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,qBAAqB,EAEtB,MAAM,uBAAuB,CAAC;AAE/B,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAsHpC,wBAAsB,UAAU,CAAC,EAC/B,OAAO,GACR,EAAE;IACD,OAAO,EAAE,MAAM,CAAC;CACjB,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAsBjC;AAED,eAAO,MAAM,OAAO,SAgBhB,CAAC"}
1
+ {"version":3,"file":"scan-node-js.d.ts","sourceRoot":"","sources":["../../src/commands/scan-node-js.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,qBAAqB,EAEtB,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAuHpC,wBAAsB,UAAU,CAAC,EAC/B,OAAO,GACR,EAAE;IACD,OAAO,EAAE,MAAM,CAAC;CACjB,GAAG,OAAO,CAAC,qBAAqB,CAAC,CAsBjC;AAED,eAAO,MAAM,OAAO,SAgBhB,CAAC"}
@@ -7,17 +7,21 @@ exports.command = exports.scanNodeJs = void 0;
7
7
  const node_fetch_1 = __importDefault(require("node-fetch"));
8
8
  const semver_1 = __importDefault(require("semver"));
9
9
  const nv_1 = __importDefault(require("@pkgjs/nv"));
10
- const snyk_vulnerability_1 = require("../snyk-vulnerability");
10
+ const vulnerability_1 = require("../vulnerability");
11
+ const vulnerability_2 = require("../vulnerability");
11
12
  const commander_1 = require("commander");
12
13
  async function formatVulnerability(id, nodeVulnerability, nodeVersion) {
13
14
  const score = await fetchScore(`NSWG-COR-${id}`, nodeVulnerability);
14
- return (0, snyk_vulnerability_1.buildSnykVulnerability)({
15
+ return (0, vulnerability_2.vulnerabilityToSnyk)({
15
16
  id: `NSWG-COR-${id}`,
17
+ title: `NSWG-COR-${id}`,
16
18
  cves: nodeVulnerability.cve,
17
19
  fixedIn: (nodeVulnerability.patched || '').split(' || '),
18
20
  packageName: '.node.js',
19
21
  score,
20
- url: nodeVulnerability.ref,
22
+ severity: (0, vulnerability_1.scoreToSeverity)(score),
23
+ urls: [{ title: 'Ref', url: nodeVulnerability.ref }],
24
+ origins: [`.node.js@${nodeVersion}`],
21
25
  packageVersion: nodeVersion,
22
26
  description: nodeVulnerability.overview,
23
27
  vulnerableSemver: nodeVulnerability.vulnerable,
@@ -1 +1 @@
1
- {"version":3,"file":"scan-node-js.js","sourceRoot":"","sources":["../../src/commands/scan-node-js.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"scan-node-js.js","sourceRoot":"","sources":["../../src/commands/scan-node-js.ts"],"names":[],"mappings":";;;;;;AAAA,4DAA+B;AAC/B,oDAA4B;AAC5B,mDAA2B;AAK3B,oDAAmD;AACnD,oDAAuD;AACvD,yCAAoC;AAYpC,KAAK,UAAU,mBAAmB,CAChC,EAAU,EACV,iBAAoC,EACpC,WAAmB;IAEnB,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,YAAY,EAAE,EAAE,EAAE,iBAAiB,CAAC,CAAC;IAEpE,OAAO,IAAA,mCAAmB,EAAC;QACzB,EAAE,EAAE,YAAY,EAAE,EAAE;QACpB,KAAK,EAAE,YAAY,EAAE,EAAE;QACvB,IAAI,EAAE,iBAAiB,CAAC,GAAG;QAC3B,OAAO,EAAE,CAAC,iBAAiB,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC;QACxD,WAAW,EAAE,UAAU;QACvB,KAAK;QACL,QAAQ,EAAE,IAAA,+BAAe,EAAC,KAAK,CAAC;QAChC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,iBAAiB,CAAC,GAAG,EAAE,CAAC;QACpD,OAAO,EAAE,CAAC,YAAY,WAAW,EAAE,CAAC;QACpC,cAAc,EAAE,WAAW;QAC3B,WAAW,EAAE,iBAAiB,CAAC,QAAQ;QACvC,gBAAgB,EAAE,iBAAiB,CAAC,UAAU;KAC/C,CAAC,CAAC;AACL,CAAC;AAED,KAAK,UAAU,UAAU,CACvB,MAAc,EACd,iBAAoC;IAEpC,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,GAAG,CAC5B,iBAAiB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAChC,IAAA,oBAAK,EACH,0DAA0D,GAAG,EAAE,CAChE,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CACb,GAAG,CAAC,EAAE;QACJ,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE;QACZ,CAAC,CAAC,OAAO,CAAC,MAAM,CACZ,IAAI,KAAK,CAAC,SAAS,GAAG,oBAAoB,GAAG,CAAC,MAAM,EAAE,CAAC,CACxD,CACN,CACF,CACF,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;QACZ,OAAO,CAAC,KAAK,CACX,4BAA4B,MAAM,KAAM,CAAW,CAAC,OAAO,EAAE,CAC9D,CAAC;QAEF,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC,CAAC;IAEH,MAAM,sBAAsB,GAAG,CAC7B,WAGG,EACH,EAAE;;QACF,OAAO,CACL,MAAA,MAAA,MAAA,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,0CAAE,QAAQ,0CAAE,SAAS,mCAClE,MAAA,MAAA,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW,CAAC,0CAAE,QAAQ,0CAAE,SAAS,CACrE,CAAC;IACJ,CAAC,CAAC;IAEF,MAAM,OAAO,GAA2B,IAAI,CAAC,GAAG,CAC9C,CAAC,GAAG,EAAE,EAAE;;QACN,OAAA,MAAA,MAAA,sBAAsB,CACpB,MAAA,MAAA,MAAA,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,eAAe,CAAC,CAAC,CAAC,0CAAE,GAAG,0CAAE,OAAO,0CAAE,aAAa,mCAAI,EAAE,CAC3D,mCACD,sBAAsB,CACpB,MAAA,MAAA,MAAA,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,eAAe,CAAC,CAAC,CAAC,0CAAE,GAAG,0CAAE,OAAO,0CAAE,aAAa,mCAAI,EAAE,CAC3D,mCACD,sBAAsB,CACpB,MAAA,MAAA,MAAA,MAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,eAAe,CAAC,CAAC,CAAC,0CAAE,GAAG,0CAAE,OAAO,0CAAE,YAAY,mCAAI,EAAE,CAC1D,CAAA;KAAA,CACJ,CAAC;IAEF,MAAM,SAAS,GAAa,EAAE,CAAC;IAE/B,KAAK,MAAM,IAAI,IAAI,OAAO,EAAE;QAC1B,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;YAC5B,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACtB;KACF;IAKD,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;AAC/D,CAAC;AAED,KAAK,UAAU,cAAc;IAC3B,MAAM,GAAG,GACP,gFAAgF,CAAC;IAEnF,MAAM,QAAQ,GAAG,MAAM,IAAA,oBAAK,EAAC,GAAG,CAAC,CAAC;IAElC,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE;QAChB,MAAM,IAAI,KAAK,CAAC,oBAAoB,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;KACxD;IAED,OAAO,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC;AAC/B,CAAC;AAED,KAAK,UAAU,WAAW,CAAC,OAAe;IACxC,MAAM,SAAS,GAAG,CAAC,MAAM,IAAA,YAAE,EAAC,WAAW,CAAC,CAAC;SACtC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC;SAC1B,IAAI,CAAC,MAAM,CAAC,CAAC;IAEhB,OAAO,gBAAM,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;AAC9C,CAAC;AAEM,KAAK,UAAU,UAAU,CAAC,EAC/B,OAAO,GAGR;IAGC,IAAI,CAAC,CAAC,MAAM,WAAW,CAAC,OAAO,CAAC,CAAC,EAAE;QACjC,MAAM,IAAI,KAAK,CAAC,mBAAmB,OAAO,4BAA4B,CAAC,CAAC;KACzE;IAED,MAAM,mBAAmB,GAAG,MAAM,cAAc,EAAE,CAAC;IAEnD,MAAM,UAAU,GAAG,EAAE,CAAC;IAEtB,KAAK,MAAM,CAAC,EAAE,EAAE,aAAa,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,EAAE;QACrE,IACE,gBAAM,CAAC,SAAS,CAAC,OAAO,EAAE,aAAa,CAAC,UAAU,CAAC;YACnD,aAAa,CAAC,OAAO;YACrB,CAAC,gBAAM,CAAC,SAAS,CAAC,OAAO,EAAE,aAAa,CAAC,OAAO,CAAC,EACjD;YACA,UAAU,CAAC,IAAI,CAAC,MAAM,mBAAmB,CAAC,EAAE,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC,CAAC;SACxE;KACF;IAED,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC;AACzC,CAAC;AA1BD,gCA0BC;AAEY,QAAA,OAAO,GAAG,IAAI,mBAAO,CAAC,cAAc,CAAC;KAC/C,WAAW,CAAC,gDAAgD,CAAC;KAC7D,MAAM,CACL,qBAAqB,EACrB,kEAAkE,CACnE;KACA,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;IACxB,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,SAAS,CACZ,MAAM,UAAU,CAAC;QACf,OAAO,EAAE,OAAO,CAAC,OAAO;KACzB,CAAC,EACF,IAAI,EACJ,CAAC,CACF,CACF,CAAC;AACJ,CAAC,CAAC,CAAC"}
package/dist/jira.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ import type { VulnerabilityInfo } from './vulnerability';
2
+ export declare const buildJiraDescription: (vulnerability: VulnerabilityInfo) => string;
3
+ export declare function createVulnerabilityTickets(vulnerabilities: VulnerabilityInfo[]): Promise<void>;
4
+ //# sourceMappingURL=jira.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jira.d.ts","sourceRoot":"","sources":["../src/jira.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAY,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAwInE,eAAO,MAAM,oBAAoB,kBAChB,iBAAiB,KAC/B,MAkCF,CAAC;AAEF,wBAAsB,0BAA0B,CAC9C,eAAe,EAAE,iBAAiB,EAAE,GACnC,OAAO,CAAC,IAAI,CAAC,CAyCf"}
package/dist/jira.js ADDED
@@ -0,0 +1,161 @@
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.createVulnerabilityTickets = exports.buildJiraDescription = void 0;
7
+ const node_fetch_1 = __importDefault(require("node-fetch"));
8
+ const vulnerability_1 = require("./vulnerability");
9
+ const vulnerability_2 = require("./vulnerability");
10
+ const formatDueDate = (date) => {
11
+ const yy = date.getFullYear();
12
+ const MM = String(date.getMonth() + 1).padStart(2, '0');
13
+ const dd = String(date.getDate()).padStart(2, '0');
14
+ return `${yy}-${MM}-${dd}`;
15
+ };
16
+ async function createJiraTicket(jiraBaseUrl, auth, issue) {
17
+ var _a, _b;
18
+ jiraBaseUrl = jiraBaseUrl.replace(/\/$/, '');
19
+ const issueApiUrl = `${jiraBaseUrl}/rest/api/2/issue/`;
20
+ const headers = {
21
+ Authorization: `Bearer ${auth.token}`,
22
+ Accept: 'application/json',
23
+ };
24
+ const jqlQuery = new URLSearchParams({
25
+ jql: `project="${issue.project}" AND issuetype="${issue.issueType}" AND resolution=Unresolved AND summary~"${issue.summary}"`,
26
+ }).toString();
27
+ const searchApiUrl = `${jiraBaseUrl}/rest/api/2/search?${jqlQuery}`;
28
+ const exists = await (0, node_fetch_1.default)(searchApiUrl, {
29
+ method: 'GET',
30
+ headers: {
31
+ ...headers,
32
+ },
33
+ }).then(async (res) => res.ok
34
+ ? (await res.json()).total > 0
35
+ : Promise.reject(new Error(`HTTP error: ${res.status}. ${await res.text()}`)));
36
+ if (exists) {
37
+ console.info(`The ${issue.issueType} ticket ${issue.project} - ${issue.summary}, already exists.`);
38
+ return;
39
+ }
40
+ const response = await (0, node_fetch_1.default)(issueApiUrl, {
41
+ method: 'POST',
42
+ headers: {
43
+ ...headers,
44
+ 'Content-Type': 'application/json',
45
+ },
46
+ body: JSON.stringify({
47
+ fields: {
48
+ project: {
49
+ key: issue.project,
50
+ },
51
+ summary: issue.summary,
52
+ description: issue.description,
53
+ issuetype: {
54
+ name: issue.issueType,
55
+ },
56
+ components: issue.components.length
57
+ ? issue.components.map((c) => ({ name: c }))
58
+ : undefined,
59
+ labels: issue.labels.length ? issue.labels : undefined,
60
+ priority: {
61
+ name: issue.priority,
62
+ },
63
+ duedate: formatDueDate(issue.dueDate),
64
+ },
65
+ }),
66
+ });
67
+ if (!response.ok) {
68
+ throw new Error(`HTTP error: ${response.status}.`);
69
+ }
70
+ const key = (_b = (_a = (await response.json())) === null || _a === void 0 ? void 0 : _a.res) === null || _b === void 0 ? void 0 : _b.key;
71
+ console.info('Created issue: ', `${jiraBaseUrl}/browse/${key}`);
72
+ }
73
+ const JIRA_ISSUE_TYPE = 'Build Failure';
74
+ function severityToJiraPriority(severity) {
75
+ if (severity === 'high') {
76
+ return 'Critical - P2';
77
+ }
78
+ if (severity === 'medium') {
79
+ return 'Major - P3';
80
+ }
81
+ if (severity === 'low') {
82
+ return 'Minor - P4';
83
+ }
84
+ return 'Blocker - P1';
85
+ }
86
+ function severityToDueDate(severity) {
87
+ const triageSlaDays = 2;
88
+ const resolutionSlaDays = severity === 'high'
89
+ ? 5
90
+ : severity === 'medium'
91
+ ? 6 * 7
92
+ : severity === 'low'
93
+ ? 12 * 7
94
+ :
95
+ 1;
96
+ return new Date(new Date().getTime() +
97
+ triageSlaDays +
98
+ resolutionSlaDays * 24 * 60 * 60 * 1000);
99
+ }
100
+ const buildJiraDescription = (vulnerability) => {
101
+ var _a, _b;
102
+ return (`h4. Vulnerability Details
103
+
104
+ - *Affected Package*: ${vulnerability.packageName}
105
+ - *Affected Version*: ${vulnerability.packageVersion}
106
+ - *Fixed In*: ${((_a = vulnerability.fixedIn) === null || _a === void 0 ? void 0 : _a.length) ? vulnerability.fixedIn.join(', ') : 'N/A'}
107
+ - *Severity*: ${vulnerability.severity}
108
+ - *Cvss score*: ${(_b = vulnerability.score) !== null && _b !== void 0 ? _b : '-'}
109
+
110
+ h4. Vulnerability Description
111
+
112
+ {panel:title=${vulnerability.title}}
113
+ ${vulnerability.description}
114
+ {panel}
115
+
116
+ h4. Vulnerable Paths
117
+
118
+ ${vulnerability.origins.map((o) => `# {{${o}}}`).join('\n')}
119
+
120
+ h4. Links
121
+
122
+ ${vulnerability.urls.map((l) => `- [${l.title}|${l.url}]`).join('\n')}
123
+ ` +
124
+ (process.env.JIRA_VULNERABILITY_BUILD_INFO
125
+ ? `
126
+ h4. Build Info
127
+
128
+ ${process.env.JIRA_VULNERABILITY_BUILD_INFO}
129
+ `
130
+ : ''));
131
+ };
132
+ exports.buildJiraDescription = buildJiraDescription;
133
+ async function createVulnerabilityTickets(vulnerabilities) {
134
+ if (!process.env.JIRA_BASE_URL ||
135
+ !process.env.JIRA_API_TOKEN ||
136
+ !process.env.JIRA_PROJECT) {
137
+ const missingEnv = ['JIRA_BASE_URL', 'JIRA_API_TOKEN', 'JIRA_PROJECT']
138
+ .filter((k) => !process.env[k])
139
+ .join(', ');
140
+ throw new Error(`Missing required variables to create Jira tickets: ${missingEnv}`);
141
+ }
142
+ for (const vulnerability of vulnerabilities) {
143
+ if ((0, vulnerability_2.isIgnored)(vulnerability)) {
144
+ return;
145
+ }
146
+ await createJiraTicket(process.env.JIRA_BASE_URL, {
147
+ token: process.env.JIRA_API_TOKEN,
148
+ }, {
149
+ project: process.env.JIRA_PROJECT,
150
+ summary: `Vulnerability ${vulnerability.id} found on ${vulnerability.packageName}@${vulnerability.packageVersion}${(0, vulnerability_1.hasExpiredPolicy)(vulnerability) ? ' (Policy Expired)' : ''}`,
151
+ description: (0, exports.buildJiraDescription)(vulnerability),
152
+ components: ['Vulnerability Management'],
153
+ labels: [],
154
+ priority: severityToJiraPriority(vulnerability.severity),
155
+ issueType: JIRA_ISSUE_TYPE,
156
+ dueDate: severityToDueDate(vulnerability.severity),
157
+ });
158
+ }
159
+ }
160
+ exports.createVulnerabilityTickets = createVulnerabilityTickets;
161
+ //# sourceMappingURL=jira.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jira.js","sourceRoot":"","sources":["../src/jira.ts"],"names":[],"mappings":"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"}
@@ -1,10 +1,31 @@
1
1
  export declare type KnownSeverity = 'low' | 'medium' | 'high' | 'critical';
2
2
  export declare type Severity = KnownSeverity | 'unknown';
3
- declare type Score = number | undefined;
4
- export declare function severityToScore(severity: Severity): Score;
5
- export declare function scoreToSeverity(score: number | undefined): Severity;
3
+ export declare type SnykPolicyRules = any;
4
+ export declare type VulnerabilityInfo = {
5
+ id: string;
6
+ score?: number;
7
+ fixedIn: string[];
8
+ origins: string[];
9
+ severity: Severity;
10
+ title: string;
11
+ description: string;
12
+ packageName: string;
13
+ packageVersion: string;
14
+ vulnerableSemver: string;
15
+ cves: string[];
16
+ policy?: {
17
+ type: 'ignore';
18
+ reason: string;
19
+ expires: any;
20
+ };
21
+ urls: {
22
+ title: string;
23
+ url: string;
24
+ }[];
25
+ };
6
26
  export declare type SnykVulnerability = {
7
27
  id: string;
28
+ type?: 'license';
8
29
  title: string;
9
30
  CVSSv3: string;
10
31
  credit: string[];
@@ -54,16 +75,15 @@ export declare type SnykVulnerability = {
54
75
  export declare type SnykTestProjectResult = {
55
76
  vulnerabilities: SnykVulnerability[];
56
77
  };
57
- export declare function buildSnykVulnerability({ id, packageName, packageVersion, score, cves, vulnerableSemver, fixedIn, description, url, }: {
58
- cves: string[];
59
- fixedIn: string[];
60
- id: string;
61
- description?: string;
62
- packageName: string;
63
- score: number | undefined;
64
- url?: string;
65
- packageVersion: string;
66
- vulnerableSemver: string;
67
- }): SnykVulnerability | PromiseLike<SnykVulnerability>;
78
+ declare type Score = number | undefined;
79
+ export declare function severityToScore(severity: Severity): Score;
80
+ export declare function scoreToSeverity(score: number | undefined): Severity;
81
+ export declare function vulnerabilityToSnyk(vulnerability: VulnerabilityInfo): SnykVulnerability | PromiseLike<SnykVulnerability>;
82
+ export declare function vulnerabilityFromSnyk(snykVulnerability: SnykVulnerability, rules: SnykPolicyRules): VulnerabilityInfo;
83
+ export declare const loadSnykPolicyRules: (snykPolicyPath: string | undefined) => Promise<SnykPolicyRules>;
84
+ export declare function isIgnored(vulnerability: VulnerabilityInfo): boolean;
85
+ export declare function hasIgnorePolicy(vulnerability: VulnerabilityInfo): boolean;
86
+ export declare function hasExpiredPolicy(vulnerability: VulnerabilityInfo): boolean;
87
+ export declare function hasKnownRemediation(vulnerability: VulnerabilityInfo): boolean;
68
88
  export {};
69
- //# sourceMappingURL=snyk-vulnerability.d.ts.map
89
+ //# sourceMappingURL=vulnerability.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vulnerability.d.ts","sourceRoot":"","sources":["../src/vulnerability.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.hasKnownRemediation = exports.hasExpiredPolicy = exports.hasIgnorePolicy = exports.isIgnored = exports.loadSnykPolicyRules = exports.vulnerabilityFromSnyk = exports.vulnerabilityToSnyk = exports.scoreToSeverity = exports.severityToScore = void 0;
4
+ const snykPolicy = require('snyk-policy');
5
+ const SEVERITY_TO_SCORE = {
6
+ low: 0,
7
+ medium: 4,
8
+ high: 7,
9
+ critical: 9,
10
+ unknown: undefined,
11
+ };
12
+ function severityToScore(severity) {
13
+ return SEVERITY_TO_SCORE[severity];
14
+ }
15
+ exports.severityToScore = severityToScore;
16
+ function scoreToSeverity(score) {
17
+ if (score === undefined) {
18
+ return 'unknown';
19
+ }
20
+ if (score >= 9) {
21
+ return 'critical';
22
+ }
23
+ if (score >= 7) {
24
+ return 'high';
25
+ }
26
+ if (score >= 4) {
27
+ return 'medium';
28
+ }
29
+ return 'low';
30
+ }
31
+ exports.scoreToSeverity = scoreToSeverity;
32
+ function vulnerabilityToSnyk(vulnerability) {
33
+ const { id, packageName, packageVersion, score, cves, vulnerableSemver, fixedIn, description, urls, } = vulnerability;
34
+ const severity = scoreToSeverity(score);
35
+ return {
36
+ id,
37
+ title: id,
38
+ CVSSv3: '-',
39
+ credit: ['-'],
40
+ semver: {
41
+ vulnerable: vulnerableSemver,
42
+ },
43
+ exploit: '-',
44
+ patched: fixedIn,
45
+ patches: [],
46
+ fixedIn: fixedIn,
47
+ insights: {
48
+ triageAdvice: null,
49
+ },
50
+ language: 'js',
51
+ severity: severity,
52
+ cvssScore: score,
53
+ functions: [],
54
+ moduleName: packageName,
55
+ references: urls,
56
+ cvssDetails: [],
57
+ description: description !== null && description !== void 0 ? description : '',
58
+ epssDetails: null,
59
+ identifiers: {
60
+ CVE: cves,
61
+ },
62
+ packageName: packageName,
63
+ proprietary: true,
64
+ creationTime: '-',
65
+ functions_new: [],
66
+ alternativeIds: [],
67
+ disclosureTime: '-',
68
+ packageManager: 'npm',
69
+ publicationTime: '-',
70
+ modificationTime: '-',
71
+ socialTrendAlert: false,
72
+ severityWithCritical: severity,
73
+ from: [`${packageName}@${packageVersion}`],
74
+ upgradePath: [],
75
+ isUpgradable: true,
76
+ isPatchable: false,
77
+ name: packageName,
78
+ version: packageVersion,
79
+ };
80
+ }
81
+ exports.vulnerabilityToSnyk = vulnerabilityToSnyk;
82
+ function vulnerabilityFromSnyk(snykVulnerability, rules) {
83
+ var _a, _b, _c, _d, _e, _f, _g;
84
+ const urls = [];
85
+ if ((_a = snykVulnerability.id) === null || _a === void 0 ? void 0 : _a.startsWith('NSWG-COR-')) {
86
+ const id = snykVulnerability.id.split('-').reverse()[0];
87
+ urls.push({
88
+ title: snykVulnerability.id,
89
+ url: `https://github.com/nodejs/security-wg/blob/main/vuln/core/${id}.json`,
90
+ });
91
+ }
92
+ else {
93
+ urls.push({
94
+ title: snykVulnerability.id,
95
+ url: `https://security.snyk.io/vuln/${snykVulnerability.id}`,
96
+ });
97
+ urls.push({
98
+ title: `${snykVulnerability.name}@${snykVulnerability.version} vulnerabilities`,
99
+ url: `https://security.snyk.io/package/npm/${snykVulnerability.name}/${snykVulnerability.version}`,
100
+ });
101
+ }
102
+ for (const cve of (_c = (_b = snykVulnerability.identifiers) === null || _b === void 0 ? void 0 : _b.CVE) !== null && _c !== void 0 ? _c : []) {
103
+ urls.push({ title: cve, url: `https://nvd.nist.gov/vuln/detail/${cve}` });
104
+ }
105
+ return {
106
+ packageName: snykVulnerability.name,
107
+ packageVersion: snykVulnerability.version,
108
+ id: snykVulnerability.id,
109
+ score: snykVulnerability.cvssScore,
110
+ severity: snykVulnerability.severity,
111
+ title: snykVulnerability.title,
112
+ description: snykVulnerability.description,
113
+ fixedIn: snykVulnerability.fixedIn,
114
+ cves: (_e = (_d = snykVulnerability.identifiers) === null || _d === void 0 ? void 0 : _d.CVE) !== null && _e !== void 0 ? _e : [],
115
+ origins: snykVulnerability.from ? [snykVulnerability.from.join(' > ')] : [],
116
+ vulnerableSemver: (_g = (_f = snykVulnerability.semver) === null || _f === void 0 ? void 0 : _f.vulnerable) !== null && _g !== void 0 ? _g : snykVulnerability.version,
117
+ policy: snykPolicy.getByVuln(rules, snykVulnerability),
118
+ urls: urls,
119
+ };
120
+ }
121
+ exports.vulnerabilityFromSnyk = vulnerabilityFromSnyk;
122
+ const loadSnykPolicyRules = async (snykPolicyPath) => await snykPolicy.load(snykPolicyPath !== null && snykPolicyPath !== void 0 ? snykPolicyPath : process.cwd(), {
123
+ loose: true,
124
+ });
125
+ exports.loadSnykPolicyRules = loadSnykPolicyRules;
126
+ function isIgnored(vulnerability) {
127
+ return hasIgnorePolicy(vulnerability) && !hasExpiredPolicy(vulnerability);
128
+ }
129
+ exports.isIgnored = isIgnored;
130
+ function hasIgnorePolicy(vulnerability) {
131
+ var _a;
132
+ return ((_a = vulnerability.policy) === null || _a === void 0 ? void 0 : _a.type) === 'ignore';
133
+ }
134
+ exports.hasIgnorePolicy = hasIgnorePolicy;
135
+ function hasExpiredPolicy(vulnerability) {
136
+ var _a;
137
+ return new Date() >= ((_a = vulnerability.policy) === null || _a === void 0 ? void 0 : _a.expires);
138
+ }
139
+ exports.hasExpiredPolicy = hasExpiredPolicy;
140
+ function hasKnownRemediation(vulnerability) {
141
+ return !!vulnerability.fixedIn.length;
142
+ }
143
+ exports.hasKnownRemediation = hasKnownRemediation;
144
+ //# sourceMappingURL=vulnerability.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"vulnerability.js","sourceRoot":"","sources":["../src/vulnerability.ts"],"names":[],"mappings":"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"}
@@ -13,7 +13,8 @@ export declare class WebpackDependenciesPlugin implements WebpackPluginInstance
13
13
  includePackages: string[];
14
14
  constructor(options?: WebpackDependenciesPluginOptions);
15
15
  private isThirdPartyModule;
16
- private handleTap;
16
+ private getWebpackModulePath;
17
+ private addIncludedPackages;
17
18
  apply(compiler: Compiler): void;
18
19
  }
19
20
  export default WebpackDependenciesPlugin;
@@ -1 +1 @@
1
- {"version":3,"file":"webpack-dependencies-plugin.d.ts","sourceRoot":"","sources":["../src/webpack-dependencies-plugin.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAe,QAAQ,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAW5E,oBAAY,gCAAgC,GAAG;IAC7C,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,qCAAqC,CAAC,EAAE,OAAO,CAAC;CACjD,CAAC;AAMF,qBAAa,yBAA0B,YAAW,qBAAqB;IAOzD,OAAO,CAAC,OAAO;IAN3B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAe;IAC1C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,cAAqB;IACpC,qCAAqC,EAAE,OAAO,CAAC;IAC/C,eAAe,EAAE,MAAM,EAAE,CAAM;gBAEX,OAAO,GAAE,gCAAqC;IAOlE,OAAO,CAAC,kBAAkB;IAI1B,OAAO,CAAC,SAAS,CA8Bf;IAEF,KAAK,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;CA4BhC;AAED,eAAe,yBAAyB,CAAC"}
1
+ {"version":3,"file":"webpack-dependencies-plugin.d.ts","sourceRoot":"","sources":["../src/webpack-dependencies-plugin.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAa/D,oBAAY,gCAAgC,GAAG;IAC7C,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,qCAAqC,CAAC,EAAE,OAAO,CAAC;CACjD,CAAC;AAMF,qBAAa,yBAA0B,YAAW,qBAAqB;IAOzD,OAAO,CAAC,OAAO;IAN3B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAe;IAC1C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,cAAqB;IACpC,qCAAqC,EAAE,OAAO,CAAC;IAC/C,eAAe,EAAE,MAAM,EAAE,CAAM;gBAEX,OAAO,GAAE,gCAAqC;IAOlE,OAAO,CAAC,kBAAkB;IAI1B,OAAO,CAAC,oBAAoB;IAa5B,OAAO,CAAC,mBAAmB;IAmB3B,KAAK,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;CAwDhC;AAED,eAAe,yBAAyB,CAAC"}
@@ -7,6 +7,7 @@ exports.WebpackDependenciesPlugin = void 0;
7
7
  const path_1 = __importDefault(require("path"));
8
8
  const fs_1 = require("fs");
9
9
  const lodash_1 = __importDefault(require("lodash"));
10
+ const error_stack_parser_1 = __importDefault(require("error-stack-parser"));
10
11
  const production_deps_1 = require("./production-deps");
11
12
  const get_package_info_1 = require("./get-package-info");
12
13
  const PLUGIN_NAME = 'WebpackDependenciesPlugin';
@@ -17,30 +18,6 @@ class WebpackDependenciesPlugin {
17
18
  this.pluginName = PLUGIN_NAME;
18
19
  this.resolvedModules = new Set();
19
20
  this.includePackages = [];
20
- this.handleTap = (compilation) => {
21
- for (const module of compilation.modules) {
22
- const resource = module.resource;
23
- if (resource) {
24
- const modulePath = resource;
25
- if (typeof modulePath === 'string' &&
26
- this.isThirdPartyModule(modulePath)) {
27
- this.resolvedModules.add(modulePath);
28
- }
29
- }
30
- }
31
- const includePackages = [
32
- ...(this.includeExternalProductionDependencies
33
- ? (0, production_deps_1.findAllProdDepsTreeLocations)(compilation.compiler.context)
34
- : []),
35
- ...(this.includePackages || []).map((packageName) => (0, production_deps_1.findPackageLocation)(packageName, compilation.compiler.context)),
36
- ];
37
- for (const includedPackagePath of includePackages) {
38
- const packageJsonPath = path_1.default.join(includedPackagePath, 'package.json');
39
- if (packageJsonPath) {
40
- this.resolvedModules.add(packageJsonPath);
41
- }
42
- }
43
- };
44
21
  this.includeExternalProductionDependencies =
45
22
  (_a = options.includeExternalProductionDependencies) !== null && _a !== void 0 ? _a : false;
46
23
  this.includePackages = (_b = options.includePackages) !== null && _b !== void 0 ? _b : [];
@@ -49,7 +26,46 @@ class WebpackDependenciesPlugin {
49
26
  isThirdPartyModule(modulePath) {
50
27
  return modulePath.split(path_1.default.sep).includes('node_modules');
51
28
  }
29
+ getWebpackModulePath(error) {
30
+ const stack = error_stack_parser_1.default.parse(error);
31
+ const webpackEntry = stack.find((entry) => {
32
+ var _a;
33
+ return (_a = entry.fileName) === null || _a === void 0 ? void 0 : _a.split(path_1.default.win32.sep).join(path_1.default.posix.sep).includes('node_modules/webpack');
34
+ });
35
+ return webpackEntry === null || webpackEntry === void 0 ? void 0 : webpackEntry.fileName;
36
+ }
37
+ addIncludedPackages(compiler) {
38
+ const includePackages = [
39
+ ...(this.includeExternalProductionDependencies
40
+ ? (0, production_deps_1.findAllProdDepsTreeLocations)(compiler.context)
41
+ : []),
42
+ ...(this.includePackages || []).map((packageName) => (0, production_deps_1.findPackageLocation)(packageName, compiler.context)),
43
+ ];
44
+ for (const includedPackagePath of includePackages) {
45
+ const packageJsonPath = path_1.default.join(includedPackagePath, 'package.json');
46
+ if (packageJsonPath) {
47
+ this.resolvedModules.add(packageJsonPath);
48
+ }
49
+ }
50
+ }
52
51
  apply(compiler) {
52
+ const webpackModulePath = this.getWebpackModulePath(new Error());
53
+ this.addIncludedPackages(compiler);
54
+ compiler.hooks.done.tapAsync(PLUGIN_NAME, (stats, done) => {
55
+ const { modules } = stats.toJson();
56
+ modules === null || modules === void 0 ? void 0 : modules.forEach(({ type, nameForCondition }) => {
57
+ if (type === 'module' &&
58
+ nameForCondition &&
59
+ this.isThirdPartyModule(nameForCondition)) {
60
+ this.resolvedModules.add(nameForCondition);
61
+ }
62
+ });
63
+ if ((modules === null || modules === void 0 ? void 0 : modules.find((m) => { var _a; return m.moduleType === 'runtime' && ((_a = m.name) === null || _a === void 0 ? void 0 : _a.startsWith('webpack/runtime')); })) &&
64
+ webpackModulePath) {
65
+ this.resolvedModules.add(webpackModulePath);
66
+ }
67
+ done();
68
+ });
53
69
  compiler.hooks.shutdown.tapPromise(PLUGIN_NAME, async () => {
54
70
  var _a;
55
71
  const dependencyList = await Promise.all(Array.from(this.resolvedModules).map(get_package_info_1.getPackageInfo));
@@ -61,7 +77,6 @@ class WebpackDependenciesPlugin {
61
77
  });
62
78
  await fs_1.promises.writeFile(outputPath, JSON.stringify(sortedList, null, 2));
63
79
  });
64
- compiler.hooks.emit.tap(PLUGIN_NAME, this.handleTap);
65
80
  }
66
81
  }
67
82
  exports.WebpackDependenciesPlugin = WebpackDependenciesPlugin;
@@ -1 +1 @@
1
- {"version":3,"file":"webpack-dependencies-plugin.js","sourceRoot":"","sources":["../src/webpack-dependencies-plugin.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"webpack-dependencies-plugin.js","sourceRoot":"","sources":["../src/webpack-dependencies-plugin.ts"],"names":[],"mappings":";;;;;;AAAA,gDAAwB;AACxB,2BAAoC;AAEpC,oDAAuB;AAEvB,4EAAkD;AAElD,uDAG2B;AAC3B,yDAAoD;AAEpD,MAAM,WAAW,GAAG,2BAA2B,CAAC;AAYhD,MAAa,yBAAyB;IAOpC,YAAoB,UAA4C,EAAE;;QAA9C,YAAO,GAAP,OAAO,CAAuC;QANjD,eAAU,GAAG,WAAW,CAAC;QAE1C,oBAAe,GAAG,IAAI,GAAG,EAAU,CAAC;QAEpC,oBAAe,GAAa,EAAE,CAAC;QAG7B,IAAI,CAAC,qCAAqC;YACxC,MAAA,OAAO,CAAC,qCAAqC,mCAAI,KAAK,CAAC;QACzD,IAAI,CAAC,eAAe,GAAG,MAAA,OAAO,CAAC,eAAe,mCAAI,EAAE,CAAC;QACrD,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,cAAc,CAAC;IAC3C,CAAC;IAEO,kBAAkB,CAAC,UAAkB;QAC3C,OAAO,UAAU,CAAC,KAAK,CAAC,cAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IAC7D,CAAC;IAEO,oBAAoB,CAAC,KAAY;QACvC,MAAM,KAAK,GAAG,4BAAgB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAE5C,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;;YACxC,OAAA,MAAA,KAAK,CAAC,QAAQ,0CACV,KAAK,CAAC,cAAI,CAAC,KAAK,CAAC,GAAG,EACrB,IAAI,CAAC,cAAI,CAAC,KAAK,CAAC,GAAG,EACnB,QAAQ,CAAC,sBAAsB,CAAC,CAAA;SAAA,CACpC,CAAC;QAEF,OAAO,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,QAAQ,CAAC;IAChC,CAAC;IAEO,mBAAmB,CAAC,QAAkB;QAC5C,MAAM,eAAe,GAAG;YACtB,GAAG,CAAC,IAAI,CAAC,qCAAqC;gBAC5C,CAAC,CAAC,IAAA,8CAA4B,EAAC,QAAQ,CAAC,OAAO,CAAC;gBAChD,CAAC,CAAC,EAAE,CAAC;YACP,GAAG,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAClD,IAAA,qCAAmB,EAAC,WAAW,EAAE,QAAQ,CAAC,OAAO,CAAC,CACnD;SACF,CAAC;QAEF,KAAK,MAAM,mBAAmB,IAAI,eAAe,EAAE;YACjD,MAAM,eAAe,GAAG,cAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,cAAc,CAAC,CAAC;YAEvE,IAAI,eAAe,EAAE;gBACnB,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;aAC3C;SACF;IACH,CAAC;IAED,KAAK,CAAC,QAAkB;QACtB,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,KAAK,EAAE,CAAC,CAAC;QAEjE,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QAEnC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;YACxD,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;YAEnC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,EAAE,EAAE;gBAC9C,IACE,IAAI,KAAK,QAAQ;oBACjB,gBAAgB;oBAChB,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,CAAC,EACzC;oBACA,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;iBAC5C;YACH,CAAC,CAAC,CAAC;YAEH,IACE,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,CACX,CAAC,CAAC,EAAE,EAAE,WACJ,OAAA,CAAC,CAAC,UAAU,KAAK,SAAS,KAAI,MAAA,CAAC,CAAC,IAAI,0CAAE,UAAU,CAAC,iBAAiB,CAAC,CAAA,CAAA,EAAA,CACtE;gBACD,iBAAiB,EACjB;gBACA,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;aAC7C;YAED,IAAI,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;QAEH,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,WAAW,EAAE,KAAK,IAAI,EAAE;;YACzD,MAAM,cAAc,GAAG,MAAM,OAAO,CAAC,GAAG,CACtC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,iCAAc,CAAC,CACrD,CAAC;YAEF,MAAM,UAAU,GAAG,gBAAC,CAAC,MAAM,CACzB,cAAc,EACd,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,IAAI,OAAO,EAAE,CAC5C,CAAC;YAEF,MAAM,UAAU,GAAG,gBAAC,CAAC,MAAM,CACzB,UAAU,EACV,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,GAAG,IAAI,IAAI,OAAO,EAAE,CAC5C,CAAC;YAEF,MAAM,UAAU,GACd,MAAA,IAAI,CAAC,UAAU,mCAAI,cAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,mBAAmB,CAAC,CAAC;YAEtE,MAAM,aAAE,CAAC,KAAK,CAAC,cAAI,CAAC,OAAO,CAAC,cAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,EAAE;gBACrD,SAAS,EAAE,IAAI;aAChB,CAAC,CAAC;YAEH,MAAM,aAAE,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AA1GD,8DA0GC;AAED,kBAAe,yBAAyB,CAAC"}
package/package.json CHANGED
@@ -16,7 +16,7 @@
16
16
  "email": "compass@mongodb.com"
17
17
  },
18
18
  "homepage": "https://github.com/mongodb-js/devtools-shared",
19
- "version": "0.3.0",
19
+ "version": "0.5.0",
20
20
  "repository": {
21
21
  "type": "git",
22
22
  "url": "https://github.com/mongodb-js/devtools-shared.git"
@@ -76,6 +76,7 @@
76
76
  "dependencies": {
77
77
  "@pkgjs/nv": "^0.2.1",
78
78
  "commander": "^10.0.1",
79
+ "error-stack-parser": "^2.1.4",
79
80
  "find-up": "^4.1.0",
80
81
  "lodash": "^4.17.21",
81
82
  "node-fetch": "^2.6.7",
@@ -83,5 +84,5 @@
83
84
  "snyk-policy": "^2.0.4",
84
85
  "spdx-satisfies": "^5.0.1"
85
86
  },
86
- "gitHead": "8588f88041f201c21d9d17980b50779fc68dfd88"
87
+ "gitHead": "000ec0937538c434a346e2a5c92c1d402e100581"
87
88
  }
@@ -1 +0,0 @@
1
- {"version":3,"file":"snyk-vulnerability.d.ts","sourceRoot":"","sources":["../src/snyk-vulnerability.ts"],"names":[],"mappings":"AAAA,oBAAY,aAAa,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;AACnE,oBAAY,QAAQ,GAAG,aAAa,GAAG,SAAS,CAAC;AAEjD,aAAK,KAAK,GAAG,MAAM,GAAG,SAAS,CAAC;AAUhC,wBAAgB,eAAe,CAAC,QAAQ,EAAE,QAAQ,GAAG,KAAK,CAEzD;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,QAAQ,CAenE;AAED,oBAAY,iBAAiB,GAAG;IAC9B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,MAAM,EAAE;QACN,UAAU,EAAE,MAAM,CAAC;KACpB,CAAC;IACF,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,OAAO,EAAE,KAAK,EAAE,CAAC;IACjB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,EAAE;QACR,YAAY,EAAE,IAAI,CAAC;KACpB,CAAC;IACF,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,QAAQ,CAAC;IACnB,SAAS,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,SAAS,EAAE,KAAK,EAAE,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE;QACV,GAAG,EAAE,MAAM,CAAC;QACZ,KAAK,EAAE,MAAM,CAAC;KACf,EAAE,CAAC;IACJ,WAAW,EAAE,KAAK,EAAE,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,IAAI,CAAC;IAClB,WAAW,EAAE;QACX,GAAG,EAAE,MAAM,EAAE,CAAC;KACf,CAAC;IACF,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,OAAO,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,KAAK,EAAE,CAAC;IACvB,cAAc,EAAE,KAAK,EAAE,CAAC;IACxB,cAAc,EAAE,MAAM,CAAC;IACvB,cAAc,EAAE,MAAM,CAAC;IACvB,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,OAAO,CAAC;IAC1B,oBAAoB,EAAE,QAAQ,CAAC;IAC/B,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,WAAW,EAAE,KAAK,EAAE,CAAC;IACrB,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,OAAO,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,oBAAY,qBAAqB,GAAG;IAClC,eAAe,EAAE,iBAAiB,EAAE,CAAC;CACtC,CAAC;AAEF,wBAAgB,sBAAsB,CAAC,EACrC,EAAE,EACF,WAAW,EACX,cAAc,EACd,KAAK,EACL,IAAI,EACJ,gBAAgB,EAChB,OAAO,EACP,WAAW,EACX,GAAG,GACJ,EAAE;IACD,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,EAAE,EAAE,MAAM,CAAC;IACX,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC;IAC1B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,cAAc,EAAE,MAAM,CAAC;IACvB,gBAAgB,EAAE,MAAM,CAAC;CAC1B,GAAG,iBAAiB,GAAG,WAAW,CAAC,iBAAiB,CAAC,CAsDrD"}
@@ -1,87 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.buildSnykVulnerability = exports.scoreToSeverity = exports.severityToScore = void 0;
4
- const SEVERITY_TO_SCORE = {
5
- low: 0,
6
- medium: 4,
7
- high: 7,
8
- critical: 9,
9
- unknown: undefined,
10
- };
11
- function severityToScore(severity) {
12
- return SEVERITY_TO_SCORE[severity];
13
- }
14
- exports.severityToScore = severityToScore;
15
- function scoreToSeverity(score) {
16
- if (score === undefined) {
17
- return 'unknown';
18
- }
19
- if (score >= 9) {
20
- return 'critical';
21
- }
22
- if (score >= 7) {
23
- return 'high';
24
- }
25
- if (score >= 4) {
26
- return 'medium';
27
- }
28
- return 'low';
29
- }
30
- exports.scoreToSeverity = scoreToSeverity;
31
- function buildSnykVulnerability({ id, packageName, packageVersion, score, cves, vulnerableSemver, fixedIn, description, url, }) {
32
- const severity = scoreToSeverity(score);
33
- return {
34
- id,
35
- title: id,
36
- CVSSv3: '-',
37
- credit: ['-'],
38
- semver: {
39
- vulnerable: vulnerableSemver,
40
- },
41
- exploit: '-',
42
- patched: fixedIn,
43
- patches: [],
44
- fixedIn: fixedIn,
45
- insights: {
46
- triageAdvice: null,
47
- },
48
- language: 'js',
49
- severity: severity,
50
- cvssScore: score,
51
- functions: [],
52
- moduleName: packageName,
53
- references: url
54
- ? [
55
- {
56
- url: url,
57
- title: 'Ref',
58
- },
59
- ]
60
- : [],
61
- cvssDetails: [],
62
- description: description !== null && description !== void 0 ? description : '',
63
- epssDetails: null,
64
- identifiers: {
65
- CVE: cves,
66
- },
67
- packageName: packageName,
68
- proprietary: true,
69
- creationTime: '-',
70
- functions_new: [],
71
- alternativeIds: [],
72
- disclosureTime: '-',
73
- packageManager: 'npm',
74
- publicationTime: '-',
75
- modificationTime: '-',
76
- socialTrendAlert: false,
77
- severityWithCritical: severity,
78
- from: [`${packageName}@${packageVersion}`],
79
- upgradePath: [],
80
- isUpgradable: true,
81
- isPatchable: false,
82
- name: packageName,
83
- version: packageVersion,
84
- };
85
- }
86
- exports.buildSnykVulnerability = buildSnykVulnerability;
87
- //# sourceMappingURL=snyk-vulnerability.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"snyk-vulnerability.js","sourceRoot":"","sources":["../src/snyk-vulnerability.ts"],"names":[],"mappings":";;;AAKA,MAAM,iBAAiB,GAA4B;IACjD,GAAG,EAAE,CAAC;IACN,MAAM,EAAE,CAAC;IACT,IAAI,EAAE,CAAC;IACP,QAAQ,EAAE,CAAC;IACX,OAAO,EAAE,SAAS;CACnB,CAAC;AAEF,SAAgB,eAAe,CAAC,QAAkB;IAChD,OAAO,iBAAiB,CAAC,QAAQ,CAAC,CAAC;AACrC,CAAC;AAFD,0CAEC;AAED,SAAgB,eAAe,CAAC,KAAyB;IACvD,IAAI,KAAK,KAAK,SAAS,EAAE;QACvB,OAAO,SAAS,CAAC;KAClB;IAED,IAAI,KAAK,IAAI,CAAC,EAAE;QACd,OAAO,UAAU,CAAC;KACnB;IACD,IAAI,KAAK,IAAI,CAAC,EAAE;QACd,OAAO,MAAM,CAAC;KACf;IACD,IAAI,KAAK,IAAI,CAAC,EAAE;QACd,OAAO,QAAQ,CAAC;KACjB;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAfD,0CAeC;AAuDD,SAAgB,sBAAsB,CAAC,EACrC,EAAE,EACF,WAAW,EACX,cAAc,EACd,KAAK,EACL,IAAI,EACJ,gBAAgB,EAChB,OAAO,EACP,WAAW,EACX,GAAG,GAWJ;IACC,MAAM,QAAQ,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;IACxC,OAAO;QACL,EAAE;QACF,KAAK,EAAE,EAAE;QACT,MAAM,EAAE,GAAG;QACX,MAAM,EAAE,CAAC,GAAG,CAAC;QACb,MAAM,EAAE;YACN,UAAU,EAAE,gBAAgB;SAC7B;QACD,OAAO,EAAE,GAAG;QACZ,OAAO,EAAE,OAAO;QAChB,OAAO,EAAE,EAAE;QACX,OAAO,EAAE,OAAO;QAChB,QAAQ,EAAE;YACR,YAAY,EAAE,IAAI;SACnB;QACD,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,QAAQ;QAClB,SAAS,EAAE,KAAK;QAChB,SAAS,EAAE,EAAE;QACb,UAAU,EAAE,WAAW;QACvB,UAAU,EAAE,GAAG;YACb,CAAC,CAAC;gBACE;oBACE,GAAG,EAAE,GAAG;oBACR,KAAK,EAAE,KAAK;iBACb;aACF;YACH,CAAC,CAAC,EAAE;QACN,WAAW,EAAE,EAAE;QACf,WAAW,EAAE,WAAW,aAAX,WAAW,cAAX,WAAW,GAAI,EAAE;QAC9B,WAAW,EAAE,IAAI;QACjB,WAAW,EAAE;YACX,GAAG,EAAE,IAAI;SACV;QACD,WAAW,EAAE,WAAW;QACxB,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,GAAG;QACjB,aAAa,EAAE,EAAE;QACjB,cAAc,EAAE,EAAE;QAClB,cAAc,EAAE,GAAG;QACnB,cAAc,EAAE,KAAK;QACrB,eAAe,EAAE,GAAG;QACpB,gBAAgB,EAAE,GAAG;QACrB,gBAAgB,EAAE,KAAK;QACvB,oBAAoB,EAAE,QAAQ;QAC9B,IAAI,EAAE,CAAC,GAAG,WAAW,IAAI,cAAc,EAAE,CAAC;QAC1C,WAAW,EAAE,EAAE;QACf,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,KAAK;QAClB,IAAI,EAAE,WAAW;QACjB,OAAO,EAAE,cAAc;KACxB,CAAC;AACJ,CAAC;AA1ED,wDA0EC"}