@kevinrabun/judges 3.88.0 → 3.89.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 (42) hide show
  1. package/CHANGELOG.md +13 -0
  2. package/dist/cli.d.ts.map +1 -1
  3. package/dist/cli.js +63 -0
  4. package/dist/cli.js.map +1 -1
  5. package/dist/commands/finding-category-map.d.ts +5 -0
  6. package/dist/commands/finding-category-map.d.ts.map +1 -0
  7. package/dist/commands/finding-category-map.js +104 -0
  8. package/dist/commands/finding-category-map.js.map +1 -0
  9. package/dist/commands/finding-dedup-report.d.ts +5 -0
  10. package/dist/commands/finding-dedup-report.d.ts.map +1 -0
  11. package/dist/commands/finding-dedup-report.js +102 -0
  12. package/dist/commands/finding-dedup-report.js.map +1 -0
  13. package/dist/commands/finding-false-positive-log.d.ts +5 -0
  14. package/dist/commands/finding-false-positive-log.d.ts.map +1 -0
  15. package/dist/commands/finding-false-positive-log.js +151 -0
  16. package/dist/commands/finding-false-positive-log.js.map +1 -0
  17. package/dist/commands/finding-fix-validation.d.ts +5 -0
  18. package/dist/commands/finding-fix-validation.d.ts.map +1 -0
  19. package/dist/commands/finding-fix-validation.js +116 -0
  20. package/dist/commands/finding-fix-validation.js.map +1 -0
  21. package/dist/commands/finding-regression-check.d.ts +5 -0
  22. package/dist/commands/finding-regression-check.d.ts.map +1 -0
  23. package/dist/commands/finding-regression-check.js +113 -0
  24. package/dist/commands/finding-regression-check.js.map +1 -0
  25. package/dist/commands/review-dashboard-data.d.ts +5 -0
  26. package/dist/commands/review-dashboard-data.d.ts.map +1 -0
  27. package/dist/commands/review-dashboard-data.js +143 -0
  28. package/dist/commands/review-dashboard-data.js.map +1 -0
  29. package/dist/commands/review-guardrail.d.ts +5 -0
  30. package/dist/commands/review-guardrail.d.ts.map +1 -0
  31. package/dist/commands/review-guardrail.js +156 -0
  32. package/dist/commands/review-guardrail.js.map +1 -0
  33. package/dist/commands/review-perf-profile.d.ts +5 -0
  34. package/dist/commands/review-perf-profile.d.ts.map +1 -0
  35. package/dist/commands/review-perf-profile.js +99 -0
  36. package/dist/commands/review-perf-profile.js.map +1 -0
  37. package/dist/commands/review-scope-limit.d.ts +5 -0
  38. package/dist/commands/review-scope-limit.d.ts.map +1 -0
  39. package/dist/commands/review-scope-limit.js +101 -0
  40. package/dist/commands/review-scope-limit.js.map +1 -0
  41. package/package.json +1 -1
  42. package/server.json +2 -2
@@ -0,0 +1,113 @@
1
+ /**
2
+ * Finding-regression-check — Check for regressions by comparing current vs baseline findings.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function checkRegression(baseline, current) {
7
+ const baselineRules = new Set(baseline.findings.map((f) => f.ruleId));
8
+ const currentRules = new Set(current.findings.map((f) => f.ruleId));
9
+ const newFindings = current.findings
10
+ .filter((f) => !baselineRules.has(f.ruleId))
11
+ .map((f) => ({ ruleId: f.ruleId, title: f.title, severity: (f.severity || "medium").toLowerCase() }));
12
+ const resolvedFindings = baseline.findings
13
+ .filter((f) => !currentRules.has(f.ruleId))
14
+ .map((f) => ({ ruleId: f.ruleId, title: f.title, severity: (f.severity || "medium").toLowerCase() }));
15
+ const scoreDelta = current.overallScore - baseline.overallScore;
16
+ const verdictChanged = current.overallVerdict !== baseline.overallVerdict;
17
+ const hasCriticalNew = newFindings.some((f) => f.severity === "critical" || f.severity === "high");
18
+ let status = "stable";
19
+ if (hasCriticalNew || scoreDelta < -10) {
20
+ status = "regression";
21
+ }
22
+ else if (scoreDelta > 5 || resolvedFindings.length > newFindings.length) {
23
+ status = "improvement";
24
+ }
25
+ return { status, newFindings, resolvedFindings, scoreDelta, verdictChanged };
26
+ }
27
+ // ─── CLI ────────────────────────────────────────────────────────────────────
28
+ export function runFindingRegressionCheck(argv) {
29
+ const baselineIdx = argv.indexOf("--baseline");
30
+ const currentIdx = argv.indexOf("--current");
31
+ const formatIdx = argv.indexOf("--format");
32
+ const baselinePath = baselineIdx >= 0 ? argv[baselineIdx + 1] : undefined;
33
+ const currentPath = currentIdx >= 0 ? argv[currentIdx + 1] : undefined;
34
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
35
+ if (argv.includes("--help") || argv.includes("-h")) {
36
+ console.log(`
37
+ judges finding-regression-check — Check for regressions
38
+
39
+ Usage:
40
+ judges finding-regression-check --baseline <old.json> --current <new.json>
41
+ [--format table|json]
42
+
43
+ Options:
44
+ --baseline <path> Path to baseline verdict JSON (required)
45
+ --current <path> Path to current verdict JSON (required)
46
+ --format <fmt> Output format: table (default), json
47
+ --help, -h Show this help
48
+ `);
49
+ return;
50
+ }
51
+ if (!baselinePath || !currentPath) {
52
+ console.error("Error: --baseline and --current required");
53
+ process.exitCode = 1;
54
+ return;
55
+ }
56
+ if (!existsSync(baselinePath)) {
57
+ console.error(`Error: not found: ${baselinePath}`);
58
+ process.exitCode = 1;
59
+ return;
60
+ }
61
+ if (!existsSync(currentPath)) {
62
+ console.error(`Error: not found: ${currentPath}`);
63
+ process.exitCode = 1;
64
+ return;
65
+ }
66
+ let baseline;
67
+ let current;
68
+ try {
69
+ baseline = JSON.parse(readFileSync(baselinePath, "utf-8"));
70
+ }
71
+ catch {
72
+ console.error("Error: invalid JSON in baseline");
73
+ process.exitCode = 1;
74
+ return;
75
+ }
76
+ try {
77
+ current = JSON.parse(readFileSync(currentPath, "utf-8"));
78
+ }
79
+ catch {
80
+ console.error("Error: invalid JSON in current");
81
+ process.exitCode = 1;
82
+ return;
83
+ }
84
+ const result = checkRegression(baseline, current);
85
+ if (format === "json") {
86
+ console.log(JSON.stringify(result, null, 2));
87
+ if (result.status === "regression")
88
+ process.exitCode = 1;
89
+ return;
90
+ }
91
+ const icon = result.status === "regression" ? "FAIL" : result.status === "improvement" ? "PASS" : "STABLE";
92
+ console.log(`\nRegression Check: ${icon}`);
93
+ console.log("═".repeat(65));
94
+ console.log(` Status: ${result.status.toUpperCase()}`);
95
+ console.log(` Score delta: ${result.scoreDelta > 0 ? "+" : ""}${result.scoreDelta}`);
96
+ console.log(` Verdict changed: ${result.verdictChanged}`);
97
+ if (result.newFindings.length > 0) {
98
+ console.log(`\n New Findings (+${result.newFindings.length}):`);
99
+ for (const f of result.newFindings) {
100
+ console.log(` + [${f.severity}] ${f.ruleId}: ${f.title}`);
101
+ }
102
+ }
103
+ if (result.resolvedFindings.length > 0) {
104
+ console.log(`\n Resolved Findings (-${result.resolvedFindings.length}):`);
105
+ for (const f of result.resolvedFindings) {
106
+ console.log(` - [${f.severity}] ${f.ruleId}: ${f.title}`);
107
+ }
108
+ }
109
+ console.log("═".repeat(65));
110
+ if (result.status === "regression")
111
+ process.exitCode = 1;
112
+ }
113
+ //# sourceMappingURL=finding-regression-check.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"finding-regression-check.js","sourceRoot":"","sources":["../../src/commands/finding-regression-check.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAa9C,+EAA+E;AAE/E,SAAS,eAAe,CAAC,QAAyB,EAAE,OAAwB;IAC1E,MAAM,aAAa,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IACtE,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IAEpE,MAAM,WAAW,GAAG,OAAO,CAAC,QAAQ;SACjC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;SAC3C,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,CAAC;IAExG,MAAM,gBAAgB,GAAG,QAAQ,CAAC,QAAQ;SACvC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;SAC1C,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,CAAC;IAExG,MAAM,UAAU,GAAG,OAAO,CAAC,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;IAChE,MAAM,cAAc,GAAG,OAAO,CAAC,cAAc,KAAK,QAAQ,CAAC,cAAc,CAAC;IAE1E,MAAM,cAAc,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,UAAU,IAAI,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC;IACnG,IAAI,MAAM,GAA+B,QAAQ,CAAC;IAClD,IAAI,cAAc,IAAI,UAAU,GAAG,CAAC,EAAE,EAAE,CAAC;QACvC,MAAM,GAAG,YAAY,CAAC;IACxB,CAAC;SAAM,IAAI,UAAU,GAAG,CAAC,IAAI,gBAAgB,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC;QAC1E,MAAM,GAAG,aAAa,CAAC;IACzB,CAAC;IAED,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,gBAAgB,EAAE,UAAU,EAAE,cAAc,EAAE,CAAC;AAC/E,CAAC;AAED,+EAA+E;AAE/E,MAAM,UAAU,yBAAyB,CAAC,IAAc;IACtD,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;IAC/C,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAC7C,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,MAAM,YAAY,GAAG,WAAW,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC1E,MAAM,WAAW,GAAG,UAAU,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IACvE,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;;;;;;;;;;;;CAYf,CAAC,CAAC;QACC,OAAO;IACT,CAAC;IAED,IAAI,CAAC,YAAY,IAAI,CAAC,WAAW,EAAE,CAAC;QAClC,OAAO,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC;QAC1D,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IACD,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,CAAC;QAC9B,OAAO,CAAC,KAAK,CAAC,qBAAqB,YAAY,EAAE,CAAC,CAAC;QACnD,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IACD,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC;QAC7B,OAAO,CAAC,KAAK,CAAC,qBAAqB,WAAW,EAAE,CAAC,CAAC;QAClD,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,IAAI,QAAyB,CAAC;IAC9B,IAAI,OAAwB,CAAC;IAC7B,IAAI,CAAC;QACH,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,CAAC;IAC7D,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAC;QACjD,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IACD,IAAI,CAAC;QACH,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;IAC3D,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,CAAC,KAAK,CAAC,gCAAgC,CAAC,CAAC;QAChD,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACrB,OAAO;IACT,CAAC;IAED,MAAM,MAAM,GAAG,eAAe,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAElD,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAI,MAAM,CAAC,MAAM,KAAK,YAAY;YAAE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;QACzD,OAAO;IACT,CAAC;IAED,MAAM,IAAI,GAAG,MAAM,CAAC,MAAM,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,KAAK,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC;IAC3G,OAAO,CAAC,GAAG,CAAC,uBAAuB,IAAI,EAAE,CAAC,CAAC;IAC3C,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,OAAO,CAAC,GAAG,CAAC,aAAa,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;IACxD,OAAO,CAAC,GAAG,CAAC,kBAAkB,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC;IACtF,OAAO,CAAC,GAAG,CAAC,sBAAsB,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC;IAE3D,IAAI,MAAM,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAClC,OAAO,CAAC,GAAG,CAAC,sBAAsB,MAAM,CAAC,WAAW,CAAC,MAAM,IAAI,CAAC,CAAC;QACjE,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;YACnC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;IAED,IAAI,MAAM,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACvC,OAAO,CAAC,GAAG,CAAC,2BAA2B,MAAM,CAAC,gBAAgB,CAAC,MAAM,IAAI,CAAC,CAAC;QAC3E,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,gBAAgB,EAAE,CAAC;YACxC,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;QAC/D,CAAC;IACH,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,IAAI,MAAM,CAAC,MAAM,KAAK,YAAY;QAAE,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;AAC3D,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-dashboard-data — Generate dashboard-ready data from verdict reports.
3
+ */
4
+ export declare function runReviewDashboardData(argv: string[]): void;
5
+ //# sourceMappingURL=review-dashboard-data.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-dashboard-data.d.ts","sourceRoot":"","sources":["../../src/commands/review-dashboard-data.ts"],"names":[],"mappings":"AAAA;;GAEG;AAgFH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAuF3D"}
@@ -0,0 +1,143 @@
1
+ /**
2
+ * Review-dashboard-data — Generate dashboard-ready data from verdict reports.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync, readdirSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function generateDashboard(verdicts) {
7
+ const totalReports = verdicts.length;
8
+ let totalScore = 0;
9
+ let passCount = 0;
10
+ let totalFindings = 0;
11
+ let criticalCount = 0;
12
+ let highCount = 0;
13
+ const ruleCounts = new Map();
14
+ const trends = [];
15
+ for (const v of verdicts) {
16
+ totalScore += v.verdict.overallScore;
17
+ if (v.verdict.overallVerdict === "pass")
18
+ passCount++;
19
+ totalFindings += v.verdict.findings.length;
20
+ criticalCount += v.verdict.criticalCount;
21
+ highCount += v.verdict.highCount;
22
+ trends.push({
23
+ timestamp: v.timestamp,
24
+ score: v.verdict.overallScore,
25
+ findings: v.verdict.findings.length,
26
+ });
27
+ for (const f of v.verdict.findings) {
28
+ const existing = ruleCounts.get(f.ruleId);
29
+ if (existing) {
30
+ existing.count++;
31
+ }
32
+ else {
33
+ ruleCounts.set(f.ruleId, {
34
+ count: 1,
35
+ severity: (f.severity || "medium").toLowerCase(),
36
+ });
37
+ }
38
+ }
39
+ }
40
+ const topRules = [...ruleCounts.entries()]
41
+ .map(([ruleId, data]) => ({ ruleId, count: data.count, severity: data.severity }))
42
+ .sort((a, b) => b.count - a.count)
43
+ .slice(0, 15);
44
+ return {
45
+ summary: {
46
+ totalReports,
47
+ avgScore: totalReports > 0 ? Math.round(totalScore / totalReports) : 0,
48
+ passRate: totalReports > 0 ? Math.round((passCount / totalReports) * 100) : 0,
49
+ totalFindings,
50
+ criticalCount,
51
+ highCount,
52
+ },
53
+ trends: trends.sort((a, b) => a.timestamp.localeCompare(b.timestamp)),
54
+ topRules,
55
+ };
56
+ }
57
+ // ─── CLI ────────────────────────────────────────────────────────────────────
58
+ export function runReviewDashboardData(argv) {
59
+ const dirIdx = argv.indexOf("--dir");
60
+ const fileIdx = argv.indexOf("--file");
61
+ const outputIdx = argv.indexOf("--output");
62
+ const formatIdx = argv.indexOf("--format");
63
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : undefined;
64
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
65
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
66
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
67
+ if (argv.includes("--help") || argv.includes("-h")) {
68
+ console.log(`
69
+ judges review-dashboard-data — Generate dashboard data
70
+
71
+ Usage:
72
+ judges review-dashboard-data --dir <verdicts-dir> [--output <file>]
73
+ [--format table|json]
74
+ judges review-dashboard-data --file <verdict.json> [--format table|json]
75
+
76
+ Options:
77
+ --dir <path> Directory of verdict JSON files
78
+ --file <path> Single verdict JSON file
79
+ --output <path> Write dashboard data to file
80
+ --format <fmt> Output format: table (default), json
81
+ --help, -h Show this help
82
+ `);
83
+ return;
84
+ }
85
+ const verdicts = [];
86
+ if (dirPath && existsSync(dirPath)) {
87
+ const files = readdirSync(dirPath);
88
+ for (const file of files) {
89
+ if (!file.endsWith(".json"))
90
+ continue;
91
+ try {
92
+ const v = JSON.parse(readFileSync(`${dirPath}/${file}`, "utf-8"));
93
+ verdicts.push({ verdict: v, timestamp: v.timestamp || file.replace(".json", "") });
94
+ }
95
+ catch {
96
+ // skip
97
+ }
98
+ }
99
+ }
100
+ else if (filePath && existsSync(filePath)) {
101
+ try {
102
+ const v = JSON.parse(readFileSync(filePath, "utf-8"));
103
+ verdicts.push({ verdict: v, timestamp: v.timestamp || new Date().toISOString() });
104
+ }
105
+ catch {
106
+ console.error("Error: invalid JSON");
107
+ process.exitCode = 1;
108
+ return;
109
+ }
110
+ }
111
+ else {
112
+ console.error("Error: --dir or --file required");
113
+ process.exitCode = 1;
114
+ return;
115
+ }
116
+ const dashboard = generateDashboard(verdicts);
117
+ if (outputPath) {
118
+ writeFileSync(outputPath, JSON.stringify(dashboard, null, 2));
119
+ console.log(`Dashboard data written to ${outputPath}`);
120
+ return;
121
+ }
122
+ if (format === "json") {
123
+ console.log(JSON.stringify(dashboard, null, 2));
124
+ return;
125
+ }
126
+ console.log(`\nDashboard Summary`);
127
+ console.log("═".repeat(50));
128
+ console.log(` Reports: ${dashboard.summary.totalReports}`);
129
+ console.log(` Avg Score: ${dashboard.summary.avgScore}`);
130
+ console.log(` Pass Rate: ${dashboard.summary.passRate}%`);
131
+ console.log(` Findings: ${dashboard.summary.totalFindings}`);
132
+ console.log(` Critical: ${dashboard.summary.criticalCount}`);
133
+ console.log(` High: ${dashboard.summary.highCount}`);
134
+ if (dashboard.topRules.length > 0) {
135
+ console.log(`\n Top Rules:`);
136
+ console.log(" " + "─".repeat(45));
137
+ for (const r of dashboard.topRules.slice(0, 10)) {
138
+ console.log(` ${r.ruleId.padEnd(20)} ×${String(r.count).padEnd(5)} [${r.severity}]`);
139
+ }
140
+ }
141
+ console.log("═".repeat(50));
142
+ }
143
+ //# sourceMappingURL=review-dashboard-data.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-dashboard-data.js","sourceRoot":"","sources":["../../src/commands/review-dashboard-data.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-guardrail — Define and enforce review guardrails.
3
+ */
4
+ export declare function runReviewGuardrail(argv: string[]): void;
5
+ //# sourceMappingURL=review-guardrail.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-guardrail.d.ts","sourceRoot":"","sources":["../../src/commands/review-guardrail.ts"],"names":[],"mappings":"AAAA;;GAEG;AAiGH,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAoGvD"}
@@ -0,0 +1,156 @@
1
+ /**
2
+ * Review-guardrail — Define and enforce review guardrails.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync, mkdirSync } from "fs";
5
+ import { dirname } from "path";
6
+ // ─── Helpers ────────────────────────────────────────────────────────────────
7
+ function loadGuardrails(configPath) {
8
+ if (!existsSync(configPath)) {
9
+ return {
10
+ version: 1,
11
+ guardrails: [
12
+ { id: "no-critical", type: "no-critical", threshold: 0, enabled: true },
13
+ { id: "min-score-60", type: "min-score", threshold: 60, enabled: true },
14
+ { id: "max-findings-50", type: "max-findings", threshold: 50, enabled: true },
15
+ ],
16
+ };
17
+ }
18
+ try {
19
+ return JSON.parse(readFileSync(configPath, "utf-8"));
20
+ }
21
+ catch {
22
+ return { version: 1, guardrails: [] };
23
+ }
24
+ }
25
+ function saveGuardrails(configPath, config) {
26
+ const dir = dirname(configPath);
27
+ if (!existsSync(dir)) {
28
+ mkdirSync(dir, { recursive: true });
29
+ }
30
+ writeFileSync(configPath, JSON.stringify(config, null, 2));
31
+ }
32
+ function evaluateGuardrails(verdict, guardrails) {
33
+ const results = [];
34
+ for (const g of guardrails) {
35
+ if (!g.enabled)
36
+ continue;
37
+ let passed = true;
38
+ let detail = "";
39
+ switch (g.type) {
40
+ case "no-critical":
41
+ passed = verdict.criticalCount === 0;
42
+ detail = passed ? "No critical findings" : `${verdict.criticalCount} critical findings found`;
43
+ break;
44
+ case "min-score":
45
+ passed = verdict.overallScore >= g.threshold;
46
+ detail = `Score: ${verdict.overallScore} (threshold: ${g.threshold})`;
47
+ break;
48
+ case "max-findings":
49
+ passed = verdict.findings.length <= g.threshold;
50
+ detail = `Findings: ${verdict.findings.length} (max: ${g.threshold})`;
51
+ break;
52
+ case "max-severity-count": {
53
+ const sev = (g.severity || "high").toLowerCase();
54
+ const count = verdict.findings.filter((f) => (f.severity || "medium").toLowerCase() === sev).length;
55
+ passed = count <= g.threshold;
56
+ detail = `${sev}: ${count} (max: ${g.threshold})`;
57
+ break;
58
+ }
59
+ }
60
+ results.push({ guardrailId: g.id, passed, detail });
61
+ }
62
+ return results;
63
+ }
64
+ // ─── CLI ────────────────────────────────────────────────────────────────────
65
+ export function runReviewGuardrail(argv) {
66
+ const actionIdx = argv.indexOf("--action");
67
+ const fileIdx = argv.indexOf("--file");
68
+ const configIdx = argv.indexOf("--config");
69
+ const formatIdx = argv.indexOf("--format");
70
+ const action = actionIdx >= 0 ? argv[actionIdx + 1] : "check";
71
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
72
+ const configPath = configIdx >= 0 ? argv[configIdx + 1] : ".judges-guardrails.json";
73
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
74
+ if (argv.includes("--help") || argv.includes("-h")) {
75
+ console.log(`
76
+ judges review-guardrail — Define and enforce review guardrails
77
+
78
+ Usage:
79
+ judges review-guardrail --action <action> [options]
80
+
81
+ Actions:
82
+ check Check verdict against guardrails (default)
83
+ list List configured guardrails
84
+ init Initialize default guardrails config
85
+
86
+ Options:
87
+ --action <act> Action: check, list, init
88
+ --file <path> Verdict JSON file (for check)
89
+ --config <path> Guardrails config (default: .judges-guardrails.json)
90
+ --format <fmt> Output format: table (default), json
91
+ --help, -h Show this help
92
+ `);
93
+ return;
94
+ }
95
+ const config = loadGuardrails(configPath);
96
+ if (action === "init") {
97
+ saveGuardrails(configPath, config);
98
+ console.log(`Guardrails config initialized: ${configPath}`);
99
+ return;
100
+ }
101
+ if (action === "list") {
102
+ if (format === "json") {
103
+ console.log(JSON.stringify(config, null, 2));
104
+ return;
105
+ }
106
+ console.log(`\nGuardrails (${config.guardrails.length})`);
107
+ console.log("═".repeat(60));
108
+ console.log(`${"ID".padEnd(22)} ${"Type".padEnd(22)} ${"Threshold".padEnd(12)} Enabled`);
109
+ console.log("─".repeat(60));
110
+ for (const g of config.guardrails) {
111
+ console.log(`${g.id.padEnd(22)} ${g.type.padEnd(22)} ${String(g.threshold).padEnd(12)} ${g.enabled}`);
112
+ }
113
+ console.log("═".repeat(60));
114
+ return;
115
+ }
116
+ // check
117
+ if (!filePath) {
118
+ console.error("Error: --file required for check");
119
+ process.exitCode = 1;
120
+ return;
121
+ }
122
+ if (!existsSync(filePath)) {
123
+ console.error(`Error: not found: ${filePath}`);
124
+ process.exitCode = 1;
125
+ return;
126
+ }
127
+ let verdict;
128
+ try {
129
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
130
+ }
131
+ catch {
132
+ console.error("Error: invalid JSON");
133
+ process.exitCode = 1;
134
+ return;
135
+ }
136
+ const results = evaluateGuardrails(verdict, config.guardrails);
137
+ const allPassed = results.every((r) => r.passed);
138
+ if (format === "json") {
139
+ console.log(JSON.stringify({ allPassed, results }, null, 2));
140
+ if (!allPassed)
141
+ process.exitCode = 1;
142
+ return;
143
+ }
144
+ console.log(`\nGuardrail Check: ${allPassed ? "PASS" : "FAIL"}`);
145
+ console.log("═".repeat(60));
146
+ console.log(`${"Status".padEnd(8)} ${"Guardrail".padEnd(25)} Detail`);
147
+ console.log("─".repeat(60));
148
+ for (const r of results) {
149
+ const icon = r.passed ? "PASS" : "FAIL";
150
+ console.log(`${icon.padEnd(8)} ${r.guardrailId.padEnd(25)} ${r.detail}`);
151
+ }
152
+ console.log("═".repeat(60));
153
+ if (!allPassed)
154
+ process.exitCode = 1;
155
+ }
156
+ //# sourceMappingURL=review-guardrail.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-guardrail.js","sourceRoot":"","sources":["../../src/commands/review-guardrail.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-perf-profile — Profile review performance and timing.
3
+ */
4
+ export declare function runReviewPerfProfile(argv: string[]): void;
5
+ //# sourceMappingURL=review-perf-profile.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-perf-profile.d.ts","sourceRoot":"","sources":["../../src/commands/review-perf-profile.ts"],"names":[],"mappings":"AAAA;;GAEG;AA8DH,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA6DzD"}
@@ -0,0 +1,99 @@
1
+ /**
2
+ * Review-perf-profile — Profile review performance and timing.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ import { defaultRegistry } from "../judge-registry.js";
6
+ // ─── Analysis ───────────────────────────────────────────────────────────────
7
+ function profileReview(verdict, sourceFile) {
8
+ const metrics = [];
9
+ const judges = defaultRegistry.getJudges();
10
+ // findings per judge
11
+ const judgeFindings = new Map();
12
+ for (const f of verdict.findings) {
13
+ for (const j of judges) {
14
+ if (f.ruleId.startsWith(j.rulePrefix)) {
15
+ judgeFindings.set(j.id, (judgeFindings.get(j.id) || 0) + 1);
16
+ break;
17
+ }
18
+ }
19
+ }
20
+ // judge count
21
+ metrics.push({ component: "judges", metric: "total-judges", value: judges.length, unit: "count" });
22
+ metrics.push({ component: "judges", metric: "active-judges", value: judgeFindings.size, unit: "count" });
23
+ // findings metrics
24
+ metrics.push({ component: "findings", metric: "total-findings", value: verdict.findings.length, unit: "count" });
25
+ metrics.push({ component: "findings", metric: "critical", value: verdict.criticalCount, unit: "count" });
26
+ metrics.push({ component: "findings", metric: "high", value: verdict.highCount, unit: "count" });
27
+ // source file size
28
+ if (sourceFile && existsSync(sourceFile)) {
29
+ const content = readFileSync(sourceFile, "utf-8");
30
+ metrics.push({ component: "source", metric: "file-size", value: content.length, unit: "bytes" });
31
+ metrics.push({ component: "source", metric: "line-count", value: content.split("\n").length, unit: "lines" });
32
+ }
33
+ // evaluations count
34
+ metrics.push({ component: "evaluations", metric: "total", value: verdict.evaluations.length, unit: "count" });
35
+ // average score
36
+ if (verdict.evaluations.length > 0) {
37
+ const avgScore = verdict.evaluations.reduce((s, e) => s + e.score, 0) / verdict.evaluations.length;
38
+ metrics.push({ component: "evaluations", metric: "avg-score", value: Math.round(avgScore), unit: "score" });
39
+ }
40
+ return metrics;
41
+ }
42
+ // ─── CLI ────────────────────────────────────────────────────────────────────
43
+ export function runReviewPerfProfile(argv) {
44
+ const fileIdx = argv.indexOf("--file");
45
+ const sourceIdx = argv.indexOf("--source");
46
+ const formatIdx = argv.indexOf("--format");
47
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
48
+ const sourceFile = sourceIdx >= 0 ? argv[sourceIdx + 1] : undefined;
49
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
50
+ if (argv.includes("--help") || argv.includes("-h")) {
51
+ console.log(`
52
+ judges review-perf-profile — Profile review performance
53
+
54
+ Usage:
55
+ judges review-perf-profile --file <verdict.json> [--source <src.ts>]
56
+ [--format table|json]
57
+
58
+ Options:
59
+ --file <path> Path to verdict JSON file (required)
60
+ --source <path> Source file for size metrics
61
+ --format <fmt> Output format: table (default), json
62
+ --help, -h Show this help
63
+ `);
64
+ return;
65
+ }
66
+ if (!filePath) {
67
+ console.error("Error: --file required");
68
+ process.exitCode = 1;
69
+ return;
70
+ }
71
+ if (!existsSync(filePath)) {
72
+ console.error(`Error: not found: ${filePath}`);
73
+ process.exitCode = 1;
74
+ return;
75
+ }
76
+ let verdict;
77
+ try {
78
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
79
+ }
80
+ catch {
81
+ console.error("Error: invalid JSON");
82
+ process.exitCode = 1;
83
+ return;
84
+ }
85
+ const metrics = profileReview(verdict, sourceFile);
86
+ if (format === "json") {
87
+ console.log(JSON.stringify(metrics, null, 2));
88
+ return;
89
+ }
90
+ console.log(`\nReview Performance Profile`);
91
+ console.log("═".repeat(60));
92
+ console.log(`${"Component".padEnd(16)} ${"Metric".padEnd(20)} ${"Value".padEnd(12)} Unit`);
93
+ console.log("─".repeat(60));
94
+ for (const m of metrics) {
95
+ console.log(`${m.component.padEnd(16)} ${m.metric.padEnd(20)} ${String(m.value).padEnd(12)} ${m.unit}`);
96
+ }
97
+ console.log("═".repeat(60));
98
+ }
99
+ //# sourceMappingURL=review-perf-profile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-perf-profile.js","sourceRoot":"","sources":["../../src/commands/review-perf-profile.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-scope-limit — Limit review scope to specific files, directories, or rules.
3
+ */
4
+ export declare function runReviewScopeLimit(argv: string[]): void;
5
+ //# sourceMappingURL=review-scope-limit.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-scope-limit.d.ts","sourceRoot":"","sources":["../../src/commands/review-scope-limit.ts"],"names":[],"mappings":"AAAA;;GAEG;AAiDH,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA6ExD"}