audit-trace 0.1.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 +101 -0
- package/dist/cli/ink/ReportTui.d.ts +8 -0
- package/dist/cli/ink/ReportTui.d.ts.map +1 -0
- package/dist/cli/ink/ReportTui.js +20 -0
- package/dist/cli/ink/ReportTui.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +150 -0
- package/dist/cli.js.map +1 -0
- package/dist/core/audit-parser/normalize.d.ts +8 -0
- package/dist/core/audit-parser/normalize.d.ts.map +1 -0
- package/dist/core/audit-parser/normalize.js +107 -0
- package/dist/core/audit-parser/normalize.js.map +1 -0
- package/dist/core/audit-parser/run-audit.d.ts +9 -0
- package/dist/core/audit-parser/run-audit.d.ts.map +1 -0
- package/dist/core/audit-parser/run-audit.js +25 -0
- package/dist/core/audit-parser/run-audit.js.map +1 -0
- package/dist/core/graph-engine/load-lockfile.d.ts +20 -0
- package/dist/core/graph-engine/load-lockfile.d.ts.map +1 -0
- package/dist/core/graph-engine/load-lockfile.js +43 -0
- package/dist/core/graph-engine/load-lockfile.js.map +1 -0
- package/dist/core/graph-engine/npm-lock.d.ts +5 -0
- package/dist/core/graph-engine/npm-lock.d.ts.map +1 -0
- package/dist/core/graph-engine/npm-lock.js +159 -0
- package/dist/core/graph-engine/npm-lock.js.map +1 -0
- package/dist/core/graph-engine/pnpm-lock.d.ts +4 -0
- package/dist/core/graph-engine/pnpm-lock.d.ts.map +1 -0
- package/dist/core/graph-engine/pnpm-lock.js +152 -0
- package/dist/core/graph-engine/pnpm-lock.js.map +1 -0
- package/dist/core/graph-engine/traverse.d.ts +17 -0
- package/dist/core/graph-engine/traverse.d.ts.map +1 -0
- package/dist/core/graph-engine/traverse.js +125 -0
- package/dist/core/graph-engine/traverse.js.map +1 -0
- package/dist/core/graph-engine/yarn-lock.d.ts +4 -0
- package/dist/core/graph-engine/yarn-lock.d.ts.map +1 -0
- package/dist/core/graph-engine/yarn-lock.js +128 -0
- package/dist/core/graph-engine/yarn-lock.js.map +1 -0
- package/dist/core/models.d.ts +88 -0
- package/dist/core/models.d.ts.map +1 -0
- package/dist/core/models.js +9 -0
- package/dist/core/models.js.map +1 -0
- package/dist/core/ownership/tracer.d.ts +16 -0
- package/dist/core/ownership/tracer.d.ts.map +1 -0
- package/dist/core/ownership/tracer.js +65 -0
- package/dist/core/ownership/tracer.js.map +1 -0
- package/dist/core/remediation-engine/engine.d.ts +3 -0
- package/dist/core/remediation-engine/engine.d.ts.map +1 -0
- package/dist/core/remediation-engine/engine.js +42 -0
- package/dist/core/remediation-engine/engine.js.map +1 -0
- package/dist/core/risk-engine/scripts.d.ts +6 -0
- package/dist/core/risk-engine/scripts.d.ts.map +1 -0
- package/dist/core/risk-engine/scripts.js +19 -0
- package/dist/core/risk-engine/scripts.js.map +1 -0
- package/dist/core/risk-engine/workspace-risk.d.ts +2 -0
- package/dist/core/risk-engine/workspace-risk.d.ts.map +1 -0
- package/dist/core/risk-engine/workspace-risk.js +2 -0
- package/dist/core/risk-engine/workspace-risk.js.map +1 -0
- package/dist/core/workspace-engine/detect.d.ts +3 -0
- package/dist/core/workspace-engine/detect.d.ts.map +1 -0
- package/dist/core/workspace-engine/detect.js +53 -0
- package/dist/core/workspace-engine/detect.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -0
- package/dist/ink/ReportTui.d.ts +8 -0
- package/dist/ink/ReportTui.d.ts.map +1 -0
- package/dist/ink/ReportTui.js +20 -0
- package/dist/ink/ReportTui.js.map +1 -0
- package/dist/integrations/ci-mode/policy.d.ts +17 -0
- package/dist/integrations/ci-mode/policy.d.ts.map +1 -0
- package/dist/integrations/ci-mode/policy.js +71 -0
- package/dist/integrations/ci-mode/policy.js.map +1 -0
- package/dist/integrations/lockfile-diff/compare.d.ts +11 -0
- package/dist/integrations/lockfile-diff/compare.d.ts.map +1 -0
- package/dist/integrations/lockfile-diff/compare.js +44 -0
- package/dist/integrations/lockfile-diff/compare.js.map +1 -0
- package/dist/integrations/reachability/madge-check.d.ts +12 -0
- package/dist/integrations/reachability/madge-check.d.ts.map +1 -0
- package/dist/integrations/reachability/madge-check.js +41 -0
- package/dist/integrations/reachability/madge-check.js.map +1 -0
- package/dist/lib/analyze.d.ts +22 -0
- package/dist/lib/analyze.d.ts.map +1 -0
- package/dist/lib/analyze.js +107 -0
- package/dist/lib/analyze.js.map +1 -0
- package/dist/output/html-reporter.d.ts +4 -0
- package/dist/output/html-reporter.d.ts.map +1 -0
- package/dist/output/html-reporter.js +18 -0
- package/dist/output/html-reporter.js.map +1 -0
- package/dist/output/json-reporter.d.ts +5 -0
- package/dist/output/json-reporter.d.ts.map +1 -0
- package/dist/output/json-reporter.js +18 -0
- package/dist/output/json-reporter.js.map +1 -0
- package/dist/output/markdown-reporter.d.ts +4 -0
- package/dist/output/markdown-reporter.d.ts.map +1 -0
- package/dist/output/markdown-reporter.js +28 -0
- package/dist/output/markdown-reporter.js.map +1 -0
- package/dist/output/terminal-renderer.d.ts +8 -0
- package/dist/output/terminal-renderer.d.ts.map +1 -0
- package/dist/output/terminal-renderer.js +51 -0
- package/dist/output/terminal-renderer.js.map +1 -0
- package/dist/output/tree-format.d.ts +3 -0
- package/dist/output/tree-format.d.ts.map +1 -0
- package/dist/output/tree-format.js +12 -0
- package/dist/output/tree-format.js.map +1 -0
- package/dist/plugins/registry.d.ts +4 -0
- package/dist/plugins/registry.d.ts.map +1 -0
- package/dist/plugins/registry.js +8 -0
- package/dist/plugins/registry.js.map +1 -0
- package/dist/plugins/types.d.ts +10 -0
- package/dist/plugins/types.d.ts.map +1 -0
- package/dist/plugins/types.js +2 -0
- package/dist/plugins/types.js.map +1 -0
- package/examples/github-actions/ci.yml +34 -0
- package/package.json +58 -0
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
/** Unified vulnerability after normalizing npm/pnpm/yarn audit output */
|
|
2
|
+
export type Severity = "info" | "low" | "moderate" | "high" | "critical";
|
|
3
|
+
export interface VulnerabilityFinding {
|
|
4
|
+
id: string;
|
|
5
|
+
packageName: string;
|
|
6
|
+
/** Installed version(s) observed in audit if known */
|
|
7
|
+
versions?: string[];
|
|
8
|
+
/** Semver range affected per advisory */
|
|
9
|
+
vulnerableRange?: string;
|
|
10
|
+
/** Suggested patched range or version if known */
|
|
11
|
+
patchedRange?: string;
|
|
12
|
+
severity: Severity;
|
|
13
|
+
title?: string;
|
|
14
|
+
url?: string;
|
|
15
|
+
cveIds?: string[];
|
|
16
|
+
/** Raw paths from audit e.g. node_refs */
|
|
17
|
+
nodePaths?: string[];
|
|
18
|
+
}
|
|
19
|
+
export interface DependencyNode {
|
|
20
|
+
id: string;
|
|
21
|
+
/** logical path in lockfile / graph id */
|
|
22
|
+
pathKey: string;
|
|
23
|
+
name: string;
|
|
24
|
+
version: string;
|
|
25
|
+
dev: boolean;
|
|
26
|
+
optional: boolean;
|
|
27
|
+
peer: boolean;
|
|
28
|
+
}
|
|
29
|
+
export interface DependencyEdge {
|
|
30
|
+
from: string;
|
|
31
|
+
to: string;
|
|
32
|
+
depType: "dependencies" | "devDependencies" | "optionalDependencies" | "peerDependencies";
|
|
33
|
+
}
|
|
34
|
+
export interface DependencyGraphSnapshot {
|
|
35
|
+
nodes: Map<string, DependencyNode>;
|
|
36
|
+
edges: DependencyEdge[];
|
|
37
|
+
rootIds: string[];
|
|
38
|
+
lockfileKind: "npm" | "pnpm" | "yarn-classic" | "unknown";
|
|
39
|
+
/** package name -> node ids (same name may appear multiple times) */
|
|
40
|
+
byPackageName: Map<string, string[]>;
|
|
41
|
+
}
|
|
42
|
+
export type CiDiagnosticSeverity = "info" | "warn" | "error";
|
|
43
|
+
export interface CiDiagnostic {
|
|
44
|
+
severity: CiDiagnosticSeverity;
|
|
45
|
+
/** Stable machine-readable code */
|
|
46
|
+
code: string;
|
|
47
|
+
message: string;
|
|
48
|
+
detail?: string;
|
|
49
|
+
relatedPackages?: string[];
|
|
50
|
+
remediationHint?: string;
|
|
51
|
+
policy?: Record<string, unknown>;
|
|
52
|
+
}
|
|
53
|
+
export interface AuditReport {
|
|
54
|
+
findings: VulnerabilityFinding[];
|
|
55
|
+
graph: DependencyGraphSnapshot | null;
|
|
56
|
+
diagnostics: CiDiagnostic[];
|
|
57
|
+
remediation: RemediationSuggestion[];
|
|
58
|
+
}
|
|
59
|
+
export interface RemediationSuggestion {
|
|
60
|
+
kind: "overrides" | "resolutions" | "upgrade";
|
|
61
|
+
reason: string;
|
|
62
|
+
targetPackage: string;
|
|
63
|
+
/** JSON snippet or semver constraint */
|
|
64
|
+
constraint?: string;
|
|
65
|
+
/** Example package.json patch */
|
|
66
|
+
manifestPatch?: Record<string, unknown>;
|
|
67
|
+
}
|
|
68
|
+
export interface WorkspaceInfo {
|
|
69
|
+
isMonorepo: boolean;
|
|
70
|
+
rootDir: string;
|
|
71
|
+
packagePaths: string[];
|
|
72
|
+
tools: {
|
|
73
|
+
nx?: boolean;
|
|
74
|
+
turbo?: boolean;
|
|
75
|
+
pnpmWorkspace?: boolean;
|
|
76
|
+
npmWorkspaces?: boolean;
|
|
77
|
+
yarnWorkspaces?: boolean;
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
export declare const CI_CODES: {
|
|
81
|
+
readonly FAIL_POLICY: "FAIL_POLICY";
|
|
82
|
+
readonly FAIL_HIGH_PROD: "FAIL_HIGH_PROD";
|
|
83
|
+
readonly VULN_FOUND: "VULN_FOUND";
|
|
84
|
+
readonly AUDIT_SOURCE_FALLBACK: "AUDIT_SOURCE_FALLBACK";
|
|
85
|
+
readonly NO_LOCKFILE: "NO_LOCKFILE";
|
|
86
|
+
readonly GRAPH_BUILD_WARN: "GRAPH_BUILD_WARN";
|
|
87
|
+
};
|
|
88
|
+
//# sourceMappingURL=models.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"models.d.ts","sourceRoot":"","sources":["../../src/core/models.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export const CI_CODES = {
|
|
2
|
+
FAIL_POLICY: "FAIL_POLICY",
|
|
3
|
+
FAIL_HIGH_PROD: "FAIL_HIGH_PROD",
|
|
4
|
+
VULN_FOUND: "VULN_FOUND",
|
|
5
|
+
AUDIT_SOURCE_FALLBACK: "AUDIT_SOURCE_FALLBACK",
|
|
6
|
+
NO_LOCKFILE: "NO_LOCKFILE",
|
|
7
|
+
GRAPH_BUILD_WARN: "GRAPH_BUILD_WARN",
|
|
8
|
+
};
|
|
9
|
+
//# sourceMappingURL=models.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/core/models.ts"],"names":[],"mappings":"AAmFA,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,WAAW,EAAE,aAAa;IAC1B,cAAc,EAAE,gBAAgB;IAChC,UAAU,EAAE,YAAY;IACxB,qBAAqB,EAAE,uBAAuB;IAC9C,WAAW,EAAE,aAAa;IAC1B,gBAAgB,EAAE,kBAAkB;CAC5B,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { DependencyGraphSnapshot, DependencyNode, VulnerabilityFinding } from "../models.js";
|
|
2
|
+
export interface OwnershipPath {
|
|
3
|
+
findingId: string;
|
|
4
|
+
packageName: string;
|
|
5
|
+
severity: VulnerabilityFinding["severity"];
|
|
6
|
+
nodeId: string;
|
|
7
|
+
pathNodeIds: string[];
|
|
8
|
+
topLevelNames: string[];
|
|
9
|
+
isDevDependency: boolean;
|
|
10
|
+
isOptional: boolean;
|
|
11
|
+
isPeer: boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare function matchNodesForFinding(graph: DependencyGraphSnapshot, finding: VulnerabilityFinding): DependencyNode[];
|
|
14
|
+
export declare function traceOwnership(graph: DependencyGraphSnapshot, findings: VulnerabilityFinding[]): OwnershipPath[];
|
|
15
|
+
export declare function duplicatePackageReport(graph: DependencyGraphSnapshot): Map<string, Set<string>>;
|
|
16
|
+
//# sourceMappingURL=tracer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tracer.d.ts","sourceRoot":"","sources":["../../../src/core/ownership/tracer.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,uBAAuB,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAGlG,MAAM,WAAW,aAAa;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAC3C,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,aAAa,EAAE,MAAM,EAAE,CAAC;IACxB,eAAe,EAAE,OAAO,CAAC;IACzB,UAAU,EAAE,OAAO,CAAC;IACpB,MAAM,EAAE,OAAO,CAAC;CACjB;AAED,wBAAgB,oBAAoB,CAClC,KAAK,EAAE,uBAAuB,EAC9B,OAAO,EAAE,oBAAoB,GAC5B,cAAc,EAAE,CAsBlB;AAED,wBAAgB,cAAc,CAC5B,KAAK,EAAE,uBAAuB,EAC9B,QAAQ,EAAE,oBAAoB,EAAE,GAC/B,aAAa,EAAE,CA0BjB;AAcD,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,uBAAuB,4BAEpE"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import semver from "semver";
|
|
2
|
+
import { buildIndexes, duplicateVersions, shortestPathFromRoots } from "../graph-engine/traverse.js";
|
|
3
|
+
export function matchNodesForFinding(graph, finding) {
|
|
4
|
+
const names = graph.byPackageName.get(finding.packageName) ?? [];
|
|
5
|
+
const nodes = names.map((id) => graph.nodes.get(id)).filter(Boolean);
|
|
6
|
+
const range = finding.vulnerableRange;
|
|
7
|
+
const filtered = range
|
|
8
|
+
? nodes.filter((n) => {
|
|
9
|
+
try {
|
|
10
|
+
return semver.satisfies(n.version, range, { includePrerelease: true });
|
|
11
|
+
}
|
|
12
|
+
catch {
|
|
13
|
+
return true;
|
|
14
|
+
}
|
|
15
|
+
})
|
|
16
|
+
: nodes;
|
|
17
|
+
if (finding.nodePaths?.length) {
|
|
18
|
+
const pathMatches = nodes.filter((n) => finding.nodePaths.some((p) => n.pathKey === p || p.endsWith(n.pathKey) || n.pathKey.endsWith(p)));
|
|
19
|
+
if (pathMatches.length)
|
|
20
|
+
return pathMatches;
|
|
21
|
+
}
|
|
22
|
+
return filtered;
|
|
23
|
+
}
|
|
24
|
+
export function traceOwnership(graph, findings) {
|
|
25
|
+
const indexes = buildIndexes(graph);
|
|
26
|
+
const out = [];
|
|
27
|
+
for (const f of findings) {
|
|
28
|
+
const matched = matchNodesForFinding(graph, f);
|
|
29
|
+
for (const node of matched) {
|
|
30
|
+
const sp = shortestPathFromRoots(graph, indexes, node.id);
|
|
31
|
+
if (!sp || sp.length < 2)
|
|
32
|
+
continue;
|
|
33
|
+
const topNode = sp.length >= 2 ? graph.nodes.get(sp[1]) : undefined;
|
|
34
|
+
const topNames = topNode ? [topNode.name] : [];
|
|
35
|
+
out.push({
|
|
36
|
+
findingId: f.id,
|
|
37
|
+
packageName: f.packageName,
|
|
38
|
+
severity: f.severity,
|
|
39
|
+
nodeId: node.id,
|
|
40
|
+
pathNodeIds: sp,
|
|
41
|
+
topLevelNames: topNames,
|
|
42
|
+
isDevDependency: node.dev,
|
|
43
|
+
isOptional: node.optional,
|
|
44
|
+
isPeer: node.peer,
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return dedupeOwnership(out);
|
|
49
|
+
}
|
|
50
|
+
function dedupeOwnership(rows) {
|
|
51
|
+
const k = new Set();
|
|
52
|
+
const out = [];
|
|
53
|
+
for (const r of rows) {
|
|
54
|
+
const key = `${r.findingId}::${r.nodeId}`;
|
|
55
|
+
if (k.has(key))
|
|
56
|
+
continue;
|
|
57
|
+
k.add(key);
|
|
58
|
+
out.push(r);
|
|
59
|
+
}
|
|
60
|
+
return out;
|
|
61
|
+
}
|
|
62
|
+
export function duplicatePackageReport(graph) {
|
|
63
|
+
return duplicateVersions(graph);
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=tracer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tracer.js","sourceRoot":"","sources":["../../../src/core/ownership/tracer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../../src/core/remediation-engine/engine.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAGhF,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,oBAAoB,EAAE,GAAG,qBAAqB,EAAE,CAqB5F"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import semver from "semver";
|
|
2
|
+
export function suggestRemediation(findings) {
|
|
3
|
+
const out = [];
|
|
4
|
+
for (const f of findings) {
|
|
5
|
+
if (f.patchedRange) {
|
|
6
|
+
const constraint = coerceConstraint(f.patchedRange);
|
|
7
|
+
out.push({
|
|
8
|
+
kind: "overrides",
|
|
9
|
+
reason: `Advisory suggests patched versions: ${f.patchedRange}`,
|
|
10
|
+
targetPackage: f.packageName,
|
|
11
|
+
constraint,
|
|
12
|
+
manifestPatch: { overrides: { [f.packageName]: constraint } },
|
|
13
|
+
});
|
|
14
|
+
continue;
|
|
15
|
+
}
|
|
16
|
+
out.push({
|
|
17
|
+
kind: "upgrade",
|
|
18
|
+
reason: "No patched range in audit data; upgrade transitive chain or add an override after verifying compatibility.",
|
|
19
|
+
targetPackage: f.packageName,
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
return dedupeRem(out);
|
|
23
|
+
}
|
|
24
|
+
function coerceConstraint(patched) {
|
|
25
|
+
const first = patched.split(",").map((s) => s.trim()).filter(Boolean)[0];
|
|
26
|
+
if (!first)
|
|
27
|
+
return patched;
|
|
28
|
+
if (semver.validRange(first))
|
|
29
|
+
return first;
|
|
30
|
+
const v = semver.coerce(first);
|
|
31
|
+
return v ? `>=${v.version}` : patched;
|
|
32
|
+
}
|
|
33
|
+
function dedupeRem(s) {
|
|
34
|
+
const m = new Map();
|
|
35
|
+
for (const x of s) {
|
|
36
|
+
const k = `${x.kind}:${x.targetPackage}`;
|
|
37
|
+
if (!m.has(k))
|
|
38
|
+
m.set(k, x);
|
|
39
|
+
}
|
|
40
|
+
return [...m.values()];
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../../../src/core/remediation-engine/engine.ts"],"names":[],"mappings":"AACA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAE5B,MAAM,UAAU,kBAAkB,CAAC,QAAgC;IACjE,MAAM,GAAG,GAA4B,EAAE,CAAC;IACxC,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;QACzB,IAAI,CAAC,CAAC,YAAY,EAAE,CAAC;YACnB,MAAM,UAAU,GAAG,gBAAgB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;YACpD,GAAG,CAAC,IAAI,CAAC;gBACP,IAAI,EAAE,WAAW;gBACjB,MAAM,EAAE,uCAAuC,CAAC,CAAC,YAAY,EAAE;gBAC/D,aAAa,EAAE,CAAC,CAAC,WAAW;gBAC5B,UAAU;gBACV,aAAa,EAAE,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,EAAE,UAAU,EAAE,EAAE;aAC9D,CAAC,CAAC;YACH,SAAS;QACX,CAAC;QACD,GAAG,CAAC,IAAI,CAAC;YACP,IAAI,EAAE,SAAS;YACf,MAAM,EAAE,4GAA4G;YACpH,aAAa,EAAE,CAAC,CAAC,WAAW;SAC7B,CAAC,CAAC;IACL,CAAC;IACD,OAAO,SAAS,CAAC,GAAG,CAAC,CAAC;AACxB,CAAC;AAED,SAAS,gBAAgB,CAAC,OAAe;IACvC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACzE,IAAI,CAAC,KAAK;QAAE,OAAO,OAAO,CAAC;IAC3B,IAAI,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC;QAAE,OAAO,KAAK,CAAC;IAC3C,MAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC/B,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;AACxC,CAAC;AAED,SAAS,SAAS,CAAC,CAA0B;IAC3C,MAAM,CAAC,GAAG,IAAI,GAAG,EAAiC,CAAC;IACnD,KAAK,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;QAClB,MAAM,CAAC,GAAG,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,aAAa,EAAE,CAAC;QACzC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC7B,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;AACzB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/** Lightweight package.json read for risk hints (root workspace). */
|
|
2
|
+
export declare function loadLocalPackageScripts(rootDir: string): Promise<{
|
|
3
|
+
installScripts: string[];
|
|
4
|
+
}>;
|
|
5
|
+
export declare function scriptExecutesShell(script: string): boolean;
|
|
6
|
+
//# sourceMappingURL=scripts.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scripts.d.ts","sourceRoot":"","sources":["../../../src/core/risk-engine/scripts.ts"],"names":[],"mappings":"AAGA,qEAAqE;AACrE,wBAAsB,uBAAuB,CAC3C,OAAO,EAAE,MAAM,GACd,OAAO,CAAC;IAAE,cAAc,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC,CAYvC;AAED,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAE3D"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { readFile } from "node:fs/promises";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
/** Lightweight package.json read for risk hints (root workspace). */
|
|
4
|
+
export async function loadLocalPackageScripts(rootDir) {
|
|
5
|
+
try {
|
|
6
|
+
const raw = await readFile(join(rootDir, "package.json"), "utf8");
|
|
7
|
+
const pkg = JSON.parse(raw);
|
|
8
|
+
const s = pkg.scripts ?? {};
|
|
9
|
+
const keys = ["postinstall", "preinstall", "install", "prepare"].filter((k) => typeof s[k] === "string" && s[k]);
|
|
10
|
+
return { installScripts: keys };
|
|
11
|
+
}
|
|
12
|
+
catch {
|
|
13
|
+
return { installScripts: [] };
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export function scriptExecutesShell(script) {
|
|
17
|
+
return /(\bsh\b|\bbash\b|curl\b|wget\b|node-gyp|prebuild)/i.test(script);
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=scripts.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scripts.js","sourceRoot":"","sources":["../../../src/core/risk-engine/scripts.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,qEAAqE;AACrE,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC3C,OAAe;IAEf,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,cAAc,CAAC,EAAE,MAAM,CAAC,CAAC;QAClE,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAyC,CAAC;QACpE,MAAM,CAAC,GAAG,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC;QAC5B,MAAM,IAAI,GAAG,CAAC,aAAa,EAAE,YAAY,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC,MAAM,CACrE,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC,CACxC,CAAC;QACF,OAAO,EAAE,cAAc,EAAE,IAAI,EAAE,CAAC;IAClC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,cAAc,EAAE,EAAE,EAAE,CAAC;IAChC,CAAC;AACH,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,MAAc;IAChD,OAAO,oDAAoD,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;AAC3E,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workspace-risk.d.ts","sourceRoot":"","sources":["../../../src/core/risk-engine/workspace-risk.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workspace-risk.js","sourceRoot":"","sources":["../../../src/core/risk-engine/workspace-risk.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detect.d.ts","sourceRoot":"","sources":["../../../src/core/workspace-engine/detect.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAElD,wBAAsB,gBAAgB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAoD9E"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { readFile, access } from "node:fs/promises";
|
|
2
|
+
import { join } from "node:path";
|
|
3
|
+
export async function detectWorkspaces(rootDir) {
|
|
4
|
+
const pkgPath = join(rootDir, "package.json");
|
|
5
|
+
const tools = {};
|
|
6
|
+
let pkg = {};
|
|
7
|
+
try {
|
|
8
|
+
pkg = JSON.parse(await readFile(pkgPath, "utf8"));
|
|
9
|
+
}
|
|
10
|
+
catch {
|
|
11
|
+
return {
|
|
12
|
+
isMonorepo: false,
|
|
13
|
+
rootDir,
|
|
14
|
+
packagePaths: [pkgPath],
|
|
15
|
+
tools,
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
const workspaces = pkg.workspaces;
|
|
19
|
+
const hasNpmWs = Array.isArray(workspaces) || (typeof workspaces === "object" && workspaces !== null);
|
|
20
|
+
if (hasNpmWs)
|
|
21
|
+
tools.npmWorkspaces = true;
|
|
22
|
+
let pnpmWs = false;
|
|
23
|
+
try {
|
|
24
|
+
await access(join(rootDir, "pnpm-workspace.yaml"));
|
|
25
|
+
pnpmWs = true;
|
|
26
|
+
tools.pnpmWorkspace = true;
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
/* no */
|
|
30
|
+
}
|
|
31
|
+
try {
|
|
32
|
+
await access(join(rootDir, "nx.json"));
|
|
33
|
+
tools.nx = true;
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
/* no */
|
|
37
|
+
}
|
|
38
|
+
try {
|
|
39
|
+
await access(join(rootDir, "turbo.json"));
|
|
40
|
+
tools.turbo = true;
|
|
41
|
+
}
|
|
42
|
+
catch {
|
|
43
|
+
/* no */
|
|
44
|
+
}
|
|
45
|
+
const isMonorepo = Boolean(tools.npmWorkspaces || tools.pnpmWorkspace || tools.nx || tools.turbo);
|
|
46
|
+
return {
|
|
47
|
+
isMonorepo,
|
|
48
|
+
rootDir,
|
|
49
|
+
packagePaths: [pkgPath],
|
|
50
|
+
tools,
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=detect.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detect.js","sourceRoot":"","sources":["../../../src/core/workspace-engine/detect.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGjC,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,OAAe;IACpD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,cAAc,CAAC,CAAC;IAC9C,MAAM,KAAK,GAA2B,EAAE,CAAC;IACzC,IAAI,GAAG,GAA4B,EAAE,CAAC;IACtC,IAAI,CAAC;QACH,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC,CAA4B,CAAC;IAC/E,CAAC;IAAC,MAAM,CAAC;QACP,OAAO;YACL,UAAU,EAAE,KAAK;YACjB,OAAO;YACP,YAAY,EAAE,CAAC,OAAO,CAAC;YACvB,KAAK;SACN,CAAC;IACJ,CAAC;IAED,MAAM,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC;IAClC,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,UAAU,KAAK,QAAQ,IAAI,UAAU,KAAK,IAAI,CAAC,CAAC;IACtG,IAAI,QAAQ;QAAE,KAAK,CAAC,aAAa,GAAG,IAAI,CAAC;IAEzC,IAAI,MAAM,GAAG,KAAK,CAAC;IACnB,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,qBAAqB,CAAC,CAAC,CAAC;QACnD,MAAM,GAAG,IAAI,CAAC;QACd,KAAK,CAAC,aAAa,GAAG,IAAI,CAAC;IAC7B,CAAC;IAAC,MAAM,CAAC;QACP,QAAQ;IACV,CAAC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC;QACvC,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC;IAClB,CAAC;IAAC,MAAM,CAAC;QACP,QAAQ;IACV,CAAC;IAED,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;QAC1C,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC;IACrB,CAAC;IAAC,MAAM,CAAC;QACP,QAAQ;IACV,CAAC;IAED,MAAM,UAAU,GAAG,OAAO,CACxB,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,EAAE,IAAI,KAAK,CAAC,KAAK,CACtE,CAAC;IAEF,OAAO;QACL,UAAU;QACV,OAAO;QACP,YAAY,EAAE,CAAC,OAAO,CAAC;QACvB,KAAK;KACN,CAAC;AACJ,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type { AuditReport } from "../core/models.js";
|
|
3
|
+
import type { OwnershipPath } from "../core/ownership/tracer.js";
|
|
4
|
+
export declare function ReportTui(props: {
|
|
5
|
+
report: AuditReport;
|
|
6
|
+
ownership: OwnershipPath[];
|
|
7
|
+
}): React.ReactElement;
|
|
8
|
+
//# sourceMappingURL=ReportTui.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReportTui.d.ts","sourceRoot":"","sources":["../../src/ink/ReportTui.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAmB,MAAM,OAAO,CAAC;AAExC,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAEjE,wBAAgB,SAAS,CAAC,KAAK,EAAE;IAC/B,MAAM,EAAE,WAAW,CAAC;IACpB,SAAS,EAAE,aAAa,EAAE,CAAC;CAC5B,GAAG,KAAK,CAAC,YAAY,CAwCrB"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from "react";
|
|
3
|
+
import { Box, Text, useInput } from "ink";
|
|
4
|
+
export function ReportTui(props) {
|
|
5
|
+
const [idx, setIdx] = useState(0);
|
|
6
|
+
useInput((input, key) => {
|
|
7
|
+
if (key.upArrow)
|
|
8
|
+
setIdx((i) => Math.max(0, i - 1));
|
|
9
|
+
if (key.downArrow)
|
|
10
|
+
setIdx((i) => Math.min(props.report.findings.length - 1, i + 1));
|
|
11
|
+
if (input === "q" || key.escape)
|
|
12
|
+
process.exit(0);
|
|
13
|
+
});
|
|
14
|
+
const f = props.report.findings[idx];
|
|
15
|
+
return (_jsxs(Box, { flexDirection: "column", padding: 1, children: [_jsx(Text, { bold: true, children: "audit-trace \u2014 interactive (\u2191/\u2193 navigate, q quit)" }), _jsx(Box, { marginTop: 1, children: _jsxs(Text, { dimColor: true, children: ["Finding ", idx + 1, "/", props.report.findings.length] }) }), f ? (_jsxs(Box, { flexDirection: "column", marginTop: 1, children: [_jsxs(Text, { color: f.severity === "critical" ? "red" : "yellow", children: ["[", f.severity, "] ", f.packageName] }), _jsx(Text, { children: f.title ?? f.id }), _jsxs(Box, { marginTop: 1, flexDirection: "column", children: [_jsx(Text, { bold: true, children: "Owners / paths sample" }), props.ownership
|
|
16
|
+
.filter((o) => o.packageName === f.packageName)
|
|
17
|
+
.slice(0, 5)
|
|
18
|
+
.map((o, i) => (_jsxs(Text, { children: ["via ", o.topLevelNames.join(", ") || "?", " \u2014 dev:", String(o.isDevDependency)] }, i)))] })] })) : (_jsx(Text, { children: "No findings." }))] }));
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=ReportTui.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReportTui.js","sourceRoot":"","sources":["../../src/ink/ReportTui.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAI1C,MAAM,UAAU,SAAS,CAAC,KAGzB;IACC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAClC,QAAQ,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QACtB,IAAI,GAAG,CAAC,OAAO;YAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,GAAG,CAAC,SAAS;YAAE,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACpF,IAAI,KAAK,KAAK,GAAG,IAAI,GAAG,CAAC,MAAM;YAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IACH,MAAM,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;IAErC,OAAO,CACL,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,OAAO,EAAE,CAAC,aACpC,KAAC,IAAI,IAAC,IAAI,sFAAwD,EAClE,KAAC,GAAG,IAAC,SAAS,EAAE,CAAC,YACf,MAAC,IAAI,IAAC,QAAQ,+BACH,GAAG,GAAG,CAAC,OAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,IAC1C,GACH,EACL,CAAC,CAAC,CAAC,CAAC,CACH,MAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,SAAS,EAAE,CAAC,aACtC,MAAC,IAAI,IAAC,KAAK,EAAE,CAAC,CAAC,QAAQ,KAAK,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,kBACrD,CAAC,CAAC,QAAQ,QAAI,CAAC,CAAC,WAAW,IACxB,EACP,KAAC,IAAI,cAAE,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,EAAE,GAAQ,EAC9B,MAAC,GAAG,IAAC,SAAS,EAAE,CAAC,EAAE,aAAa,EAAC,QAAQ,aACvC,KAAC,IAAI,IAAC,IAAI,4CAA6B,EACtC,KAAK,CAAC,SAAS;iCACb,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,CAAC,CAAC,WAAW,CAAC;iCAC9C,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;iCACX,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CACb,MAAC,IAAI,uBACE,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,GAAG,kBAAS,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,KAD/D,CAAC,CAEL,CACR,CAAC,IACA,IACF,CACP,CAAC,CAAC,CAAC,CACF,KAAC,IAAI,+BAAoB,CAC1B,IACG,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { CiDiagnostic, VulnerabilityFinding } from "../../core/models.js";
|
|
2
|
+
export interface CiPolicy {
|
|
3
|
+
failOn: "critical" | "high" | "moderate" | "low" | "info" | "none";
|
|
4
|
+
prodOnly: boolean;
|
|
5
|
+
runtimeReachableOnly: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare const rank: Record<string, number>;
|
|
8
|
+
export declare function evaluateExit(findings: VulnerabilityFinding[], policy: CiPolicy, opts: {
|
|
9
|
+
noLockfile?: boolean;
|
|
10
|
+
auditFallback?: boolean;
|
|
11
|
+
filteredCount?: number;
|
|
12
|
+
}): {
|
|
13
|
+
exitCode: number;
|
|
14
|
+
diagnostics: CiDiagnostic[];
|
|
15
|
+
};
|
|
16
|
+
export declare function mergeDiagnostics(a: CiDiagnostic[], b: CiDiagnostic[]): CiDiagnostic[];
|
|
17
|
+
//# sourceMappingURL=policy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy.d.ts","sourceRoot":"","sources":["../../../src/integrations/ci-mode/policy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAG/E,MAAM,WAAW,QAAQ;IACvB,MAAM,EAAE,UAAU,GAAG,MAAM,GAAG,UAAU,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,CAAC;IACnE,QAAQ,EAAE,OAAO,CAAC;IAClB,oBAAoB,EAAE,OAAO,CAAC;CAC/B;AAED,eAAO,MAAM,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAMvC,CAAC;AAEF,wBAAgB,YAAY,CAC1B,QAAQ,EAAE,oBAAoB,EAAE,EAChC,MAAM,EAAE,QAAQ,EAChB,IAAI,EAAE;IACJ,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,GACA;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,WAAW,EAAE,YAAY,EAAE,CAAA;CAAE,CAoEnD;AAED,wBAAgB,gBAAgB,CAAC,CAAC,EAAE,YAAY,EAAE,EAAE,CAAC,EAAE,YAAY,EAAE,GAAG,YAAY,EAAE,CAErF"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { CI_CODES } from "../../core/models.js";
|
|
2
|
+
export const rank = {
|
|
3
|
+
critical: 4,
|
|
4
|
+
high: 3,
|
|
5
|
+
moderate: 2,
|
|
6
|
+
low: 1,
|
|
7
|
+
info: 0,
|
|
8
|
+
};
|
|
9
|
+
export function evaluateExit(findings, policy, opts) {
|
|
10
|
+
const diagnostics = [];
|
|
11
|
+
if (opts.noLockfile) {
|
|
12
|
+
diagnostics.push({
|
|
13
|
+
severity: "warn",
|
|
14
|
+
code: CI_CODES.NO_LOCKFILE,
|
|
15
|
+
message: "No supported lockfile found; graph ownership is limited.",
|
|
16
|
+
remediationHint: "Commit package-lock.json, pnpm-lock.yaml, or yarn.lock at the repository root.",
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
if (opts.auditFallback) {
|
|
20
|
+
diagnostics.push({
|
|
21
|
+
severity: "info",
|
|
22
|
+
code: CI_CODES.AUDIT_SOURCE_FALLBACK,
|
|
23
|
+
message: "Audit output may be partial; verify package manager version.",
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
if (opts.filteredCount && opts.filteredCount > 0) {
|
|
27
|
+
diagnostics.push({
|
|
28
|
+
severity: "info",
|
|
29
|
+
code: "FILTER_CONTEXT",
|
|
30
|
+
message: `${opts.filteredCount} finding(s) excluded by policy filters.`,
|
|
31
|
+
policy: { prodOnly: policy.prodOnly, runtimeReachableOnly: policy.runtimeReachableOnly },
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
let relevant = findings;
|
|
35
|
+
if (policy.failOn === "none") {
|
|
36
|
+
return { exitCode: 0, diagnostics };
|
|
37
|
+
}
|
|
38
|
+
const threshold = rank[policy.failOn] ?? 0;
|
|
39
|
+
relevant = relevant.filter((f) => (rank[f.severity] ?? 0) >= threshold);
|
|
40
|
+
if (relevant.length === 0) {
|
|
41
|
+
return { exitCode: 0, diagnostics };
|
|
42
|
+
}
|
|
43
|
+
const names = [...new Set(relevant.map((r) => r.packageName))];
|
|
44
|
+
const highSeverity = relevant.filter((f) => f.severity === "high" || f.severity === "critical");
|
|
45
|
+
if (highSeverity.length && (policy.failOn === "high" || policy.failOn === "critical")) {
|
|
46
|
+
diagnostics.push({
|
|
47
|
+
severity: "error",
|
|
48
|
+
code: CI_CODES.FAIL_HIGH_PROD,
|
|
49
|
+
message: "High or critical severity vulnerabilities matched the failure threshold.",
|
|
50
|
+
relatedPackages: [...new Set(highSeverity.map((h) => h.packageName))],
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
diagnostics.push({
|
|
54
|
+
severity: "error",
|
|
55
|
+
code: CI_CODES.FAIL_POLICY,
|
|
56
|
+
message: `Dependency audit policy failed (fail-on=${policy.failOn}).`,
|
|
57
|
+
detail: names.slice(0, 20).join(", ") + (names.length > 20 ? "…" : ""),
|
|
58
|
+
relatedPackages: names,
|
|
59
|
+
remediationHint: "Apply overrides/upgrades from the report or adjust --fail-on / filters.",
|
|
60
|
+
policy: {
|
|
61
|
+
failOn: policy.failOn,
|
|
62
|
+
prodOnly: policy.prodOnly,
|
|
63
|
+
runtimeReachableOnly: policy.runtimeReachableOnly,
|
|
64
|
+
},
|
|
65
|
+
});
|
|
66
|
+
return { exitCode: 1, diagnostics };
|
|
67
|
+
}
|
|
68
|
+
export function mergeDiagnostics(a, b) {
|
|
69
|
+
return [...a, ...b];
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy.js","sourceRoot":"","sources":["../../../src/integrations/ci-mode/policy.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface LockDiffSummary {
|
|
2
|
+
addedPackages: string[];
|
|
3
|
+
removedPackages: string[];
|
|
4
|
+
versionChanges: {
|
|
5
|
+
name: string;
|
|
6
|
+
from: string;
|
|
7
|
+
to: string;
|
|
8
|
+
}[];
|
|
9
|
+
}
|
|
10
|
+
export declare function diffLockfiles(beforeText: string, afterText: string, kind: "npm" | "pnpm"): LockDiffSummary;
|
|
11
|
+
//# sourceMappingURL=compare.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compare.d.ts","sourceRoot":"","sources":["../../../src/integrations/lockfile-diff/compare.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,eAAe;IAC9B,aAAa,EAAE,MAAM,EAAE,CAAC;IACxB,eAAe,EAAE,MAAM,EAAE,CAAC;IAC1B,cAAc,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;CAC9D;AAmCD,wBAAgB,aAAa,CAC3B,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,KAAK,GAAG,MAAM,GACnB,eAAe,CAOjB"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { parse as parseYaml } from "yaml";
|
|
2
|
+
function listNpmPackages(text) {
|
|
3
|
+
const m = new Map();
|
|
4
|
+
try {
|
|
5
|
+
const j = JSON.parse(text);
|
|
6
|
+
const pk = j.packages ?? {};
|
|
7
|
+
for (const [path, ent] of Object.entries(pk)) {
|
|
8
|
+
if (path === "")
|
|
9
|
+
continue;
|
|
10
|
+
const name = ent.name ?? path.split("node_modules/").pop() ?? path;
|
|
11
|
+
const v = ent.version ?? "";
|
|
12
|
+
if (name && v)
|
|
13
|
+
m.set(`${name}@${v}`, `${name}@${v}`);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
catch {
|
|
17
|
+
/* ignore */
|
|
18
|
+
}
|
|
19
|
+
return m;
|
|
20
|
+
}
|
|
21
|
+
function listPnpmPackages(text) {
|
|
22
|
+
const m = new Map();
|
|
23
|
+
try {
|
|
24
|
+
const doc = parseYaml(text);
|
|
25
|
+
const pk = doc.packages ?? {};
|
|
26
|
+
for (const k of Object.keys(pk)) {
|
|
27
|
+
if (k.startsWith("/"))
|
|
28
|
+
m.set(k, k);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
catch {
|
|
32
|
+
/* ignore */
|
|
33
|
+
}
|
|
34
|
+
return m;
|
|
35
|
+
}
|
|
36
|
+
export function diffLockfiles(beforeText, afterText, kind) {
|
|
37
|
+
const a = kind === "npm" ? listNpmPackages(beforeText) : listPnpmPackages(beforeText);
|
|
38
|
+
const b = kind === "npm" ? listNpmPackages(afterText) : listPnpmPackages(afterText);
|
|
39
|
+
const addedPackages = [...b.keys()].filter((k) => !a.has(k));
|
|
40
|
+
const removedPackages = [...a.keys()].filter((k) => !b.has(k));
|
|
41
|
+
const versionChanges = [];
|
|
42
|
+
return { addedPackages, removedPackages, versionChanges };
|
|
43
|
+
}
|
|
44
|
+
//# sourceMappingURL=compare.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compare.js","sourceRoot":"","sources":["../../../src/integrations/lockfile-diff/compare.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,MAAM,CAAC;AAQ1C,SAAS,eAAe,CAAC,IAAY;IACnC,MAAM,CAAC,GAAG,IAAI,GAAG,EAAkB,CAAC;IACpC,IAAI,CAAC;QACH,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAExB,CAAC;QACF,MAAM,EAAE,GAAG,CAAC,CAAC,QAAQ,IAAI,EAAE,CAAC;QAC5B,KAAK,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;YAC7C,IAAI,IAAI,KAAK,EAAE;gBAAE,SAAS;YAC1B,MAAM,IAAI,GAAG,GAAG,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC;YACnE,MAAM,CAAC,GAAG,GAAG,CAAC,OAAO,IAAI,EAAE,CAAC;YAC5B,IAAI,IAAI,IAAI,CAAC;gBAAE,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,IAAI,CAAC,EAAE,EAAE,GAAG,IAAI,IAAI,CAAC,EAAE,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,YAAY;IACd,CAAC;IACD,OAAO,CAAC,CAAC;AACX,CAAC;AAED,SAAS,gBAAgB,CAAC,IAAY;IACpC,MAAM,CAAC,GAAG,IAAI,GAAG,EAAkB,CAAC;IACpC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,SAAS,CAAC,IAAI,CAA2C,CAAC;QACtE,MAAM,EAAE,GAAG,GAAG,CAAC,QAAQ,IAAI,EAAE,CAAC;QAC9B,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC;gBAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,YAAY;IACd,CAAC;IACD,OAAO,CAAC,CAAC;AACX,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,UAAkB,EAClB,SAAiB,EACjB,IAAoB;IAEpB,MAAM,CAAC,GAAG,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;IACtF,MAAM,CAAC,GAAG,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;IACpF,MAAM,aAAa,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7D,MAAM,eAAe,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/D,MAAM,cAAc,GAAsC,EAAE,CAAC;IAC7D,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,cAAc,EAAE,CAAC;AAC5D,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export type ReachabilityResult = {
|
|
2
|
+
status: "reachable" | "not_reachable";
|
|
3
|
+
evidence: string;
|
|
4
|
+
} | {
|
|
5
|
+
status: "unknown";
|
|
6
|
+
evidence: string;
|
|
7
|
+
};
|
|
8
|
+
/**
|
|
9
|
+
* Best-effort: if madge dependency graph includes the package name under node_modules, treat as reachable.
|
|
10
|
+
*/
|
|
11
|
+
export declare function checkRuntimeReachable(entryFile: string, packageName: string, cwd: string): Promise<ReachabilityResult>;
|
|
12
|
+
//# sourceMappingURL=madge-check.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"madge-check.d.ts","sourceRoot":"","sources":["../../../src/integrations/reachability/madge-check.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,kBAAkB,GAC1B;IAAE,MAAM,EAAE,WAAW,GAAG,eAAe,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,GAC3D;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAA;CAAE,CAAC;AAE5C;;GAEG;AACH,wBAAsB,qBAAqB,CACzC,SAAS,EAAE,MAAM,EACjB,WAAW,EAAE,MAAM,EACnB,GAAG,EAAE,MAAM,GACV,OAAO,CAAC,kBAAkB,CAAC,CAiC7B"}
|