UNPKG

@nodesecure/scanner

Version:

A package API to run a static analysis of your module's dependencies.

66 lines 2.63 kB
// Import Node.js Dependencies import path from "node:path"; import fs from "node:fs/promises"; import os from "node:os"; // Import Third-party Dependencies import pacote from "pacote"; import { getLocalRegistryURL } from "@nodesecure/npm-registry-sdk"; import * as tarball from "@nodesecure/tarball"; // Import Internal Dependencies import { depWalker } from "./depWalker.js"; import { NPM_TOKEN, urlToString } from "./utils/index.js"; import { Logger, ScannerLoggerEvents } from "./class/logger.class.js"; import { TempDirectory } from "./class/TempDirectory.class.js"; import { comparePayloads } from "./comparePayloads.js"; // CONSTANTS const kDefaultWorkingDirOptions = { forceRootAnalysis: true, includeDevDeps: false }; export * from "./types.js"; export * from "./extractors/index.js"; export async function workingDir(location = process.cwd(), options = {}, logger = new Logger()) { const registry = options.registry ? urlToString(options.registry) : getLocalRegistryURL(); const packageLock = options.packageLock ?? { location }; const finalizedOptions = Object.assign({ location }, kDefaultWorkingDirOptions, { ...options, packageLock, registry }); logger.start(ScannerLoggerEvents.manifest.read); const packagePath = path.join(location, "package.json"); const str = await fs.readFile(packagePath, "utf-8"); logger.end(ScannerLoggerEvents.manifest.read); return depWalker(JSON.parse(str), finalizedOptions, logger); } export async function from(packageName, options = {}, logger = new Logger()) { const registry = options.registry ? urlToString(options.registry) : getLocalRegistryURL(); logger.start(ScannerLoggerEvents.manifest.fetch); const manifest = await pacote.manifest(packageName, { ...NPM_TOKEN, registry, cache: `${os.homedir()}/.npm` }); logger.end(ScannerLoggerEvents.manifest.fetch); return depWalker( // FIX: find a way to merge pacote & registry interfaces manifest, Object.assign(options, { registry }), logger); } export async function verify(packageName) { if (typeof packageName === "undefined") { return tarball.scanPackage(process.cwd()); } await using tempDir = await TempDirectory.create(); const mama = await tarball.extractAndResolve(tempDir.location, { spec: packageName, registry: getLocalRegistryURL() }); const scanResult = await tarball.scanPackage(mama); return scanResult; } export { depWalker, tarball, comparePayloads, Logger, ScannerLoggerEvents }; //# sourceMappingURL=index.js.map