@kevinrabun/judges 3.86.0 → 3.88.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 (78) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/dist/cli.d.ts.map +1 -1
  3. package/dist/cli.js +126 -0
  4. package/dist/cli.js.map +1 -1
  5. package/dist/commands/finding-age-analysis.d.ts +5 -0
  6. package/dist/commands/finding-age-analysis.d.ts.map +1 -0
  7. package/dist/commands/finding-age-analysis.js +145 -0
  8. package/dist/commands/finding-age-analysis.js.map +1 -0
  9. package/dist/commands/finding-code-smell.d.ts +5 -0
  10. package/dist/commands/finding-code-smell.d.ts.map +1 -0
  11. package/dist/commands/finding-code-smell.js +114 -0
  12. package/dist/commands/finding-code-smell.js.map +1 -0
  13. package/dist/commands/finding-correlation.d.ts +5 -0
  14. package/dist/commands/finding-correlation.d.ts.map +1 -0
  15. package/dist/commands/finding-correlation.js +104 -0
  16. package/dist/commands/finding-correlation.js.map +1 -0
  17. package/dist/commands/finding-dependency-tree.d.ts +5 -0
  18. package/dist/commands/finding-dependency-tree.d.ts.map +1 -0
  19. package/dist/commands/finding-dependency-tree.js +117 -0
  20. package/dist/commands/finding-dependency-tree.js.map +1 -0
  21. package/dist/commands/finding-owner-assign.d.ts +5 -0
  22. package/dist/commands/finding-owner-assign.d.ts.map +1 -0
  23. package/dist/commands/finding-owner-assign.js +134 -0
  24. package/dist/commands/finding-owner-assign.js.map +1 -0
  25. package/dist/commands/finding-pattern-library.d.ts +5 -0
  26. package/dist/commands/finding-pattern-library.d.ts.map +1 -0
  27. package/dist/commands/finding-pattern-library.js +146 -0
  28. package/dist/commands/finding-pattern-library.js.map +1 -0
  29. package/dist/commands/finding-related-rules.d.ts +5 -0
  30. package/dist/commands/finding-related-rules.d.ts.map +1 -0
  31. package/dist/commands/finding-related-rules.js +152 -0
  32. package/dist/commands/finding-related-rules.js.map +1 -0
  33. package/dist/commands/finding-rule-explain.d.ts +5 -0
  34. package/dist/commands/finding-rule-explain.d.ts.map +1 -0
  35. package/dist/commands/finding-rule-explain.js +141 -0
  36. package/dist/commands/finding-rule-explain.js.map +1 -0
  37. package/dist/commands/finding-suppression-audit.d.ts +5 -0
  38. package/dist/commands/finding-suppression-audit.d.ts.map +1 -0
  39. package/dist/commands/finding-suppression-audit.js +138 -0
  40. package/dist/commands/finding-suppression-audit.js.map +1 -0
  41. package/dist/commands/review-ci-integration.d.ts +5 -0
  42. package/dist/commands/review-ci-integration.d.ts.map +1 -0
  43. package/dist/commands/review-ci-integration.js +126 -0
  44. package/dist/commands/review-ci-integration.js.map +1 -0
  45. package/dist/commands/review-comparative.d.ts +5 -0
  46. package/dist/commands/review-comparative.d.ts.map +1 -0
  47. package/dist/commands/review-comparative.js +150 -0
  48. package/dist/commands/review-comparative.js.map +1 -0
  49. package/dist/commands/review-custom-rule.d.ts +5 -0
  50. package/dist/commands/review-custom-rule.d.ts.map +1 -0
  51. package/dist/commands/review-custom-rule.js +170 -0
  52. package/dist/commands/review-custom-rule.js.map +1 -0
  53. package/dist/commands/review-lock-file.d.ts +5 -0
  54. package/dist/commands/review-lock-file.d.ts.map +1 -0
  55. package/dist/commands/review-lock-file.js +154 -0
  56. package/dist/commands/review-lock-file.js.map +1 -0
  57. package/dist/commands/review-notification.d.ts +5 -0
  58. package/dist/commands/review-notification.d.ts.map +1 -0
  59. package/dist/commands/review-notification.js +127 -0
  60. package/dist/commands/review-notification.js.map +1 -0
  61. package/dist/commands/review-plugin-list.d.ts +5 -0
  62. package/dist/commands/review-plugin-list.d.ts.map +1 -0
  63. package/dist/commands/review-plugin-list.js +100 -0
  64. package/dist/commands/review-plugin-list.js.map +1 -0
  65. package/dist/commands/review-status-badge.d.ts +5 -0
  66. package/dist/commands/review-status-badge.d.ts.map +1 -0
  67. package/dist/commands/review-status-badge.js +121 -0
  68. package/dist/commands/review-status-badge.js.map +1 -0
  69. package/dist/commands/review-template-export.d.ts +5 -0
  70. package/dist/commands/review-template-export.d.ts.map +1 -0
  71. package/dist/commands/review-template-export.js +147 -0
  72. package/dist/commands/review-template-export.js.map +1 -0
  73. package/dist/commands/review-token-budget.d.ts +5 -0
  74. package/dist/commands/review-token-budget.d.ts.map +1 -0
  75. package/dist/commands/review-token-budget.js +118 -0
  76. package/dist/commands/review-token-budget.js.map +1 -0
  77. package/package.json +1 -1
  78. package/server.json +2 -2
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-age-analysis.d.ts","sourceRoot":"","sources":["../../src/commands/finding-age-analysis.ts"],"names":[],"mappings":"AAAA;;GAEG;AAmFH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyF1D"}
@@ -0,0 +1,145 @@
1
+ /**
2
+ * Finding-age-analysis — Analyze the age and lifecycle of findings over time.
3
+ */
4
+ import { readFileSync, existsSync, readdirSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function analyzeAge(verdicts) {
7
+ const ruleOccurrences = new Map();
8
+ const ruleFirstSeen = new Map();
9
+ const now = Date.now();
10
+ const timestamps = verdicts.map((v) => v.timestamp).sort();
11
+ for (const v of verdicts) {
12
+ for (const f of v.verdict.findings) {
13
+ ruleOccurrences.set(f.ruleId, (ruleOccurrences.get(f.ruleId) || 0) + 1);
14
+ if (!ruleFirstSeen.has(f.ruleId)) {
15
+ ruleFirstSeen.set(f.ruleId, v.timestamp);
16
+ }
17
+ }
18
+ }
19
+ // bucket by age
20
+ const buckets = [
21
+ { label: "< 1 day", count: 0, ruleIds: [] },
22
+ { label: "1-7 days", count: 0, ruleIds: [] },
23
+ { label: "1-4 weeks", count: 0, ruleIds: [] },
24
+ { label: "> 4 weeks", count: 0, ruleIds: [] },
25
+ ];
26
+ for (const [ruleId, firstSeen] of ruleFirstSeen) {
27
+ const age = now - new Date(firstSeen).getTime();
28
+ const days = age / (1000 * 60 * 60 * 24);
29
+ if (days < 1) {
30
+ buckets[0].count++;
31
+ buckets[0].ruleIds.push(ruleId);
32
+ }
33
+ else if (days < 7) {
34
+ buckets[1].count++;
35
+ buckets[1].ruleIds.push(ruleId);
36
+ }
37
+ else if (days < 28) {
38
+ buckets[2].count++;
39
+ buckets[2].ruleIds.push(ruleId);
40
+ }
41
+ else {
42
+ buckets[3].count++;
43
+ buckets[3].ruleIds.push(ruleId);
44
+ }
45
+ }
46
+ // recurring rules
47
+ const recurring = [...ruleOccurrences.entries()]
48
+ .filter(([, count]) => count > 1)
49
+ .sort((a, b) => b[1] - a[1])
50
+ .map(([ruleId, occurrences]) => ({ ruleId, occurrences }));
51
+ return {
52
+ totalFindings: ruleFirstSeen.size,
53
+ oldestTimestamp: timestamps[0] || "",
54
+ newestTimestamp: timestamps[timestamps.length - 1] || "",
55
+ buckets,
56
+ recurringRules: recurring,
57
+ };
58
+ }
59
+ // ─── CLI ────────────────────────────────────────────────────────────────────
60
+ export function runFindingAgeAnalysis(argv) {
61
+ const dirIdx = argv.indexOf("--dir");
62
+ const fileIdx = argv.indexOf("--file");
63
+ const formatIdx = argv.indexOf("--format");
64
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : undefined;
65
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
66
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
67
+ if (argv.includes("--help") || argv.includes("-h")) {
68
+ console.log(`
69
+ judges finding-age-analysis — Analyze finding age over time
70
+
71
+ Usage:
72
+ judges finding-age-analysis --dir <verdicts-dir> [--format table|json]
73
+ judges finding-age-analysis --file <verdict.json> [--format table|json]
74
+
75
+ Options:
76
+ --dir <path> Directory of verdict JSON files
77
+ --file <path> Single verdict JSON file
78
+ --format <fmt> Output format: table (default), json
79
+ --help, -h Show this help
80
+ `);
81
+ return;
82
+ }
83
+ const verdicts = [];
84
+ if (dirPath && existsSync(dirPath)) {
85
+ const files = readdirSync(dirPath);
86
+ for (const file of files) {
87
+ if (!file.endsWith(".json"))
88
+ continue;
89
+ try {
90
+ const content = readFileSync(`${dirPath}/${file}`, "utf-8");
91
+ const verdict = JSON.parse(content);
92
+ verdicts.push({ verdict, timestamp: verdict.timestamp || file.replace(".json", "") });
93
+ }
94
+ catch {
95
+ // skip invalid files
96
+ }
97
+ }
98
+ }
99
+ else if (filePath && existsSync(filePath)) {
100
+ try {
101
+ const verdict = JSON.parse(readFileSync(filePath, "utf-8"));
102
+ verdicts.push({ verdict, timestamp: verdict.timestamp || new Date().toISOString() });
103
+ }
104
+ catch {
105
+ console.error("Error: invalid JSON");
106
+ process.exitCode = 1;
107
+ return;
108
+ }
109
+ }
110
+ else {
111
+ console.error("Error: --dir or --file required");
112
+ process.exitCode = 1;
113
+ return;
114
+ }
115
+ if (verdicts.length === 0) {
116
+ console.log("No verdict files found");
117
+ return;
118
+ }
119
+ const report = analyzeAge(verdicts);
120
+ if (format === "json") {
121
+ console.log(JSON.stringify(report, null, 2));
122
+ return;
123
+ }
124
+ console.log(`\nFinding Age Analysis`);
125
+ console.log("═".repeat(60));
126
+ console.log(` Total unique findings: ${report.totalFindings}`);
127
+ console.log(` Reports analyzed: ${verdicts.length}`);
128
+ console.log(` Range: ${report.oldestTimestamp} → ${report.newestTimestamp}`);
129
+ console.log("─".repeat(60));
130
+ console.log(`${"Age Bucket".padEnd(16)} ${"Count".padEnd(8)} Rules`);
131
+ console.log("─".repeat(60));
132
+ for (const b of report.buckets) {
133
+ const rules = b.ruleIds.slice(0, 3).join(", ");
134
+ const more = b.ruleIds.length > 3 ? ` +${b.ruleIds.length - 3} more` : "";
135
+ console.log(`${b.label.padEnd(16)} ${String(b.count).padEnd(8)} ${rules}${more}`);
136
+ }
137
+ if (report.recurringRules.length > 0) {
138
+ console.log(`\n Recurring Rules (${report.recurringRules.length}):`);
139
+ for (const r of report.recurringRules.slice(0, 10)) {
140
+ console.log(` ${r.ruleId.padEnd(20)} × ${r.occurrences}`);
141
+ }
142
+ }
143
+ console.log("═".repeat(60));
144
+ }
145
+ //# sourceMappingURL=finding-age-analysis.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-age-analysis.js","sourceRoot":"","sources":["../../src/commands/finding-age-analysis.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Finding-code-smell — Detect code-smell indicators among findings.
3
+ */
4
+ export declare function runFindingCodeSmell(argv: string[]): void;
5
+ //# sourceMappingURL=finding-code-smell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-code-smell.d.ts","sourceRoot":"","sources":["../../src/commands/finding-code-smell.ts"],"names":[],"mappings":"AAAA;;GAEG;AA0DH,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAgFxD"}
@@ -0,0 +1,114 @@
1
+ /**
2
+ * Finding-code-smell — Detect code-smell indicators among findings.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── Patterns ───────────────────────────────────────────────────────────────
6
+ const SMELL_KEYWORDS = [
7
+ { keywords: ["duplicate", "copy", "clone", "repeated"], label: "duplication" },
8
+ { keywords: ["complex", "nested", "cyclomatic", "branch"], label: "complexity" },
9
+ { keywords: ["long", "large", "big", "oversized", "bloat"], label: "bloat" },
10
+ { keywords: ["magic", "hardcod", "literal", "constant"], label: "magic-values" },
11
+ { keywords: ["dead", "unused", "unreachable", "orphan"], label: "dead-code" },
12
+ { keywords: ["coupling", "depend", "import", "circular"], label: "coupling" },
13
+ { keywords: ["naming", "convention", "inconsistent", "style"], label: "naming" },
14
+ { keywords: ["comment", "todo", "fixme", "hack", "workaround"], label: "tech-debt" },
15
+ ];
16
+ function detectSmell(title, desc) {
17
+ const combined = `${title} ${desc}`.toLowerCase();
18
+ for (const s of SMELL_KEYWORDS) {
19
+ const matches = s.keywords.filter((k) => combined.includes(k));
20
+ if (matches.length > 0) {
21
+ return { label: s.label, confidence: Math.min(1, 0.5 + matches.length * 0.2) };
22
+ }
23
+ }
24
+ return { label: "general", confidence: 0.3 };
25
+ }
26
+ // ─── Analysis ───────────────────────────────────────────────────────────────
27
+ function analyzeSmells(verdict) {
28
+ const results = [];
29
+ for (const f of verdict.findings) {
30
+ const { label, confidence } = detectSmell(f.title, f.description);
31
+ results.push({
32
+ ruleId: f.ruleId,
33
+ title: f.title,
34
+ severity: (f.severity || "medium").toLowerCase(),
35
+ smellType: label,
36
+ confidence,
37
+ });
38
+ }
39
+ return results;
40
+ }
41
+ // ─── CLI ────────────────────────────────────────────────────────────────────
42
+ export function runFindingCodeSmell(argv) {
43
+ const fileIdx = argv.indexOf("--file");
44
+ const formatIdx = argv.indexOf("--format");
45
+ const minIdx = argv.indexOf("--min-confidence");
46
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
47
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
48
+ const minConf = minIdx >= 0 ? parseFloat(argv[minIdx + 1]) : 0;
49
+ if (argv.includes("--help") || argv.includes("-h")) {
50
+ console.log(`
51
+ judges finding-code-smell — Detect code-smell indicators
52
+
53
+ Usage:
54
+ judges finding-code-smell --file <verdict.json> [--format table|json]
55
+ [--min-confidence <0-1>]
56
+
57
+ Options:
58
+ --file <path> Path to verdict JSON file (required)
59
+ --format <fmt> Output format: table (default), json
60
+ --min-confidence <n> Minimum confidence threshold (0-1)
61
+ --help, -h Show this help
62
+ `);
63
+ return;
64
+ }
65
+ if (!filePath) {
66
+ console.error("Error: --file required");
67
+ process.exitCode = 1;
68
+ return;
69
+ }
70
+ if (!existsSync(filePath)) {
71
+ console.error(`Error: not found: ${filePath}`);
72
+ process.exitCode = 1;
73
+ return;
74
+ }
75
+ let verdict;
76
+ try {
77
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
78
+ }
79
+ catch {
80
+ console.error("Error: invalid JSON");
81
+ process.exitCode = 1;
82
+ return;
83
+ }
84
+ let results = analyzeSmells(verdict);
85
+ if (minConf > 0) {
86
+ results = results.filter((r) => r.confidence >= minConf);
87
+ }
88
+ if (format === "json") {
89
+ console.log(JSON.stringify(results, null, 2));
90
+ return;
91
+ }
92
+ // group by smell type
93
+ const byType = new Map();
94
+ for (const r of results) {
95
+ const arr = byType.get(r.smellType) || [];
96
+ arr.push(r);
97
+ byType.set(r.smellType, arr);
98
+ }
99
+ console.log(`\nCode Smell Analysis (${results.length} findings)`);
100
+ console.log("═".repeat(70));
101
+ console.log(`${"Type".padEnd(16)} ${"Count".padEnd(8)} ${"Severity".padEnd(10)} ${"Avg Conf".padEnd(10)}`);
102
+ console.log("─".repeat(70));
103
+ for (const [type, items] of byType) {
104
+ const avgConf = items.reduce((s, i) => s + i.confidence, 0) / items.length;
105
+ const topSev = items.some((i) => i.severity === "critical")
106
+ ? "critical"
107
+ : items.some((i) => i.severity === "high")
108
+ ? "high"
109
+ : "medium";
110
+ console.log(`${type.padEnd(16)} ${String(items.length).padEnd(8)} ${topSev.padEnd(10)} ${avgConf.toFixed(2).padEnd(10)}`);
111
+ }
112
+ console.log("═".repeat(70));
113
+ }
114
+ //# sourceMappingURL=finding-code-smell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-code-smell.js","sourceRoot":"","sources":["../../src/commands/finding-code-smell.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Finding-correlation — Find correlations between findings across reports.
3
+ */
4
+ export declare function runFindingCorrelation(argv: string[]): void;
5
+ //# sourceMappingURL=finding-correlation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-correlation.d.ts","sourceRoot":"","sources":["../../src/commands/finding-correlation.ts"],"names":[],"mappings":"AAAA;;GAEG;AA6DH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAuE1D"}
@@ -0,0 +1,104 @@
1
+ /**
2
+ * Finding-correlation — Find correlations between findings across reports.
3
+ */
4
+ import { readFileSync, existsSync, readdirSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function computeCorrelations(verdicts) {
7
+ // count co-occurrences of rule pairs across reports
8
+ const pairCounts = new Map();
9
+ const ruleCounts = new Map();
10
+ const totalReports = verdicts.length;
11
+ for (const v of verdicts) {
12
+ const rulesInReport = new Set(v.findings.map((f) => f.ruleId));
13
+ const ruleList = [...rulesInReport].sort();
14
+ for (const rule of ruleList) {
15
+ ruleCounts.set(rule, (ruleCounts.get(rule) || 0) + 1);
16
+ }
17
+ for (let i = 0; i < ruleList.length; i++) {
18
+ for (let j = i + 1; j < ruleList.length; j++) {
19
+ const key = `${ruleList[i]}|||${ruleList[j]}`;
20
+ pairCounts.set(key, (pairCounts.get(key) || 0) + 1);
21
+ }
22
+ }
23
+ }
24
+ const correlations = [];
25
+ for (const [key, coOccurrences] of pairCounts) {
26
+ const [ruleA, ruleB] = key.split("|||");
27
+ const countA = ruleCounts.get(ruleA) || 0;
28
+ const countB = ruleCounts.get(ruleB) || 0;
29
+ // Jaccard similarity as correlation proxy
30
+ const union = countA + countB - coOccurrences;
31
+ const correlation = union > 0 ? coOccurrences / union : 0;
32
+ if (coOccurrences >= 2) {
33
+ correlations.push({ ruleA, ruleB, coOccurrences, totalReports, correlation });
34
+ }
35
+ }
36
+ correlations.sort((a, b) => b.correlation - a.correlation);
37
+ return correlations;
38
+ }
39
+ // ─── CLI ────────────────────────────────────────────────────────────────────
40
+ export function runFindingCorrelation(argv) {
41
+ const dirIdx = argv.indexOf("--dir");
42
+ const formatIdx = argv.indexOf("--format");
43
+ const limitIdx = argv.indexOf("--limit");
44
+ const minIdx = argv.indexOf("--min-correlation");
45
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : undefined;
46
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
47
+ const limit = limitIdx >= 0 ? parseInt(argv[limitIdx + 1], 10) : 20;
48
+ const minCorrelation = minIdx >= 0 ? parseFloat(argv[minIdx + 1]) : 0.3;
49
+ if (argv.includes("--help") || argv.includes("-h")) {
50
+ console.log(`
51
+ judges finding-correlation — Find correlations between findings
52
+
53
+ Usage:
54
+ judges finding-correlation --dir <verdicts-dir> [--format table|json]
55
+ [--limit <n>] [--min-correlation <0-1>]
56
+
57
+ Options:
58
+ --dir <path> Directory of verdict JSON files (required)
59
+ --format <fmt> Output format: table (default), json
60
+ --limit <n> Max results (default: 20)
61
+ --min-correlation <n> Minimum correlation threshold (default: 0.3)
62
+ --help, -h Show this help
63
+ `);
64
+ return;
65
+ }
66
+ if (!dirPath || !existsSync(dirPath)) {
67
+ console.error("Error: --dir required and must exist");
68
+ process.exitCode = 1;
69
+ return;
70
+ }
71
+ const verdicts = [];
72
+ const files = readdirSync(dirPath);
73
+ for (const file of files) {
74
+ if (!file.endsWith(".json"))
75
+ continue;
76
+ try {
77
+ verdicts.push(JSON.parse(readFileSync(`${dirPath}/${file}`, "utf-8")));
78
+ }
79
+ catch {
80
+ // skip invalid files
81
+ }
82
+ }
83
+ if (verdicts.length < 2) {
84
+ console.log("Need at least 2 verdict reports for correlation analysis");
85
+ return;
86
+ }
87
+ let correlations = computeCorrelations(verdicts);
88
+ correlations = correlations.filter((c) => c.correlation >= minCorrelation).slice(0, limit);
89
+ if (format === "json") {
90
+ console.log(JSON.stringify(correlations, null, 2));
91
+ return;
92
+ }
93
+ console.log(`\nFinding Correlations (${verdicts.length} reports analyzed)`);
94
+ console.log("═".repeat(75));
95
+ console.log(`${"Rule A".padEnd(20)} ${"Rule B".padEnd(20)} ${"Co-occur".padEnd(10)} ${"Correlation".padEnd(14)}`);
96
+ console.log("─".repeat(75));
97
+ for (const c of correlations) {
98
+ const rA = c.ruleA.length > 18 ? c.ruleA.slice(0, 18) + "…" : c.ruleA;
99
+ const rB = c.ruleB.length > 18 ? c.ruleB.slice(0, 18) + "…" : c.ruleB;
100
+ console.log(`${rA.padEnd(20)} ${rB.padEnd(20)} ${String(c.coOccurrences).padEnd(10)} ${c.correlation.toFixed(3).padEnd(14)}`);
101
+ }
102
+ console.log("═".repeat(75));
103
+ }
104
+ //# sourceMappingURL=finding-correlation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-correlation.js","sourceRoot":"","sources":["../../src/commands/finding-correlation.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,IAAI,CAAC;AAa3D,+EAA+E;AAE/E,SAAS,mBAAmB,CAAC,QAA2B;IACtD,oDAAoD;IACpD,MAAM,UAAU,GAAG,IAAI,GAAG,EAAkB,CAAC;IAC7C,MAAM,UAAU,GAAG,IAAI,GAAG,EAAkB,CAAC;IAC7C,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC;IAErC,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;QACzB,MAAM,aAAa,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;QAC/D,MAAM,QAAQ,GAAG,CAAC,GAAG,aAAa,CAAC,CAAC,IAAI,EAAE,CAAC;QAE3C,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;YAC5B,UAAU,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACxD,CAAC;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACzC,KAAK,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC7C,MAAM,GAAG,GAAG,GAAG,QAAQ,CAAC,CAAC,CAAC,MAAM,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC9C,UAAU,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YACtD,CAAC;QACH,CAAC;IACH,CAAC;IAED,MAAM,YAAY,GAAsB,EAAE,CAAC;IAE3C,KAAK,MAAM,CAAC,GAAG,EAAE,aAAa,CAAC,IAAI,UAAU,EAAE,CAAC;QAC9C,MAAM,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACxC,MAAM,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC1C,MAAM,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAE1C,0CAA0C;QAC1C,MAAM,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,aAAa,CAAC;QAC9C,MAAM,WAAW,GAAG,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QAE1D,IAAI,aAAa,IAAI,CAAC,EAAE,CAAC;YACvB,YAAY,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC;QAChF,CAAC;IACH,CAAC;IAED,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC;IAC3D,OAAO,YAAY,CAAC;AACtB,CAAC;AAED,+EAA+E;AAE/E,MAAM,UAAU,qBAAqB,CAAC,IAAc;IAClD,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACrC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACzC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC;IACjD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC3D,MAAM,MAAM,GAAG,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IAC9D,MAAM,KAAK,GAAG,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACpE,MAAM,cAAc,GAAG,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;IAExE,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACnD,OAAO,CAAC,GAAG,CAAC;;;;;;;;;;;;;CAaf,CAAC,CAAC;QACC,OAAO;IACT,CAAC;IAED,IAAI,CAAC,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;QACrC,OAAO,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;QACtD,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,MAAM,QAAQ,GAAsB,EAAE,CAAC;IACvC,MAAM,KAAK,GAAG,WAAW,CAAC,OAAO,CAAwB,CAAC;IAC1D,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,SAAS;QACtC,IAAI,CAAC;YACH,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,OAAO,IAAI,IAAI,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;QACzE,CAAC;QAAC,MAAM,CAAC;YACP,qBAAqB;QACvB,CAAC;IACH,CAAC;IAED,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,0DAA0D,CAAC,CAAC;QACxE,OAAO;IACT,CAAC;IAED,IAAI,YAAY,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IACjD,YAAY,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,IAAI,cAAc,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;IAE3F,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACnD,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,2BAA2B,QAAQ,CAAC,MAAM,oBAAoB,CAAC,CAAC;IAC5E,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,OAAO,CAAC,GAAG,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,aAAa,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAClH,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAE5B,KAAK,MAAM,CAAC,IAAI,YAAY,EAAE,CAAC;QAC7B,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACtE,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACtE,OAAO,CAAC,GAAG,CACT,GAAG,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CACjH,CAAC;IACJ,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAC9B,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Finding-dependency-tree — Visualize dependency relationships among findings.
3
+ */
4
+ export declare function runFindingDependencyTree(argv: string[]): void;
5
+ //# sourceMappingURL=finding-dependency-tree.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-dependency-tree.d.ts","sourceRoot":"","sources":["../../src/commands/finding-dependency-tree.ts"],"names":[],"mappings":"AAAA;;GAEG;AAgFH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA8D7D"}
@@ -0,0 +1,117 @@
1
+ /**
2
+ * Finding-dependency-tree — Visualize dependency relationships among findings.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function buildDependencyTree(verdict) {
7
+ const nodes = new Map();
8
+ const findings = verdict.findings;
9
+ // create nodes
10
+ for (const f of findings) {
11
+ nodes.set(f.ruleId, {
12
+ ruleId: f.ruleId,
13
+ title: f.title,
14
+ severity: (f.severity || "medium").toLowerCase(),
15
+ children: [],
16
+ depth: 0,
17
+ });
18
+ }
19
+ // build relationships — findings sharing line numbers are related
20
+ for (let i = 0; i < findings.length; i++) {
21
+ for (let j = i + 1; j < findings.length; j++) {
22
+ const a = findings[i];
23
+ const b = findings[j];
24
+ const aLines = new Set(a.lineNumbers || []);
25
+ const bLines = b.lineNumbers || [];
26
+ if (bLines.some((ln) => aLines.has(ln))) {
27
+ const nodeA = nodes.get(a.ruleId);
28
+ const nodeB = nodes.get(b.ruleId);
29
+ if (nodeA !== undefined && !nodeA.children.includes(b.ruleId)) {
30
+ nodeA.children.push(b.ruleId);
31
+ }
32
+ if (nodeB !== undefined && !nodeB.children.includes(a.ruleId)) {
33
+ nodeB.children.push(a.ruleId);
34
+ }
35
+ }
36
+ }
37
+ }
38
+ // compute depths via BFS
39
+ const roots = [...nodes.values()].filter((n) => ![...nodes.values()].some((other) => other.children.includes(n.ruleId)));
40
+ for (const root of roots) {
41
+ const queue = [{ id: root.ruleId, depth: 0 }];
42
+ const visited = new Set();
43
+ while (queue.length > 0) {
44
+ const item = queue.shift();
45
+ if (visited.has(item.id))
46
+ continue;
47
+ visited.add(item.id);
48
+ const node = nodes.get(item.id);
49
+ if (node !== undefined) {
50
+ node.depth = Math.max(node.depth, item.depth);
51
+ for (const child of node.children) {
52
+ queue.push({ id: child, depth: item.depth + 1 });
53
+ }
54
+ }
55
+ }
56
+ }
57
+ return [...nodes.values()].sort((a, b) => a.depth - b.depth);
58
+ }
59
+ // ─── CLI ────────────────────────────────────────────────────────────────────
60
+ export function runFindingDependencyTree(argv) {
61
+ const fileIdx = argv.indexOf("--file");
62
+ const formatIdx = argv.indexOf("--format");
63
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
64
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "tree";
65
+ if (argv.includes("--help") || argv.includes("-h")) {
66
+ console.log(`
67
+ judges finding-dependency-tree — Visualize finding dependencies
68
+
69
+ Usage:
70
+ judges finding-dependency-tree --file <verdict.json> [--format tree|json]
71
+
72
+ Options:
73
+ --file <path> Path to verdict JSON file (required)
74
+ --format <fmt> Output format: tree (default), json
75
+ --help, -h Show this help
76
+ `);
77
+ return;
78
+ }
79
+ if (!filePath) {
80
+ console.error("Error: --file required");
81
+ process.exitCode = 1;
82
+ return;
83
+ }
84
+ if (!existsSync(filePath)) {
85
+ console.error(`Error: not found: ${filePath}`);
86
+ process.exitCode = 1;
87
+ return;
88
+ }
89
+ let verdict;
90
+ try {
91
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
92
+ }
93
+ catch {
94
+ console.error("Error: invalid JSON");
95
+ process.exitCode = 1;
96
+ return;
97
+ }
98
+ const nodes = buildDependencyTree(verdict);
99
+ if (format === "json") {
100
+ console.log(JSON.stringify(nodes, null, 2));
101
+ return;
102
+ }
103
+ console.log(`\nFinding Dependency Tree (${nodes.length} nodes)`);
104
+ console.log("═".repeat(70));
105
+ for (const node of nodes) {
106
+ const indent = " ".repeat(node.depth);
107
+ const connector = node.depth > 0 ? "├─ " : "";
108
+ const title = node.title.length > 35 ? node.title.slice(0, 35) + "…" : node.title;
109
+ console.log(`${indent}${connector}[${node.severity.toUpperCase()}] ${node.ruleId}`);
110
+ console.log(`${indent} ${title}`);
111
+ if (node.children.length > 0) {
112
+ console.log(`${indent} └─ related: ${node.children.join(", ")}`);
113
+ }
114
+ }
115
+ console.log("═".repeat(70));
116
+ }
117
+ //# sourceMappingURL=finding-dependency-tree.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-dependency-tree.js","sourceRoot":"","sources":["../../src/commands/finding-dependency-tree.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAa9C,+EAA+E;AAE/E,SAAS,mBAAmB,CAAC,OAAwB;IACnD,MAAM,KAAK,GAAG,IAAI,GAAG,EAAmB,CAAC;IACzC,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;IAElC,eAAe;IACf,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;QACzB,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE;YAClB,MAAM,EAAE,CAAC,CAAC,MAAM;YAChB,KAAK,EAAE,CAAC,CAAC,KAAK;YACd,QAAQ,EAAE,CAAC,CAAC,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC,WAAW,EAAE;YAChD,QAAQ,EAAE,EAAE;YACZ,KAAK,EAAE,CAAC;SACT,CAAC,CAAC;IACL,CAAC;IAED,kEAAkE;IAClE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACzC,KAAK,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC7C,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;YACtB,MAAM,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;YACtB,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YAC5C,MAAM,MAAM,GAAG,CAAC,CAAC,WAAW,IAAI,EAAE,CAAC;YAEnC,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;gBACxC,MAAM,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;gBAClC,MAAM,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;gBAClC,IAAI,KAAK,KAAK,SAAS,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC9D,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;gBAChC,CAAC;gBACD,IAAI,KAAK,KAAK,SAAS,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC;oBAC9D,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;gBAChC,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,yBAAyB;IACzB,MAAM,KAAK,GAAG,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CACtC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAC/E,CAAC;IAEF,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,KAAK,GAAG,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QAC9C,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAC;QAClC,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,EAAG,CAAC;YAC5B,IAAI,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;gBAAE,SAAS;YACnC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACrB,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAChC,IAAI,IAAI,KAAK,SAAS,EAAE,CAAC;gBACvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC9C,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAClC,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC;gBACnD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;AAC/D,CAAC;AAED,+EAA+E;AAE/E,MAAM,UAAU,wBAAwB,CAAC,IAAc;IACrD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACvC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,MAAM,QAAQ,GAAG,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC9D,MAAM,MAAM,GAAG,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IAE7D,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;QACnD,OAAO,CAAC,GAAG,CAAC;;;;;;;;;;CAUf,CAAC,CAAC;QACC,OAAO;IACT,CAAC;IAED,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,OAAO,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC;QACxC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IACD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC1B,OAAO,CAAC,KAAK,CAAC,qBAAqB,QAAQ,EAAE,CAAC,CAAC;QAC/C,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,IAAI,OAAwB,CAAC;IAC7B,IAAI,CAAC;QACH,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;IACxD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACrC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,MAAM,KAAK,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;IAE3C,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5C,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,8BAA8B,KAAK,CAAC,MAAM,SAAS,CAAC,CAAC;IACjE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAE5B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;QAClF,OAAO,CAAC,GAAG,CAAC,GAAG,MAAM,GAAG,SAAS,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACpF,OAAO,CAAC,GAAG,CAAC,GAAG,MAAM,MAAM,KAAK,EAAE,CAAC,CAAC;QACpC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7B,OAAO,CAAC,GAAG,CAAC,GAAG,MAAM,kBAAkB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACrE,CAAC;IACH,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAC9B,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Finding-owner-assign — Assign ownership of findings based on configurable rules.
3
+ */
4
+ export declare function runFindingOwnerAssign(argv: string[]): void;
5
+ //# sourceMappingURL=finding-owner-assign.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-owner-assign.d.ts","sourceRoot":"","sources":["../../src/commands/finding-owner-assign.ts"],"names":[],"mappings":"AAAA;;GAEG;AA6EH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAwF1D"}