@nodesecure/scanner
Version:
A package API to run a static analysis of your module's dependencies.
66 lines • 2.63 kB
JavaScript
// 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