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,159 @@
|
|
|
1
|
+
function scopedSeg(name) {
|
|
2
|
+
return name.startsWith("@") ? name.split("/").slice(0, 2).join("/") : name;
|
|
3
|
+
}
|
|
4
|
+
/** Resolve child path for a dependency name from parent lock path (npm v2/v3 packages keys). */
|
|
5
|
+
export function resolveNpmPackagePath(packages, parentPath, depName) {
|
|
6
|
+
const seg = scopedSeg(depName);
|
|
7
|
+
let current = parentPath;
|
|
8
|
+
for (let hop = 0; hop < 512; hop++) {
|
|
9
|
+
const candidate = current === "" ? `node_modules/${seg}` : `${current}/node_modules/${seg}`;
|
|
10
|
+
if (candidate in packages)
|
|
11
|
+
return candidate;
|
|
12
|
+
if (current === "")
|
|
13
|
+
break;
|
|
14
|
+
const idx = current.lastIndexOf("/node_modules/");
|
|
15
|
+
if (idx === -1) {
|
|
16
|
+
const rootCand = `node_modules/${seg}`;
|
|
17
|
+
if (rootCand in packages)
|
|
18
|
+
return rootCand;
|
|
19
|
+
break;
|
|
20
|
+
}
|
|
21
|
+
current = current.slice(0, idx);
|
|
22
|
+
if (current === "") {
|
|
23
|
+
const rootCand = `node_modules/${seg}`;
|
|
24
|
+
if (rootCand in packages)
|
|
25
|
+
return rootCand;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
return undefined;
|
|
29
|
+
}
|
|
30
|
+
export function buildGraphFromPackageLock(raw, _rootDir) {
|
|
31
|
+
const packages = raw.packages;
|
|
32
|
+
if (!packages || typeof packages !== "object") {
|
|
33
|
+
return emptyGraph();
|
|
34
|
+
}
|
|
35
|
+
const nodes = new Map();
|
|
36
|
+
const edges = [];
|
|
37
|
+
const byPackageName = new Map();
|
|
38
|
+
const rootIds = [];
|
|
39
|
+
const registerNode = (pathKey, name, ver, dev, opt, peer) => {
|
|
40
|
+
const id = `${pathKey}::${name}@${ver}`;
|
|
41
|
+
if (nodes.has(id))
|
|
42
|
+
return id;
|
|
43
|
+
const node = {
|
|
44
|
+
id,
|
|
45
|
+
pathKey,
|
|
46
|
+
name,
|
|
47
|
+
version: ver,
|
|
48
|
+
dev,
|
|
49
|
+
optional: opt,
|
|
50
|
+
peer,
|
|
51
|
+
};
|
|
52
|
+
nodes.set(id, node);
|
|
53
|
+
const list = byPackageName.get(name) ?? [];
|
|
54
|
+
list.push(id);
|
|
55
|
+
byPackageName.set(name, list);
|
|
56
|
+
return id;
|
|
57
|
+
};
|
|
58
|
+
const getEntry = (k) => packages[k] ?? {};
|
|
59
|
+
for (const pathKey of Object.keys(packages)) {
|
|
60
|
+
if (pathKey === "")
|
|
61
|
+
continue;
|
|
62
|
+
const ent = getEntry(pathKey);
|
|
63
|
+
const ver = ent.version ?? "";
|
|
64
|
+
if (!ver)
|
|
65
|
+
continue;
|
|
66
|
+
const nameFromPath = pathToPackageName(pathKey);
|
|
67
|
+
const name = ent.name ?? nameFromPath;
|
|
68
|
+
const dev = Boolean(ent.dev);
|
|
69
|
+
const optional = Boolean(ent.optional);
|
|
70
|
+
registerNode(pathKey, name, ver, dev, optional, false);
|
|
71
|
+
}
|
|
72
|
+
const rootEntry = getEntry("");
|
|
73
|
+
const ensureRoot = () => registerOrGetRoot(rootIds, nodes, byPackageName, rootEntry);
|
|
74
|
+
const linkDeps = (parentPath, deps, type) => {
|
|
75
|
+
if (!deps)
|
|
76
|
+
return;
|
|
77
|
+
for (const depName of Object.keys(deps)) {
|
|
78
|
+
const childPath = resolveNpmPackagePath(packages, parentPath, depName);
|
|
79
|
+
if (!childPath)
|
|
80
|
+
continue;
|
|
81
|
+
const childEnt = getEntry(childPath);
|
|
82
|
+
const childVer = childEnt.version ?? "";
|
|
83
|
+
const childName = childEnt.name ?? pathToPackageName(childPath);
|
|
84
|
+
const fromId = parentPath === ""
|
|
85
|
+
? ensureRoot()
|
|
86
|
+
: findNodeId(nodes, parentPath, pathToPackageName(parentPath), getEntry(parentPath).version ?? "");
|
|
87
|
+
const toId = findNodeId(nodes, childPath, childName, childVer);
|
|
88
|
+
if (fromId && toId)
|
|
89
|
+
edges.push({ from: fromId, to: toId, depType: type });
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
linkDeps("", rootEntry.dependencies, "dependencies");
|
|
93
|
+
linkDeps("", rootEntry.devDependencies, "devDependencies");
|
|
94
|
+
linkDeps("", rootEntry.optionalDependencies, "optionalDependencies");
|
|
95
|
+
linkDeps("", rootEntry.peerDependencies, "peerDependencies");
|
|
96
|
+
for (const pathKey of Object.keys(packages)) {
|
|
97
|
+
if (pathKey === "")
|
|
98
|
+
continue;
|
|
99
|
+
const ent = getEntry(pathKey);
|
|
100
|
+
linkDeps(pathKey, ent.dependencies, "dependencies");
|
|
101
|
+
linkDeps(pathKey, ent.devDependencies, "devDependencies");
|
|
102
|
+
linkDeps(pathKey, ent.optionalDependencies, "optionalDependencies");
|
|
103
|
+
linkDeps(pathKey, ent.peerDependencies, "peerDependencies");
|
|
104
|
+
}
|
|
105
|
+
return {
|
|
106
|
+
nodes,
|
|
107
|
+
edges,
|
|
108
|
+
rootIds,
|
|
109
|
+
lockfileKind: "npm",
|
|
110
|
+
byPackageName,
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
function pathToPackageName(pathKey) {
|
|
114
|
+
const idx = pathKey.lastIndexOf("node_modules/");
|
|
115
|
+
if (idx === -1)
|
|
116
|
+
return pathKey;
|
|
117
|
+
return pathKey.slice(idx + "node_modules/".length);
|
|
118
|
+
}
|
|
119
|
+
function findNodeId(nodes, pathKey, name, version) {
|
|
120
|
+
for (const n of nodes.values()) {
|
|
121
|
+
if (n.pathKey === pathKey && n.name === name && n.version === version)
|
|
122
|
+
return n.id;
|
|
123
|
+
}
|
|
124
|
+
return undefined;
|
|
125
|
+
}
|
|
126
|
+
function registerOrGetRoot(rootIds, nodes, byPackageName, rootEntry) {
|
|
127
|
+
const name = rootEntry.name ?? "__root__";
|
|
128
|
+
const ver = rootEntry.version ?? "0.0.0";
|
|
129
|
+
const pathKey = "";
|
|
130
|
+
const id = `${pathKey}::${name}@${ver}`;
|
|
131
|
+
if (!nodes.has(id)) {
|
|
132
|
+
const node = {
|
|
133
|
+
id,
|
|
134
|
+
pathKey,
|
|
135
|
+
name,
|
|
136
|
+
version: ver,
|
|
137
|
+
dev: false,
|
|
138
|
+
optional: false,
|
|
139
|
+
peer: false,
|
|
140
|
+
};
|
|
141
|
+
nodes.set(id, node);
|
|
142
|
+
const list = byPackageName.get(name) ?? [];
|
|
143
|
+
list.push(id);
|
|
144
|
+
byPackageName.set(name, list);
|
|
145
|
+
}
|
|
146
|
+
if (!rootIds.includes(id))
|
|
147
|
+
rootIds.push(id);
|
|
148
|
+
return id;
|
|
149
|
+
}
|
|
150
|
+
function emptyGraph() {
|
|
151
|
+
return {
|
|
152
|
+
nodes: new Map(),
|
|
153
|
+
edges: [],
|
|
154
|
+
rootIds: [],
|
|
155
|
+
lockfileKind: "unknown",
|
|
156
|
+
byPackageName: new Map(),
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
//# sourceMappingURL=npm-lock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"npm-lock.js","sourceRoot":"","sources":["../../../src/core/graph-engine/npm-lock.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { DependencyGraphSnapshot } from "../models.js";
|
|
2
|
+
/** Build graph from pnpm-lock.yaml (lockfile 6.x–9.x style with `packages` map). */
|
|
3
|
+
export declare function buildGraphFromPnpmLock(content: string): DependencyGraphSnapshot;
|
|
4
|
+
//# sourceMappingURL=pnpm-lock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pnpm-lock.d.ts","sourceRoot":"","sources":["../../../src/core/graph-engine/pnpm-lock.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAkB,uBAAuB,EAAkB,MAAM,cAAc,CAAC;AAE5F,oFAAoF;AACpF,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,MAAM,GACd,uBAAuB,CA4JzB"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { parse as parseYaml } from "yaml";
|
|
2
|
+
/** Build graph from pnpm-lock.yaml (lockfile 6.x–9.x style with `packages` map). */
|
|
3
|
+
export function buildGraphFromPnpmLock(content) {
|
|
4
|
+
const doc = parseYaml(content);
|
|
5
|
+
const packages = doc.packages;
|
|
6
|
+
if (!packages || typeof packages !== "object") {
|
|
7
|
+
return empty();
|
|
8
|
+
}
|
|
9
|
+
const nodes = new Map();
|
|
10
|
+
const edges = [];
|
|
11
|
+
const byPackageName = new Map();
|
|
12
|
+
const rootIds = [];
|
|
13
|
+
const nodeIdForKey = (lockKey, name, ver) => `pnpm:${lockKey}::${name}@${ver}`;
|
|
14
|
+
const register = (lockKey, name, ver, dev, opt) => {
|
|
15
|
+
const id = nodeIdForKey(lockKey, name, ver);
|
|
16
|
+
if (nodes.has(id))
|
|
17
|
+
return id;
|
|
18
|
+
const n = {
|
|
19
|
+
id,
|
|
20
|
+
pathKey: lockKey,
|
|
21
|
+
name,
|
|
22
|
+
version: ver,
|
|
23
|
+
dev,
|
|
24
|
+
optional: opt,
|
|
25
|
+
peer: false,
|
|
26
|
+
};
|
|
27
|
+
nodes.set(id, n);
|
|
28
|
+
const arr = byPackageName.get(name) ?? [];
|
|
29
|
+
arr.push(id);
|
|
30
|
+
byPackageName.set(name, arr);
|
|
31
|
+
return id;
|
|
32
|
+
};
|
|
33
|
+
const parsePkgKey = (k) => {
|
|
34
|
+
if (!k.startsWith("/"))
|
|
35
|
+
return undefined;
|
|
36
|
+
const parts = k.slice(1).split("/").filter(Boolean);
|
|
37
|
+
if (parts.length < 2)
|
|
38
|
+
return undefined;
|
|
39
|
+
if (parts[0]?.startsWith("@")) {
|
|
40
|
+
const name = `${parts[0]}/${parts[1]}`;
|
|
41
|
+
const version = parts[2] ?? "";
|
|
42
|
+
if (!version)
|
|
43
|
+
return undefined;
|
|
44
|
+
return { name, version };
|
|
45
|
+
}
|
|
46
|
+
const name = parts[0] ?? "";
|
|
47
|
+
const version = parts[1] ?? "";
|
|
48
|
+
return { name, version };
|
|
49
|
+
};
|
|
50
|
+
const resolveKey = (depName, depVersion) => {
|
|
51
|
+
const v = depVersion.replace(/^\^|~|\*/g, "").trim();
|
|
52
|
+
if (depName.startsWith("@")) {
|
|
53
|
+
const cand = `/${depName}/${v}`;
|
|
54
|
+
if (packages[cand])
|
|
55
|
+
return cand;
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
const cand = `/${depName}/${v}`;
|
|
59
|
+
if (packages[cand])
|
|
60
|
+
return cand;
|
|
61
|
+
}
|
|
62
|
+
for (const key of Object.keys(packages)) {
|
|
63
|
+
const p = parsePkgKey(key);
|
|
64
|
+
if (p && p.name === depName && (p.version === v || p.version.startsWith(v)))
|
|
65
|
+
return key;
|
|
66
|
+
}
|
|
67
|
+
return undefined;
|
|
68
|
+
};
|
|
69
|
+
for (const lockKey of Object.keys(packages)) {
|
|
70
|
+
const p = parsePkgKey(lockKey);
|
|
71
|
+
if (!p)
|
|
72
|
+
continue;
|
|
73
|
+
const ent = packages[lockKey] ?? {};
|
|
74
|
+
const dev = Boolean(ent.dev === "true");
|
|
75
|
+
const opt = Boolean(ent.optional === "true");
|
|
76
|
+
register(lockKey, p.name, p.version, dev, opt);
|
|
77
|
+
}
|
|
78
|
+
for (const lockKey of Object.keys(packages)) {
|
|
79
|
+
const fromP = parsePkgKey(lockKey);
|
|
80
|
+
if (!fromP)
|
|
81
|
+
continue;
|
|
82
|
+
const ent = packages[lockKey] ?? {};
|
|
83
|
+
const fromId = register(lockKey, fromP.name, fromP.version, false, false);
|
|
84
|
+
const deps = ent.dependencies;
|
|
85
|
+
const optDeps = ent
|
|
86
|
+
.optionalDependencies;
|
|
87
|
+
const devDeps = ent.devDependencies;
|
|
88
|
+
const peerDeps = ent.peerDependencies;
|
|
89
|
+
const link = (m, t) => {
|
|
90
|
+
if (!m)
|
|
91
|
+
return;
|
|
92
|
+
for (const [dname, dver] of Object.entries(m)) {
|
|
93
|
+
const tgt = resolveKey(dname, dver);
|
|
94
|
+
if (!tgt)
|
|
95
|
+
continue;
|
|
96
|
+
const tp = parsePkgKey(tgt);
|
|
97
|
+
if (!tp)
|
|
98
|
+
continue;
|
|
99
|
+
const toId = register(tgt, tp.name, tp.version, false, false);
|
|
100
|
+
edges.push({ from: fromId, to: toId, depType: t });
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
link(deps, "dependencies");
|
|
104
|
+
link(optDeps, "optionalDependencies");
|
|
105
|
+
link(devDeps, "devDependencies");
|
|
106
|
+
link(peerDeps, "peerDependencies");
|
|
107
|
+
}
|
|
108
|
+
const importers = doc.importers;
|
|
109
|
+
if (importers) {
|
|
110
|
+
for (const [impPath, imp] of Object.entries(importers)) {
|
|
111
|
+
const rootName = impPath === "." ? "__workspace_root__" : impPath;
|
|
112
|
+
const rootVer = "0.0.0";
|
|
113
|
+
const rootKey = `importer:${impPath}`;
|
|
114
|
+
const rootId = register(rootKey, rootName, rootVer, false, false);
|
|
115
|
+
rootIds.push(rootId);
|
|
116
|
+
const linkImp = (block, t) => {
|
|
117
|
+
if (!block)
|
|
118
|
+
return;
|
|
119
|
+
for (const [dname, spec] of Object.entries(block)) {
|
|
120
|
+
const v = spec.version ?? spec.specifier ?? "";
|
|
121
|
+
const tgt = resolveKey(dname, v);
|
|
122
|
+
if (!tgt)
|
|
123
|
+
continue;
|
|
124
|
+
const tp = parsePkgKey(tgt);
|
|
125
|
+
if (!tp)
|
|
126
|
+
continue;
|
|
127
|
+
const toId = register(tgt, tp.name, tp.version, false, false);
|
|
128
|
+
edges.push({ from: rootId, to: toId, depType: t });
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
linkImp(imp.dependencies, "dependencies");
|
|
132
|
+
linkImp(imp.devDependencies, "devDependencies");
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
return {
|
|
136
|
+
nodes,
|
|
137
|
+
edges,
|
|
138
|
+
rootIds,
|
|
139
|
+
lockfileKind: "pnpm",
|
|
140
|
+
byPackageName,
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
function empty() {
|
|
144
|
+
return {
|
|
145
|
+
nodes: new Map(),
|
|
146
|
+
edges: [],
|
|
147
|
+
rootIds: [],
|
|
148
|
+
lockfileKind: "unknown",
|
|
149
|
+
byPackageName: new Map(),
|
|
150
|
+
};
|
|
151
|
+
}
|
|
152
|
+
//# sourceMappingURL=pnpm-lock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pnpm-lock.js","sourceRoot":"","sources":["../../../src/core/graph-engine/pnpm-lock.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Graph } from "graphlib";
|
|
2
|
+
import type { DependencyGraphSnapshot, DependencyNode } from "../models.js";
|
|
3
|
+
export interface GraphIndexes {
|
|
4
|
+
forward: Graph;
|
|
5
|
+
reverse: Graph;
|
|
6
|
+
nodeById: Map<string, import("../models.js").DependencyNode>;
|
|
7
|
+
}
|
|
8
|
+
export declare function buildIndexes(snapshot: DependencyGraphSnapshot): GraphIndexes;
|
|
9
|
+
/** Shortest path (fewest edges) from any root to target using BFS on reverse graph from target... actually we need path from root to vulnerable: BFS forward from roots */
|
|
10
|
+
export declare function shortestPathFromRoots(snapshot: DependencyGraphSnapshot, indexes: GraphIndexes, targetId: string): string[] | null;
|
|
11
|
+
export declare function dfsAllPathsWithLimit(indexes: GraphIndexes, fromId: string, toId: string, maxPaths: number, maxDepth: number): string[][];
|
|
12
|
+
export declare function reverseLookupConsumers(indexes: GraphIndexes, packageNodeId: string): string[];
|
|
13
|
+
/** All transitive predecessors (who depends on this) */
|
|
14
|
+
export declare function impactSet(indexes: GraphIndexes, packageNodeId: string): Set<string>;
|
|
15
|
+
export declare function duplicateVersions(snapshot: DependencyGraphSnapshot): Map<string, Set<string>>;
|
|
16
|
+
export declare function formatPathNames(pathIds: string[], nodes: Map<string, DependencyNode>): string;
|
|
17
|
+
//# sourceMappingURL=traverse.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"traverse.d.ts","sourceRoot":"","sources":["../../../src/core/graph-engine/traverse.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACjC,OAAO,KAAK,EAAE,uBAAuB,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAE5E,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,KAAK,CAAC;IACf,OAAO,EAAE,KAAK,CAAC;IACf,QAAQ,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,cAAc,EAAE,cAAc,CAAC,CAAC;CAC9D;AAED,wBAAgB,YAAY,CAAC,QAAQ,EAAE,uBAAuB,GAAG,YAAY,CAkB5E;AAED,2KAA2K;AAC3K,wBAAgB,qBAAqB,CACnC,QAAQ,EAAE,uBAAuB,EACjC,OAAO,EAAE,YAAY,EACrB,QAAQ,EAAE,MAAM,GACf,MAAM,EAAE,GAAG,IAAI,CAsCjB;AAED,wBAAgB,oBAAoB,CAClC,OAAO,EAAE,YAAY,EACrB,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,GACf,MAAM,EAAE,EAAE,CAoBZ;AAED,wBAAgB,sBAAsB,CACpC,OAAO,EAAE,YAAY,EACrB,aAAa,EAAE,MAAM,GACpB,MAAM,EAAE,CAGV;AAED,wDAAwD;AACxD,wBAAgB,SAAS,CAAC,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAUnF;AAED,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,uBAAuB,GAAG,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,CAY7F;AAED,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,cAAc,CAAC,GAAG,MAAM,CAO7F"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { Graph } from "graphlib";
|
|
2
|
+
export function buildIndexes(snapshot) {
|
|
3
|
+
const forward = new Graph({ directed: true, multigraph: false });
|
|
4
|
+
const reverse = new Graph({ directed: true, multigraph: false });
|
|
5
|
+
const nodeById = new Map(snapshot.nodes);
|
|
6
|
+
for (const n of snapshot.nodes.keys()) {
|
|
7
|
+
forward.setNode(n);
|
|
8
|
+
reverse.setNode(n);
|
|
9
|
+
}
|
|
10
|
+
for (const e of snapshot.edges) {
|
|
11
|
+
if (!forward.hasNode(e.from) || !forward.hasNode(e.to))
|
|
12
|
+
continue;
|
|
13
|
+
const label = `${e.depType}`;
|
|
14
|
+
if (!forward.hasEdge(e.from, e.to))
|
|
15
|
+
forward.setEdge(e.from, e.to, label);
|
|
16
|
+
if (!reverse.hasEdge(e.to, e.from))
|
|
17
|
+
reverse.setEdge(e.to, e.from, label);
|
|
18
|
+
}
|
|
19
|
+
return { forward, reverse, nodeById };
|
|
20
|
+
}
|
|
21
|
+
/** Shortest path (fewest edges) from any root to target using BFS on reverse graph from target... actually we need path from root to vulnerable: BFS forward from roots */
|
|
22
|
+
export function shortestPathFromRoots(snapshot, indexes, targetId) {
|
|
23
|
+
const { forward } = indexes;
|
|
24
|
+
if (!forward.hasNode(targetId))
|
|
25
|
+
return null;
|
|
26
|
+
const roots = new Set(snapshot.rootIds.filter((r) => forward.hasNode(r)));
|
|
27
|
+
if (roots.size === 0) {
|
|
28
|
+
for (const n of forward.nodes()) {
|
|
29
|
+
const preds = forward.predecessors(n) ?? [];
|
|
30
|
+
if (preds.length === 0)
|
|
31
|
+
roots.add(n);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
const queue = [...roots];
|
|
35
|
+
const prev = new Map();
|
|
36
|
+
for (const r of roots)
|
|
37
|
+
prev.set(r, null);
|
|
38
|
+
const seen = new Set(queue);
|
|
39
|
+
while (queue.length) {
|
|
40
|
+
const u = queue.shift();
|
|
41
|
+
if (u === targetId)
|
|
42
|
+
break;
|
|
43
|
+
const succ = forward.successors(u) ?? [];
|
|
44
|
+
for (const v of succ) {
|
|
45
|
+
if (seen.has(v))
|
|
46
|
+
continue;
|
|
47
|
+
seen.add(v);
|
|
48
|
+
prev.set(v, u);
|
|
49
|
+
queue.push(v);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
if (!seen.has(targetId))
|
|
53
|
+
return null;
|
|
54
|
+
const path = [];
|
|
55
|
+
let cur = targetId;
|
|
56
|
+
while (cur != null) {
|
|
57
|
+
path.push(cur);
|
|
58
|
+
cur = prev.get(cur) ?? null;
|
|
59
|
+
}
|
|
60
|
+
path.reverse();
|
|
61
|
+
return path;
|
|
62
|
+
}
|
|
63
|
+
export function dfsAllPathsWithLimit(indexes, fromId, toId, maxPaths, maxDepth) {
|
|
64
|
+
const paths = [];
|
|
65
|
+
const path = [fromId];
|
|
66
|
+
const visit = (u, depth) => {
|
|
67
|
+
if (paths.length >= maxPaths)
|
|
68
|
+
return;
|
|
69
|
+
if (depth > maxDepth)
|
|
70
|
+
return;
|
|
71
|
+
if (u === toId) {
|
|
72
|
+
paths.push([...path]);
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
for (const v of indexes.forward.successors(u) ?? []) {
|
|
76
|
+
path.push(v);
|
|
77
|
+
visit(v, depth + 1);
|
|
78
|
+
path.pop();
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
visit(fromId, 0);
|
|
82
|
+
return paths;
|
|
83
|
+
}
|
|
84
|
+
export function reverseLookupConsumers(indexes, packageNodeId) {
|
|
85
|
+
if (!indexes.reverse.hasNode(packageNodeId))
|
|
86
|
+
return [];
|
|
87
|
+
return indexes.reverse.successors(packageNodeId) ?? [];
|
|
88
|
+
}
|
|
89
|
+
/** All transitive predecessors (who depends on this) */
|
|
90
|
+
export function impactSet(indexes, packageNodeId) {
|
|
91
|
+
const out = new Set();
|
|
92
|
+
const q = [...reverseLookupConsumers(indexes, packageNodeId)];
|
|
93
|
+
while (q.length) {
|
|
94
|
+
const u = q.pop();
|
|
95
|
+
if (out.has(u))
|
|
96
|
+
continue;
|
|
97
|
+
out.add(u);
|
|
98
|
+
for (const p of reverseLookupConsumers(indexes, u))
|
|
99
|
+
q.push(p);
|
|
100
|
+
}
|
|
101
|
+
return out;
|
|
102
|
+
}
|
|
103
|
+
export function duplicateVersions(snapshot) {
|
|
104
|
+
const m = new Map();
|
|
105
|
+
for (const n of snapshot.nodes.values()) {
|
|
106
|
+
const s = m.get(n.name) ?? new Set();
|
|
107
|
+
s.add(n.version);
|
|
108
|
+
m.set(n.name, s);
|
|
109
|
+
}
|
|
110
|
+
const dup = new Map();
|
|
111
|
+
for (const [name, vers] of m) {
|
|
112
|
+
if (vers.size > 1)
|
|
113
|
+
dup.set(name, vers);
|
|
114
|
+
}
|
|
115
|
+
return dup;
|
|
116
|
+
}
|
|
117
|
+
export function formatPathNames(pathIds, nodes) {
|
|
118
|
+
return pathIds
|
|
119
|
+
.map((id) => {
|
|
120
|
+
const n = nodes.get(id);
|
|
121
|
+
return n ? `${n.name}@${n.version}` : id;
|
|
122
|
+
})
|
|
123
|
+
.join(" → ");
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=traverse.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"traverse.js","sourceRoot":"","sources":["../../../src/core/graph-engine/traverse.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { DependencyGraphSnapshot } from "../models.js";
|
|
2
|
+
/** Parse yarn.lock v1 into dependency graph (resolved versions as nodes). */
|
|
3
|
+
export declare function buildGraphFromYarnLock(content: string): DependencyGraphSnapshot;
|
|
4
|
+
//# sourceMappingURL=yarn-lock.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"yarn-lock.d.ts","sourceRoot":"","sources":["../../../src/core/graph-engine/yarn-lock.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAkB,uBAAuB,EAAkB,MAAM,cAAc,CAAC;AAE5F,6EAA6E;AAC7E,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,MAAM,GAAG,uBAAuB,CAmI/E"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import lockfile from "@yarnpkg/lockfile";
|
|
2
|
+
/** Parse yarn.lock v1 into dependency graph (resolved versions as nodes). */
|
|
3
|
+
export function buildGraphFromYarnLock(content) {
|
|
4
|
+
const parsed = lockfile.parse(content);
|
|
5
|
+
if (parsed.type !== "success" || !parsed.object) {
|
|
6
|
+
return empty();
|
|
7
|
+
}
|
|
8
|
+
const obj = parsed.object;
|
|
9
|
+
const nodes = new Map();
|
|
10
|
+
const edges = [];
|
|
11
|
+
const byPackageName = new Map();
|
|
12
|
+
const rootIds = [];
|
|
13
|
+
const parseKey = (key) => {
|
|
14
|
+
const idx = key.lastIndexOf("@");
|
|
15
|
+
if (idx <= 0)
|
|
16
|
+
return undefined;
|
|
17
|
+
const name = key.slice(0, idx);
|
|
18
|
+
const range = key.slice(idx + 1);
|
|
19
|
+
if (!name || !range)
|
|
20
|
+
return undefined;
|
|
21
|
+
return { name, range };
|
|
22
|
+
};
|
|
23
|
+
const canonicalId = (name, version) => `yarn:${name}@${version}`;
|
|
24
|
+
const register = (name, version) => {
|
|
25
|
+
const id = canonicalId(name, version);
|
|
26
|
+
if (nodes.has(id))
|
|
27
|
+
return id;
|
|
28
|
+
const n = {
|
|
29
|
+
id,
|
|
30
|
+
pathKey: id,
|
|
31
|
+
name,
|
|
32
|
+
version,
|
|
33
|
+
dev: false,
|
|
34
|
+
optional: false,
|
|
35
|
+
peer: false,
|
|
36
|
+
};
|
|
37
|
+
nodes.set(id, n);
|
|
38
|
+
const arr = byPackageName.get(name) ?? [];
|
|
39
|
+
arr.push(id);
|
|
40
|
+
byPackageName.set(name, arr);
|
|
41
|
+
return id;
|
|
42
|
+
};
|
|
43
|
+
/** name+constraint -> resolved version from lockfile entries */
|
|
44
|
+
const resolveVersion = (name, constraint) => {
|
|
45
|
+
for (const [k, v] of Object.entries(obj)) {
|
|
46
|
+
const p = parseKey(k);
|
|
47
|
+
if (!p)
|
|
48
|
+
continue;
|
|
49
|
+
if (p.name === name && (v.version === constraint || k.includes(constraint))) {
|
|
50
|
+
return v.version;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
for (const [, v] of Object.entries(obj)) {
|
|
54
|
+
if (v.version === constraint)
|
|
55
|
+
return v.version;
|
|
56
|
+
}
|
|
57
|
+
return undefined;
|
|
58
|
+
};
|
|
59
|
+
for (const key of Object.keys(obj)) {
|
|
60
|
+
const pk = parseKey(key);
|
|
61
|
+
if (!pk)
|
|
62
|
+
continue;
|
|
63
|
+
const entry = obj[key];
|
|
64
|
+
register(pk.name, entry.version);
|
|
65
|
+
}
|
|
66
|
+
const rootId = register("__root__", "0.0.0");
|
|
67
|
+
rootIds.push(rootId);
|
|
68
|
+
const directDeps = new Set();
|
|
69
|
+
for (const key of Object.keys(obj)) {
|
|
70
|
+
const pk = parseKey(key);
|
|
71
|
+
if (!pk)
|
|
72
|
+
continue;
|
|
73
|
+
const entry = obj[key];
|
|
74
|
+
if (key === `${pk.name}@${entry.version}` ||
|
|
75
|
+
pk.range === entry.version ||
|
|
76
|
+
obj[`${pk.name}@${entry.version}`]) {
|
|
77
|
+
directDeps.add(`${pk.name}@${entry.version}`);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
for (const key of Object.keys(obj)) {
|
|
81
|
+
const pk = parseKey(key);
|
|
82
|
+
if (!pk)
|
|
83
|
+
continue;
|
|
84
|
+
const entry = obj[key];
|
|
85
|
+
const fromId = register(pk.name, entry.version);
|
|
86
|
+
const link = (m, t) => {
|
|
87
|
+
if (!m)
|
|
88
|
+
return;
|
|
89
|
+
for (const [dname, dconstraint] of Object.entries(m)) {
|
|
90
|
+
const ver = resolveVersion(dname, dconstraint) ?? dconstraint;
|
|
91
|
+
const toId = register(dname, ver);
|
|
92
|
+
edges.push({ from: fromId, to: toId, depType: t });
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
link(entry.dependencies, "dependencies");
|
|
96
|
+
link(entry.optionalDependencies, "optionalDependencies");
|
|
97
|
+
}
|
|
98
|
+
for (const key of Object.keys(obj)) {
|
|
99
|
+
const pk = parseKey(key);
|
|
100
|
+
if (!pk)
|
|
101
|
+
continue;
|
|
102
|
+
const entry = obj[key];
|
|
103
|
+
const isLikelyTop = !pk.range.includes("^") &&
|
|
104
|
+
!pk.range.includes("~") &&
|
|
105
|
+
pk.range === entry.version;
|
|
106
|
+
if (isLikelyTop) {
|
|
107
|
+
const toId = register(pk.name, entry.version);
|
|
108
|
+
edges.push({ from: rootId, to: toId, depType: "dependencies" });
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
return {
|
|
112
|
+
nodes,
|
|
113
|
+
edges,
|
|
114
|
+
rootIds,
|
|
115
|
+
lockfileKind: "yarn-classic",
|
|
116
|
+
byPackageName,
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
function empty() {
|
|
120
|
+
return {
|
|
121
|
+
nodes: new Map(),
|
|
122
|
+
edges: [],
|
|
123
|
+
rootIds: [],
|
|
124
|
+
lockfileKind: "unknown",
|
|
125
|
+
byPackageName: new Map(),
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
//# sourceMappingURL=yarn-lock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"yarn-lock.js","sourceRoot":"","sources":["../../../src/core/graph-engine/yarn-lock.ts"],"names":[],"mappings":"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"}
|