@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,96 @@
1
+ /**
2
+ * Review-merge-request — Format findings for merge/pull request comments.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── Formatting ─────────────────────────────────────────────────────────────
6
+ function toMarkdownComment(verdict) {
7
+ const lines = [];
8
+ lines.push(`## Judges Review Summary`);
9
+ lines.push(``);
10
+ lines.push(`**Verdict:** ${verdict.overallVerdict} | **Score:** ${verdict.overallScore} | **Findings:** ${verdict.findings.length}`);
11
+ lines.push(``);
12
+ if (verdict.criticalCount > 0 || verdict.highCount > 0) {
13
+ lines.push(`> ⚠️ ${verdict.criticalCount} critical, ${verdict.highCount} high severity finding(s)`);
14
+ lines.push(``);
15
+ }
16
+ const bySeverity = {};
17
+ for (const f of verdict.findings) {
18
+ if (bySeverity[f.severity] === undefined) {
19
+ bySeverity[f.severity] = [];
20
+ }
21
+ bySeverity[f.severity].push(f);
22
+ }
23
+ const order = ["critical", "high", "medium", "low", "info"];
24
+ for (const sev of order) {
25
+ const group = bySeverity[sev];
26
+ if (group === undefined || group.length === 0)
27
+ continue;
28
+ lines.push(`### ${sev.charAt(0).toUpperCase() + sev.slice(1)} (${group.length})`);
29
+ lines.push(``);
30
+ for (const f of group) {
31
+ const loc = f.lineNumbers !== undefined && f.lineNumbers.length > 0 ? ` (L${f.lineNumbers.join(",")})` : "";
32
+ lines.push(`- **${f.ruleId}**${loc}: ${f.title}`);
33
+ lines.push(` - ${f.recommendation}`);
34
+ }
35
+ lines.push(``);
36
+ }
37
+ lines.push(`---`);
38
+ lines.push(`*Generated by [Judges](https://github.com/KevinRabun/judges) at ${verdict.timestamp ?? new Date().toISOString()}*`);
39
+ return lines.join("\n");
40
+ }
41
+ // ─── CLI ────────────────────────────────────────────────────────────────────
42
+ export function runReviewMergeRequest(argv) {
43
+ const fileIdx = argv.indexOf("--file");
44
+ const outputIdx = argv.indexOf("--output");
45
+ const formatIdx = argv.indexOf("--format");
46
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
47
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
48
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "markdown";
49
+ if (argv.includes("--help") || argv.includes("-h")) {
50
+ console.log(`
51
+ judges review-merge-request — Format findings for MR/PR comments
52
+
53
+ Usage:
54
+ judges review-merge-request --file <review.json> [--output <file>]
55
+ [--format markdown|json]
56
+
57
+ Options:
58
+ --file <path> Review result JSON file
59
+ --output <path> Write formatted comment to file
60
+ --format <fmt> Output format: markdown (default), json
61
+ --help, -h Show this help
62
+ `);
63
+ return;
64
+ }
65
+ if (!filePath) {
66
+ console.error("Error: --file is required");
67
+ process.exitCode = 1;
68
+ return;
69
+ }
70
+ if (!existsSync(filePath)) {
71
+ console.error(`Error: file not found: ${filePath}`);
72
+ process.exitCode = 1;
73
+ return;
74
+ }
75
+ let verdict;
76
+ try {
77
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
78
+ }
79
+ catch {
80
+ console.error(`Error: failed to parse review file: ${filePath}`);
81
+ process.exitCode = 1;
82
+ return;
83
+ }
84
+ if (format === "json") {
85
+ console.log(JSON.stringify({ comment: toMarkdownComment(verdict) }, null, 2));
86
+ return;
87
+ }
88
+ const output = toMarkdownComment(verdict);
89
+ if (outputPath) {
90
+ writeFileSync(outputPath, output);
91
+ console.log(`MR comment written to ${outputPath}`);
92
+ return;
93
+ }
94
+ console.log(output);
95
+ }
96
+ //# sourceMappingURL=review-merge-request.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-merge-request.js","sourceRoot":"","sources":["../../src/commands/review-merge-request.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-notification-config — Configure notification preferences for review results.
3
+ */
4
+ export declare function runReviewNotificationConfig(argv: string[]): void;
5
+ //# sourceMappingURL=review-notification-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-notification-config.d.ts","sourceRoot":"","sources":["../../src/commands/review-notification-config.ts"],"names":[],"mappings":"AAAA;;GAEG;AAoBH,wBAAgB,2BAA2B,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA2HhE"}
@@ -0,0 +1,123 @@
1
+ /**
2
+ * Review-notification-config — Configure notification preferences for review results.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewNotificationConfig(argv) {
7
+ const fileIdx = argv.indexOf("--file");
8
+ const enableIdx = argv.indexOf("--enable");
9
+ const disableIdx = argv.indexOf("--disable");
10
+ const severityIdx = argv.indexOf("--severity");
11
+ const digestIdx = argv.indexOf("--digest");
12
+ const formatIdx = argv.indexOf("--format");
13
+ const configPath = fileIdx >= 0 ? argv[fileIdx + 1] : ".judges-notifications.json";
14
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
15
+ if (argv.includes("--help") || argv.includes("-h")) {
16
+ console.log(`
17
+ judges review-notification-config — Configure notification preferences
18
+
19
+ Usage:
20
+ judges review-notification-config [--file <config>] [--enable <channel>]
21
+ [--disable <channel>] [--severity <level>]
22
+ [--digest daily|weekly] [--format table|json]
23
+
24
+ Options:
25
+ --file <path> Config file (default: .judges-notifications.json)
26
+ --enable <channel> Enable: console, file, slack, email
27
+ --disable <channel> Disable a channel
28
+ --severity <level> Set min severity for notifications
29
+ --digest <freq> Enable digest: daily, weekly
30
+ --format <fmt> Output format: table (default), json
31
+ --help, -h Show this help
32
+ `);
33
+ return;
34
+ }
35
+ // Load or init config
36
+ let config;
37
+ if (existsSync(configPath)) {
38
+ config = JSON.parse(readFileSync(configPath, "utf-8"));
39
+ }
40
+ else {
41
+ config = {
42
+ channels: [
43
+ { type: "console", enabled: true, minSeverity: "medium" },
44
+ { type: "file", enabled: false, minSeverity: "low" },
45
+ { type: "slack", enabled: false, minSeverity: "high" },
46
+ { type: "email", enabled: false, minSeverity: "critical" },
47
+ ],
48
+ digest: false,
49
+ digestFrequency: "daily",
50
+ };
51
+ }
52
+ let changed = false;
53
+ // Enable channel
54
+ if (enableIdx >= 0) {
55
+ const channel = argv[enableIdx + 1];
56
+ const ch = config.channels.find((c) => c.type === channel);
57
+ if (ch) {
58
+ ch.enabled = true;
59
+ changed = true;
60
+ console.log(`Enabled ${channel} notifications.`);
61
+ }
62
+ else {
63
+ config.channels.push({ type: channel, enabled: true, minSeverity: "medium" });
64
+ changed = true;
65
+ console.log(`Added and enabled ${channel} notifications.`);
66
+ }
67
+ }
68
+ // Disable channel
69
+ if (disableIdx >= 0) {
70
+ const channel = argv[disableIdx + 1];
71
+ const ch = config.channels.find((c) => c.type === channel);
72
+ if (ch) {
73
+ ch.enabled = false;
74
+ changed = true;
75
+ console.log(`Disabled ${channel} notifications.`);
76
+ }
77
+ else {
78
+ console.error(`Channel not found: ${channel}`);
79
+ }
80
+ }
81
+ // Set severity
82
+ if (severityIdx >= 0) {
83
+ const sev = argv[severityIdx + 1];
84
+ for (const ch of config.channels) {
85
+ if (ch.enabled) {
86
+ ch.minSeverity = sev;
87
+ }
88
+ }
89
+ changed = true;
90
+ console.log(`Set min severity to ${sev} for enabled channels.`);
91
+ }
92
+ // Digest
93
+ if (digestIdx >= 0) {
94
+ const freq = argv[digestIdx + 1];
95
+ config.digest = true;
96
+ config.digestFrequency = freq;
97
+ changed = true;
98
+ console.log(`Enabled ${freq} digest.`);
99
+ }
100
+ if (changed) {
101
+ writeFileSync(configPath, JSON.stringify(config, null, 2));
102
+ console.log(`Config saved to ${configPath}`);
103
+ return;
104
+ }
105
+ // Display current config
106
+ if (format === "json") {
107
+ console.log(JSON.stringify(config, null, 2));
108
+ return;
109
+ }
110
+ console.log(`\nNotification Configuration`);
111
+ console.log("═".repeat(55));
112
+ console.log(` Digest: ${config.digest ? `enabled (${config.digestFrequency})` : "disabled"}`);
113
+ console.log(`\n Channels:`);
114
+ for (const ch of config.channels) {
115
+ const status = ch.enabled ? "ON " : "OFF";
116
+ console.log(` [${status}] ${ch.type.padEnd(10)} min: ${ch.minSeverity}`);
117
+ }
118
+ if (config.quietHours) {
119
+ console.log(`\n Quiet Hours: ${config.quietHours.start} – ${config.quietHours.end}`);
120
+ }
121
+ console.log("═".repeat(55));
122
+ }
123
+ //# sourceMappingURL=review-notification-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-notification-config.js","sourceRoot":"","sources":["../../src/commands/review-notification-config.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAgB7D,+EAA+E;AAE/E,MAAM,UAAU,2BAA2B,CAAC,IAAc;IACxD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IACvC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAC7C,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;IAC/C,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,MAAM,UAAU,GAAG,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,4BAA4B,CAAC;IACnF,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;;;;;;;;;;;;;;;;CAgBf,CAAC,CAAC;QACC,OAAO;IACT,CAAC;IAED,sBAAsB;IACtB,IAAI,MAA0B,CAAC;IAC/B,IAAI,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;QAC3B,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,UAAU,EAAE,OAAO,CAAC,CAAuB,CAAC;IAC/E,CAAC;SAAM,CAAC;QACN,MAAM,GAAG;YACP,QAAQ,EAAE;gBACR,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE;gBACzD,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE;gBACpD,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE;gBACtD,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE;aAC3D;YACD,MAAM,EAAE,KAAK;YACb,eAAe,EAAE,OAAO;SACzB,CAAC;IACJ,CAAC;IAED,IAAI,OAAO,GAAG,KAAK,CAAC;IAEpB,iBAAiB;IACjB,IAAI,SAAS,IAAI,CAAC,EAAE,CAAC;QACnB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;QACpC,MAAM,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC;QAC3D,IAAI,EAAE,EAAE,CAAC;YACP,EAAE,CAAC,OAAO,GAAG,IAAI,CAAC;YAClB,OAAO,GAAG,IAAI,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,WAAW,OAAO,iBAAiB,CAAC,CAAC;QACnD,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC,CAAC;YAC9E,OAAO,GAAG,IAAI,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,qBAAqB,OAAO,iBAAiB,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAED,kBAAkB;IAClB,IAAI,UAAU,IAAI,CAAC,EAAE,CAAC;QACpB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC;QACrC,MAAM,EAAE,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC;QAC3D,IAAI,EAAE,EAAE,CAAC;YACP,EAAE,CAAC,OAAO,GAAG,KAAK,CAAC;YACnB,OAAO,GAAG,IAAI,CAAC;YACf,OAAO,CAAC,GAAG,CAAC,YAAY,OAAO,iBAAiB,CAAC,CAAC;QACpD,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,sBAAsB,OAAO,EAAE,CAAC,CAAC;QACjD,CAAC;IACH,CAAC;IAED,eAAe;IACf,IAAI,WAAW,IAAI,CAAC,EAAE,CAAC;QACrB,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC;QAClC,KAAK,MAAM,EAAE,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YACjC,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC;gBACf,EAAE,CAAC,WAAW,GAAG,GAAG,CAAC;YACvB,CAAC;QACH,CAAC;QACD,OAAO,GAAG,IAAI,CAAC;QACf,OAAO,CAAC,GAAG,CAAC,uBAAuB,GAAG,wBAAwB,CAAC,CAAC;IAClE,CAAC;IAED,SAAS;IACT,IAAI,SAAS,IAAI,CAAC,EAAE,CAAC;QACnB,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;QACjC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC;QACrB,MAAM,CAAC,eAAe,GAAG,IAAI,CAAC;QAC9B,OAAO,GAAG,IAAI,CAAC;QACf,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,UAAU,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,OAAO,EAAE,CAAC;QACZ,aAAa,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3D,OAAO,CAAC,GAAG,CAAC,mBAAmB,UAAU,EAAE,CAAC,CAAC;QAC7C,OAAO;IACT,CAAC;IAED,yBAAyB;IACzB,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7C,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,8BAA8B,CAAC,CAAC;IAC5C,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,OAAO,CAAC,GAAG,CAAC,aAAa,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,MAAM,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC;IAC/F,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAC7B,KAAK,MAAM,EAAE,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QAC1C,OAAO,CAAC,GAAG,CAAC,QAAQ,MAAM,KAAK,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;IAC9E,CAAC;IACD,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,oBAAoB,MAAM,CAAC,UAAU,CAAC,KAAK,MAAM,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,CAAC,CAAC;IACxF,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAC9B,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-output-transform — Transform review output between formats.
3
+ */
4
+ export declare function runReviewOutputTransform(argv: string[]): void;
5
+ //# sourceMappingURL=review-output-transform.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-output-transform.d.ts","sourceRoot":"","sources":["../../src/commands/review-output-transform.ts"],"names":[],"mappings":"AAAA;;GAEG;AA2DH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyE7D"}
@@ -0,0 +1,120 @@
1
+ /**
2
+ * Review-output-transform — Transform review output between formats.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ // ─── Transformers ───────────────────────────────────────────────────────────
6
+ function toMarkdown(verdict) {
7
+ const lines = [];
8
+ lines.push(`# Review Report`);
9
+ lines.push(``);
10
+ lines.push(`- **Verdict:** ${verdict.overallVerdict}`);
11
+ lines.push(`- **Score:** ${verdict.overallScore}`);
12
+ lines.push(`- **Findings:** ${verdict.findings.length}`);
13
+ lines.push(``);
14
+ if (verdict.findings.length > 0) {
15
+ lines.push(`## Findings`);
16
+ lines.push(``);
17
+ lines.push(`| Severity | Rule | Title | Recommendation |`);
18
+ lines.push(`|----------|------|-------|----------------|`);
19
+ for (const f of verdict.findings) {
20
+ lines.push(`| ${f.severity} | ${f.ruleId} | ${f.title} | ${f.recommendation} |`);
21
+ }
22
+ }
23
+ return lines.join("\n");
24
+ }
25
+ function toCsv(verdict) {
26
+ const lines = [];
27
+ lines.push("ruleId,severity,title,description,recommendation,lineNumbers,confidence");
28
+ for (const f of verdict.findings) {
29
+ const ln = f.lineNumbers !== undefined ? f.lineNumbers.join(";") : "";
30
+ const conf = f.confidence !== undefined ? String(f.confidence) : "";
31
+ const desc = f.description.replace(/"/g, '""');
32
+ const title = f.title.replace(/"/g, '""');
33
+ const rec = f.recommendation.replace(/"/g, '""');
34
+ lines.push(`"${f.ruleId}","${f.severity}","${title}","${desc}","${rec}","${ln}","${conf}"`);
35
+ }
36
+ return lines.join("\n");
37
+ }
38
+ function toSummaryText(verdict) {
39
+ const lines = [];
40
+ lines.push(`Review Summary`);
41
+ lines.push(`==============`);
42
+ lines.push(`Verdict: ${verdict.overallVerdict} Score: ${verdict.overallScore}`);
43
+ lines.push(`Findings: ${verdict.findings.length} (${verdict.criticalCount} critical, ${verdict.highCount} high)`);
44
+ lines.push(``);
45
+ for (const f of verdict.findings) {
46
+ lines.push(`[${f.severity.toUpperCase()}] ${f.ruleId}: ${f.title}`);
47
+ lines.push(` → ${f.recommendation}`);
48
+ }
49
+ return lines.join("\n");
50
+ }
51
+ // ─── CLI ────────────────────────────────────────────────────────────────────
52
+ export function runReviewOutputTransform(argv) {
53
+ const fileIdx = argv.indexOf("--file");
54
+ const toIdx = argv.indexOf("--to");
55
+ const outputIdx = argv.indexOf("--output");
56
+ const filePath = fileIdx >= 0 ? argv[fileIdx + 1] : undefined;
57
+ const targetFormat = toIdx >= 0 ? argv[toIdx + 1] : "markdown";
58
+ const outputPath = outputIdx >= 0 ? argv[outputIdx + 1] : undefined;
59
+ if (argv.includes("--help") || argv.includes("-h")) {
60
+ console.log(`
61
+ judges review-output-transform — Transform output formats
62
+
63
+ Usage:
64
+ judges review-output-transform --file <review.json> --to <format>
65
+ [--output <file>]
66
+
67
+ Options:
68
+ --file <path> Review result JSON file
69
+ --to <format> Target: markdown, csv, text, json
70
+ --output <path> Write transformed output to file
71
+ --help, -h Show this help
72
+ `);
73
+ return;
74
+ }
75
+ if (!filePath) {
76
+ console.error("Error: --file is required");
77
+ process.exitCode = 1;
78
+ return;
79
+ }
80
+ if (!existsSync(filePath)) {
81
+ console.error(`Error: file not found: ${filePath}`);
82
+ process.exitCode = 1;
83
+ return;
84
+ }
85
+ let verdict;
86
+ try {
87
+ verdict = JSON.parse(readFileSync(filePath, "utf-8"));
88
+ }
89
+ catch {
90
+ console.error(`Error: failed to parse review file: ${filePath}`);
91
+ process.exitCode = 1;
92
+ return;
93
+ }
94
+ let output;
95
+ switch (targetFormat) {
96
+ case "markdown":
97
+ output = toMarkdown(verdict);
98
+ break;
99
+ case "csv":
100
+ output = toCsv(verdict);
101
+ break;
102
+ case "text":
103
+ output = toSummaryText(verdict);
104
+ break;
105
+ case "json":
106
+ output = JSON.stringify(verdict, null, 2);
107
+ break;
108
+ default:
109
+ console.error(`Error: unknown format: ${targetFormat}. Use markdown, csv, text, or json.`);
110
+ process.exitCode = 1;
111
+ return;
112
+ }
113
+ if (outputPath) {
114
+ writeFileSync(outputPath, output);
115
+ console.log(`Transformed to ${targetFormat}, written to ${outputPath}`);
116
+ return;
117
+ }
118
+ console.log(output);
119
+ }
120
+ //# sourceMappingURL=review-output-transform.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-output-transform.js","sourceRoot":"","sources":["../../src/commands/review-output-transform.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-scope-select — Select review scope by path patterns and exclusions.
3
+ */
4
+ export declare function runReviewScopeSelect(argv: string[]): void;
5
+ //# sourceMappingURL=review-scope-select.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-scope-select.d.ts","sourceRoot":"","sources":["../../src/commands/review-scope-select.ts"],"names":[],"mappings":"AAAA;;GAEG;AAoCH,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA4EzD"}
@@ -0,0 +1,99 @@
1
+ /**
2
+ * Review-scope-select — Select review scope by path patterns and exclusions.
3
+ */
4
+ import { existsSync, readdirSync, statSync } from "fs";
5
+ import { join, relative } from "path";
6
+ // ─── Helpers ────────────────────────────────────────────────────────────────
7
+ function collectFiles(dir, extensions) {
8
+ const results = [];
9
+ function walk(d) {
10
+ const entries = readdirSync(d);
11
+ for (const entry of entries) {
12
+ if (typeof entry !== "string")
13
+ continue;
14
+ const full = join(d, entry);
15
+ try {
16
+ const stat = statSync(full);
17
+ if (stat.isDirectory()) {
18
+ if (entry !== "node_modules" && entry !== ".git" && entry !== "dist") {
19
+ walk(full);
20
+ }
21
+ }
22
+ else if (extensions.some((ext) => entry.endsWith(ext))) {
23
+ results.push(full);
24
+ }
25
+ }
26
+ catch {
27
+ // skip inaccessible
28
+ }
29
+ }
30
+ }
31
+ walk(dir);
32
+ return results;
33
+ }
34
+ // ─── CLI ────────────────────────────────────────────────────────────────────
35
+ export function runReviewScopeSelect(argv) {
36
+ const dirIdx = argv.indexOf("--dir");
37
+ const extIdx = argv.indexOf("--ext");
38
+ const excludeIdx = argv.indexOf("--exclude");
39
+ const formatIdx = argv.indexOf("--format");
40
+ const limitIdx = argv.indexOf("--limit");
41
+ const projectDir = dirIdx >= 0 ? argv[dirIdx + 1] : process.cwd();
42
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
43
+ if (argv.includes("--help") || argv.includes("-h")) {
44
+ console.log(`
45
+ judges review-scope-select — Select review scope by path/extension
46
+
47
+ Usage:
48
+ judges review-scope-select [--dir <path>] [--ext .ts,.js,...]
49
+ [--exclude <pattern>] [--limit <n>]
50
+ [--format table|json]
51
+
52
+ Options:
53
+ --dir <path> Project directory (default: cwd)
54
+ --ext <extensions> Comma-separated file extensions (default: .ts,.js,.py,.java,.go)
55
+ --exclude <pattern> Exclude paths containing pattern
56
+ --limit <n> Maximum files to list
57
+ --format <fmt> Output format: table (default), json
58
+ --help, -h Show this help
59
+ `);
60
+ return;
61
+ }
62
+ if (!existsSync(projectDir)) {
63
+ console.error(`Error: directory not found: ${projectDir}`);
64
+ process.exitCode = 1;
65
+ return;
66
+ }
67
+ const extensions = extIdx >= 0 ? argv[extIdx + 1].split(",") : [".ts", ".js", ".py", ".java", ".go"];
68
+ const excludePattern = excludeIdx >= 0 ? argv[excludeIdx + 1] : undefined;
69
+ const limit = limitIdx >= 0 ? parseInt(argv[limitIdx + 1], 10) : undefined;
70
+ let files = collectFiles(projectDir, extensions);
71
+ if (excludePattern) {
72
+ files = files.filter((f) => !f.includes(excludePattern));
73
+ }
74
+ if (limit !== undefined && limit > 0) {
75
+ files = files.slice(0, limit);
76
+ }
77
+ const relativePaths = files.map((f) => relative(projectDir, f));
78
+ if (format === "json") {
79
+ console.log(JSON.stringify({ count: relativePaths.length, files: relativePaths }, null, 2));
80
+ return;
81
+ }
82
+ console.log(`\nReview Scope: ${relativePaths.length} file(s)`);
83
+ console.log("═".repeat(55));
84
+ const byExt = {};
85
+ for (const f of relativePaths) {
86
+ const ext = f.substring(f.lastIndexOf("."));
87
+ byExt[ext] = (byExt[ext] ?? 0) + 1;
88
+ }
89
+ console.log(" Extensions:");
90
+ for (const [ext, count] of Object.entries(byExt)) {
91
+ console.log(` ${ext.padEnd(8)} ${count} file(s)`);
92
+ }
93
+ console.log("\n Files:");
94
+ for (const f of relativePaths) {
95
+ console.log(` ${f}`);
96
+ }
97
+ console.log("═".repeat(55));
98
+ }
99
+ //# sourceMappingURL=review-scope-select.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-scope-select.js","sourceRoot":"","sources":["../../src/commands/review-scope-select.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-summary-dashboard — Aggregate review dashboard with key metrics.
3
+ */
4
+ export declare function runReviewSummaryDashboard(argv: string[]): void;
5
+ //# sourceMappingURL=review-summary-dashboard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-summary-dashboard.d.ts","sourceRoot":"","sources":["../../src/commands/review-summary-dashboard.ts"],"names":[],"mappings":"AAAA;;GAEG;AAmBH,wBAAgB,yBAAyB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAsG9D"}
@@ -0,0 +1,97 @@
1
+ /**
2
+ * Review-summary-dashboard — Aggregate review dashboard with key metrics.
3
+ */
4
+ import { readFileSync, existsSync, readdirSync } from "fs";
5
+ import { join } from "path";
6
+ // ─── CLI ────────────────────────────────────────────────────────────────────
7
+ export function runReviewSummaryDashboard(argv) {
8
+ const dirIdx = argv.indexOf("--dir");
9
+ const formatIdx = argv.indexOf("--format");
10
+ const reviewDir = 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-summary-dashboard — Aggregate review dashboard
15
+
16
+ Usage:
17
+ judges review-summary-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(reviewDir)) {
27
+ console.error(`Error: directory not found: ${reviewDir}`);
28
+ process.exitCode = 1;
29
+ return;
30
+ }
31
+ const files = readdirSync(reviewDir).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(reviewDir, file), "utf-8"));
36
+ if (v.overallVerdict !== undefined && v.findings !== undefined) {
37
+ verdicts.push(v);
38
+ }
39
+ }
40
+ catch {
41
+ // skip non-review files
42
+ }
43
+ }
44
+ if (verdicts.length === 0) {
45
+ console.log("No review files found. Run reviews and save as JSON first.");
46
+ return;
47
+ }
48
+ const dashboard = {
49
+ totalReviews: verdicts.length,
50
+ totalFindings: 0,
51
+ verdictBreakdown: {},
52
+ severityBreakdown: {},
53
+ averageScore: 0,
54
+ topRules: [],
55
+ };
56
+ let scoreSum = 0;
57
+ const ruleCounts = {};
58
+ for (const v of verdicts) {
59
+ scoreSum += v.overallScore;
60
+ dashboard.verdictBreakdown[v.overallVerdict] = (dashboard.verdictBreakdown[v.overallVerdict] ?? 0) + 1;
61
+ for (const f of v.findings) {
62
+ dashboard.totalFindings++;
63
+ dashboard.severityBreakdown[f.severity] = (dashboard.severityBreakdown[f.severity] ?? 0) + 1;
64
+ ruleCounts[f.ruleId] = (ruleCounts[f.ruleId] ?? 0) + 1;
65
+ }
66
+ }
67
+ dashboard.averageScore = Math.round((scoreSum / verdicts.length) * 100) / 100;
68
+ dashboard.topRules = Object.entries(ruleCounts)
69
+ .sort((a, b) => b[1] - a[1])
70
+ .slice(0, 10)
71
+ .map(([ruleId, count]) => ({ ruleId, count }));
72
+ if (format === "json") {
73
+ console.log(JSON.stringify(dashboard, null, 2));
74
+ return;
75
+ }
76
+ console.log(`\nReview Dashboard`);
77
+ console.log("═".repeat(55));
78
+ console.log(` Reviews: ${dashboard.totalReviews}`);
79
+ console.log(` Findings: ${dashboard.totalFindings}`);
80
+ console.log(` Avg Score: ${dashboard.averageScore}`);
81
+ console.log(`\n Verdict Breakdown:`);
82
+ for (const [v, c] of Object.entries(dashboard.verdictBreakdown)) {
83
+ console.log(` ${v.padEnd(12)} ${c}`);
84
+ }
85
+ console.log(`\n Severity Breakdown:`);
86
+ for (const [s, c] of Object.entries(dashboard.severityBreakdown)) {
87
+ console.log(` ${s.padEnd(12)} ${c}`);
88
+ }
89
+ if (dashboard.topRules.length > 0) {
90
+ console.log(`\n Top Rules:`);
91
+ for (const r of dashboard.topRules) {
92
+ console.log(` ${r.ruleId.padEnd(25)} ${r.count}`);
93
+ }
94
+ }
95
+ console.log("═".repeat(55));
96
+ }
97
+ //# sourceMappingURL=review-summary-dashboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-summary-dashboard.js","sourceRoot":"","sources":["../../src/commands/review-summary-dashboard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-team-dashboard — Team-level review dashboard with aggregated metrics.
3
+ */
4
+ export declare function runReviewTeamDashboard(argv: string[]): void;
5
+ //# sourceMappingURL=review-team-dashboard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-team-dashboard.d.ts","sourceRoot":"","sources":["../../src/commands/review-team-dashboard.ts"],"names":[],"mappings":"AAAA;;GAEG;AAoBH,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA0G3D"}