@kevinrabun/judges 3.89.0 → 3.91.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-tag.d.ts +5 -0
  6. package/dist/commands/finding-auto-tag.d.ts.map +1 -0
  7. package/dist/commands/finding-auto-tag.js +114 -0
  8. package/dist/commands/finding-auto-tag.js.map +1 -0
  9. package/dist/commands/finding-blast-radius.d.ts +5 -0
  10. package/dist/commands/finding-blast-radius.d.ts.map +1 -0
  11. package/dist/commands/finding-blast-radius.js +92 -0
  12. package/dist/commands/finding-blast-radius.js.map +1 -0
  13. package/dist/commands/finding-cluster-group.d.ts +5 -0
  14. package/dist/commands/finding-cluster-group.d.ts.map +1 -0
  15. package/dist/commands/finding-cluster-group.js +106 -0
  16. package/dist/commands/finding-cluster-group.js.map +1 -0
  17. package/dist/commands/finding-evidence-collect.d.ts +5 -0
  18. package/dist/commands/finding-evidence-collect.d.ts.map +1 -0
  19. package/dist/commands/finding-evidence-collect.js +115 -0
  20. package/dist/commands/finding-evidence-collect.js.map +1 -0
  21. package/dist/commands/finding-hotspot-map.d.ts +5 -0
  22. package/dist/commands/finding-hotspot-map.d.ts.map +1 -0
  23. package/dist/commands/finding-hotspot-map.js +107 -0
  24. package/dist/commands/finding-hotspot-map.js.map +1 -0
  25. package/dist/commands/finding-metadata-enrich.d.ts +5 -0
  26. package/dist/commands/finding-metadata-enrich.d.ts.map +1 -0
  27. package/dist/commands/finding-metadata-enrich.js +93 -0
  28. package/dist/commands/finding-metadata-enrich.js.map +1 -0
  29. package/dist/commands/finding-resolution-tracker.d.ts +5 -0
  30. package/dist/commands/finding-resolution-tracker.d.ts.map +1 -0
  31. package/dist/commands/finding-resolution-tracker.js +164 -0
  32. package/dist/commands/finding-resolution-tracker.js.map +1 -0
  33. package/dist/commands/finding-trend-analysis.d.ts +5 -0
  34. package/dist/commands/finding-trend-analysis.d.ts.map +1 -0
  35. package/dist/commands/finding-trend-analysis.js +96 -0
  36. package/dist/commands/finding-trend-analysis.js.map +1 -0
  37. package/dist/commands/review-annotation-export.d.ts +5 -0
  38. package/dist/commands/review-annotation-export.d.ts.map +1 -0
  39. package/dist/commands/review-annotation-export.js +106 -0
  40. package/dist/commands/review-annotation-export.js.map +1 -0
  41. package/dist/commands/review-batch-mode.d.ts +5 -0
  42. package/dist/commands/review-batch-mode.d.ts.map +1 -0
  43. package/dist/commands/review-batch-mode.js +98 -0
  44. package/dist/commands/review-batch-mode.js.map +1 -0
  45. package/dist/commands/review-cache-warm.d.ts +5 -0
  46. package/dist/commands/review-cache-warm.d.ts.map +1 -0
  47. package/dist/commands/review-cache-warm.js +71 -0
  48. package/dist/commands/review-cache-warm.js.map +1 -0
  49. package/dist/commands/review-compliance-gate.d.ts +5 -0
  50. package/dist/commands/review-compliance-gate.d.ts.map +1 -0
  51. package/dist/commands/review-compliance-gate.js +152 -0
  52. package/dist/commands/review-compliance-gate.js.map +1 -0
  53. package/dist/commands/review-merge-config.d.ts +5 -0
  54. package/dist/commands/review-merge-config.d.ts.map +1 -0
  55. package/dist/commands/review-merge-config.js +120 -0
  56. package/dist/commands/review-merge-config.js.map +1 -0
  57. package/dist/commands/review-onboard-wizard.d.ts +5 -0
  58. package/dist/commands/review-onboard-wizard.d.ts.map +1 -0
  59. package/dist/commands/review-onboard-wizard.js +93 -0
  60. package/dist/commands/review-onboard-wizard.js.map +1 -0
  61. package/dist/commands/review-parallel-run.d.ts +5 -0
  62. package/dist/commands/review-parallel-run.d.ts.map +1 -0
  63. package/dist/commands/review-parallel-run.js +117 -0
  64. package/dist/commands/review-parallel-run.js.map +1 -0
  65. package/dist/commands/review-quality-score.d.ts +5 -0
  66. package/dist/commands/review-quality-score.d.ts.map +1 -0
  67. package/dist/commands/review-quality-score.js +128 -0
  68. package/dist/commands/review-quality-score.js.map +1 -0
  69. package/dist/commands/review-threshold-tune.d.ts +5 -0
  70. package/dist/commands/review-threshold-tune.d.ts.map +1 -0
  71. package/dist/commands/review-threshold-tune.js +136 -0
  72. package/dist/commands/review-threshold-tune.js.map +1 -0
  73. package/dist/commands/review-webhook-notify.d.ts +5 -0
  74. package/dist/commands/review-webhook-notify.d.ts.map +1 -0
  75. package/dist/commands/review-webhook-notify.js +146 -0
  76. package/dist/commands/review-webhook-notify.js.map +1 -0
  77. package/package.json +1 -1
  78. package/server.json +2 -2
@@ -0,0 +1,117 @@
1
+ /**
2
+ * Review-parallel-run — Configure and summarize parallel review runs.
3
+ */
4
+ import { readFileSync, existsSync, readdirSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function summarizeParallel(verdicts) {
7
+ const totalRuns = verdicts.length;
8
+ const scores = verdicts.map((v) => v.overallScore);
9
+ const avgScore = Math.round(scores.reduce((a, b) => a + b, 0) / totalRuns);
10
+ // variance
11
+ const variance = scores.reduce((sum, s) => sum + Math.pow(s - avgScore, 2), 0) / totalRuns;
12
+ const scoreVariance = Math.round(Math.sqrt(variance) * 10) / 10;
13
+ // verdict agreement
14
+ const verdictCounts = new Map();
15
+ for (const v of verdicts) {
16
+ verdictCounts.set(v.overallVerdict, (verdictCounts.get(v.overallVerdict) || 0) + 1);
17
+ }
18
+ const maxVerdictEntry = [...verdictCounts.entries()].sort((a, b) => b[1] - a[1])[0];
19
+ const consensusVerdict = maxVerdictEntry[0];
20
+ const verdictAgreement = Math.round((maxVerdictEntry[1] / totalRuns) * 100);
21
+ // finding consensus
22
+ const findingCounts = new Map();
23
+ for (const v of verdicts) {
24
+ const seen = new Set();
25
+ for (const f of v.findings) {
26
+ if (!seen.has(f.ruleId)) {
27
+ seen.add(f.ruleId);
28
+ const existing = findingCounts.get(f.ruleId);
29
+ if (existing) {
30
+ existing.count++;
31
+ }
32
+ else {
33
+ findingCounts.set(f.ruleId, { title: f.title, count: 1 });
34
+ }
35
+ }
36
+ }
37
+ }
38
+ const mergedFindings = [...findingCounts.entries()]
39
+ .map(([ruleId, data]) => ({
40
+ ruleId,
41
+ title: data.title,
42
+ agreedCount: data.count,
43
+ totalRuns,
44
+ }))
45
+ .sort((a, b) => b.agreedCount - a.agreedCount);
46
+ return { totalRuns, scores, avgScore, scoreVariance, consensusVerdict, verdictAgreement, mergedFindings };
47
+ }
48
+ // ─── CLI ────────────────────────────────────────────────────────────────────
49
+ export function runReviewParallelRun(argv) {
50
+ const dirIdx = argv.indexOf("--dir");
51
+ const formatIdx = argv.indexOf("--format");
52
+ const minAgreeIdx = argv.indexOf("--min-agree");
53
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : undefined;
54
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
55
+ const minAgree = minAgreeIdx >= 0 ? parseInt(argv[minAgreeIdx + 1], 10) : 1;
56
+ if (argv.includes("--help") || argv.includes("-h")) {
57
+ console.log(`
58
+ judges review-parallel-run — Summarize parallel review runs
59
+
60
+ Usage:
61
+ judges review-parallel-run --dir <verdicts-dir> [--min-agree <n>]
62
+ [--format table|json]
63
+
64
+ Options:
65
+ --dir <path> Directory of verdict JSON files (required)
66
+ --min-agree <n> Minimum agreement count to include finding (default: 1)
67
+ --format <fmt> Output format: table (default), json
68
+ --help, -h Show this help
69
+ `);
70
+ return;
71
+ }
72
+ if (!dirPath) {
73
+ console.error("Error: --dir required");
74
+ process.exitCode = 1;
75
+ return;
76
+ }
77
+ if (!existsSync(dirPath)) {
78
+ console.error(`Error: not found: ${dirPath}`);
79
+ process.exitCode = 1;
80
+ return;
81
+ }
82
+ const files = readdirSync(dirPath).filter((f) => f.endsWith(".json"));
83
+ const verdicts = [];
84
+ for (const file of files) {
85
+ try {
86
+ verdicts.push(JSON.parse(readFileSync(`${dirPath}/${file}`, "utf-8")));
87
+ }
88
+ catch {
89
+ // skip
90
+ }
91
+ }
92
+ if (verdicts.length === 0) {
93
+ console.error("Error: no valid verdict files found");
94
+ process.exitCode = 1;
95
+ return;
96
+ }
97
+ const summary = summarizeParallel(verdicts);
98
+ const filtered = summary.mergedFindings.filter((f) => f.agreedCount >= minAgree);
99
+ if (format === "json") {
100
+ console.log(JSON.stringify({ ...summary, mergedFindings: filtered }, null, 2));
101
+ return;
102
+ }
103
+ console.log(`\nParallel Run Summary (${summary.totalRuns} runs)`);
104
+ console.log("═".repeat(70));
105
+ console.log(` Avg Score: ${summary.avgScore} | Variance: ${summary.scoreVariance}`);
106
+ console.log(` Consensus: ${summary.consensusVerdict} (${summary.verdictAgreement}% agreement)`);
107
+ console.log("─".repeat(70));
108
+ console.log(`${"Rule".padEnd(22)} ${"Agreement".padEnd(14)} Title`);
109
+ console.log("─".repeat(70));
110
+ for (const f of filtered.slice(0, 20)) {
111
+ const rule = f.ruleId.length > 20 ? f.ruleId.slice(0, 20) + "…" : f.ruleId;
112
+ const title = f.title.length > 30 ? f.title.slice(0, 30) + "…" : f.title;
113
+ console.log(`${rule.padEnd(22)} ${f.agreedCount}/${f.totalRuns}${" ".repeat(10)} ${title}`);
114
+ }
115
+ console.log("═".repeat(70));
116
+ }
117
+ //# sourceMappingURL=review-parallel-run.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-parallel-run.js","sourceRoot":"","sources":["../../src/commands/review-parallel-run.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-quality-score — Compute a quality score from multiple dimensions.
3
+ */
4
+ export declare function runReviewQualityScore(argv: string[]): void;
5
+ //# sourceMappingURL=review-quality-score.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-quality-score.d.ts","sourceRoot":"","sources":["../../src/commands/review-quality-score.ts"],"names":[],"mappings":"AAAA;;GAEG;AA0GH,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyD1D"}
@@ -0,0 +1,128 @@
1
+ /**
2
+ * Review-quality-score — Compute a quality score from multiple dimensions.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function computeQuality(verdict) {
7
+ const dimensions = [];
8
+ // Security dimension
9
+ const secFindings = verdict.findings.filter((f) => {
10
+ const combined = `${f.ruleId} ${f.title}`.toLowerCase();
11
+ return (combined.includes("auth") ||
12
+ combined.includes("inject") ||
13
+ combined.includes("xss") ||
14
+ combined.includes("crypt") ||
15
+ combined.includes("vuln") ||
16
+ combined.includes("secret"));
17
+ });
18
+ const secScore = secFindings.length === 0 ? 100 : Math.max(0, 100 - secFindings.length * 15);
19
+ dimensions.push({
20
+ name: "Security",
21
+ score: secScore,
22
+ weight: 3,
23
+ detail: `${secFindings.length} security findings`,
24
+ });
25
+ // Reliability dimension
26
+ const relScore = Math.max(0, 100 - verdict.criticalCount * 25 - verdict.highCount * 10);
27
+ dimensions.push({
28
+ name: "Reliability",
29
+ score: relScore,
30
+ weight: 2,
31
+ detail: `${verdict.criticalCount} critical, ${verdict.highCount} high`,
32
+ });
33
+ // Maintainability dimension
34
+ const totalFindings = verdict.findings.length;
35
+ const maintScore = totalFindings === 0 ? 100 : Math.max(0, 100 - totalFindings * 3);
36
+ dimensions.push({
37
+ name: "Maintainability",
38
+ score: maintScore,
39
+ weight: 2,
40
+ detail: `${totalFindings} total findings`,
41
+ });
42
+ // Judge coverage dimension
43
+ const uniqueJudges = new Set(verdict.evaluations.map((e) => e.judgeId));
44
+ const coverageScore = Math.min(100, uniqueJudges.size * 15);
45
+ dimensions.push({
46
+ name: "Coverage",
47
+ score: coverageScore,
48
+ weight: 1,
49
+ detail: `${uniqueJudges.size} unique judges`,
50
+ });
51
+ // Verdict confidence dimension
52
+ const avgEvalScore = verdict.evaluations.length > 0
53
+ ? verdict.evaluations.reduce((s, e) => s + e.score, 0) / verdict.evaluations.length
54
+ : 50;
55
+ dimensions.push({
56
+ name: "Confidence",
57
+ score: Math.round(avgEvalScore),
58
+ weight: 1,
59
+ detail: `avg eval score: ${Math.round(avgEvalScore)}`,
60
+ });
61
+ // weighted average
62
+ const totalWeight = dimensions.reduce((s, d) => s + d.weight, 0);
63
+ const overallQuality = Math.round(dimensions.reduce((s, d) => s + d.score * d.weight, 0) / totalWeight);
64
+ const grade = overallQuality >= 90
65
+ ? "A"
66
+ : overallQuality >= 80
67
+ ? "B"
68
+ : overallQuality >= 70
69
+ ? "C"
70
+ : overallQuality >= 60
71
+ ? "D"
72
+ : "F";
73
+ return { overallQuality, grade, dimensions };
74
+ }
75
+ // ─── CLI ────────────────────────────────────────────────────────────────────
76
+ export function runReviewQualityScore(argv) {
77
+ const fileIdx = argv.indexOf("--file");
78
+ const formatIdx = argv.indexOf("--format");
79
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
80
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
81
+ if (argv.includes("--help") || argv.includes("-h")) {
82
+ console.log(`
83
+ judges review-quality-score — Compute multi-dimension quality score
84
+
85
+ Usage:
86
+ judges review-quality-score --file <verdict.json> [--format table|json]
87
+
88
+ Options:
89
+ --file <path> Path to verdict JSON file (required)
90
+ --format <fmt> Output format: table (default), json
91
+ --help, -h Show this help
92
+ `);
93
+ return;
94
+ }
95
+ if (!filePath) {
96
+ console.error("Error: --file required");
97
+ process.exitCode = 1;
98
+ return;
99
+ }
100
+ if (!existsSync(filePath)) {
101
+ console.error(`Error: not found: ${filePath}`);
102
+ process.exitCode = 1;
103
+ return;
104
+ }
105
+ let verdict;
106
+ try {
107
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
108
+ }
109
+ catch {
110
+ console.error("Error: invalid JSON");
111
+ process.exitCode = 1;
112
+ return;
113
+ }
114
+ const report = computeQuality(verdict);
115
+ if (format === "json") {
116
+ console.log(JSON.stringify(report, null, 2));
117
+ return;
118
+ }
119
+ console.log(`\nQuality Score: ${report.overallQuality}/100 (Grade: ${report.grade})`);
120
+ console.log("═".repeat(60));
121
+ console.log(`${"Dimension".padEnd(18)} ${"Score".padEnd(8)} ${"Weight".padEnd(8)} Detail`);
122
+ console.log("─".repeat(60));
123
+ for (const d of report.dimensions) {
124
+ console.log(`${d.name.padEnd(18)} ${String(d.score).padEnd(8)} ×${String(d.weight).padEnd(7)} ${d.detail}`);
125
+ }
126
+ console.log("═".repeat(60));
127
+ }
128
+ //# sourceMappingURL=review-quality-score.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-quality-score.js","sourceRoot":"","sources":["../../src/commands/review-quality-score.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-threshold-tune — Tune review thresholds for optimal signal-to-noise.
3
+ */
4
+ export declare function runReviewThresholdTune(argv: string[]): void;
5
+ //# sourceMappingURL=review-threshold-tune.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-threshold-tune.d.ts","sourceRoot":"","sources":["../../src/commands/review-threshold-tune.ts"],"names":[],"mappings":"AAAA;;GAEG;AAuFH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyE3D"}
@@ -0,0 +1,136 @@
1
+ /**
2
+ * Review-threshold-tune — Tune review thresholds for optimal signal-to-noise.
3
+ */
4
+ import { readFileSync, existsSync, readdirSync } from "fs";
5
+ // ─── Analysis ───────────────────────────────────────────────────────────────
6
+ function analyzeThresholds(verdicts) {
7
+ if (verdicts.length === 0)
8
+ return [];
9
+ const scores = verdicts.map((v) => v.overallScore);
10
+ const findingCounts = verdicts.map((v) => v.findings.length);
11
+ const criticals = verdicts.map((v) => v.criticalCount);
12
+ const avgScore = Math.round(scores.reduce((a, b) => a + b, 0) / scores.length);
13
+ const maxCritical = Math.max(...criticals);
14
+ const passRate = Math.round((verdicts.filter((v) => v.overallVerdict === "pass").length / verdicts.length) * 100);
15
+ const suggestions = [];
16
+ // score threshold
17
+ const p25Score = scores.sort((a, b) => a - b)[Math.floor(scores.length * 0.25)];
18
+ if (passRate < 30) {
19
+ suggestions.push({
20
+ metric: "min-score",
21
+ currentValue: 70,
22
+ suggestedValue: Math.max(30, p25Score - 5),
23
+ rationale: `Pass rate is ${passRate}%. Lowering threshold to increase adoption.`,
24
+ });
25
+ }
26
+ else if (passRate > 90) {
27
+ suggestions.push({
28
+ metric: "min-score",
29
+ currentValue: 70,
30
+ suggestedValue: Math.min(90, avgScore - 10),
31
+ rationale: `Pass rate is ${passRate}%. Raising threshold for higher quality.`,
32
+ });
33
+ }
34
+ // finding count threshold
35
+ const avgFindingsActual = Math.round(findingCounts.reduce((a, b) => a + b, 0) / findingCounts.length);
36
+ if (avgFindingsActual > 30) {
37
+ suggestions.push({
38
+ metric: "max-findings",
39
+ currentValue: 50,
40
+ suggestedValue: avgFindingsActual + 10,
41
+ rationale: `Average findings: ${avgFindingsActual}. Adjusting max to reduce noise.`,
42
+ });
43
+ }
44
+ // critical threshold
45
+ if (maxCritical > 5) {
46
+ suggestions.push({
47
+ metric: "max-critical",
48
+ currentValue: 0,
49
+ suggestedValue: 2,
50
+ rationale: `Max critical: ${maxCritical}. Allowing some criticals for gradual adoption.`,
51
+ });
52
+ }
53
+ // severity filter suggestion
54
+ const lowFindings = verdicts.reduce((sum, v) => sum + v.findings.filter((f) => (f.severity || "medium").toLowerCase() === "low").length, 0);
55
+ if (lowFindings > verdicts.length * 5) {
56
+ suggestions.push({
57
+ metric: "min-severity",
58
+ currentValue: 0,
59
+ suggestedValue: 1,
60
+ rationale: `${lowFindings} low-severity findings across ${verdicts.length} reports. Consider filtering.`,
61
+ });
62
+ }
63
+ return suggestions;
64
+ }
65
+ // ─── CLI ────────────────────────────────────────────────────────────────────
66
+ export function runReviewThresholdTune(argv) {
67
+ const dirIdx = argv.indexOf("--dir");
68
+ const fileIdx = argv.indexOf("--file");
69
+ const formatIdx = argv.indexOf("--format");
70
+ const dirPath = dirIdx >= 0 ? argv[dirIdx + 1] : undefined;
71
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
72
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
73
+ if (argv.includes("--help") || argv.includes("-h")) {
74
+ console.log(`
75
+ judges review-threshold-tune — Tune review thresholds
76
+
77
+ Usage:
78
+ judges review-threshold-tune --dir <verdicts-dir> [--format table|json]
79
+ judges review-threshold-tune --file <verdict.json> [--format table|json]
80
+
81
+ Options:
82
+ --dir <path> Directory of verdict JSON files
83
+ --file <path> Single verdict JSON file
84
+ --format <fmt> Output format: table (default), json
85
+ --help, -h Show this help
86
+ `);
87
+ return;
88
+ }
89
+ const verdicts = [];
90
+ if (dirPath && existsSync(dirPath)) {
91
+ const files = readdirSync(dirPath).filter((f) => f.endsWith(".json"));
92
+ for (const file of files) {
93
+ try {
94
+ verdicts.push(JSON.parse(readFileSync(`${dirPath}/${file}`, "utf-8")));
95
+ }
96
+ catch {
97
+ // skip
98
+ }
99
+ }
100
+ }
101
+ else if (filePath && existsSync(filePath)) {
102
+ try {
103
+ verdicts.push(JSON.parse(readFileSync(filePath, "utf-8")));
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 suggestions = analyzeThresholds(verdicts);
117
+ if (format === "json") {
118
+ console.log(JSON.stringify(suggestions, null, 2));
119
+ return;
120
+ }
121
+ console.log(`\nThreshold Tuning Suggestions (${verdicts.length} reports analyzed)`);
122
+ console.log("═".repeat(70));
123
+ if (suggestions.length === 0) {
124
+ console.log(" No threshold adjustments needed. Current settings look good.");
125
+ }
126
+ else {
127
+ console.log(`${"Metric".padEnd(18)} ${"Current".padEnd(10)} ${"Suggested".padEnd(12)} Rationale`);
128
+ console.log("─".repeat(70));
129
+ for (const s of suggestions) {
130
+ const rationale = s.rationale.length > 35 ? s.rationale.slice(0, 35) + "…" : s.rationale;
131
+ console.log(`${s.metric.padEnd(18)} ${String(s.currentValue).padEnd(10)} ${String(s.suggestedValue).padEnd(12)} ${rationale}`);
132
+ }
133
+ }
134
+ console.log("═".repeat(70));
135
+ }
136
+ //# sourceMappingURL=review-threshold-tune.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-threshold-tune.js","sourceRoot":"","sources":["../../src/commands/review-threshold-tune.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-webhook-notify — Configure and test webhook notifications for reviews.
3
+ */
4
+ export declare function runReviewWebhookNotify(argv: string[]): void;
5
+ //# sourceMappingURL=review-webhook-notify.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-webhook-notify.d.ts","sourceRoot":"","sources":["../../src/commands/review-webhook-notify.ts"],"names":[],"mappings":"AAAA;;GAEG;AAoEH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAmH3D"}
@@ -0,0 +1,146 @@
1
+ /**
2
+ * Review-webhook-notify — Configure and test webhook notifications for reviews.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync, mkdirSync } from "fs";
5
+ import { dirname } from "path";
6
+ // ─── Helpers ────────────────────────────────────────────────────────────────
7
+ function loadConfig(configPath) {
8
+ if (!existsSync(configPath)) {
9
+ return { version: 1, webhooks: [] };
10
+ }
11
+ try {
12
+ return JSON.parse(readFileSync(configPath, "utf-8"));
13
+ }
14
+ catch {
15
+ return { version: 1, webhooks: [] };
16
+ }
17
+ }
18
+ function saveConfig(configPath, config) {
19
+ const dir = dirname(configPath);
20
+ if (!existsSync(dir)) {
21
+ mkdirSync(dir, { recursive: true });
22
+ }
23
+ writeFileSync(configPath, JSON.stringify(config, null, 2));
24
+ }
25
+ function buildPayload(verdict, event) {
26
+ return {
27
+ event,
28
+ timestamp: verdict.timestamp || new Date().toISOString(),
29
+ summary: {
30
+ score: verdict.overallScore,
31
+ verdict: verdict.overallVerdict,
32
+ findingCount: verdict.findings.length,
33
+ criticalCount: verdict.criticalCount,
34
+ },
35
+ };
36
+ }
37
+ // ─── CLI ────────────────────────────────────────────────────────────────────
38
+ export function runReviewWebhookNotify(argv) {
39
+ const actionIdx = argv.indexOf("--action");
40
+ const configIdx = argv.indexOf("--config");
41
+ const fileIdx = argv.indexOf("--file");
42
+ const nameIdx = argv.indexOf("--name");
43
+ const urlIdx = argv.indexOf("--url");
44
+ const formatIdx = argv.indexOf("--format");
45
+ const action = actionIdx >= 0 ? argv[actionIdx + 1] : "list";
46
+ const configPath = configIdx >= 0 ? argv[configIdx + 1] : ".judges-webhooks.json";
47
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
48
+ const name = nameIdx >= 0 ? argv[nameIdx + 1] : undefined;
49
+ const url = urlIdx >= 0 ? argv[urlIdx + 1] : undefined;
50
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
51
+ if (argv.includes("--help") || argv.includes("-h")) {
52
+ console.log(`
53
+ judges review-webhook-notify — Configure webhook notifications
54
+
55
+ Usage:
56
+ judges review-webhook-notify --action <action> [options]
57
+
58
+ Actions:
59
+ list List configured webhooks (default)
60
+ add Add a webhook (requires --name and --url)
61
+ remove Remove a webhook (requires --name)
62
+ preview Preview payload for a verdict (requires --file)
63
+
64
+ Options:
65
+ --action <act> Action: list, add, remove, preview
66
+ --config <path> Config file (default: .judges-webhooks.json)
67
+ --file <path> Verdict JSON file (for preview)
68
+ --name <name> Webhook name
69
+ --url <url> Webhook URL (for add)
70
+ --format <fmt> Output format: table (default), json
71
+ --help, -h Show this help
72
+ `);
73
+ return;
74
+ }
75
+ const config = loadConfig(configPath);
76
+ if (action === "add") {
77
+ if (!name || !url) {
78
+ console.error("Error: --name and --url required for add");
79
+ process.exitCode = 1;
80
+ return;
81
+ }
82
+ config.webhooks.push({
83
+ id: `wh-${Date.now()}`,
84
+ name,
85
+ url,
86
+ events: ["review-complete", "critical-found"],
87
+ enabled: true,
88
+ });
89
+ saveConfig(configPath, config);
90
+ console.log(`Webhook added: ${name}`);
91
+ return;
92
+ }
93
+ if (action === "remove") {
94
+ if (!name) {
95
+ console.error("Error: --name required for remove");
96
+ process.exitCode = 1;
97
+ return;
98
+ }
99
+ const idx = config.webhooks.findIndex((w) => w.name === name);
100
+ if (idx < 0) {
101
+ console.error(`Error: webhook not found: ${name}`);
102
+ process.exitCode = 1;
103
+ return;
104
+ }
105
+ config.webhooks.splice(idx, 1);
106
+ saveConfig(configPath, config);
107
+ console.log(`Webhook removed: ${name}`);
108
+ return;
109
+ }
110
+ if (action === "preview") {
111
+ if (!filePath || !existsSync(filePath)) {
112
+ console.error("Error: --file required for preview");
113
+ process.exitCode = 1;
114
+ return;
115
+ }
116
+ let verdict;
117
+ try {
118
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
119
+ }
120
+ catch {
121
+ console.error("Error: invalid JSON");
122
+ process.exitCode = 1;
123
+ return;
124
+ }
125
+ const payload = buildPayload(verdict, "review-complete");
126
+ console.log(JSON.stringify(payload, null, 2));
127
+ return;
128
+ }
129
+ // list
130
+ if (format === "json") {
131
+ console.log(JSON.stringify(config, null, 2));
132
+ return;
133
+ }
134
+ console.log(`\nWebhook Notifications (${config.webhooks.length})`);
135
+ console.log("═".repeat(70));
136
+ console.log(`${"Name".padEnd(20)} ${"URL".padEnd(30)} ${"Events".padEnd(15)} Enabled`);
137
+ console.log("─".repeat(70));
138
+ for (const w of config.webhooks) {
139
+ const urlStr = w.url.length > 28 ? w.url.slice(0, 28) + "…" : w.url;
140
+ const events = w.events.join(",");
141
+ const evStr = events.length > 13 ? events.slice(0, 13) + "…" : events;
142
+ console.log(`${w.name.padEnd(20)} ${urlStr.padEnd(30)} ${evStr.padEnd(15)} ${w.enabled}`);
143
+ }
144
+ console.log("═".repeat(70));
145
+ }
146
+ //# sourceMappingURL=review-webhook-notify.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-webhook-notify.js","sourceRoot":"","sources":["../../src/commands/review-webhook-notify.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.89.0",
3
+ "version": "3.91.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.89.0",
10
+ "version": "3.91.0",
11
11
  "packages": [
12
12
  {
13
13
  "registryType": "npm",
14
14
  "identifier": "@kevinrabun/judges",
15
- "version": "3.89.0",
15
+ "version": "3.91.0",
16
16
  "transport": {
17
17
  "type": "stdio"
18
18
  }