@kevinrabun/judges 3.98.0 → 3.100.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-auto-suppress.d.ts +5 -0
  6. package/dist/commands/finding-auto-suppress.d.ts.map +1 -0
  7. package/dist/commands/finding-auto-suppress.js +127 -0
  8. package/dist/commands/finding-auto-suppress.js.map +1 -0
  9. package/dist/commands/finding-auto-triage.d.ts +5 -0
  10. package/dist/commands/finding-auto-triage.d.ts.map +1 -0
  11. package/dist/commands/finding-auto-triage.js +109 -0
  12. package/dist/commands/finding-auto-triage.js.map +1 -0
  13. package/dist/commands/finding-change-impact.d.ts +5 -0
  14. package/dist/commands/finding-change-impact.d.ts.map +1 -0
  15. package/dist/commands/finding-change-impact.js +108 -0
  16. package/dist/commands/finding-change-impact.js.map +1 -0
  17. package/dist/commands/finding-context-enrich.d.ts +5 -0
  18. package/dist/commands/finding-context-enrich.d.ts.map +1 -0
  19. package/dist/commands/finding-context-enrich.js +90 -0
  20. package/dist/commands/finding-context-enrich.js.map +1 -0
  21. package/dist/commands/finding-dismiss-workflow.d.ts +5 -0
  22. package/dist/commands/finding-dismiss-workflow.d.ts.map +1 -0
  23. package/dist/commands/finding-dismiss-workflow.js +120 -0
  24. package/dist/commands/finding-dismiss-workflow.js.map +1 -0
  25. package/dist/commands/finding-false-positive-learn.d.ts +5 -0
  26. package/dist/commands/finding-false-positive-learn.d.ts.map +1 -0
  27. package/dist/commands/finding-false-positive-learn.js +86 -0
  28. package/dist/commands/finding-false-positive-learn.js.map +1 -0
  29. package/dist/commands/finding-reachability-check.d.ts +5 -0
  30. package/dist/commands/finding-reachability-check.d.ts.map +1 -0
  31. package/dist/commands/finding-reachability-check.js +103 -0
  32. package/dist/commands/finding-reachability-check.js.map +1 -0
  33. package/dist/commands/review-audit-export.d.ts +5 -0
  34. package/dist/commands/review-audit-export.d.ts.map +1 -0
  35. package/dist/commands/review-audit-export.js +94 -0
  36. package/dist/commands/review-audit-export.js.map +1 -0
  37. package/dist/commands/review-data-retention.d.ts +5 -0
  38. package/dist/commands/review-data-retention.d.ts.map +1 -0
  39. package/dist/commands/review-data-retention.js +120 -0
  40. package/dist/commands/review-data-retention.js.map +1 -0
  41. package/dist/commands/review-deployment-gate.d.ts +5 -0
  42. package/dist/commands/review-deployment-gate.d.ts.map +1 -0
  43. package/dist/commands/review-deployment-gate.js +95 -0
  44. package/dist/commands/review-deployment-gate.js.map +1 -0
  45. package/dist/commands/review-environment-config.d.ts +5 -0
  46. package/dist/commands/review-environment-config.d.ts.map +1 -0
  47. package/dist/commands/review-environment-config.js +103 -0
  48. package/dist/commands/review-environment-config.js.map +1 -0
  49. package/dist/commands/review-multi-repo-sync.d.ts +5 -0
  50. package/dist/commands/review-multi-repo-sync.d.ts.map +1 -0
  51. package/dist/commands/review-multi-repo-sync.js +116 -0
  52. package/dist/commands/review-multi-repo-sync.js.map +1 -0
  53. package/dist/commands/review-permission-model.d.ts +5 -0
  54. package/dist/commands/review-permission-model.d.ts.map +1 -0
  55. package/dist/commands/review-permission-model.js +150 -0
  56. package/dist/commands/review-permission-model.js.map +1 -0
  57. package/dist/commands/review-pipeline-status.d.ts +5 -0
  58. package/dist/commands/review-pipeline-status.d.ts.map +1 -0
  59. package/dist/commands/review-pipeline-status.js +55 -0
  60. package/dist/commands/review-pipeline-status.js.map +1 -0
  61. package/dist/commands/review-repo-onboard.d.ts +5 -0
  62. package/dist/commands/review-repo-onboard.d.ts.map +1 -0
  63. package/dist/commands/review-repo-onboard.js +115 -0
  64. package/dist/commands/review-repo-onboard.js.map +1 -0
  65. package/dist/commands/review-review-comments.d.ts +5 -0
  66. package/dist/commands/review-review-comments.d.ts.map +1 -0
  67. package/dist/commands/review-review-comments.js +85 -0
  68. package/dist/commands/review-review-comments.js.map +1 -0
  69. package/dist/commands/review-session-replay.d.ts +5 -0
  70. package/dist/commands/review-session-replay.d.ts.map +1 -0
  71. package/dist/commands/review-session-replay.js +82 -0
  72. package/dist/commands/review-session-replay.js.map +1 -0
  73. package/dist/commands/review-stakeholder-report.d.ts +5 -0
  74. package/dist/commands/review-stakeholder-report.d.ts.map +1 -0
  75. package/dist/commands/review-stakeholder-report.js +76 -0
  76. package/dist/commands/review-stakeholder-report.js.map +1 -0
  77. package/package.json +1 -1
  78. package/server.json +2 -2
@@ -0,0 +1,85 @@
1
+ /**
2
+ * Review-review-comments — Generate structured review comments from findings.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewReviewComments(argv) {
7
+ const reportIdx = argv.indexOf("--report");
8
+ const styleIdx = argv.indexOf("--style");
9
+ const formatIdx = argv.indexOf("--format");
10
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
11
+ const style = styleIdx >= 0 ? argv[styleIdx + 1] : "detailed";
12
+ if (argv.includes("--help") || argv.includes("-h")) {
13
+ console.log(`
14
+ judges review-review-comments — Generate structured review comments
15
+
16
+ Usage:
17
+ judges review-review-comments --report <path> [--style <style>]
18
+ [--format table|json]
19
+
20
+ Options:
21
+ --report <path> Report file with findings
22
+ --style <style> Comment style: detailed (default), concise, inline
23
+ --format <fmt> Output format: table (default), json
24
+ --help, -h Show this help
25
+ `);
26
+ return;
27
+ }
28
+ if (reportIdx < 0) {
29
+ console.error("Missing --report <path>");
30
+ process.exitCode = 1;
31
+ return;
32
+ }
33
+ const reportPath = argv[reportIdx + 1];
34
+ if (!existsSync(reportPath)) {
35
+ console.error(`Report not found: ${reportPath}`);
36
+ process.exitCode = 1;
37
+ return;
38
+ }
39
+ const report = JSON.parse(readFileSync(reportPath, "utf-8"));
40
+ const findings = report.findings ?? [];
41
+ if (findings.length === 0) {
42
+ console.log("No findings to generate comments for.");
43
+ return;
44
+ }
45
+ const comments = findings.map((f) => {
46
+ const lineRef = f.lineNumbers !== undefined && f.lineNumbers.length > 0
47
+ ? `L${f.lineNumbers[0]}${f.lineNumbers.length > 1 ? `-L${f.lineNumbers[f.lineNumbers.length - 1]}` : ""}`
48
+ : "N/A";
49
+ let body;
50
+ if (style === "concise") {
51
+ body = `[${f.severity.toUpperCase()}] ${f.title}`;
52
+ }
53
+ else if (style === "inline") {
54
+ body = `// ${f.severity.toUpperCase()}: ${f.title} — ${f.recommendation}`;
55
+ }
56
+ else {
57
+ body = `**${f.severity.toUpperCase()}**: ${f.title}\n\n${f.description}\n\n**Recommendation**: ${f.recommendation}`;
58
+ }
59
+ return {
60
+ ruleId: f.ruleId,
61
+ severity: f.severity,
62
+ title: f.title,
63
+ body,
64
+ lineRef,
65
+ suggestion: f.recommendation,
66
+ };
67
+ });
68
+ if (format === "json") {
69
+ console.log(JSON.stringify(comments, null, 2));
70
+ return;
71
+ }
72
+ console.log(`\nReview Comments (${style})`);
73
+ console.log("═".repeat(70));
74
+ for (let i = 0; i < comments.length; i++) {
75
+ const c = comments[i];
76
+ console.log(`\n Comment ${i + 1} [${c.lineRef}]:`);
77
+ console.log(" " + "─".repeat(60));
78
+ for (const line of c.body.split("\n")) {
79
+ console.log(` ${line}`);
80
+ }
81
+ }
82
+ console.log(`\n Total comments: ${comments.length}`);
83
+ console.log("═".repeat(70));
84
+ }
85
+ //# sourceMappingURL=review-review-comments.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-review-comments.js","sourceRoot":"","sources":["../../src/commands/review-review-comments.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-session-replay — Replay and inspect past review sessions.
3
+ */
4
+ export declare function runReviewSessionReplay(argv: string[]): void;
5
+ //# sourceMappingURL=review-session-replay.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-session-replay.d.ts","sourceRoot":"","sources":["../../src/commands/review-session-replay.ts"],"names":[],"mappings":"AAAA;;GAEG;AAuBH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA0F3D"}
@@ -0,0 +1,82 @@
1
+ /**
2
+ * Review-session-replay — Replay and inspect past review sessions.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewSessionReplay(argv) {
7
+ const storeIdx = argv.indexOf("--store");
8
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-sessions.json";
9
+ const formatIdx = argv.indexOf("--format");
10
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
11
+ const sessionIdx = argv.indexOf("--session");
12
+ const sessionId = sessionIdx >= 0 ? argv[sessionIdx + 1] : "";
13
+ const lastN = argv.indexOf("--last");
14
+ const lastCount = lastN >= 0 ? parseInt(argv[lastN + 1], 10) : 0;
15
+ if (argv.includes("--help") || argv.includes("-h")) {
16
+ console.log(`
17
+ judges review-session-replay — Replay past review sessions
18
+
19
+ Usage:
20
+ judges review-session-replay [--store <path>] [--format table|json]
21
+ judges review-session-replay --session <id> [--store <path>]
22
+ judges review-session-replay --last <n> [--store <path>]
23
+
24
+ Options:
25
+ --store <path> Session store file (default: .judges-sessions.json)
26
+ --session <id> Show details for a specific session
27
+ --last <n> Show only the last N sessions
28
+ --format <fmt> Output format: table (default), json
29
+ --help, -h Show this help
30
+ `);
31
+ return;
32
+ }
33
+ if (!existsSync(storePath)) {
34
+ console.log(`No session store found at: ${storePath}`);
35
+ console.log("Sessions are recorded automatically during reviews.");
36
+ return;
37
+ }
38
+ const store = JSON.parse(readFileSync(storePath, "utf-8"));
39
+ if (sessionId) {
40
+ const session = store.sessions.find((s) => s.id === sessionId);
41
+ if (!session) {
42
+ console.error(`Session not found: ${sessionId}`);
43
+ process.exitCode = 1;
44
+ return;
45
+ }
46
+ if (format === "json") {
47
+ console.log(JSON.stringify(session, null, 2));
48
+ return;
49
+ }
50
+ console.log("\nSession Details");
51
+ console.log("═".repeat(50));
52
+ console.log(` ID: ${session.id}`);
53
+ console.log(` File: ${session.file}`);
54
+ console.log(` Timestamp: ${session.timestamp}`);
55
+ console.log(` Verdict: ${session.verdict}`);
56
+ console.log(` Score: ${session.score}/100`);
57
+ console.log(` Findings: ${session.findingCount}`);
58
+ console.log(` Duration: ${session.duration}ms`);
59
+ console.log("═".repeat(50));
60
+ return;
61
+ }
62
+ let sessions = store.sessions;
63
+ if (lastCount > 0) {
64
+ sessions = sessions.slice(-lastCount);
65
+ }
66
+ if (format === "json") {
67
+ console.log(JSON.stringify(sessions, null, 2));
68
+ return;
69
+ }
70
+ console.log(`\nReview Sessions (${sessions.length})`);
71
+ console.log("═".repeat(80));
72
+ console.log(` ${"ID".padEnd(15)} ${"File".padEnd(25)} ${"Verdict".padEnd(10)} ${"Score".padEnd(8)} ${"Findings".padEnd(10)} Date`);
73
+ console.log(" " + "─".repeat(75));
74
+ for (const s of sessions) {
75
+ const fileName = s.file.length > 23 ? "..." + s.file.slice(-20) : s.file;
76
+ console.log(` ${s.id.padEnd(15)} ${fileName.padEnd(25)} ${s.verdict.padEnd(10)} ${String(s.score).padEnd(8)} ${String(s.findingCount).padEnd(10)} ${s.timestamp.slice(0, 10)}`);
77
+ }
78
+ const avgScore = sessions.length > 0 ? Math.round(sessions.reduce((a, s) => a + s.score, 0) / sessions.length) : 0;
79
+ console.log(`\n Total sessions: ${sessions.length} | Average score: ${avgScore}`);
80
+ console.log("═".repeat(80));
81
+ }
82
+ //# sourceMappingURL=review-session-replay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-session-replay.js","sourceRoot":"","sources":["../../src/commands/review-session-replay.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-stakeholder-report — Generate stakeholder-facing summaries of review outcomes.
3
+ */
4
+ export declare function runReviewStakeholderReport(argv: string[]): void;
5
+ //# sourceMappingURL=review-stakeholder-report.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-stakeholder-report.d.ts","sourceRoot":"","sources":["../../src/commands/review-stakeholder-report.ts"],"names":[],"mappings":"AAAA;;GAEG;AAOH,wBAAgB,0BAA0B,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA8E/D"}
@@ -0,0 +1,76 @@
1
+ /**
2
+ * Review-stakeholder-report — Generate stakeholder-facing summaries of review outcomes.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewStakeholderReport(argv) {
7
+ const reportIdx = argv.indexOf("--report");
8
+ const reportPath = reportIdx >= 0 ? argv[reportIdx + 1] : "";
9
+ const formatIdx = argv.indexOf("--format");
10
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
11
+ const audience = argv.includes("--executive") ? "executive" : "technical";
12
+ if (argv.includes("--help") || argv.includes("-h")) {
13
+ console.log(`
14
+ judges review-stakeholder-report — Generate stakeholder summaries
15
+
16
+ Usage:
17
+ judges review-stakeholder-report --report <path> [--executive] [--format table|json]
18
+
19
+ Options:
20
+ --report <path> Path to tribunal verdict JSON
21
+ --executive Executive-level summary (fewer details)
22
+ --format <fmt> Output format: table (default), json
23
+ --help, -h Show this help
24
+ `);
25
+ return;
26
+ }
27
+ if (!reportPath || !existsSync(reportPath)) {
28
+ console.error("Provide --report <path> to a valid verdict JSON file.");
29
+ process.exitCode = 1;
30
+ return;
31
+ }
32
+ const verdict = JSON.parse(readFileSync(reportPath, "utf-8"));
33
+ const severityCounts = {};
34
+ for (const f of verdict.findings) {
35
+ severityCounts[f.severity] = (severityCounts[f.severity] ?? 0) + 1;
36
+ }
37
+ const summary = {
38
+ verdict: verdict.overallVerdict,
39
+ score: verdict.overallScore,
40
+ totalFindings: verdict.findings.length,
41
+ critical: verdict.criticalCount,
42
+ high: verdict.highCount,
43
+ severityBreakdown: severityCounts,
44
+ judgesRun: verdict.evaluations.length,
45
+ summary: verdict.summary,
46
+ timestamp: verdict.timestamp,
47
+ };
48
+ if (format === "json") {
49
+ console.log(JSON.stringify(summary, null, 2));
50
+ return;
51
+ }
52
+ console.log("\nStakeholder Report");
53
+ console.log("═".repeat(60));
54
+ if (audience === "executive") {
55
+ const statusLabel = verdict.overallVerdict === "pass" ? "PASS" : verdict.overallVerdict === "fail" ? "FAIL" : "WARNING";
56
+ console.log(` Status: ${statusLabel}`);
57
+ console.log(` Score: ${verdict.overallScore}/100`);
58
+ console.log(` Critical: ${verdict.criticalCount}`);
59
+ console.log(` High: ${verdict.highCount}`);
60
+ console.log(` Total: ${verdict.findings.length} findings`);
61
+ console.log(`\n ${verdict.summary}`);
62
+ }
63
+ else {
64
+ console.log(` Verdict: ${verdict.overallVerdict}`);
65
+ console.log(` Score: ${verdict.overallScore}/100`);
66
+ console.log(` Judges: ${verdict.evaluations.length}`);
67
+ console.log(` Findings: ${verdict.findings.length}`);
68
+ console.log(`\n Severity Breakdown:`);
69
+ for (const [sev, count] of Object.entries(severityCounts)) {
70
+ console.log(` ${sev.padEnd(12)} ${count}`);
71
+ }
72
+ console.log(`\n Summary: ${verdict.summary}`);
73
+ }
74
+ console.log("═".repeat(60));
75
+ }
76
+ //# sourceMappingURL=review-stakeholder-report.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-stakeholder-report.js","sourceRoot":"","sources":["../../src/commands/review-stakeholder-report.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kevinrabun/judges",
3
- "version": "3.98.0",
3
+ "version": "3.100.0",
4
4
  "description": "45 specialized judges that evaluate AI-generated code for security, cost, and quality.",
5
5
  "mcpName": "io.github.KevinRabun/judges",
6
6
  "type": "module",
package/server.json CHANGED
@@ -7,12 +7,12 @@
7
7
  "url": "https://github.com/kevinrabun/judges",
8
8
  "source": "github"
9
9
  },
10
- "version": "3.98.0",
10
+ "version": "3.100.0",
11
11
  "packages": [
12
12
  {
13
13
  "registryType": "npm",
14
14
  "identifier": "@kevinrabun/judges",
15
- "version": "3.98.0",
15
+ "version": "3.100.0",
16
16
  "transport": {
17
17
  "type": "stdio"
18
18
  }