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,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,3 @@
1
+ import type { RemediationSuggestion, VulnerabilityFinding } from "../models.js";
2
+ export declare function suggestRemediation(findings: VulnerabilityFinding[]): RemediationSuggestion[];
3
+ //# sourceMappingURL=engine.d.ts.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=workspace-risk.d.ts.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=workspace-risk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workspace-risk.js","sourceRoot":"","sources":["../../../src/core/risk-engine/workspace-risk.ts"],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ import type { WorkspaceInfo } from "../models.js";
2
+ export declare function detectWorkspaces(rootDir: string): Promise<WorkspaceInfo>;
3
+ //# sourceMappingURL=detect.d.ts.map
@@ -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"}
@@ -0,0 +1,3 @@
1
+ export * from "./core/models.js";
2
+ export { analyze } from "./lib/analyze.js";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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,3 @@
1
+ export * from "./core/models.js";
2
+ export { analyze } from "./lib/analyze.js";
3
+ //# sourceMappingURL=index.js.map
@@ -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"}