UNPKG

check-packages

Version:

CLI tool to check your npm dependencies against a list of allowed/forbidden packages.

27 lines (18 loc) 602 B
'use strict'; const childProcess = require('child_process'); const readDependencies = (options = []) => { const args = [ 'ls', '--json' ]; options.forEach(option => args.push(`--${option}`)); const result = childProcess.spawnSync('npm', args, { shell: true }); const tree = JSON.parse(result.stdout); if (!tree) { throw new Error('Failed to read dependencies'); } // mark root level -> we want to exclude this level from analysis tree.isRoot = true; return { tree, problems: result.stderr ? result.stderr.toString() : '' }; }; module.exports = readDependencies;