UNPKG

npm

Version:

a package manager for JavaScript

55 lines (49 loc) 1.5 kB
const Arborist = require('../') const print = require('./lib/print-tree.js') const options = require('./lib/options.js') require('./lib/timers.js') require('./lib/logging.js') const Vuln = require('../lib/vuln.js') const printReport = report => { for (const vuln of report.values()) { console.log(printVuln(vuln)) } if (report.topVulns.size) { console.log('\n# top-level vulnerabilities') for (const vuln of report.topVulns.values()) { console.log(printVuln(vuln)) } } } const printVuln = vuln => { return { __proto__: { constructor: Vuln }, name: vuln.name, issues: [...vuln.advisories].map(a => printAdvisory(a)), range: vuln.simpleRange, nodes: [...vuln.nodes].map(node => `${node.name} ${node.location || '#ROOT'}`), ...(vuln.topNodes.size === 0 ? {} : { topNodes: [...vuln.topNodes].map(node => `${node.location || '#ROOT'}`), }), } } const printAdvisory = a => `${a.title}${a.url ? ' ' + a.url : ''}` const start = process.hrtime() process.emit('time', 'audit script') const arb = new Arborist(options) arb.audit(options).then(tree => { process.emit('timeEnd', 'audit script') const end = process.hrtime(start) if (options.fix) { print(tree) } if (!options.quiet) { printReport(arb.auditReport) } if (options.fix) { console.error(`resolved ${tree.inventory.size} deps in ${end[0] + end[1] / 1e9}s`) } if (tree.meta && options.save) { tree.meta.save() } }).catch(er => console.error(er))