@kevinrabun/judges 3.94.0 → 3.96.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-confidence-calibrate.d.ts +5 -0
  6. package/dist/commands/finding-confidence-calibrate.d.ts.map +1 -0
  7. package/dist/commands/finding-confidence-calibrate.js +112 -0
  8. package/dist/commands/finding-confidence-calibrate.js.map +1 -0
  9. package/dist/commands/finding-correlation-map.d.ts +5 -0
  10. package/dist/commands/finding-correlation-map.d.ts.map +1 -0
  11. package/dist/commands/finding-correlation-map.js +102 -0
  12. package/dist/commands/finding-correlation-map.js.map +1 -0
  13. package/dist/commands/finding-dedup-cross.d.ts +5 -0
  14. package/dist/commands/finding-dedup-cross.d.ts.map +1 -0
  15. package/dist/commands/finding-dedup-cross.js +91 -0
  16. package/dist/commands/finding-dedup-cross.js.map +1 -0
  17. package/dist/commands/finding-groupby-file.d.ts +5 -0
  18. package/dist/commands/finding-groupby-file.d.ts.map +1 -0
  19. package/dist/commands/finding-groupby-file.js +95 -0
  20. package/dist/commands/finding-groupby-file.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/review-adoption-metrics.d.ts +5 -0
  26. package/dist/commands/review-adoption-metrics.d.ts.map +1 -0
  27. package/dist/commands/review-adoption-metrics.js +96 -0
  28. package/dist/commands/review-adoption-metrics.js.map +1 -0
  29. package/dist/commands/review-api-export.d.ts +5 -0
  30. package/dist/commands/review-api-export.d.ts.map +1 -0
  31. package/dist/commands/review-api-export.js +99 -0
  32. package/dist/commands/review-api-export.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-config-migrate.d.ts +5 -0
  38. package/dist/commands/review-config-migrate.d.ts.map +1 -0
  39. package/dist/commands/review-config-migrate.js +124 -0
  40. package/dist/commands/review-config-migrate.js.map +1 -0
  41. package/dist/commands/review-history-compare.d.ts +5 -0
  42. package/dist/commands/review-history-compare.d.ts.map +1 -0
  43. package/dist/commands/review-history-compare.js +94 -0
  44. package/dist/commands/review-history-compare.js.map +1 -0
  45. package/dist/commands/review-merge-request.d.ts +5 -0
  46. package/dist/commands/review-merge-request.d.ts.map +1 -0
  47. package/dist/commands/review-merge-request.js +96 -0
  48. package/dist/commands/review-merge-request.js.map +1 -0
  49. package/dist/commands/review-notification-config.d.ts +5 -0
  50. package/dist/commands/review-notification-config.d.ts.map +1 -0
  51. package/dist/commands/review-notification-config.js +123 -0
  52. package/dist/commands/review-notification-config.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-scope-select.d.ts +5 -0
  58. package/dist/commands/review-scope-select.d.ts.map +1 -0
  59. package/dist/commands/review-scope-select.js +99 -0
  60. package/dist/commands/review-scope-select.js.map +1 -0
  61. package/dist/commands/review-summary-dashboard.d.ts +5 -0
  62. package/dist/commands/review-summary-dashboard.d.ts.map +1 -0
  63. package/dist/commands/review-summary-dashboard.js +97 -0
  64. package/dist/commands/review-summary-dashboard.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-template-library.d.ts +5 -0
  70. package/dist/commands/review-template-library.d.ts.map +1 -0
  71. package/dist/commands/review-template-library.js +156 -0
  72. package/dist/commands/review-template-library.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,99 @@
1
+ /**
2
+ * Review-team-dashboard — Team-level review dashboard with aggregated metrics.
3
+ */
4
+ import { readFileSync, existsSync, readdirSync } from "fs";
5
+ import { join } from "path";
6
+ // ─── CLI ────────────────────────────────────────────────────────────────────
7
+ export function runReviewTeamDashboard(argv) {
8
+ const dirIdx = argv.indexOf("--dir");
9
+ const formatIdx = argv.indexOf("--format");
10
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : process.cwd();
11
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
12
+ if (argv.includes("--help") || argv.includes("-h")) {
13
+ console.log(`
14
+ judges review-team-dashboard — Team review dashboard
15
+
16
+ Usage:
17
+ judges review-team-dashboard [--dir <path>] [--format table|json]
18
+
19
+ Options:
20
+ --dir <path> Directory with review JSON files (default: cwd)
21
+ --format <fmt> Output format: table (default), json
22
+ --help, -h Show this help
23
+ `);
24
+ return;
25
+ }
26
+ if (!existsSync(dirPath)) {
27
+ console.error(`Error: directory not found: ${dirPath}`);
28
+ process.exitCode = 1;
29
+ return;
30
+ }
31
+ const files = readdirSync(dirPath).filter((f) => typeof f === "string" && f.endsWith(".json"));
32
+ const verdicts = [];
33
+ for (const file of files) {
34
+ try {
35
+ const v = JSON.parse(readFileSync(join(dirPath, file), "utf-8"));
36
+ if (v.overallVerdict !== undefined && v.findings !== undefined) {
37
+ verdicts.push(v);
38
+ }
39
+ }
40
+ catch {
41
+ // skip
42
+ }
43
+ }
44
+ if (verdicts.length === 0) {
45
+ console.log("No review files found. Generate reviews first.");
46
+ return;
47
+ }
48
+ const ruleCounts = {};
49
+ const severityCounts = {};
50
+ const dateCounts = {};
51
+ let scoreSum = 0;
52
+ let passCount = 0;
53
+ for (const v of verdicts) {
54
+ scoreSum += v.overallScore;
55
+ if (v.overallVerdict === "pass")
56
+ passCount++;
57
+ const date = v.timestamp ? v.timestamp.split("T")[0] : "unknown";
58
+ dateCounts[date] = (dateCounts[date] ?? 0) + 1;
59
+ for (const f of v.findings) {
60
+ ruleCounts[f.ruleId] = (ruleCounts[f.ruleId] ?? 0) + 1;
61
+ severityCounts[f.severity] = (severityCounts[f.severity] ?? 0) + 1;
62
+ }
63
+ }
64
+ const metrics = {
65
+ totalReviews: verdicts.length,
66
+ totalFindings: verdicts.reduce((s, v) => s + v.findings.length, 0),
67
+ avgScore: Math.round((scoreSum / verdicts.length) * 100) / 100,
68
+ passRate: Math.round((passCount / verdicts.length) * 100),
69
+ topIssues: Object.entries(ruleCounts)
70
+ .sort((a, b) => b[1] - a[1])
71
+ .slice(0, 10)
72
+ .map(([ruleId, count]) => ({ ruleId, count })),
73
+ severityTrend: severityCounts,
74
+ reviewsPerDay: dateCounts,
75
+ };
76
+ if (format === "json") {
77
+ console.log(JSON.stringify(metrics, null, 2));
78
+ return;
79
+ }
80
+ console.log(`\nTeam Review Dashboard`);
81
+ console.log("═".repeat(55));
82
+ console.log(` Reviews: ${metrics.totalReviews}`);
83
+ console.log(` Findings: ${metrics.totalFindings}`);
84
+ console.log(` Avg Score: ${metrics.avgScore}`);
85
+ console.log(` Pass Rate: ${metrics.passRate}%`);
86
+ console.log(`\n Severity Distribution:`);
87
+ for (const [sev, count] of Object.entries(metrics.severityTrend)) {
88
+ const bar = "█".repeat(Math.min(count, 30));
89
+ console.log(` ${sev.padEnd(10)} ${String(count).padStart(4)} ${bar}`);
90
+ }
91
+ if (metrics.topIssues.length > 0) {
92
+ console.log(`\n Top Issues:`);
93
+ for (const issue of metrics.topIssues) {
94
+ console.log(` ${issue.ruleId.padEnd(25)} ${issue.count}`);
95
+ }
96
+ }
97
+ console.log("═".repeat(55));
98
+ }
99
+ //# sourceMappingURL=review-team-dashboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-team-dashboard.js","sourceRoot":"","sources":["../../src/commands/review-team-dashboard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-template-library — Library of reusable review templates.
3
+ */
4
+ export declare function runReviewTemplateLibrary(argv: string[]): void;
5
+ //# sourceMappingURL=review-template-library.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-template-library.d.ts","sourceRoot":"","sources":["../../src/commands/review-template-library.ts"],"names":[],"mappings":"AAAA;;GAEG;AAiEH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAiH7D"}
@@ -0,0 +1,156 @@
1
+ /**
2
+ * Review-template-library — Library of reusable review templates.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync, readdirSync } from "fs";
5
+ import { join } from "path";
6
+ // ─── Built-in Templates ─────────────────────────────────────────────────────
7
+ function getBuiltinTemplates() {
8
+ return [
9
+ {
10
+ name: "ai-code-review",
11
+ description: "Optimized for reviewing AI-generated code",
12
+ preset: "strict",
13
+ minSeverity: "medium",
14
+ disabledRules: [],
15
+ tags: ["ai", "code-generation", "copilot"],
16
+ },
17
+ {
18
+ name: "security-audit",
19
+ description: "Deep security review with all severity levels",
20
+ preset: "security-focused",
21
+ minSeverity: "low",
22
+ disabledRules: [],
23
+ tags: ["security", "audit", "compliance"],
24
+ },
25
+ {
26
+ name: "quick-scan",
27
+ description: "Fast scan for critical issues only",
28
+ preset: "default",
29
+ minSeverity: "critical",
30
+ disabledRules: [],
31
+ tags: ["quick", "ci", "fast"],
32
+ },
33
+ {
34
+ name: "pr-review",
35
+ description: "Balanced review for pull requests",
36
+ preset: "default",
37
+ minSeverity: "medium",
38
+ disabledRules: [],
39
+ tags: ["pr", "pull-request", "review"],
40
+ },
41
+ {
42
+ name: "onboarding",
43
+ description: "Gentle review for new team members",
44
+ preset: "default",
45
+ minSeverity: "high",
46
+ disabledRules: [],
47
+ tags: ["onboarding", "learning", "gentle"],
48
+ },
49
+ ];
50
+ }
51
+ // ─── CLI ────────────────────────────────────────────────────────────────────
52
+ export function runReviewTemplateLibrary(argv) {
53
+ const dirIdx = argv.indexOf("--dir");
54
+ const nameIdx = argv.indexOf("--name");
55
+ const exportIdx = argv.indexOf("--export");
56
+ const importIdx = argv.indexOf("--import");
57
+ const tagIdx = argv.indexOf("--tag");
58
+ const formatIdx = argv.indexOf("--format");
59
+ const templateDir = dirIdx >= 0 ? argv[dirIdx + 1] : join(process.cwd(), ".judges-templates");
60
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
61
+ if (argv.includes("--help") || argv.includes("-h")) {
62
+ console.log(`
63
+ judges review-template-library — Reusable review templates
64
+
65
+ Usage:
66
+ judges review-template-library [--dir <path>] [--name <template>]
67
+ [--tag <tag>] [--export <file>]
68
+ [--import <file>] [--format table|json]
69
+
70
+ Options:
71
+ --dir <path> Template directory (default: .judges-templates/)
72
+ --name <template> Show or use specific template
73
+ --tag <tag> Filter by tag
74
+ --export <file> Export template to file
75
+ --import <file> Import template from file
76
+ --format <fmt> Output format: table (default), json
77
+ --help, -h Show this help
78
+ `);
79
+ return;
80
+ }
81
+ // Import a template
82
+ if (importIdx >= 0) {
83
+ const importPath = argv[importIdx + 1];
84
+ if (!existsSync(importPath)) {
85
+ console.error(`Error: file not found: ${importPath}`);
86
+ process.exitCode = 1;
87
+ return;
88
+ }
89
+ try {
90
+ const template = JSON.parse(readFileSync(importPath, "utf-8"));
91
+ const outPath = join(templateDir, `${template.name}.json`);
92
+ writeFileSync(outPath, JSON.stringify(template, null, 2));
93
+ console.log(`Imported template "${template.name}" to ${outPath}`);
94
+ }
95
+ catch {
96
+ console.error(`Error: failed to parse template file: ${importPath}`);
97
+ process.exitCode = 1;
98
+ }
99
+ return;
100
+ }
101
+ // Collect all templates (builtin + user)
102
+ let templates = getBuiltinTemplates();
103
+ if (existsSync(templateDir)) {
104
+ const files = readdirSync(templateDir);
105
+ for (const file of files) {
106
+ if (typeof file === "string" && file.endsWith(".json")) {
107
+ try {
108
+ const t = JSON.parse(readFileSync(join(templateDir, file), "utf-8"));
109
+ if (t.name !== undefined) {
110
+ templates = templates.filter((bt) => bt.name !== t.name);
111
+ templates.push(t);
112
+ }
113
+ }
114
+ catch {
115
+ // skip invalid
116
+ }
117
+ }
118
+ }
119
+ }
120
+ // Filter by tag
121
+ if (tagIdx >= 0) {
122
+ const tag = argv[tagIdx + 1];
123
+ templates = templates.filter((t) => t.tags.includes(tag));
124
+ }
125
+ // Show specific template
126
+ const templateName = nameIdx >= 0 ? argv[nameIdx + 1] : undefined;
127
+ if (templateName) {
128
+ const template = templates.find((t) => t.name === templateName);
129
+ if (!template) {
130
+ console.error(`Error: template not found: ${templateName}`);
131
+ process.exitCode = 1;
132
+ return;
133
+ }
134
+ if (exportIdx >= 0) {
135
+ const exportPath = argv[exportIdx + 1];
136
+ writeFileSync(exportPath, JSON.stringify(template, null, 2));
137
+ console.log(`Exported "${template.name}" to ${exportPath}`);
138
+ return;
139
+ }
140
+ console.log(JSON.stringify(template, null, 2));
141
+ return;
142
+ }
143
+ // List all templates
144
+ if (format === "json") {
145
+ console.log(JSON.stringify(templates, null, 2));
146
+ return;
147
+ }
148
+ console.log(`\nReview Template Library: ${templates.length} template(s)`);
149
+ console.log("═".repeat(65));
150
+ for (const t of templates) {
151
+ console.log(` ${t.name.padEnd(20)} ${t.description}`);
152
+ console.log(` ${"".padEnd(20)} preset: ${t.preset} minSeverity: ${t.minSeverity} tags: ${t.tags.join(", ")}`);
153
+ }
154
+ console.log("═".repeat(65));
155
+ }
156
+ //# sourceMappingURL=review-template-library.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-template-library.js","sourceRoot":"","sources":["../../src/commands/review-template-library.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-workspace-init — Initialize a workspace for Judges code review.
3
+ */
4
+ export declare function runReviewWorkspaceInit(argv: string[]): void;
5
+ //# sourceMappingURL=review-workspace-init.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-workspace-init.d.ts","sourceRoot":"","sources":["../../src/commands/review-workspace-init.ts"],"names":[],"mappings":"AAAA;;GAEG;AAuBH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA2F3D"}
@@ -0,0 +1,105 @@
1
+ /**
2
+ * Review-workspace-init — Initialize a workspace for Judges code review.
3
+ */
4
+ import { writeFileSync, mkdirSync, existsSync } from "fs";
5
+ import { join } from "path";
6
+ // ─── Default configs ────────────────────────────────────────────────────────
7
+ const DEFAULT_JUDGESRC = {
8
+ preset: "default",
9
+ disabledJudges: [],
10
+ disabledRules: [],
11
+ ruleOverrides: {},
12
+ minSeverity: "low",
13
+ };
14
+ const DEFAULT_BASELINE = {
15
+ version: 1,
16
+ baselinedAt: new Date().toISOString().split("T")[0],
17
+ findings: [],
18
+ };
19
+ // ─── CLI ────────────────────────────────────────────────────────────────────
20
+ export function runReviewWorkspaceInit(argv) {
21
+ const dirIdx = argv.indexOf("--dir");
22
+ const dir = dirIdx >= 0 ? argv[dirIdx + 1] : ".";
23
+ const force = argv.includes("--force");
24
+ const formatIdx = argv.indexOf("--format");
25
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
26
+ if (argv.includes("--help") || argv.includes("-h")) {
27
+ console.log(`
28
+ judges review-workspace-init — Initialize workspace for Judges
29
+
30
+ Usage:
31
+ judges review-workspace-init [--dir <path>] [--force] [--format table|json]
32
+
33
+ Options:
34
+ --dir <path> Workspace root (default: current directory)
35
+ --force Overwrite existing config files
36
+ --format <fmt> Output format: table (default), json
37
+ --help, -h Show this help
38
+
39
+ This creates:
40
+ .judgesrc — Judges configuration file
41
+ .judges-baseline.json — Baseline for existing findings
42
+ .judges/ — Local data directory
43
+ `);
44
+ return;
45
+ }
46
+ const created = [];
47
+ const skipped = [];
48
+ // 1. .judgesrc
49
+ const rcPath = join(dir, ".judgesrc");
50
+ if (!existsSync(rcPath) || force) {
51
+ writeFileSync(rcPath, JSON.stringify(DEFAULT_JUDGESRC, null, 2));
52
+ created.push(".judgesrc");
53
+ }
54
+ else {
55
+ skipped.push(".judgesrc (exists)");
56
+ }
57
+ // 2. .judges-baseline.json
58
+ const baselinePath = join(dir, ".judges-baseline.json");
59
+ if (!existsSync(baselinePath) || force) {
60
+ writeFileSync(baselinePath, JSON.stringify(DEFAULT_BASELINE, null, 2));
61
+ created.push(".judges-baseline.json");
62
+ }
63
+ else {
64
+ skipped.push(".judges-baseline.json (exists)");
65
+ }
66
+ // 3. .judges/ directory
67
+ const judgesDir = join(dir, ".judges");
68
+ if (!existsSync(judgesDir)) {
69
+ mkdirSync(judgesDir, { recursive: true });
70
+ created.push(".judges/");
71
+ }
72
+ else {
73
+ skipped.push(".judges/ (exists)");
74
+ }
75
+ // 4. .judges/cache directory
76
+ const cacheDir = join(judgesDir, "cache");
77
+ if (!existsSync(cacheDir)) {
78
+ mkdirSync(cacheDir, { recursive: true });
79
+ created.push(".judges/cache/");
80
+ }
81
+ else {
82
+ skipped.push(".judges/cache/ (exists)");
83
+ }
84
+ if (format === "json") {
85
+ console.log(JSON.stringify({ created, skipped }, null, 2));
86
+ return;
87
+ }
88
+ console.log(`\nWorkspace Initialization`);
89
+ console.log("═".repeat(50));
90
+ if (created.length > 0) {
91
+ console.log(`\n Created:`);
92
+ for (const c of created) {
93
+ console.log(` + ${c}`);
94
+ }
95
+ }
96
+ if (skipped.length > 0) {
97
+ console.log(`\n Skipped:`);
98
+ for (const s of skipped) {
99
+ console.log(` - ${s}`);
100
+ }
101
+ }
102
+ console.log(`\n Workspace ready at: ${dir === "." ? process.cwd() : dir}`);
103
+ console.log("═".repeat(50));
104
+ }
105
+ //# sourceMappingURL=review-workspace-init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-workspace-init.js","sourceRoot":"","sources":["../../src/commands/review-workspace-init.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.94.0",
3
+ "version": "3.96.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.94.0",
10
+ "version": "3.96.0",
11
11
  "packages": [
12
12
  {
13
13
  "registryType": "npm",
14
14
  "identifier": "@kevinrabun/judges",
15
- "version": "3.94.0",
15
+ "version": "3.96.0",
16
16
  "transport": {
17
17
  "type": "stdio"
18
18
  }