@kevinrabun/judges 3.99.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 (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-auto-triage.d.ts +5 -0
  6. package/dist/commands/finding-auto-triage.d.ts.map +1 -0
  7. package/dist/commands/finding-auto-triage.js +109 -0
  8. package/dist/commands/finding-auto-triage.js.map +1 -0
  9. package/dist/commands/finding-change-impact.d.ts +5 -0
  10. package/dist/commands/finding-change-impact.d.ts.map +1 -0
  11. package/dist/commands/finding-change-impact.js +108 -0
  12. package/dist/commands/finding-change-impact.js.map +1 -0
  13. package/dist/commands/finding-context-enrich.d.ts +5 -0
  14. package/dist/commands/finding-context-enrich.d.ts.map +1 -0
  15. package/dist/commands/finding-context-enrich.js +90 -0
  16. package/dist/commands/finding-context-enrich.js.map +1 -0
  17. package/dist/commands/finding-false-positive-learn.d.ts +5 -0
  18. package/dist/commands/finding-false-positive-learn.d.ts.map +1 -0
  19. package/dist/commands/finding-false-positive-learn.js +86 -0
  20. package/dist/commands/finding-false-positive-learn.js.map +1 -0
  21. package/dist/commands/review-deployment-gate.d.ts +5 -0
  22. package/dist/commands/review-deployment-gate.d.ts.map +1 -0
  23. package/dist/commands/review-deployment-gate.js +95 -0
  24. package/dist/commands/review-deployment-gate.js.map +1 -0
  25. package/dist/commands/review-environment-config.d.ts +5 -0
  26. package/dist/commands/review-environment-config.d.ts.map +1 -0
  27. package/dist/commands/review-environment-config.js +103 -0
  28. package/dist/commands/review-environment-config.js.map +1 -0
  29. package/dist/commands/review-multi-repo-sync.d.ts +5 -0
  30. package/dist/commands/review-multi-repo-sync.d.ts.map +1 -0
  31. package/dist/commands/review-multi-repo-sync.js +116 -0
  32. package/dist/commands/review-multi-repo-sync.js.map +1 -0
  33. package/dist/commands/review-session-replay.d.ts +5 -0
  34. package/dist/commands/review-session-replay.d.ts.map +1 -0
  35. package/dist/commands/review-session-replay.js +82 -0
  36. package/dist/commands/review-session-replay.js.map +1 -0
  37. package/dist/commands/review-stakeholder-report.d.ts +5 -0
  38. package/dist/commands/review-stakeholder-report.d.ts.map +1 -0
  39. package/dist/commands/review-stakeholder-report.js +76 -0
  40. package/dist/commands/review-stakeholder-report.js.map +1 -0
  41. package/package.json +1 -1
  42. package/server.json +2 -2
@@ -0,0 +1,103 @@
1
+ /**
2
+ * Review-environment-config — Manage per-environment review configurations.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewEnvironmentConfig(argv) {
7
+ const storeIdx = argv.indexOf("--store");
8
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-environments.json";
9
+ const formatIdx = argv.indexOf("--format");
10
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
11
+ const addIdx = argv.indexOf("--add");
12
+ const addName = addIdx >= 0 ? argv[addIdx + 1] : "";
13
+ const activateIdx = argv.indexOf("--activate");
14
+ const activateName = activateIdx >= 0 ? argv[activateIdx + 1] : "";
15
+ const initMode = argv.includes("--init");
16
+ if (argv.includes("--help") || argv.includes("-h")) {
17
+ console.log(`
18
+ judges review-environment-config — Manage per-environment review configs
19
+
20
+ Usage:
21
+ judges review-environment-config [--store <path>] [--format table|json]
22
+ judges review-environment-config --init [--store <path>]
23
+ judges review-environment-config --add <name> [--store <path>]
24
+ judges review-environment-config --activate <name> [--store <path>]
25
+
26
+ Options:
27
+ --store <path> Environment store file (default: .judges-environments.json)
28
+ --init Create default environment store
29
+ --add <name> Add a new environment
30
+ --activate <name> Set the active environment
31
+ --format <fmt> Output format: table (default), json
32
+ --help, -h Show this help
33
+ `);
34
+ return;
35
+ }
36
+ if (initMode) {
37
+ const defaultStore = {
38
+ environments: [
39
+ { name: "development", preset: "default", minSeverity: "info", disabledJudges: [], customRules: {} },
40
+ { name: "staging", preset: "strict", minSeverity: "medium", disabledJudges: [], customRules: {} },
41
+ { name: "production", preset: "strict", minSeverity: "high", disabledJudges: [], customRules: {} },
42
+ ],
43
+ activeEnvironment: "development",
44
+ lastUpdated: new Date().toISOString(),
45
+ };
46
+ writeFileSync(storePath, JSON.stringify(defaultStore, null, 2));
47
+ console.log(`Created default environment store: ${storePath}`);
48
+ return;
49
+ }
50
+ if (!existsSync(storePath)) {
51
+ console.log(`No environment store found at: ${storePath}`);
52
+ console.log("Run with --init to create one.");
53
+ return;
54
+ }
55
+ const store = JSON.parse(readFileSync(storePath, "utf-8"));
56
+ if (addName) {
57
+ const exists = store.environments.some((e) => e.name === addName);
58
+ if (exists) {
59
+ console.error(`Environment already exists: ${addName}`);
60
+ process.exitCode = 1;
61
+ return;
62
+ }
63
+ store.environments.push({
64
+ name: addName,
65
+ preset: "default",
66
+ minSeverity: "info",
67
+ disabledJudges: [],
68
+ customRules: {},
69
+ });
70
+ store.lastUpdated = new Date().toISOString();
71
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
72
+ console.log(`Added environment: ${addName}`);
73
+ return;
74
+ }
75
+ if (activateName) {
76
+ const exists = store.environments.some((e) => e.name === activateName);
77
+ if (!exists) {
78
+ console.error(`Environment not found: ${activateName}`);
79
+ process.exitCode = 1;
80
+ return;
81
+ }
82
+ store.activeEnvironment = activateName;
83
+ store.lastUpdated = new Date().toISOString();
84
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
85
+ console.log(`Activated environment: ${activateName}`);
86
+ return;
87
+ }
88
+ if (format === "json") {
89
+ console.log(JSON.stringify(store, null, 2));
90
+ return;
91
+ }
92
+ console.log("\nEnvironment Configurations");
93
+ console.log("═".repeat(70));
94
+ console.log(` ${"Name".padEnd(18)} ${"Preset".padEnd(12)} ${"Min Severity".padEnd(14)} ${"Disabled".padEnd(10)} Active`);
95
+ console.log(" " + "─".repeat(65));
96
+ for (const env of store.environments) {
97
+ const active = env.name === store.activeEnvironment ? " *" : "";
98
+ console.log(` ${env.name.padEnd(18)} ${env.preset.padEnd(12)} ${env.minSeverity.padEnd(14)} ${String(env.disabledJudges.length).padEnd(10)}${active}`);
99
+ }
100
+ console.log(`\n Active: ${store.activeEnvironment}`);
101
+ console.log("═".repeat(70));
102
+ }
103
+ //# sourceMappingURL=review-environment-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-environment-config.js","sourceRoot":"","sources":["../../src/commands/review-environment-config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-multi-repo-sync — Synchronize review configs across multiple repositories.
3
+ */
4
+ export declare function runReviewMultiRepoSync(argv: string[]): void;
5
+ //# sourceMappingURL=review-multi-repo-sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-multi-repo-sync.d.ts","sourceRoot":"","sources":["../../src/commands/review-multi-repo-sync.ts"],"names":[],"mappings":"AAAA;;GAEG;AAiCH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAiH3D"}
@@ -0,0 +1,116 @@
1
+ /**
2
+ * Review-multi-repo-sync — Synchronize review configs across multiple repositories.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── Helpers ────────────────────────────────────────────────────────────────
6
+ function simpleHash(content) {
7
+ let hash = 0;
8
+ for (let i = 0; i < content.length; i++) {
9
+ const ch = content.charCodeAt(i);
10
+ hash = ((hash << 5) - hash + ch) | 0;
11
+ }
12
+ return Math.abs(hash).toString(16).padStart(8, "0");
13
+ }
14
+ // ─── CLI ────────────────────────────────────────────────────────────────────
15
+ export function runReviewMultiRepoSync(argv) {
16
+ const storeIdx = argv.indexOf("--store");
17
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-multi-repo.json";
18
+ const formatIdx = argv.indexOf("--format");
19
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
20
+ const addIdx = argv.indexOf("--add");
21
+ const addPath = addIdx >= 0 ? argv[addIdx + 1] : "";
22
+ const checkMode = argv.includes("--check");
23
+ const initMode = argv.includes("--init");
24
+ if (argv.includes("--help") || argv.includes("-h")) {
25
+ console.log(`
26
+ judges review-multi-repo-sync — Sync review configs across repos
27
+
28
+ Usage:
29
+ judges review-multi-repo-sync [--store <path>] [--format table|json]
30
+ judges review-multi-repo-sync --init [--store <path>]
31
+ judges review-multi-repo-sync --add <repo-path> [--store <path>]
32
+ judges review-multi-repo-sync --check [--store <path>]
33
+
34
+ Options:
35
+ --store <path> Multi-repo store file (default: .judges-multi-repo.json)
36
+ --init Create default multi-repo store
37
+ --add <path> Add a repository by path
38
+ --check Check config drift across repos
39
+ --format <fmt> Output format: table (default), json
40
+ --help, -h Show this help
41
+ `);
42
+ return;
43
+ }
44
+ if (initMode) {
45
+ const defaultStore = {
46
+ repos: [],
47
+ sourceConfig: ".judgesrc",
48
+ lastUpdated: new Date().toISOString(),
49
+ };
50
+ writeFileSync(storePath, JSON.stringify(defaultStore, null, 2));
51
+ console.log(`Created multi-repo store: ${storePath}`);
52
+ return;
53
+ }
54
+ if (!existsSync(storePath)) {
55
+ console.log(`No multi-repo store found at: ${storePath}`);
56
+ console.log("Run with --init to create one.");
57
+ return;
58
+ }
59
+ const store = JSON.parse(readFileSync(storePath, "utf-8"));
60
+ if (addPath) {
61
+ const configFile = addPath.replace(/\/$/, "") + "/" + store.sourceConfig;
62
+ const hash = existsSync(configFile) ? simpleHash(readFileSync(configFile, "utf-8")) : "none";
63
+ const name = addPath.split("/").pop() ?? addPath;
64
+ store.repos.push({
65
+ name,
66
+ path: addPath,
67
+ configHash: hash,
68
+ lastSynced: new Date().toISOString(),
69
+ status: "unknown",
70
+ });
71
+ store.lastUpdated = new Date().toISOString();
72
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
73
+ console.log(`Added repository: ${name} (${addPath})`);
74
+ return;
75
+ }
76
+ if (checkMode) {
77
+ let driftCount = 0;
78
+ const sourceHash = store.repos.length > 0 ? store.repos[0].configHash : "";
79
+ for (const repo of store.repos) {
80
+ const configFile = repo.path.replace(/\/$/, "") + "/" + store.sourceConfig;
81
+ if (existsSync(configFile)) {
82
+ const currentHash = simpleHash(readFileSync(configFile, "utf-8"));
83
+ repo.configHash = currentHash;
84
+ repo.status = currentHash === sourceHash ? "synced" : "drift";
85
+ }
86
+ else {
87
+ repo.status = "drift";
88
+ }
89
+ if (repo.status === "drift")
90
+ driftCount++;
91
+ }
92
+ store.lastUpdated = new Date().toISOString();
93
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
94
+ console.log(`Checked ${store.repos.length} repos. Drift detected in ${driftCount}.`);
95
+ return;
96
+ }
97
+ if (format === "json") {
98
+ console.log(JSON.stringify(store, null, 2));
99
+ return;
100
+ }
101
+ console.log("\nMulti-Repo Sync Status");
102
+ console.log("═".repeat(70));
103
+ if (store.repos.length === 0) {
104
+ console.log(" No repositories registered. Use --add <path> to add one.");
105
+ }
106
+ else {
107
+ console.log(` ${"Name".padEnd(20)} ${"Status".padEnd(10)} ${"Hash".padEnd(12)} Last Synced`);
108
+ console.log(" " + "─".repeat(65));
109
+ for (const repo of store.repos) {
110
+ console.log(` ${repo.name.padEnd(20)} ${repo.status.padEnd(10)} ${repo.configHash.padEnd(12)} ${repo.lastSynced.slice(0, 10)}`);
111
+ }
112
+ }
113
+ console.log(`\n Source config: ${store.sourceConfig}`);
114
+ console.log("═".repeat(70));
115
+ }
116
+ //# sourceMappingURL=review-multi-repo-sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-multi-repo-sync.js","sourceRoot":"","sources":["../../src/commands/review-multi-repo-sync.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.99.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.99.0",
10
+ "version": "3.100.0",
11
11
  "packages": [
12
12
  {
13
13
  "registryType": "npm",
14
14
  "identifier": "@kevinrabun/judges",
15
- "version": "3.99.0",
15
+ "version": "3.100.0",
16
16
  "transport": {
17
17
  "type": "stdio"
18
18
  }