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.
Files changed (115) hide show
  1. package/README.md +101 -0
  2. package/dist/cli/ink/ReportTui.d.ts +8 -0
  3. package/dist/cli/ink/ReportTui.d.ts.map +1 -0
  4. package/dist/cli/ink/ReportTui.js +20 -0
  5. package/dist/cli/ink/ReportTui.js.map +1 -0
  6. package/dist/cli.d.ts +3 -0
  7. package/dist/cli.d.ts.map +1 -0
  8. package/dist/cli.js +150 -0
  9. package/dist/cli.js.map +1 -0
  10. package/dist/core/audit-parser/normalize.d.ts +8 -0
  11. package/dist/core/audit-parser/normalize.d.ts.map +1 -0
  12. package/dist/core/audit-parser/normalize.js +107 -0
  13. package/dist/core/audit-parser/normalize.js.map +1 -0
  14. package/dist/core/audit-parser/run-audit.d.ts +9 -0
  15. package/dist/core/audit-parser/run-audit.d.ts.map +1 -0
  16. package/dist/core/audit-parser/run-audit.js +25 -0
  17. package/dist/core/audit-parser/run-audit.js.map +1 -0
  18. package/dist/core/graph-engine/load-lockfile.d.ts +20 -0
  19. package/dist/core/graph-engine/load-lockfile.d.ts.map +1 -0
  20. package/dist/core/graph-engine/load-lockfile.js +43 -0
  21. package/dist/core/graph-engine/load-lockfile.js.map +1 -0
  22. package/dist/core/graph-engine/npm-lock.d.ts +5 -0
  23. package/dist/core/graph-engine/npm-lock.d.ts.map +1 -0
  24. package/dist/core/graph-engine/npm-lock.js +159 -0
  25. package/dist/core/graph-engine/npm-lock.js.map +1 -0
  26. package/dist/core/graph-engine/pnpm-lock.d.ts +4 -0
  27. package/dist/core/graph-engine/pnpm-lock.d.ts.map +1 -0
  28. package/dist/core/graph-engine/pnpm-lock.js +152 -0
  29. package/dist/core/graph-engine/pnpm-lock.js.map +1 -0
  30. package/dist/core/graph-engine/traverse.d.ts +17 -0
  31. package/dist/core/graph-engine/traverse.d.ts.map +1 -0
  32. package/dist/core/graph-engine/traverse.js +125 -0
  33. package/dist/core/graph-engine/traverse.js.map +1 -0
  34. package/dist/core/graph-engine/yarn-lock.d.ts +4 -0
  35. package/dist/core/graph-engine/yarn-lock.d.ts.map +1 -0
  36. package/dist/core/graph-engine/yarn-lock.js +128 -0
  37. package/dist/core/graph-engine/yarn-lock.js.map +1 -0
  38. package/dist/core/models.d.ts +88 -0
  39. package/dist/core/models.d.ts.map +1 -0
  40. package/dist/core/models.js +9 -0
  41. package/dist/core/models.js.map +1 -0
  42. package/dist/core/ownership/tracer.d.ts +16 -0
  43. package/dist/core/ownership/tracer.d.ts.map +1 -0
  44. package/dist/core/ownership/tracer.js +65 -0
  45. package/dist/core/ownership/tracer.js.map +1 -0
  46. package/dist/core/remediation-engine/engine.d.ts +3 -0
  47. package/dist/core/remediation-engine/engine.d.ts.map +1 -0
  48. package/dist/core/remediation-engine/engine.js +42 -0
  49. package/dist/core/remediation-engine/engine.js.map +1 -0
  50. package/dist/core/risk-engine/scripts.d.ts +6 -0
  51. package/dist/core/risk-engine/scripts.d.ts.map +1 -0
  52. package/dist/core/risk-engine/scripts.js +19 -0
  53. package/dist/core/risk-engine/scripts.js.map +1 -0
  54. package/dist/core/risk-engine/workspace-risk.d.ts +2 -0
  55. package/dist/core/risk-engine/workspace-risk.d.ts.map +1 -0
  56. package/dist/core/risk-engine/workspace-risk.js +2 -0
  57. package/dist/core/risk-engine/workspace-risk.js.map +1 -0
  58. package/dist/core/workspace-engine/detect.d.ts +3 -0
  59. package/dist/core/workspace-engine/detect.d.ts.map +1 -0
  60. package/dist/core/workspace-engine/detect.js +53 -0
  61. package/dist/core/workspace-engine/detect.js.map +1 -0
  62. package/dist/index.d.ts +3 -0
  63. package/dist/index.d.ts.map +1 -0
  64. package/dist/index.js +3 -0
  65. package/dist/index.js.map +1 -0
  66. package/dist/ink/ReportTui.d.ts +8 -0
  67. package/dist/ink/ReportTui.d.ts.map +1 -0
  68. package/dist/ink/ReportTui.js +20 -0
  69. package/dist/ink/ReportTui.js.map +1 -0
  70. package/dist/integrations/ci-mode/policy.d.ts +17 -0
  71. package/dist/integrations/ci-mode/policy.d.ts.map +1 -0
  72. package/dist/integrations/ci-mode/policy.js +71 -0
  73. package/dist/integrations/ci-mode/policy.js.map +1 -0
  74. package/dist/integrations/lockfile-diff/compare.d.ts +11 -0
  75. package/dist/integrations/lockfile-diff/compare.d.ts.map +1 -0
  76. package/dist/integrations/lockfile-diff/compare.js +44 -0
  77. package/dist/integrations/lockfile-diff/compare.js.map +1 -0
  78. package/dist/integrations/reachability/madge-check.d.ts +12 -0
  79. package/dist/integrations/reachability/madge-check.d.ts.map +1 -0
  80. package/dist/integrations/reachability/madge-check.js +41 -0
  81. package/dist/integrations/reachability/madge-check.js.map +1 -0
  82. package/dist/lib/analyze.d.ts +22 -0
  83. package/dist/lib/analyze.d.ts.map +1 -0
  84. package/dist/lib/analyze.js +107 -0
  85. package/dist/lib/analyze.js.map +1 -0
  86. package/dist/output/html-reporter.d.ts +4 -0
  87. package/dist/output/html-reporter.d.ts.map +1 -0
  88. package/dist/output/html-reporter.js +18 -0
  89. package/dist/output/html-reporter.js.map +1 -0
  90. package/dist/output/json-reporter.d.ts +5 -0
  91. package/dist/output/json-reporter.d.ts.map +1 -0
  92. package/dist/output/json-reporter.js +18 -0
  93. package/dist/output/json-reporter.js.map +1 -0
  94. package/dist/output/markdown-reporter.d.ts +4 -0
  95. package/dist/output/markdown-reporter.d.ts.map +1 -0
  96. package/dist/output/markdown-reporter.js +28 -0
  97. package/dist/output/markdown-reporter.js.map +1 -0
  98. package/dist/output/terminal-renderer.d.ts +8 -0
  99. package/dist/output/terminal-renderer.d.ts.map +1 -0
  100. package/dist/output/terminal-renderer.js +51 -0
  101. package/dist/output/terminal-renderer.js.map +1 -0
  102. package/dist/output/tree-format.d.ts +3 -0
  103. package/dist/output/tree-format.d.ts.map +1 -0
  104. package/dist/output/tree-format.js +12 -0
  105. package/dist/output/tree-format.js.map +1 -0
  106. package/dist/plugins/registry.d.ts +4 -0
  107. package/dist/plugins/registry.d.ts.map +1 -0
  108. package/dist/plugins/registry.js +8 -0
  109. package/dist/plugins/registry.js.map +1 -0
  110. package/dist/plugins/types.d.ts +10 -0
  111. package/dist/plugins/types.d.ts.map +1 -0
  112. package/dist/plugins/types.js +2 -0
  113. package/dist/plugins/types.js.map +1 -0
  114. package/examples/github-actions/ci.yml +34 -0
  115. 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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"}