@kevinrabun/judges 3.92.0 → 3.94.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 +26 -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-code-context.d.ts +5 -0
  6. package/dist/commands/finding-code-context.d.ts.map +1 -0
  7. package/dist/commands/finding-code-context.js +97 -0
  8. package/dist/commands/finding-code-context.js.map +1 -0
  9. package/dist/commands/finding-explain.d.ts +5 -0
  10. package/dist/commands/finding-explain.d.ts.map +1 -0
  11. package/dist/commands/finding-explain.js +94 -0
  12. package/dist/commands/finding-explain.js.map +1 -0
  13. package/dist/commands/finding-filter-view.d.ts +5 -0
  14. package/dist/commands/finding-filter-view.d.ts.map +1 -0
  15. package/dist/commands/finding-filter-view.js +108 -0
  16. package/dist/commands/finding-filter-view.js.map +1 -0
  17. package/dist/commands/finding-fix-suggest.d.ts +5 -0
  18. package/dist/commands/finding-fix-suggest.d.ts.map +1 -0
  19. package/dist/commands/finding-fix-suggest.js +89 -0
  20. package/dist/commands/finding-fix-suggest.js.map +1 -0
  21. package/dist/commands/finding-link-graph.d.ts +5 -0
  22. package/dist/commands/finding-link-graph.d.ts.map +1 -0
  23. package/dist/commands/finding-link-graph.js +145 -0
  24. package/dist/commands/finding-link-graph.js.map +1 -0
  25. package/dist/commands/finding-ownership-map.d.ts +5 -0
  26. package/dist/commands/finding-ownership-map.d.ts.map +1 -0
  27. package/dist/commands/finding-ownership-map.js +118 -0
  28. package/dist/commands/finding-ownership-map.js.map +1 -0
  29. package/dist/commands/finding-resolution-track.d.ts +5 -0
  30. package/dist/commands/finding-resolution-track.d.ts.map +1 -0
  31. package/dist/commands/finding-resolution-track.js +151 -0
  32. package/dist/commands/finding-resolution-track.js.map +1 -0
  33. package/dist/commands/review-audit-trail.d.ts +5 -0
  34. package/dist/commands/review-audit-trail.d.ts.map +1 -0
  35. package/dist/commands/review-audit-trail.js +97 -0
  36. package/dist/commands/review-audit-trail.js.map +1 -0
  37. package/dist/commands/review-compliance-report.d.ts +5 -0
  38. package/dist/commands/review-compliance-report.d.ts.map +1 -0
  39. package/dist/commands/review-compliance-report.js +128 -0
  40. package/dist/commands/review-compliance-report.js.map +1 -0
  41. package/dist/commands/review-config-template.d.ts +5 -0
  42. package/dist/commands/review-config-template.d.ts.map +1 -0
  43. package/dist/commands/review-config-template.js +113 -0
  44. package/dist/commands/review-config-template.js.map +1 -0
  45. package/dist/commands/review-ide-sync.d.ts +5 -0
  46. package/dist/commands/review-ide-sync.d.ts.map +1 -0
  47. package/dist/commands/review-ide-sync.js +92 -0
  48. package/dist/commands/review-ide-sync.js.map +1 -0
  49. package/dist/commands/review-interactive.d.ts +5 -0
  50. package/dist/commands/review-interactive.d.ts.map +1 -0
  51. package/dist/commands/review-interactive.js +86 -0
  52. package/dist/commands/review-interactive.js.map +1 -0
  53. package/dist/commands/review-onboard-checklist.d.ts +5 -0
  54. package/dist/commands/review-onboard-checklist.d.ts.map +1 -0
  55. package/dist/commands/review-onboard-checklist.js +120 -0
  56. package/dist/commands/review-onboard-checklist.js.map +1 -0
  57. package/dist/commands/review-progress-track.d.ts +5 -0
  58. package/dist/commands/review-progress-track.d.ts.map +1 -0
  59. package/dist/commands/review-progress-track.js +95 -0
  60. package/dist/commands/review-progress-track.js.map +1 -0
  61. package/dist/commands/review-quickstart.d.ts +5 -0
  62. package/dist/commands/review-quickstart.d.ts.map +1 -0
  63. package/dist/commands/review-quickstart.js +108 -0
  64. package/dist/commands/review-quickstart.js.map +1 -0
  65. package/dist/commands/review-report-schedule.d.ts +5 -0
  66. package/dist/commands/review-report-schedule.d.ts.map +1 -0
  67. package/dist/commands/review-report-schedule.js +97 -0
  68. package/dist/commands/review-report-schedule.js.map +1 -0
  69. package/dist/commands/review-slack-format.d.ts +5 -0
  70. package/dist/commands/review-slack-format.d.ts.map +1 -0
  71. package/dist/commands/review-slack-format.js +114 -0
  72. package/dist/commands/review-slack-format.js.map +1 -0
  73. package/dist/commands/review-tenant-config.d.ts +5 -0
  74. package/dist/commands/review-tenant-config.d.ts.map +1 -0
  75. package/dist/commands/review-tenant-config.js +117 -0
  76. package/dist/commands/review-tenant-config.js.map +1 -0
  77. package/package.json +1 -1
  78. package/server.json +2 -2
@@ -0,0 +1,118 @@
1
+ /**
2
+ * Finding-ownership-map — Map findings to code owners.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function parseCodeowners(path) {
7
+ if (!existsSync(path))
8
+ return [];
9
+ const content = readFileSync(path, "utf-8");
10
+ const mappings = [];
11
+ for (const line of content.split("\n")) {
12
+ const trimmed = line.trim();
13
+ if (trimmed.startsWith("#") || trimmed.length === 0)
14
+ continue;
15
+ const parts = trimmed.split(/\s+/);
16
+ if (parts.length >= 2) {
17
+ mappings.push({ pattern: parts[0], owner: parts[1] });
18
+ }
19
+ }
20
+ return mappings;
21
+ }
22
+ function mapOwnership(verdict, owners) {
23
+ const ownerMap = new Map();
24
+ const defaultOwner = "unassigned";
25
+ for (const f of verdict.findings) {
26
+ // Use ruleId prefix as a rough domain-to-owner mapping
27
+ let assignedOwner = defaultOwner;
28
+ const rulePrefix = f.ruleId.split("-")[0];
29
+ for (const o of owners) {
30
+ if (o.pattern.includes(rulePrefix) || f.ruleId.includes(o.pattern.replace("*", ""))) {
31
+ assignedOwner = o.owner;
32
+ break;
33
+ }
34
+ }
35
+ const existing = ownerMap.get(assignedOwner);
36
+ const sev = (f.severity || "medium").toLowerCase();
37
+ if (existing) {
38
+ existing.findingCount++;
39
+ if (sev === "critical")
40
+ existing.criticalCount++;
41
+ if (sev === "high")
42
+ existing.highCount++;
43
+ if (!existing.ruleIds.includes(f.ruleId))
44
+ existing.ruleIds.push(f.ruleId);
45
+ }
46
+ else {
47
+ ownerMap.set(assignedOwner, {
48
+ owner: assignedOwner,
49
+ findingCount: 1,
50
+ criticalCount: sev === "critical" ? 1 : 0,
51
+ highCount: sev === "high" ? 1 : 0,
52
+ ruleIds: [f.ruleId],
53
+ });
54
+ }
55
+ }
56
+ return [...ownerMap.values()].sort((a, b) => b.findingCount - a.findingCount);
57
+ }
58
+ // ─── CLI ────────────────────────────────────────────────────────────────────
59
+ export function runFindingOwnershipMap(argv) {
60
+ const fileIdx = argv.indexOf("--file");
61
+ const ownersIdx = argv.indexOf("--codeowners");
62
+ const formatIdx = argv.indexOf("--format");
63
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
64
+ const ownersPath = ownersIdx >= 0 ? argv[ownersIdx + 1] : "CODEOWNERS";
65
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
66
+ if (argv.includes("--help") || argv.includes("-h")) {
67
+ console.log(`
68
+ judges finding-ownership-map — Map findings to code owners
69
+
70
+ Usage:
71
+ judges finding-ownership-map --file <verdict.json> [--codeowners <path>]
72
+ [--format table|json]
73
+
74
+ Options:
75
+ --file <path> Path to verdict JSON file (required)
76
+ --codeowners <path> Path to CODEOWNERS file (default: CODEOWNERS)
77
+ --format <fmt> Output format: table (default), json
78
+ --help, -h Show this help
79
+ `);
80
+ return;
81
+ }
82
+ if (!filePath) {
83
+ console.error("Error: --file required");
84
+ process.exitCode = 1;
85
+ return;
86
+ }
87
+ if (!existsSync(filePath)) {
88
+ console.error(`Error: not found: ${filePath}`);
89
+ process.exitCode = 1;
90
+ return;
91
+ }
92
+ let verdict;
93
+ try {
94
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
95
+ }
96
+ catch {
97
+ console.error("Error: invalid JSON");
98
+ process.exitCode = 1;
99
+ return;
100
+ }
101
+ const owners = parseCodeowners(ownersPath);
102
+ const entries = mapOwnership(verdict, owners);
103
+ if (format === "json") {
104
+ console.log(JSON.stringify(entries, null, 2));
105
+ return;
106
+ }
107
+ console.log(`\nOwnership Map (${entries.length} owners)`);
108
+ console.log("═".repeat(65));
109
+ console.log(`${"Owner".padEnd(22)} ${"Findings".padEnd(10)} ${"Critical".padEnd(10)} ${"High".padEnd(8)} Rules`);
110
+ console.log("─".repeat(65));
111
+ for (const e of entries) {
112
+ const owner = e.owner.length > 20 ? e.owner.slice(0, 20) + "…" : e.owner;
113
+ const ruleStr = e.ruleIds.slice(0, 3).join(", ");
114
+ console.log(`${owner.padEnd(22)} ${String(e.findingCount).padEnd(10)} ${String(e.criticalCount).padEnd(10)} ${String(e.highCount).padEnd(8)} ${ruleStr}`);
115
+ }
116
+ console.log("═".repeat(65));
117
+ }
118
+ //# sourceMappingURL=finding-ownership-map.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-ownership-map.js","sourceRoot":"","sources":["../../src/commands/finding-ownership-map.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Finding-resolution-track — Track finding resolution status over time.
3
+ */
4
+ export declare function runFindingResolutionTrack(argv: string[]): void;
5
+ //# sourceMappingURL=finding-resolution-track.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-resolution-track.d.ts","sourceRoot":"","sources":["../../src/commands/finding-resolution-track.ts"],"names":[],"mappings":"AAAA;;GAEG;AAwBH,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA0J9D"}
@@ -0,0 +1,151 @@
1
+ /**
2
+ * Finding-resolution-track — Track finding resolution status over time.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runFindingResolutionTrack(argv) {
7
+ const fileIdx = argv.indexOf("--file");
8
+ const storeIdx = argv.indexOf("--store");
9
+ const resolveIdx = argv.indexOf("--resolve");
10
+ const deferIdx = argv.indexOf("--defer");
11
+ const wontfixIdx = argv.indexOf("--wontfix");
12
+ const formatIdx = argv.indexOf("--format");
13
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
14
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-resolutions.json";
15
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
16
+ if (argv.includes("--help") || argv.includes("-h")) {
17
+ console.log(`
18
+ judges finding-resolution-track — Track finding resolution status
19
+
20
+ Usage:
21
+ judges finding-resolution-track [--file <review.json>] [--store <path>]
22
+ [--resolve <ruleId>] [--defer <ruleId>]
23
+ [--wontfix <ruleId>] [--format table|json]
24
+
25
+ Options:
26
+ --file <path> Import findings from review result
27
+ --store <path> Resolution store file (default: .judges-resolutions.json)
28
+ --resolve <ruleId> Mark a rule as resolved
29
+ --defer <ruleId> Mark a rule as deferred
30
+ --wontfix <ruleId> Mark a rule as wontfix
31
+ --format <fmt> Output format: table (default), json
32
+ --help, -h Show this help
33
+ `);
34
+ return;
35
+ }
36
+ // Load or init store
37
+ let store;
38
+ if (existsSync(storePath)) {
39
+ store = JSON.parse(readFileSync(storePath, "utf-8"));
40
+ }
41
+ else {
42
+ store = { entries: [], lastUpdated: new Date().toISOString().split("T")[0] };
43
+ }
44
+ const today = new Date().toISOString().split("T")[0];
45
+ // Mark resolved
46
+ if (resolveIdx >= 0) {
47
+ const ruleId = argv[resolveIdx + 1];
48
+ const entry = store.entries.find((e) => e.ruleId === ruleId && e.status === "open");
49
+ if (entry) {
50
+ entry.status = "resolved";
51
+ entry.resolvedAt = today;
52
+ store.lastUpdated = today;
53
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
54
+ console.log(`Marked ${ruleId} as resolved.`);
55
+ }
56
+ else {
57
+ console.error(`No open entry found for ${ruleId}`);
58
+ process.exitCode = 1;
59
+ }
60
+ return;
61
+ }
62
+ // Mark deferred
63
+ if (deferIdx >= 0) {
64
+ const ruleId = argv[deferIdx + 1];
65
+ const entry = store.entries.find((e) => e.ruleId === ruleId && e.status === "open");
66
+ if (entry) {
67
+ entry.status = "deferred";
68
+ store.lastUpdated = today;
69
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
70
+ console.log(`Marked ${ruleId} as deferred.`);
71
+ }
72
+ else {
73
+ console.error(`No open entry found for ${ruleId}`);
74
+ process.exitCode = 1;
75
+ }
76
+ return;
77
+ }
78
+ // Mark wontfix
79
+ if (wontfixIdx >= 0) {
80
+ const ruleId = argv[wontfixIdx + 1];
81
+ const entry = store.entries.find((e) => e.ruleId === ruleId && e.status === "open");
82
+ if (entry) {
83
+ entry.status = "wontfix";
84
+ store.lastUpdated = today;
85
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
86
+ console.log(`Marked ${ruleId} as wontfix.`);
87
+ }
88
+ else {
89
+ console.error(`No open entry found for ${ruleId}`);
90
+ process.exitCode = 1;
91
+ }
92
+ return;
93
+ }
94
+ // Import findings from review
95
+ if (filePath) {
96
+ if (!existsSync(filePath)) {
97
+ console.error(`Error: file not found: ${filePath}`);
98
+ process.exitCode = 1;
99
+ return;
100
+ }
101
+ let verdict;
102
+ try {
103
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
104
+ }
105
+ catch {
106
+ console.error(`Error: failed to parse review file: ${filePath}`);
107
+ process.exitCode = 1;
108
+ return;
109
+ }
110
+ let added = 0;
111
+ for (const f of verdict.findings) {
112
+ const existing = store.entries.find((e) => e.ruleId === f.ruleId && e.title === f.title);
113
+ if (existing) {
114
+ existing.lastSeen = today;
115
+ }
116
+ else {
117
+ store.entries.push({
118
+ ruleId: f.ruleId,
119
+ severity: f.severity,
120
+ title: f.title,
121
+ status: "open",
122
+ firstSeen: today,
123
+ lastSeen: today,
124
+ });
125
+ added++;
126
+ }
127
+ }
128
+ store.lastUpdated = today;
129
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
130
+ console.log(`Imported ${added} new finding(s), updated ${verdict.findings.length - added} existing.`);
131
+ return;
132
+ }
133
+ // Display current state
134
+ if (format === "json") {
135
+ console.log(JSON.stringify(store, null, 2));
136
+ return;
137
+ }
138
+ const open = store.entries.filter((e) => e.status === "open");
139
+ const resolved = store.entries.filter((e) => e.status === "resolved");
140
+ const deferred = store.entries.filter((e) => e.status === "deferred");
141
+ console.log(`\nResolution Tracking: ${store.entries.length} total`);
142
+ console.log(` Open: ${open.length} Resolved: ${resolved.length} Deferred: ${deferred.length}`);
143
+ console.log("═".repeat(65));
144
+ for (const e of store.entries) {
145
+ const statusBadge = e.status === "open" ? "[ ]" : e.status === "resolved" ? "[✓]" : e.status === "deferred" ? "[~]" : "[x]";
146
+ console.log(` ${statusBadge} ${e.ruleId.padEnd(20)} [${e.severity}] ${e.title}`);
147
+ console.log(` First: ${e.firstSeen} Last: ${e.lastSeen}${e.resolvedAt ? ` Resolved: ${e.resolvedAt}` : ""}`);
148
+ }
149
+ console.log("═".repeat(65));
150
+ }
151
+ //# sourceMappingURL=finding-resolution-track.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-resolution-track.js","sourceRoot":"","sources":["../../src/commands/finding-resolution-track.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-audit-trail — Maintain an audit trail of all reviews performed.
3
+ */
4
+ export declare function runReviewAuditTrail(argv: string[]): void;
5
+ //# sourceMappingURL=review-audit-trail.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-audit-trail.d.ts","sourceRoot":"","sources":["../../src/commands/review-audit-trail.ts"],"names":[],"mappings":"AAAA;;GAEG;AAyCH,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAwFxD"}
@@ -0,0 +1,97 @@
1
+ /**
2
+ * Review-audit-trail — Maintain an audit trail of all reviews performed.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── Logic ──────────────────────────────────────────────────────────────────
6
+ function loadAuditLog(path) {
7
+ if (!existsSync(path)) {
8
+ return { version: 1, entries: [] };
9
+ }
10
+ try {
11
+ return JSON.parse(readFileSync(path, "utf-8"));
12
+ }
13
+ catch {
14
+ return { version: 1, entries: [] };
15
+ }
16
+ }
17
+ function generateId() {
18
+ return `audit-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`;
19
+ }
20
+ // ─── CLI ────────────────────────────────────────────────────────────────────
21
+ export function runReviewAuditTrail(argv) {
22
+ const fileIdx = argv.indexOf("--file");
23
+ const logIdx = argv.indexOf("--log");
24
+ const lastIdx = argv.indexOf("--last");
25
+ const formatIdx = argv.indexOf("--format");
26
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
27
+ const logPath = logIdx >= 0 ? argv[logIdx + 1] : ".judges-audit.json";
28
+ const lastN = lastIdx >= 0 ? parseInt(argv[lastIdx + 1], 10) : undefined;
29
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
30
+ if (argv.includes("--help") || argv.includes("-h")) {
31
+ console.log(`
32
+ judges review-audit-trail — Maintain review audit trail
33
+
34
+ Usage:
35
+ judges review-audit-trail [--file <verdict.json>] [--log <path>]
36
+ [--last <n>] [--format table|json]
37
+
38
+ Options:
39
+ --file <path> Add verdict to audit trail
40
+ --log <path> Audit log file (default: .judges-audit.json)
41
+ --last <n> Show last N entries
42
+ --format <fmt> Output format: table (default), json
43
+ --help, -h Show this help
44
+ `);
45
+ return;
46
+ }
47
+ const log = loadAuditLog(logPath);
48
+ // Add mode
49
+ if (filePath) {
50
+ if (!existsSync(filePath)) {
51
+ console.error(`Error: not found: ${filePath}`);
52
+ process.exitCode = 1;
53
+ return;
54
+ }
55
+ let verdict;
56
+ try {
57
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
58
+ }
59
+ catch {
60
+ console.error("Error: invalid JSON");
61
+ process.exitCode = 1;
62
+ return;
63
+ }
64
+ log.entries.push({
65
+ id: generateId(),
66
+ timestamp: new Date().toISOString(),
67
+ verdict: verdict.overallVerdict,
68
+ score: verdict.overallScore,
69
+ findingCount: verdict.findings.length,
70
+ criticalCount: verdict.criticalCount,
71
+ summary: verdict.summary.slice(0, 200),
72
+ });
73
+ writeFileSync(logPath, JSON.stringify(log, null, 2));
74
+ console.log(`Added audit entry (${log.entries.length} total)`);
75
+ return;
76
+ }
77
+ // View mode
78
+ let entries = log.entries;
79
+ if (lastN !== undefined) {
80
+ entries = entries.slice(-lastN);
81
+ }
82
+ if (format === "json") {
83
+ console.log(JSON.stringify(entries, null, 2));
84
+ return;
85
+ }
86
+ console.log(`\nAudit Trail (${entries.length} entries)`);
87
+ console.log("═".repeat(75));
88
+ console.log(`${"Timestamp".padEnd(22)} ${"Verdict".padEnd(10)} ${"Score".padEnd(8)} ${"Findings".padEnd(10)} Summary`);
89
+ console.log("─".repeat(75));
90
+ for (const e of entries) {
91
+ const ts = e.timestamp.slice(0, 19).replace("T", " ");
92
+ const summary = e.summary.length > 20 ? e.summary.slice(0, 20) + "…" : e.summary;
93
+ console.log(`${ts.padEnd(22)} ${e.verdict.padEnd(10)} ${String(e.score).padEnd(8)} ${String(e.findingCount).padEnd(10)} ${summary}`);
94
+ }
95
+ console.log("═".repeat(75));
96
+ }
97
+ //# sourceMappingURL=review-audit-trail.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-audit-trail.js","sourceRoot":"","sources":["../../src/commands/review-audit-trail.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAoB7D,+EAA+E;AAE/E,SAAS,YAAY,CAAC,IAAY;IAChC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QACtB,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IACrC,CAAC;IACD,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IACjD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;IACrC,CAAC;AACH,CAAC;AAED,SAAS,UAAU;IACjB,OAAO,SAAS,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;AACzE,CAAC;AAED,+EAA+E;AAE/E,MAAM,UAAU,mBAAmB,CAAC,IAAc;IAChD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACvC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACrC,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,OAAO,GAAG,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC;IACtE,MAAM,KAAK,GAAG,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACzE,MAAM,MAAM,GAAG,SAAS,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;IAE9D,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,MAAM,GAAG,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;IAElC,WAAW;IACX,IAAI,QAAQ,EAAE,CAAC;QACb,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,OAAO,CAAC,KAAK,CAAC,qBAAqB,QAAQ,EAAE,CAAC,CAAC;YAC/C,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;QAED,IAAI,OAAwB,CAAC;QAC7B,IAAI,CAAC;YACH,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;QACxD,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;YACrC,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;QAED,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC;YACf,EAAE,EAAE,UAAU,EAAE;YAChB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,OAAO,EAAE,OAAO,CAAC,cAAc;YAC/B,KAAK,EAAE,OAAO,CAAC,YAAY;YAC3B,YAAY,EAAE,OAAO,CAAC,QAAQ,CAAC,MAAM;YACrC,aAAa,EAAE,OAAO,CAAC,aAAa;YACpC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC;SACvC,CAAC,CAAC;QAEH,aAAa,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACrD,OAAO,CAAC,GAAG,CAAC,sBAAsB,GAAG,CAAC,OAAO,CAAC,MAAM,SAAS,CAAC,CAAC;QAC/D,OAAO;IACT,CAAC;IAED,YAAY;IACZ,IAAI,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC;IAC1B,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;QACxB,OAAO,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC9C,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,kBAAkB,OAAO,CAAC,MAAM,WAAW,CAAC,CAAC;IACzD,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,OAAO,CAAC,GAAG,CACT,GAAG,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,UAAU,CAC1G,CAAC;IACF,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAE5B,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE,CAAC;QACxB,MAAM,EAAE,GAAG,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QACtD,MAAM,OAAO,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QACjF,OAAO,CAAC,GAAG,CACT,GAAG,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,OAAO,EAAE,CACxH,CAAC;IACJ,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAC9B,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-compliance-report — Generate compliance reports from review data.
3
+ */
4
+ export declare function runReviewComplianceReport(argv: string[]): void;
5
+ //# sourceMappingURL=review-compliance-report.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-compliance-report.d.ts","sourceRoot":"","sources":["../../src/commands/review-compliance-report.ts"],"names":[],"mappings":"AAAA;;GAEG;AA4FH,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA0E9D"}
@@ -0,0 +1,128 @@
1
+ /**
2
+ * Review-compliance-report — Generate compliance reports from review data.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function generateReport(verdict, framework) {
7
+ const checks = [];
8
+ // Security findings check
9
+ const secFindings = verdict.findings.filter((f) => {
10
+ const combined = `${f.ruleId} ${f.title}`.toLowerCase();
11
+ return (combined.includes("auth") ||
12
+ combined.includes("inject") ||
13
+ combined.includes("xss") ||
14
+ combined.includes("crypt") ||
15
+ combined.includes("vuln"));
16
+ });
17
+ checks.push({
18
+ name: "Security Findings",
19
+ status: secFindings.length === 0 ? "pass" : secFindings.length <= 2 ? "warning" : "fail",
20
+ detail: `${secFindings.length} security-related findings`,
21
+ });
22
+ // Critical findings check
23
+ checks.push({
24
+ name: "No Critical Findings",
25
+ status: verdict.criticalCount === 0 ? "pass" : "fail",
26
+ detail: `${verdict.criticalCount} critical findings`,
27
+ });
28
+ // Minimum score check
29
+ const minScore = framework === "strict" ? 80 : 60;
30
+ checks.push({
31
+ name: `Minimum Score (${minScore})`,
32
+ status: verdict.overallScore >= minScore ? "pass" : verdict.overallScore >= minScore - 10 ? "warning" : "fail",
33
+ detail: `Score: ${verdict.overallScore}`,
34
+ });
35
+ // Finding density check
36
+ const density = verdict.findings.length;
37
+ checks.push({
38
+ name: "Finding Density",
39
+ status: density <= 5 ? "pass" : density <= 15 ? "warning" : "fail",
40
+ detail: `${density} total findings`,
41
+ });
42
+ // Judge coverage check
43
+ const judgeCount = verdict.evaluations.length;
44
+ checks.push({
45
+ name: "Judge Coverage",
46
+ status: judgeCount >= 3 ? "pass" : judgeCount >= 1 ? "warning" : "fail",
47
+ detail: `${judgeCount} judges evaluated`,
48
+ });
49
+ const passCount = checks.filter((c) => c.status === "pass").length;
50
+ const failCount = checks.filter((c) => c.status === "fail").length;
51
+ const score = Math.round((passCount / checks.length) * 100);
52
+ const overallStatus = failCount === 0 ? "compliant" : failCount <= 1 ? "partial" : "non-compliant";
53
+ return {
54
+ framework,
55
+ timestamp: new Date().toISOString(),
56
+ overallStatus,
57
+ checks,
58
+ score,
59
+ };
60
+ }
61
+ // ─── CLI ────────────────────────────────────────────────────────────────────
62
+ export function runReviewComplianceReport(argv) {
63
+ const fileIdx = argv.indexOf("--file");
64
+ const fwIdx = argv.indexOf("--framework");
65
+ const outputIdx = argv.indexOf("--output");
66
+ const formatIdx = argv.indexOf("--format");
67
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
68
+ const framework = fwIdx >= 0 ? argv[fwIdx + 1] : "default";
69
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
70
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
71
+ if (argv.includes("--help") || argv.includes("-h")) {
72
+ console.log(`
73
+ judges review-compliance-report — Generate compliance reports
74
+
75
+ Usage:
76
+ judges review-compliance-report --file <verdict.json> [--framework <name>]
77
+ [--output <file>] [--format table|json]
78
+
79
+ Options:
80
+ --file <path> Path to verdict JSON file (required)
81
+ --framework <name> Compliance framework: default, strict
82
+ --output <path> Write report to file
83
+ --format <fmt> Output format: table (default), json
84
+ --help, -h Show this help
85
+ `);
86
+ return;
87
+ }
88
+ if (!filePath) {
89
+ console.error("Error: --file required");
90
+ process.exitCode = 1;
91
+ return;
92
+ }
93
+ if (!existsSync(filePath)) {
94
+ console.error(`Error: not found: ${filePath}`);
95
+ process.exitCode = 1;
96
+ return;
97
+ }
98
+ let verdict;
99
+ try {
100
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
101
+ }
102
+ catch {
103
+ console.error("Error: invalid JSON");
104
+ process.exitCode = 1;
105
+ return;
106
+ }
107
+ const report = generateReport(verdict, framework);
108
+ if (outputPath) {
109
+ writeFileSync(outputPath, JSON.stringify(report, null, 2));
110
+ console.log(`Compliance report written to ${outputPath}`);
111
+ return;
112
+ }
113
+ if (format === "json") {
114
+ console.log(JSON.stringify(report, null, 2));
115
+ return;
116
+ }
117
+ const statusEmoji = report.overallStatus === "compliant" ? "PASS" : report.overallStatus === "partial" ? "PARTIAL" : "FAIL";
118
+ console.log(`\nCompliance Report: ${statusEmoji} (${report.score}%)`);
119
+ console.log("═".repeat(60));
120
+ console.log(` Framework: ${report.framework}`);
121
+ console.log("─".repeat(60));
122
+ for (const c of report.checks) {
123
+ const icon = c.status === "pass" ? "[PASS]" : c.status === "warning" ? "[WARN]" : "[FAIL]";
124
+ console.log(` ${icon.padEnd(8)} ${c.name.padEnd(24)} ${c.detail}`);
125
+ }
126
+ console.log("═".repeat(60));
127
+ }
128
+ //# sourceMappingURL=review-compliance-report.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-compliance-report.js","sourceRoot":"","sources":["../../src/commands/review-compliance-report.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-config-template — Generate config templates for common scenarios.
3
+ */
4
+ export declare function runReviewConfigTemplate(argv: string[]): void;
5
+ //# sourceMappingURL=review-config-template.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-config-template.d.ts","sourceRoot":"","sources":["../../src/commands/review-config-template.ts"],"names":[],"mappings":"AAAA;;GAEG;AAwEH,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA0D5D"}