@kevinrabun/judges 3.95.0 → 3.97.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-annotation-layer.d.ts +5 -0
  6. package/dist/commands/finding-annotation-layer.d.ts.map +1 -0
  7. package/dist/commands/finding-annotation-layer.js +129 -0
  8. package/dist/commands/finding-annotation-layer.js.map +1 -0
  9. package/dist/commands/finding-confidence-calibrate.d.ts +5 -0
  10. package/dist/commands/finding-confidence-calibrate.d.ts.map +1 -0
  11. package/dist/commands/finding-confidence-calibrate.js +112 -0
  12. package/dist/commands/finding-confidence-calibrate.js.map +1 -0
  13. package/dist/commands/finding-impact-rank.d.ts +5 -0
  14. package/dist/commands/finding-impact-rank.d.ts.map +1 -0
  15. package/dist/commands/finding-impact-rank.js +86 -0
  16. package/dist/commands/finding-impact-rank.js.map +1 -0
  17. package/dist/commands/finding-risk-score.d.ts +5 -0
  18. package/dist/commands/finding-risk-score.d.ts.map +1 -0
  19. package/dist/commands/finding-risk-score.js +96 -0
  20. package/dist/commands/finding-risk-score.js.map +1 -0
  21. package/dist/commands/finding-severity-heatmap.d.ts +5 -0
  22. package/dist/commands/finding-severity-heatmap.d.ts.map +1 -0
  23. package/dist/commands/finding-severity-heatmap.js +109 -0
  24. package/dist/commands/finding-severity-heatmap.js.map +1 -0
  25. package/dist/commands/finding-trend-forecast.d.ts +5 -0
  26. package/dist/commands/finding-trend-forecast.d.ts.map +1 -0
  27. package/dist/commands/finding-trend-forecast.js +107 -0
  28. package/dist/commands/finding-trend-forecast.js.map +1 -0
  29. package/dist/commands/review-adoption-metrics.d.ts +5 -0
  30. package/dist/commands/review-adoption-metrics.d.ts.map +1 -0
  31. package/dist/commands/review-adoption-metrics.js +96 -0
  32. package/dist/commands/review-adoption-metrics.js.map +1 -0
  33. package/dist/commands/review-bulk-apply.d.ts +5 -0
  34. package/dist/commands/review-bulk-apply.d.ts.map +1 -0
  35. package/dist/commands/review-bulk-apply.js +103 -0
  36. package/dist/commands/review-bulk-apply.js.map +1 -0
  37. package/dist/commands/review-compliance-map.d.ts +5 -0
  38. package/dist/commands/review-compliance-map.d.ts.map +1 -0
  39. package/dist/commands/review-compliance-map.js +111 -0
  40. package/dist/commands/review-compliance-map.js.map +1 -0
  41. package/dist/commands/review-config-migrate.d.ts +5 -0
  42. package/dist/commands/review-config-migrate.d.ts.map +1 -0
  43. package/dist/commands/review-config-migrate.js +124 -0
  44. package/dist/commands/review-config-migrate.js.map +1 -0
  45. package/dist/commands/review-gate-config.d.ts +5 -0
  46. package/dist/commands/review-gate-config.d.ts.map +1 -0
  47. package/dist/commands/review-gate-config.js +154 -0
  48. package/dist/commands/review-gate-config.js.map +1 -0
  49. package/dist/commands/review-history-compare.d.ts +5 -0
  50. package/dist/commands/review-history-compare.d.ts.map +1 -0
  51. package/dist/commands/review-history-compare.js +94 -0
  52. package/dist/commands/review-history-compare.js.map +1 -0
  53. package/dist/commands/review-output-transform.d.ts +5 -0
  54. package/dist/commands/review-output-transform.d.ts.map +1 -0
  55. package/dist/commands/review-output-transform.js +120 -0
  56. package/dist/commands/review-output-transform.js.map +1 -0
  57. package/dist/commands/review-policy-engine.d.ts +5 -0
  58. package/dist/commands/review-policy-engine.d.ts.map +1 -0
  59. package/dist/commands/review-policy-engine.js +136 -0
  60. package/dist/commands/review-policy-engine.js.map +1 -0
  61. package/dist/commands/review-rollout-plan.d.ts +5 -0
  62. package/dist/commands/review-rollout-plan.d.ts.map +1 -0
  63. package/dist/commands/review-rollout-plan.js +124 -0
  64. package/dist/commands/review-rollout-plan.js.map +1 -0
  65. package/dist/commands/review-team-dashboard.d.ts +5 -0
  66. package/dist/commands/review-team-dashboard.d.ts.map +1 -0
  67. package/dist/commands/review-team-dashboard.js +99 -0
  68. package/dist/commands/review-team-dashboard.js.map +1 -0
  69. package/dist/commands/review-webhook-dispatch.d.ts +5 -0
  70. package/dist/commands/review-webhook-dispatch.d.ts.map +1 -0
  71. package/dist/commands/review-webhook-dispatch.js +100 -0
  72. package/dist/commands/review-webhook-dispatch.js.map +1 -0
  73. package/dist/commands/review-workspace-init.d.ts +5 -0
  74. package/dist/commands/review-workspace-init.d.ts.map +1 -0
  75. package/dist/commands/review-workspace-init.js +105 -0
  76. package/dist/commands/review-workspace-init.js.map +1 -0
  77. package/package.json +1 -1
  78. package/server.json +2 -2
@@ -0,0 +1,154 @@
1
+ /**
2
+ * Review-gate-config — Configure quality gates for review pipelines.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewGateConfig(argv) {
7
+ const storeIdx = argv.indexOf("--store");
8
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-gates.json";
9
+ const formatIdx = argv.indexOf("--format");
10
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
11
+ if (argv.includes("--help") || argv.includes("-h")) {
12
+ console.log(`
13
+ judges review-gate-config — Configure quality gates
14
+
15
+ Usage:
16
+ judges review-gate-config [--store <path>] [--add <json>]
17
+ [--remove <id>] [--check <report>]
18
+ [--format table|json]
19
+
20
+ Options:
21
+ --store <path> Gate config file (default: .judges-gates.json)
22
+ --add <json> Add quality gate (JSON)
23
+ --remove <id> Remove gate by id
24
+ --check <report> Check report against configured gates
25
+ --format <fmt> Output format: table (default), json
26
+ --help, -h Show this help
27
+
28
+ Example gate JSON:
29
+ {"id":"no-criticals","name":"No Critical Findings",
30
+ "conditions":[{"metric":"criticalCount","operator":"eq","threshold":0}],
31
+ "enabled":true}
32
+ `);
33
+ return;
34
+ }
35
+ let store;
36
+ if (existsSync(storePath)) {
37
+ store = JSON.parse(readFileSync(storePath, "utf-8"));
38
+ }
39
+ else {
40
+ store = { gates: [], lastUpdated: new Date().toISOString().split("T")[0] };
41
+ }
42
+ // Add gate
43
+ const addIdx = argv.indexOf("--add");
44
+ if (addIdx >= 0) {
45
+ const gate = JSON.parse(argv[addIdx + 1]);
46
+ const existingIdx = store.gates.findIndex((g) => g.id === gate.id);
47
+ if (existingIdx >= 0) {
48
+ store.gates[existingIdx] = gate;
49
+ }
50
+ else {
51
+ store.gates.push(gate);
52
+ }
53
+ store.lastUpdated = new Date().toISOString().split("T")[0];
54
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
55
+ console.log(`Gate "${gate.id}" saved.`);
56
+ return;
57
+ }
58
+ // Remove gate
59
+ const removeIdx = argv.indexOf("--remove");
60
+ if (removeIdx >= 0) {
61
+ const id = argv[removeIdx + 1];
62
+ store.gates = store.gates.filter((g) => g.id !== id);
63
+ store.lastUpdated = new Date().toISOString().split("T")[0];
64
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
65
+ console.log(`Gate "${id}" removed.`);
66
+ return;
67
+ }
68
+ // Check report
69
+ const checkIdx = argv.indexOf("--check");
70
+ if (checkIdx >= 0) {
71
+ const reportPath = argv[checkIdx + 1];
72
+ if (!existsSync(reportPath)) {
73
+ console.error(`Report not found: ${reportPath}`);
74
+ process.exitCode = 1;
75
+ return;
76
+ }
77
+ const report = JSON.parse(readFileSync(reportPath, "utf-8"));
78
+ const totalFindings = report.findings?.length ?? 0;
79
+ const criticalCount = report.criticalCount ?? 0;
80
+ const highCount = report.highCount ?? 0;
81
+ const overallScore = report.overallScore ?? 0;
82
+ const passRate = report.overallVerdict === "pass" ? 100 : 0;
83
+ const metrics = {
84
+ criticalCount,
85
+ highCount,
86
+ totalFindings,
87
+ passRate,
88
+ overallScore,
89
+ };
90
+ const results = [];
91
+ for (const gate of store.gates.filter((g) => g.enabled)) {
92
+ let gatePassed = true;
93
+ const details = [];
94
+ for (const cond of gate.conditions) {
95
+ const actual = metrics[cond.metric] ?? 0;
96
+ let condPassed = false;
97
+ if (cond.operator === "lt")
98
+ condPassed = actual < cond.threshold;
99
+ else if (cond.operator === "lte")
100
+ condPassed = actual <= cond.threshold;
101
+ else if (cond.operator === "gt")
102
+ condPassed = actual > cond.threshold;
103
+ else if (cond.operator === "gte")
104
+ condPassed = actual >= cond.threshold;
105
+ else if (cond.operator === "eq")
106
+ condPassed = actual === cond.threshold;
107
+ if (!condPassed) {
108
+ gatePassed = false;
109
+ details.push(`${cond.metric} ${cond.operator} ${cond.threshold} (actual: ${actual})`);
110
+ }
111
+ }
112
+ results.push({ gateId: gate.id, passed: gatePassed, details: details.join("; ") });
113
+ }
114
+ const allPassed = results.every((r) => r.passed);
115
+ if (format === "json") {
116
+ console.log(JSON.stringify({ allPassed, results }, null, 2));
117
+ }
118
+ else {
119
+ console.log(`\nQuality Gate Results`);
120
+ console.log("═".repeat(60));
121
+ for (const r of results) {
122
+ const icon = r.passed ? "PASS" : "FAIL";
123
+ console.log(` [${icon}] ${r.gateId}${r.details.length > 0 ? ` — ${r.details}` : ""}`);
124
+ }
125
+ console.log(`\n Overall: ${allPassed ? "ALL GATES PASSED" : "GATE FAILURE"}`);
126
+ console.log("═".repeat(60));
127
+ if (!allPassed) {
128
+ process.exitCode = 1;
129
+ }
130
+ }
131
+ return;
132
+ }
133
+ // List gates
134
+ if (format === "json") {
135
+ console.log(JSON.stringify(store, null, 2));
136
+ return;
137
+ }
138
+ console.log(`\nQuality Gates`);
139
+ console.log("═".repeat(60));
140
+ if (store.gates.length === 0) {
141
+ console.log(" No quality gates configured. Use --add to create one.");
142
+ }
143
+ else {
144
+ for (const g of store.gates) {
145
+ const status = g.enabled ? "ON" : "OFF";
146
+ console.log(` [${status}] ${g.id.padEnd(20)} ${g.name}`);
147
+ for (const c of g.conditions) {
148
+ console.log(` ${c.metric} ${c.operator} ${c.threshold}`);
149
+ }
150
+ }
151
+ }
152
+ console.log("═".repeat(60));
153
+ }
154
+ //# sourceMappingURL=review-gate-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-gate-config.js","sourceRoot":"","sources":["../../src/commands/review-gate-config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-history-compare — Compare review results over time.
3
+ */
4
+ export declare function runReviewHistoryCompare(argv: string[]): void;
5
+ //# sourceMappingURL=review-history-compare.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-history-compare.d.ts","sourceRoot":"","sources":["../../src/commands/review-history-compare.ts"],"names":[],"mappings":"AAAA;;GAEG;AAmBH,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAsG5D"}
@@ -0,0 +1,94 @@
1
+ /**
2
+ * Review-history-compare — Compare review results over time.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewHistoryCompare(argv) {
7
+ const beforeIdx = argv.indexOf("--before");
8
+ const afterIdx = argv.indexOf("--after");
9
+ const formatIdx = argv.indexOf("--format");
10
+ const beforeFile = beforeIdx >= 0 ? argv[beforeIdx + 1] : undefined;
11
+ const afterFile = afterIdx >= 0 ? argv[afterIdx + 1] : undefined;
12
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
13
+ if (argv.includes("--help") || argv.includes("-h")) {
14
+ console.log(`
15
+ judges review-history-compare — Compare review results over time
16
+
17
+ Usage:
18
+ judges review-history-compare --before <old.json> --after <new.json>
19
+ [--format table|json]
20
+
21
+ Options:
22
+ --before <path> Earlier review result JSON
23
+ --after <path> Later review result JSON
24
+ --format <fmt> Output format: table (default), json
25
+ --help, -h Show this help
26
+ `);
27
+ return;
28
+ }
29
+ if (!beforeFile || !afterFile) {
30
+ console.error("Error: --before and --after are required");
31
+ process.exitCode = 1;
32
+ return;
33
+ }
34
+ if (!existsSync(beforeFile)) {
35
+ console.error(`Error: file not found: ${beforeFile}`);
36
+ process.exitCode = 1;
37
+ return;
38
+ }
39
+ if (!existsSync(afterFile)) {
40
+ console.error(`Error: file not found: ${afterFile}`);
41
+ process.exitCode = 1;
42
+ return;
43
+ }
44
+ let before;
45
+ let after;
46
+ try {
47
+ before = JSON.parse(readFileSync(beforeFile, "utf-8"));
48
+ after = JSON.parse(readFileSync(afterFile, "utf-8"));
49
+ }
50
+ catch {
51
+ console.error("Error: failed to parse review files");
52
+ process.exitCode = 1;
53
+ return;
54
+ }
55
+ const beforeKeys = new Set(before.findings.map((f) => `${f.ruleId}|${f.title}`));
56
+ const afterKeys = new Set(after.findings.map((f) => `${f.ruleId}|${f.title}`));
57
+ const comparison = {
58
+ beforeFile,
59
+ afterFile,
60
+ scoreDelta: after.overallScore - before.overallScore,
61
+ findingDelta: after.findings.length - before.findings.length,
62
+ newFindings: after.findings
63
+ .filter((f) => !beforeKeys.has(`${f.ruleId}|${f.title}`))
64
+ .map((f) => ({ ruleId: f.ruleId, severity: f.severity, title: f.title })),
65
+ resolvedFindings: before.findings
66
+ .filter((f) => !afterKeys.has(`${f.ruleId}|${f.title}`))
67
+ .map((f) => ({ ruleId: f.ruleId, severity: f.severity, title: f.title })),
68
+ persistentFindings: after.findings.filter((f) => beforeKeys.has(`${f.ruleId}|${f.title}`)).length,
69
+ };
70
+ if (format === "json") {
71
+ console.log(JSON.stringify(comparison, null, 2));
72
+ return;
73
+ }
74
+ const scoreTrend = comparison.scoreDelta > 0 ? "↑" : comparison.scoreDelta < 0 ? "↓" : "→";
75
+ console.log(`\nReview History Comparison`);
76
+ console.log("═".repeat(55));
77
+ console.log(` Score: ${before.overallScore} → ${after.overallScore} (${scoreTrend}${Math.abs(comparison.scoreDelta).toFixed(1)})`);
78
+ console.log(` Findings: ${before.findings.length} → ${after.findings.length} (${comparison.findingDelta >= 0 ? "+" : ""}${comparison.findingDelta})`);
79
+ console.log(` Persistent: ${comparison.persistentFindings}`);
80
+ if (comparison.newFindings.length > 0) {
81
+ console.log(`\n New Findings (${comparison.newFindings.length}):`);
82
+ for (const f of comparison.newFindings) {
83
+ console.log(` + [${f.severity}] ${f.ruleId}: ${f.title}`);
84
+ }
85
+ }
86
+ if (comparison.resolvedFindings.length > 0) {
87
+ console.log(`\n Resolved Findings (${comparison.resolvedFindings.length}):`);
88
+ for (const f of comparison.resolvedFindings) {
89
+ console.log(` - [${f.severity}] ${f.ruleId}: ${f.title}`);
90
+ }
91
+ }
92
+ console.log("═".repeat(55));
93
+ }
94
+ //# sourceMappingURL=review-history-compare.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-history-compare.js","sourceRoot":"","sources":["../../src/commands/review-history-compare.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-output-transform — Transform review output between formats.
3
+ */
4
+ export declare function runReviewOutputTransform(argv: string[]): void;
5
+ //# sourceMappingURL=review-output-transform.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-output-transform.d.ts","sourceRoot":"","sources":["../../src/commands/review-output-transform.ts"],"names":[],"mappings":"AAAA;;GAEG;AA2DH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyE7D"}
@@ -0,0 +1,120 @@
1
+ /**
2
+ * Review-output-transform — Transform review output between formats.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── Transformers ───────────────────────────────────────────────────────────
6
+ function toMarkdown(verdict) {
7
+ const lines = [];
8
+ lines.push(`# Review Report`);
9
+ lines.push(``);
10
+ lines.push(`- **Verdict:** ${verdict.overallVerdict}`);
11
+ lines.push(`- **Score:** ${verdict.overallScore}`);
12
+ lines.push(`- **Findings:** ${verdict.findings.length}`);
13
+ lines.push(``);
14
+ if (verdict.findings.length > 0) {
15
+ lines.push(`## Findings`);
16
+ lines.push(``);
17
+ lines.push(`| Severity | Rule | Title | Recommendation |`);
18
+ lines.push(`|----------|------|-------|----------------|`);
19
+ for (const f of verdict.findings) {
20
+ lines.push(`| ${f.severity} | ${f.ruleId} | ${f.title} | ${f.recommendation} |`);
21
+ }
22
+ }
23
+ return lines.join("\n");
24
+ }
25
+ function toCsv(verdict) {
26
+ const lines = [];
27
+ lines.push("ruleId,severity,title,description,recommendation,lineNumbers,confidence");
28
+ for (const f of verdict.findings) {
29
+ const ln = f.lineNumbers !== undefined ? f.lineNumbers.join(";") : "";
30
+ const conf = f.confidence !== undefined ? String(f.confidence) : "";
31
+ const desc = f.description.replace(/"/g, '""');
32
+ const title = f.title.replace(/"/g, '""');
33
+ const rec = f.recommendation.replace(/"/g, '""');
34
+ lines.push(`"${f.ruleId}","${f.severity}","${title}","${desc}","${rec}","${ln}","${conf}"`);
35
+ }
36
+ return lines.join("\n");
37
+ }
38
+ function toSummaryText(verdict) {
39
+ const lines = [];
40
+ lines.push(`Review Summary`);
41
+ lines.push(`==============`);
42
+ lines.push(`Verdict: ${verdict.overallVerdict} Score: ${verdict.overallScore}`);
43
+ lines.push(`Findings: ${verdict.findings.length} (${verdict.criticalCount} critical, ${verdict.highCount} high)`);
44
+ lines.push(``);
45
+ for (const f of verdict.findings) {
46
+ lines.push(`[${f.severity.toUpperCase()}] ${f.ruleId}: ${f.title}`);
47
+ lines.push(` → ${f.recommendation}`);
48
+ }
49
+ return lines.join("\n");
50
+ }
51
+ // ─── CLI ────────────────────────────────────────────────────────────────────
52
+ export function runReviewOutputTransform(argv) {
53
+ const fileIdx = argv.indexOf("--file");
54
+ const toIdx = argv.indexOf("--to");
55
+ const outputIdx = argv.indexOf("--output");
56
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
57
+ const targetFormat = toIdx >= 0 ? argv[toIdx + 1] : "markdown";
58
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
59
+ if (argv.includes("--help") || argv.includes("-h")) {
60
+ console.log(`
61
+ judges review-output-transform — Transform output formats
62
+
63
+ Usage:
64
+ judges review-output-transform --file <review.json> --to <format>
65
+ [--output <file>]
66
+
67
+ Options:
68
+ --file <path> Review result JSON file
69
+ --to <format> Target: markdown, csv, text, json
70
+ --output <path> Write transformed output to file
71
+ --help, -h Show this help
72
+ `);
73
+ return;
74
+ }
75
+ if (!filePath) {
76
+ console.error("Error: --file is required");
77
+ process.exitCode = 1;
78
+ return;
79
+ }
80
+ if (!existsSync(filePath)) {
81
+ console.error(`Error: file not found: ${filePath}`);
82
+ process.exitCode = 1;
83
+ return;
84
+ }
85
+ let verdict;
86
+ try {
87
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
88
+ }
89
+ catch {
90
+ console.error(`Error: failed to parse review file: ${filePath}`);
91
+ process.exitCode = 1;
92
+ return;
93
+ }
94
+ let output;
95
+ switch (targetFormat) {
96
+ case "markdown":
97
+ output = toMarkdown(verdict);
98
+ break;
99
+ case "csv":
100
+ output = toCsv(verdict);
101
+ break;
102
+ case "text":
103
+ output = toSummaryText(verdict);
104
+ break;
105
+ case "json":
106
+ output = JSON.stringify(verdict, null, 2);
107
+ break;
108
+ default:
109
+ console.error(`Error: unknown format: ${targetFormat}. Use markdown, csv, text, or json.`);
110
+ process.exitCode = 1;
111
+ return;
112
+ }
113
+ if (outputPath) {
114
+ writeFileSync(outputPath, output);
115
+ console.log(`Transformed to ${targetFormat}, written to ${outputPath}`);
116
+ return;
117
+ }
118
+ console.log(output);
119
+ }
120
+ //# sourceMappingURL=review-output-transform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-output-transform.js","sourceRoot":"","sources":["../../src/commands/review-output-transform.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-policy-engine — Define and enforce code-review policies locally.
3
+ */
4
+ export declare function runReviewPolicyEngine(argv: string[]): void;
5
+ //# sourceMappingURL=review-policy-engine.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-policy-engine.d.ts","sourceRoot":"","sources":["../../src/commands/review-policy-engine.ts"],"names":[],"mappings":"AAAA;;GAEG;AA6BH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAsI1D"}
@@ -0,0 +1,136 @@
1
+ /**
2
+ * Review-policy-engine — Define and enforce code-review policies locally.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewPolicyEngine(argv) {
7
+ const storeIdx = argv.indexOf("--store");
8
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-policies.json";
9
+ const formatIdx = argv.indexOf("--format");
10
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
11
+ if (argv.includes("--help") || argv.includes("-h")) {
12
+ console.log(`
13
+ judges review-policy-engine — Define and enforce code-review policies
14
+
15
+ Usage:
16
+ judges review-policy-engine [--store <path>] [--add <json>]
17
+ [--remove <id>] [--check <report>]
18
+ [--format table|json]
19
+
20
+ Options:
21
+ --store <path> Policy store file (default: .judges-policies.json)
22
+ --add <json> Add a policy (JSON string)
23
+ --remove <id> Remove policy by id
24
+ --check <report> Check a report file against policies
25
+ --format <fmt> Output format: table (default), json
26
+ --help, -h Show this help
27
+
28
+ Example policy JSON:
29
+ {"id":"no-critical","name":"Block Critical","description":"Block critical findings",
30
+ "rules":[{"field":"severity","operator":"eq","value":"critical","action":"block"}],
31
+ "enabled":true}
32
+ `);
33
+ return;
34
+ }
35
+ let store;
36
+ if (existsSync(storePath)) {
37
+ store = JSON.parse(readFileSync(storePath, "utf-8"));
38
+ }
39
+ else {
40
+ store = { policies: [], lastUpdated: new Date().toISOString().split("T")[0] };
41
+ }
42
+ // Add policy
43
+ const addIdx = argv.indexOf("--add");
44
+ if (addIdx >= 0) {
45
+ const policy = JSON.parse(argv[addIdx + 1]);
46
+ const existingIdx = store.policies.findIndex((p) => p.id === policy.id);
47
+ if (existingIdx >= 0) {
48
+ store.policies[existingIdx] = policy;
49
+ }
50
+ else {
51
+ store.policies.push(policy);
52
+ }
53
+ store.lastUpdated = new Date().toISOString().split("T")[0];
54
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
55
+ console.log(`Policy "${policy.id}" saved.`);
56
+ return;
57
+ }
58
+ // Remove policy
59
+ const removeIdx = argv.indexOf("--remove");
60
+ if (removeIdx >= 0) {
61
+ const id = argv[removeIdx + 1];
62
+ store.policies = store.policies.filter((p) => p.id !== id);
63
+ store.lastUpdated = new Date().toISOString().split("T")[0];
64
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
65
+ console.log(`Policy "${id}" removed.`);
66
+ return;
67
+ }
68
+ // Check report against policies
69
+ const checkIdx = argv.indexOf("--check");
70
+ if (checkIdx >= 0) {
71
+ const reportPath = argv[checkIdx + 1];
72
+ if (!existsSync(reportPath)) {
73
+ console.error(`Report not found: ${reportPath}`);
74
+ process.exitCode = 1;
75
+ return;
76
+ }
77
+ const report = JSON.parse(readFileSync(reportPath, "utf-8"));
78
+ const findings = report.findings ?? [];
79
+ const violations = [];
80
+ for (const policy of store.policies.filter((p) => p.enabled)) {
81
+ for (const f of findings) {
82
+ for (const rule of policy.rules) {
83
+ const fieldVal = f[rule.field];
84
+ let match = false;
85
+ if (rule.operator === "eq")
86
+ match = fieldVal === rule.value;
87
+ else if (rule.operator === "neq")
88
+ match = fieldVal !== rule.value;
89
+ else if (rule.operator === "gte" && typeof fieldVal === "number")
90
+ match = fieldVal >= rule.value;
91
+ else if (rule.operator === "lte" && typeof fieldVal === "number")
92
+ match = fieldVal <= rule.value;
93
+ if (match && rule.action === "block") {
94
+ violations.push({ policyId: policy.id, action: "block", finding: String(f.ruleId ?? "unknown") });
95
+ }
96
+ }
97
+ }
98
+ }
99
+ if (format === "json") {
100
+ console.log(JSON.stringify({ passed: violations.length === 0, violations }, null, 2));
101
+ }
102
+ else {
103
+ if (violations.length === 0) {
104
+ console.log("All policies passed.");
105
+ }
106
+ else {
107
+ console.log(`Policy violations (${violations.length}):`);
108
+ for (const v of violations) {
109
+ console.log(` BLOCK: ${v.policyId} — finding ${v.finding}`);
110
+ }
111
+ process.exitCode = 1;
112
+ }
113
+ }
114
+ return;
115
+ }
116
+ // List policies
117
+ if (format === "json") {
118
+ console.log(JSON.stringify(store, null, 2));
119
+ return;
120
+ }
121
+ console.log(`\nReview Policies`);
122
+ console.log("═".repeat(60));
123
+ if (store.policies.length === 0) {
124
+ console.log(" No policies defined. Use --add to create one.");
125
+ }
126
+ else {
127
+ for (const p of store.policies) {
128
+ const status = p.enabled ? "ON" : "OFF";
129
+ console.log(` [${status}] ${p.id.padEnd(20)} ${p.name}`);
130
+ console.log(` ${p.description}`);
131
+ console.log(` Rules: ${p.rules.length}`);
132
+ }
133
+ }
134
+ console.log("═".repeat(60));
135
+ }
136
+ //# sourceMappingURL=review-policy-engine.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-policy-engine.js","sourceRoot":"","sources":["../../src/commands/review-policy-engine.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-rollout-plan — Generate a phased rollout plan for Judges adoption.
3
+ */
4
+ export declare function runReviewRolloutPlan(argv: string[]): void;
5
+ //# sourceMappingURL=review-rollout-plan.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-rollout-plan.d.ts","sourceRoot":"","sources":["../../src/commands/review-rollout-plan.ts"],"names":[],"mappings":"AAAA;;GAEG;AAwBH,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA+HzD"}