@kevinrabun/judges 3.98.0 → 3.99.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-suppress.d.ts +5 -0
  6. package/dist/commands/finding-auto-suppress.d.ts.map +1 -0
  7. package/dist/commands/finding-auto-suppress.js +127 -0
  8. package/dist/commands/finding-auto-suppress.js.map +1 -0
  9. package/dist/commands/finding-dismiss-workflow.d.ts +5 -0
  10. package/dist/commands/finding-dismiss-workflow.d.ts.map +1 -0
  11. package/dist/commands/finding-dismiss-workflow.js +120 -0
  12. package/dist/commands/finding-dismiss-workflow.js.map +1 -0
  13. package/dist/commands/finding-reachability-check.d.ts +5 -0
  14. package/dist/commands/finding-reachability-check.d.ts.map +1 -0
  15. package/dist/commands/finding-reachability-check.js +103 -0
  16. package/dist/commands/finding-reachability-check.js.map +1 -0
  17. package/dist/commands/review-audit-export.d.ts +5 -0
  18. package/dist/commands/review-audit-export.d.ts.map +1 -0
  19. package/dist/commands/review-audit-export.js +94 -0
  20. package/dist/commands/review-audit-export.js.map +1 -0
  21. package/dist/commands/review-data-retention.d.ts +5 -0
  22. package/dist/commands/review-data-retention.d.ts.map +1 -0
  23. package/dist/commands/review-data-retention.js +120 -0
  24. package/dist/commands/review-data-retention.js.map +1 -0
  25. package/dist/commands/review-permission-model.d.ts +5 -0
  26. package/dist/commands/review-permission-model.d.ts.map +1 -0
  27. package/dist/commands/review-permission-model.js +150 -0
  28. package/dist/commands/review-permission-model.js.map +1 -0
  29. package/dist/commands/review-pipeline-status.d.ts +5 -0
  30. package/dist/commands/review-pipeline-status.d.ts.map +1 -0
  31. package/dist/commands/review-pipeline-status.js +55 -0
  32. package/dist/commands/review-pipeline-status.js.map +1 -0
  33. package/dist/commands/review-repo-onboard.d.ts +5 -0
  34. package/dist/commands/review-repo-onboard.d.ts.map +1 -0
  35. package/dist/commands/review-repo-onboard.js +115 -0
  36. package/dist/commands/review-repo-onboard.js.map +1 -0
  37. package/dist/commands/review-review-comments.d.ts +5 -0
  38. package/dist/commands/review-review-comments.d.ts.map +1 -0
  39. package/dist/commands/review-review-comments.js +85 -0
  40. package/dist/commands/review-review-comments.js.map +1 -0
  41. package/package.json +1 -1
  42. package/server.json +2 -2
@@ -0,0 +1,120 @@
1
+ /**
2
+ * Review-data-retention — Configure data retention policies for review data.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync, readdirSync, unlinkSync } from "fs";
5
+ import { join } from "path";
6
+ const DEFAULT_POLICIES = [
7
+ { dataType: "reports", retentionDays: 90, autoClean: false },
8
+ { dataType: "cache", retentionDays: 30, autoClean: true },
9
+ { dataType: "annotations", retentionDays: 365, autoClean: false },
10
+ { dataType: "dismissals", retentionDays: 180, autoClean: false },
11
+ ];
12
+ // ─── CLI ────────────────────────────────────────────────────────────────────
13
+ export function runReviewDataRetention(argv) {
14
+ const storeIdx = argv.indexOf("--store");
15
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-retention.json";
16
+ const formatIdx = argv.indexOf("--format");
17
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
18
+ if (argv.includes("--help") || argv.includes("-h")) {
19
+ console.log(`
20
+ judges review-data-retention — Configure data retention policies
21
+
22
+ Usage:
23
+ judges review-data-retention [--store <path>] [--init] [--set <json>]
24
+ [--clean <dir>] [--format table|json]
25
+
26
+ Options:
27
+ --store <path> Retention config file (default: .judges-retention.json)
28
+ --init Initialize with default retention policies
29
+ --set <json> Set retention policy (JSON)
30
+ --clean <dir> Run cleanup on directory based on retention policy
31
+ --format <fmt> Output format: table (default), json
32
+ --help, -h Show this help
33
+ `);
34
+ return;
35
+ }
36
+ // Init
37
+ if (argv.includes("--init")) {
38
+ const store = {
39
+ policies: DEFAULT_POLICIES,
40
+ lastUpdated: new Date().toISOString().split("T")[0],
41
+ };
42
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
43
+ console.log(`Retention policies initialized at: ${storePath}`);
44
+ return;
45
+ }
46
+ let store;
47
+ if (existsSync(storePath)) {
48
+ store = JSON.parse(readFileSync(storePath, "utf-8"));
49
+ }
50
+ else {
51
+ store = { policies: [], lastUpdated: new Date().toISOString().split("T")[0] };
52
+ }
53
+ // Set policy
54
+ const setIdx = argv.indexOf("--set");
55
+ if (setIdx >= 0) {
56
+ const policy = JSON.parse(argv[setIdx + 1]);
57
+ const existingIdx = store.policies.findIndex((p) => p.dataType === policy.dataType);
58
+ if (existingIdx >= 0) {
59
+ store.policies[existingIdx] = policy;
60
+ }
61
+ else {
62
+ store.policies.push(policy);
63
+ }
64
+ store.lastUpdated = new Date().toISOString().split("T")[0];
65
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
66
+ console.log(`Retention policy for "${policy.dataType}" saved.`);
67
+ return;
68
+ }
69
+ // Clean
70
+ const cleanIdx = argv.indexOf("--clean");
71
+ if (cleanIdx >= 0) {
72
+ const cleanDir = argv[cleanIdx + 1];
73
+ if (!existsSync(cleanDir)) {
74
+ console.log(`Directory not found: ${cleanDir}`);
75
+ return;
76
+ }
77
+ const files = readdirSync(cleanDir).filter((f) => f.endsWith(".json"));
78
+ const cutoffMs = 30 * 24 * 60 * 60 * 1000; // Default 30 days
79
+ const now = Date.now();
80
+ let cleaned = 0;
81
+ for (const file of files) {
82
+ const filePath = join(cleanDir, file);
83
+ try {
84
+ const content = JSON.parse(readFileSync(filePath, "utf-8"));
85
+ if (content.timestamp !== undefined) {
86
+ const fileTime = new Date(content.timestamp).getTime();
87
+ if (now - fileTime > cutoffMs) {
88
+ unlinkSync(filePath);
89
+ cleaned++;
90
+ }
91
+ }
92
+ }
93
+ catch {
94
+ // Skip files that can't be parsed
95
+ }
96
+ }
97
+ console.log(`Cleaned ${cleaned} file(s) from ${cleanDir}`);
98
+ return;
99
+ }
100
+ // Display
101
+ if (format === "json") {
102
+ console.log(JSON.stringify(store, null, 2));
103
+ return;
104
+ }
105
+ console.log(`\nData Retention Policies`);
106
+ console.log("═".repeat(55));
107
+ if (store.policies.length === 0) {
108
+ console.log(" No retention policies. Use --init for defaults.");
109
+ }
110
+ else {
111
+ console.log(` ${"Data Type".padEnd(15)} ${"Retention".padEnd(12)} Auto-clean`);
112
+ console.log(" " + "─".repeat(40));
113
+ for (const p of store.policies) {
114
+ const retention = p.retentionDays < 365 ? `${p.retentionDays}d` : `${Math.round(p.retentionDays / 365)}y`;
115
+ console.log(` ${p.dataType.padEnd(15)} ${retention.padEnd(12)} ${p.autoClean ? "Yes" : "No"}`);
116
+ }
117
+ }
118
+ console.log("═".repeat(55));
119
+ }
120
+ //# sourceMappingURL=review-data-retention.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-data-retention.js","sourceRoot":"","sources":["../../src/commands/review-data-retention.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,UAAU,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AACtF,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAe5B,MAAM,gBAAgB,GAAsB;IAC1C,EAAE,QAAQ,EAAE,SAAS,EAAE,aAAa,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;IAC5D,EAAE,QAAQ,EAAE,OAAO,EAAE,aAAa,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE;IACzD,EAAE,QAAQ,EAAE,aAAa,EAAE,aAAa,EAAE,GAAG,EAAE,SAAS,EAAE,KAAK,EAAE;IACjE,EAAE,QAAQ,EAAE,YAAY,EAAE,aAAa,EAAE,GAAG,EAAE,SAAS,EAAE,KAAK,EAAE;CACjE,CAAC;AAEF,+EAA+E;AAE/E,MAAM,UAAU,sBAAsB,CAAC,IAAc;IACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACzC,MAAM,SAAS,GAAG,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,wBAAwB,CAAC;IAChF,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3C,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;;;;;;;;;;;;;;CAcf,CAAC,CAAC;QACC,OAAO;IACT,CAAC;IAED,OAAO;IACP,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC5B,MAAM,KAAK,GAAmB;YAC5B,QAAQ,EAAE,gBAAgB;YAC1B,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;SACpD,CAAC;QACF,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACzD,OAAO,CAAC,GAAG,CAAC,sCAAsC,SAAS,EAAE,CAAC,CAAC;QAC/D,OAAO;IACT,CAAC;IAED,IAAI,KAAqB,CAAC;IAC1B,IAAI,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QAC1B,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAmB,CAAC;IACzE,CAAC;SAAM,CAAC;QACN,KAAK,GAAG,EAAE,QAAQ,EAAE,EAAE,EAAE,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAChF,CAAC;IAED,aAAa;IACb,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACrC,IAAI,MAAM,IAAI,CAAC,EAAE,CAAC;QAChB,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAoB,CAAC;QAC/D,MAAM,WAAW,GAAG,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC;QACpF,IAAI,WAAW,IAAI,CAAC,EAAE,CAAC;YACrB,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,GAAG,MAAM,CAAC;QACvC,CAAC;aAAM,CAAC;YACN,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,CAAC;QACD,KAAK,CAAC,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3D,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACzD,OAAO,CAAC,GAAG,CAAC,yBAAyB,MAAM,CAAC,QAAQ,UAAU,CAAC,CAAC;QAChE,OAAO;IACT,CAAC;IAED,QAAQ;IACR,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IACzC,IAAI,QAAQ,IAAI,CAAC,EAAE,CAAC;QAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;QACpC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1B,OAAO,CAAC,GAAG,CAAC,wBAAwB,QAAQ,EAAE,CAAC,CAAC;YAChD,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAI,WAAW,CAAC,QAAQ,CAAyB,CAAC,MAAM,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;QACxG,MAAM,QAAQ,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC,kBAAkB;QAC7D,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,OAAO,GAAG,CAAC,CAAC;QAEhB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;YACtC,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAA2B,CAAC;gBACtF,IAAI,OAAO,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;oBACpC,MAAM,QAAQ,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAAC;oBACvD,IAAI,GAAG,GAAG,QAAQ,GAAG,QAAQ,EAAE,CAAC;wBAC9B,UAAU,CAAC,QAAQ,CAAC,CAAC;wBACrB,OAAO,EAAE,CAAC;oBACZ,CAAC;gBACH,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,kCAAkC;YACpC,CAAC;QACH,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,WAAW,OAAO,iBAAiB,QAAQ,EAAE,CAAC,CAAC;QAC3D,OAAO;IACT,CAAC;IAED,UAAU;IACV,IAAI,MAAM,KAAK,MAAM,EAAE,CAAC;QACtB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5C,OAAO;IACT,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;IACzC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAE5B,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAChC,OAAO,CAAC,GAAG,CAAC,mDAAmD,CAAC,CAAC;IACnE,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,KAAK,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,WAAW,CAAC,MAAM,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC;QAChF,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAEnC,KAAK,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;YAC/B,MAAM,SAAS,GAAG,CAAC,CAAC,aAAa,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,GAAG,GAAG,CAAC,GAAG,CAAC;YAC1G,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QAClG,CAAC;IACH,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAC9B,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-permission-model — Define role-based permissions for Judges features.
3
+ */
4
+ export declare function runReviewPermissionModel(argv: string[]): void;
5
+ //# sourceMappingURL=review-permission-model.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-permission-model.d.ts","sourceRoot":"","sources":["../../src/commands/review-permission-model.ts"],"names":[],"mappings":"AAAA;;GAEG;AAwDH,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAmH7D"}
@@ -0,0 +1,150 @@
1
+ /**
2
+ * Review-permission-model — Define role-based permissions for Judges features.
3
+ */
4
+ import { readFileSync, writeFileSync, existsSync } from "fs";
5
+ const DEFAULT_ROLES = [
6
+ {
7
+ id: "viewer",
8
+ name: "Viewer",
9
+ permissions: ["view-reports", "view-findings", "view-dashboard"],
10
+ },
11
+ {
12
+ id: "reviewer",
13
+ name: "Reviewer",
14
+ permissions: [
15
+ "view-reports",
16
+ "view-findings",
17
+ "view-dashboard",
18
+ "add-annotations",
19
+ "dismiss-findings",
20
+ "run-reviews",
21
+ ],
22
+ },
23
+ {
24
+ id: "admin",
25
+ name: "Admin",
26
+ permissions: [
27
+ "view-reports",
28
+ "view-findings",
29
+ "view-dashboard",
30
+ "add-annotations",
31
+ "dismiss-findings",
32
+ "run-reviews",
33
+ "configure-judges",
34
+ "manage-policies",
35
+ "manage-gates",
36
+ "manage-roles",
37
+ "manage-webhooks",
38
+ ],
39
+ },
40
+ ];
41
+ // ─── CLI ────────────────────────────────────────────────────────────────────
42
+ export function runReviewPermissionModel(argv) {
43
+ const storeIdx = argv.indexOf("--store");
44
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-permissions.json";
45
+ const formatIdx = argv.indexOf("--format");
46
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
47
+ if (argv.includes("--help") || argv.includes("-h")) {
48
+ console.log(`
49
+ judges review-permission-model — Define role-based permissions
50
+
51
+ Usage:
52
+ judges review-permission-model [--store <path>] [--init]
53
+ [--add-role <json>] [--remove-role <id>] [--check <role> --action <perm>]
54
+ [--format table|json]
55
+
56
+ Options:
57
+ --store <path> Permission store (default: .judges-permissions.json)
58
+ --init Initialize with default roles
59
+ --add-role <json> Add or update a role
60
+ --remove-role <id> Remove a role by id
61
+ --check <role> Check if role has a permission
62
+ --action <perm> Permission to check
63
+ --format <fmt> Output format: table (default), json
64
+ --help, -h Show this help
65
+ `);
66
+ return;
67
+ }
68
+ // Init with defaults
69
+ if (argv.includes("--init")) {
70
+ const store = {
71
+ roles: DEFAULT_ROLES,
72
+ lastUpdated: new Date().toISOString().split("T")[0],
73
+ };
74
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
75
+ console.log(`Permission model initialized at: ${storePath}`);
76
+ return;
77
+ }
78
+ let store;
79
+ if (existsSync(storePath)) {
80
+ store = JSON.parse(readFileSync(storePath, "utf-8"));
81
+ }
82
+ else {
83
+ store = { roles: [], lastUpdated: new Date().toISOString().split("T")[0] };
84
+ }
85
+ // Add role
86
+ const addIdx = argv.indexOf("--add-role");
87
+ if (addIdx >= 0) {
88
+ const role = JSON.parse(argv[addIdx + 1]);
89
+ const existingIdx = store.roles.findIndex((r) => r.id === role.id);
90
+ if (existingIdx >= 0) {
91
+ store.roles[existingIdx] = role;
92
+ }
93
+ else {
94
+ store.roles.push(role);
95
+ }
96
+ store.lastUpdated = new Date().toISOString().split("T")[0];
97
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
98
+ console.log(`Role "${role.id}" saved.`);
99
+ return;
100
+ }
101
+ // Remove role
102
+ const removeIdx = argv.indexOf("--remove-role");
103
+ if (removeIdx >= 0) {
104
+ const id = argv[removeIdx + 1];
105
+ store.roles = store.roles.filter((r) => r.id !== id);
106
+ store.lastUpdated = new Date().toISOString().split("T")[0];
107
+ writeFileSync(storePath, JSON.stringify(store, null, 2));
108
+ console.log(`Role "${id}" removed.`);
109
+ return;
110
+ }
111
+ // Check permission
112
+ const checkIdx = argv.indexOf("--check");
113
+ const actionIdx = argv.indexOf("--action");
114
+ if (checkIdx >= 0 && actionIdx >= 0) {
115
+ const roleId = argv[checkIdx + 1];
116
+ const action = argv[actionIdx + 1];
117
+ const role = store.roles.find((r) => r.id === roleId);
118
+ if (role === undefined) {
119
+ console.error(`Role "${roleId}" not found.`);
120
+ process.exitCode = 1;
121
+ return;
122
+ }
123
+ const allowed = role.permissions.includes(action);
124
+ if (format === "json") {
125
+ console.log(JSON.stringify({ role: roleId, action, allowed }, null, 2));
126
+ }
127
+ else {
128
+ console.log(`${allowed ? "ALLOWED" : "DENIED"}: ${roleId} → ${action}`);
129
+ }
130
+ return;
131
+ }
132
+ // List roles
133
+ if (format === "json") {
134
+ console.log(JSON.stringify(store, null, 2));
135
+ return;
136
+ }
137
+ console.log(`\nPermission Model`);
138
+ console.log("═".repeat(60));
139
+ if (store.roles.length === 0) {
140
+ console.log(" No roles defined. Use --init for defaults or --add-role.");
141
+ }
142
+ else {
143
+ for (const r of store.roles) {
144
+ console.log(` ${r.id.padEnd(15)} ${r.name}`);
145
+ console.log(` Permissions: ${r.permissions.join(", ")}`);
146
+ }
147
+ }
148
+ console.log("═".repeat(60));
149
+ }
150
+ //# sourceMappingURL=review-permission-model.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-permission-model.js","sourceRoot":"","sources":["../../src/commands/review-permission-model.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-pipeline-status — Show status of review pipelines and integrations.
3
+ */
4
+ export declare function runReviewPipelineStatus(argv: string[]): void;
5
+ //# sourceMappingURL=review-pipeline-status.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-pipeline-status.d.ts","sourceRoot":"","sources":["../../src/commands/review-pipeline-status.ts"],"names":[],"mappings":"AAAA;;GAEG;AAuBH,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyD5D"}
@@ -0,0 +1,55 @@
1
+ /**
2
+ * Review-pipeline-status — Show status of review pipelines and integrations.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewPipelineStatus(argv) {
7
+ const storeIdx = argv.indexOf("--store");
8
+ const storePath = storeIdx >= 0 ? argv[storeIdx + 1] : ".judges-pipelines.json";
9
+ const formatIdx = argv.indexOf("--format");
10
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
11
+ if (argv.includes("--help") || argv.includes("-h")) {
12
+ console.log(`
13
+ judges review-pipeline-status — Show pipeline status
14
+
15
+ Usage:
16
+ judges review-pipeline-status [--store <path>] [--format table|json]
17
+
18
+ Options:
19
+ --store <path> Pipeline config file (default: .judges-pipelines.json)
20
+ --format <fmt> Output format: table (default), json
21
+ --help, -h Show this help
22
+
23
+ The pipeline store tracks CI integrations, webhooks, and scheduled reviews.
24
+ `);
25
+ return;
26
+ }
27
+ if (!existsSync(storePath)) {
28
+ console.log(`No pipeline config found at: ${storePath}`);
29
+ console.log("Configure pipelines using review-cicd-integrate or review-webhook-dispatch.");
30
+ return;
31
+ }
32
+ const store = JSON.parse(readFileSync(storePath, "utf-8"));
33
+ if (format === "json") {
34
+ console.log(JSON.stringify(store, null, 2));
35
+ return;
36
+ }
37
+ console.log(`\nPipeline Status`);
38
+ console.log("═".repeat(70));
39
+ if (store.pipelines.length === 0) {
40
+ console.log(" No pipelines configured.");
41
+ }
42
+ else {
43
+ console.log(` ${"ID".padEnd(15)} ${"Type".padEnd(12)} ${"Status".padEnd(10)} ${"Last Run".padEnd(14)} Next Run`);
44
+ console.log(" " + "─".repeat(65));
45
+ for (const p of store.pipelines) {
46
+ const statusIcon = p.status === "active" ? "OK" : p.status === "paused" ? "PAUSE" : "ERR";
47
+ console.log(` ${p.id.padEnd(15)} ${p.type.padEnd(12)} ${statusIcon.padEnd(10)} ${p.lastRun.padEnd(14)} ${p.nextRun}`);
48
+ }
49
+ }
50
+ const active = store.pipelines.filter((p) => p.status === "active").length;
51
+ const errored = store.pipelines.filter((p) => p.status === "error").length;
52
+ console.log(`\n Active: ${active} | Paused: ${store.pipelines.length - active - errored} | Errors: ${errored}`);
53
+ console.log("═".repeat(70));
54
+ }
55
+ //# sourceMappingURL=review-pipeline-status.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-pipeline-status.js","sourceRoot":"","sources":["../../src/commands/review-pipeline-status.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-repo-onboard — Onboard a repository to Judges code review.
3
+ */
4
+ export declare function runReviewRepoOnboard(argv: string[]): void;
5
+ //# sourceMappingURL=review-repo-onboard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-repo-onboard.d.ts","sourceRoot":"","sources":["../../src/commands/review-repo-onboard.ts"],"names":[],"mappings":"AAAA;;GAEG;AAOH,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAiHzD"}
@@ -0,0 +1,115 @@
1
+ /**
2
+ * Review-repo-onboard — Onboard a repository to Judges code review.
3
+ */
4
+ import { writeFileSync, mkdirSync, existsSync } from "fs";
5
+ import { join } from "path";
6
+ // ─── CLI ────────────────────────────────────────────────────────────────────
7
+ export function runReviewRepoOnboard(argv) {
8
+ const repoIdx = argv.indexOf("--repo");
9
+ const presetIdx = argv.indexOf("--preset");
10
+ const formatIdx = argv.indexOf("--format");
11
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
12
+ const repo = repoIdx >= 0 ? argv[repoIdx + 1] : ".";
13
+ const preset = presetIdx >= 0 ? argv[presetIdx + 1] : "default";
14
+ if (argv.includes("--help") || argv.includes("-h")) {
15
+ console.log(`
16
+ judges review-repo-onboard — Onboard a repository to Judges
17
+
18
+ Usage:
19
+ judges review-repo-onboard [--repo <path>] [--preset <name>]
20
+ [--format table|json]
21
+
22
+ Options:
23
+ --repo <path> Repository path (default: current directory)
24
+ --preset <name> Config preset: default, strict, security-only (default: default)
25
+ --format <fmt> Output format: table (default), json
26
+ --help, -h Show this help
27
+
28
+ Creates:
29
+ .judgesrc Config file
30
+ .judges-baseline.json Empty baseline
31
+ .judges/ Data directory
32
+ .github/workflows/judges.yml CI integration (if .github exists)
33
+ `);
34
+ return;
35
+ }
36
+ const steps = [];
37
+ // 1. Config file
38
+ const rcPath = join(repo, ".judgesrc");
39
+ if (!existsSync(rcPath)) {
40
+ const config = {
41
+ preset,
42
+ disabledJudges: [],
43
+ disabledRules: [],
44
+ ruleOverrides: {},
45
+ minSeverity: preset === "strict" ? "info" : "low",
46
+ };
47
+ writeFileSync(rcPath, JSON.stringify(config, null, 2));
48
+ steps.push({ name: ".judgesrc", status: "created", detail: `preset: ${preset}` });
49
+ }
50
+ else {
51
+ steps.push({ name: ".judgesrc", status: "skipped", detail: "already exists" });
52
+ }
53
+ // 2. Baseline
54
+ const baselinePath = join(repo, ".judges-baseline.json");
55
+ if (!existsSync(baselinePath)) {
56
+ writeFileSync(baselinePath, JSON.stringify({ version: 1, findings: [] }, null, 2));
57
+ steps.push({ name: ".judges-baseline.json", status: "created", detail: "empty baseline" });
58
+ }
59
+ else {
60
+ steps.push({ name: ".judges-baseline.json", status: "skipped", detail: "already exists" });
61
+ }
62
+ // 3. Data directory
63
+ const judgesDir = join(repo, ".judges");
64
+ if (!existsSync(judgesDir)) {
65
+ mkdirSync(judgesDir, { recursive: true });
66
+ steps.push({ name: ".judges/", status: "created", detail: "data directory" });
67
+ }
68
+ else {
69
+ steps.push({ name: ".judges/", status: "skipped", detail: "already exists" });
70
+ }
71
+ // 4. CI workflow (only if .github exists)
72
+ const ghDir = join(repo, ".github", "workflows");
73
+ if (existsSync(join(repo, ".github"))) {
74
+ const workflowPath = join(ghDir, "judges.yml");
75
+ if (!existsSync(workflowPath)) {
76
+ if (!existsSync(ghDir)) {
77
+ mkdirSync(ghDir, { recursive: true });
78
+ }
79
+ const workflow = `name: Judges Review
80
+ on: [pull_request]
81
+ jobs:
82
+ review:
83
+ runs-on: ubuntu-latest
84
+ steps:
85
+ - uses: actions/checkout@v4
86
+ - uses: actions/setup-node@v4
87
+ with:
88
+ node-version: '20'
89
+ - run: npx @kevinrabun/judges eval --format sarif --fail-on-findings
90
+ `;
91
+ writeFileSync(workflowPath, workflow);
92
+ steps.push({ name: ".github/workflows/judges.yml", status: "created", detail: "CI workflow" });
93
+ }
94
+ else {
95
+ steps.push({ name: ".github/workflows/judges.yml", status: "skipped", detail: "already exists" });
96
+ }
97
+ }
98
+ if (format === "json") {
99
+ console.log(JSON.stringify({ repo, preset, steps }, null, 2));
100
+ return;
101
+ }
102
+ console.log(`\nRepository Onboarding`);
103
+ console.log("═".repeat(55));
104
+ console.log(` Repo: ${repo}`);
105
+ console.log(` Preset: ${preset}`);
106
+ console.log("");
107
+ for (const s of steps) {
108
+ const icon = s.status === "created" ? "+" : "-";
109
+ console.log(` [${icon}] ${s.name.padEnd(35)} ${s.detail}`);
110
+ }
111
+ const created = steps.filter((s) => s.status === "created").length;
112
+ console.log(`\n ${created} file(s) created, ${steps.length - created} skipped.`);
113
+ console.log("═".repeat(55));
114
+ }
115
+ //# sourceMappingURL=review-repo-onboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-repo-onboard.js","sourceRoot":"","sources":["../../src/commands/review-repo-onboard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Review-review-comments — Generate structured review comments from findings.
3
+ */
4
+ export declare function runReviewReviewComments(argv: string[]): void;
5
+ //# sourceMappingURL=review-review-comments.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-review-comments.d.ts","sourceRoot":"","sources":["../../src/commands/review-review-comments.ts"],"names":[],"mappings":"AAAA;;GAEG;AAkBH,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAyF5D"}
@@ -0,0 +1,85 @@
1
+ /**
2
+ * Review-review-comments — Generate structured review comments from findings.
3
+ */
4
+ import { readFileSync, existsSync } from "fs";
5
+ // ─── CLI ────────────────────────────────────────────────────────────────────
6
+ export function runReviewReviewComments(argv) {
7
+ const reportIdx = argv.indexOf("--report");
8
+ const styleIdx = argv.indexOf("--style");
9
+ const formatIdx = argv.indexOf("--format");
10
+ const format = formatIdx >= 0 ? argv[formatIdx + 1] : "table";
11
+ const style = styleIdx >= 0 ? argv[styleIdx + 1] : "detailed";
12
+ if (argv.includes("--help") || argv.includes("-h")) {
13
+ console.log(`
14
+ judges review-review-comments — Generate structured review comments
15
+
16
+ Usage:
17
+ judges review-review-comments --report <path> [--style <style>]
18
+ [--format table|json]
19
+
20
+ Options:
21
+ --report <path> Report file with findings
22
+ --style <style> Comment style: detailed (default), concise, inline
23
+ --format <fmt> Output format: table (default), json
24
+ --help, -h Show this help
25
+ `);
26
+ return;
27
+ }
28
+ if (reportIdx < 0) {
29
+ console.error("Missing --report <path>");
30
+ process.exitCode = 1;
31
+ return;
32
+ }
33
+ const reportPath = argv[reportIdx + 1];
34
+ if (!existsSync(reportPath)) {
35
+ console.error(`Report not found: ${reportPath}`);
36
+ process.exitCode = 1;
37
+ return;
38
+ }
39
+ const report = JSON.parse(readFileSync(reportPath, "utf-8"));
40
+ const findings = report.findings ?? [];
41
+ if (findings.length === 0) {
42
+ console.log("No findings to generate comments for.");
43
+ return;
44
+ }
45
+ const comments = findings.map((f) => {
46
+ const lineRef = f.lineNumbers !== undefined && f.lineNumbers.length > 0
47
+ ? `L${f.lineNumbers[0]}${f.lineNumbers.length > 1 ? `-L${f.lineNumbers[f.lineNumbers.length - 1]}` : ""}`
48
+ : "N/A";
49
+ let body;
50
+ if (style === "concise") {
51
+ body = `[${f.severity.toUpperCase()}] ${f.title}`;
52
+ }
53
+ else if (style === "inline") {
54
+ body = `// ${f.severity.toUpperCase()}: ${f.title} — ${f.recommendation}`;
55
+ }
56
+ else {
57
+ body = `**${f.severity.toUpperCase()}**: ${f.title}\n\n${f.description}\n\n**Recommendation**: ${f.recommendation}`;
58
+ }
59
+ return {
60
+ ruleId: f.ruleId,
61
+ severity: f.severity,
62
+ title: f.title,
63
+ body,
64
+ lineRef,
65
+ suggestion: f.recommendation,
66
+ };
67
+ });
68
+ if (format === "json") {
69
+ console.log(JSON.stringify(comments, null, 2));
70
+ return;
71
+ }
72
+ console.log(`\nReview Comments (${style})`);
73
+ console.log("═".repeat(70));
74
+ for (let i = 0; i < comments.length; i++) {
75
+ const c = comments[i];
76
+ console.log(`\n Comment ${i + 1} [${c.lineRef}]:`);
77
+ console.log(" " + "─".repeat(60));
78
+ for (const line of c.body.split("\n")) {
79
+ console.log(` ${line}`);
80
+ }
81
+ }
82
+ console.log(`\n Total comments: ${comments.length}`);
83
+ console.log("═".repeat(70));
84
+ }
85
+ //# sourceMappingURL=review-review-comments.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review-review-comments.js","sourceRoot":"","sources":["../../src/commands/review-review-comments.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kevinrabun/judges",
3
- "version": "3.98.0",
3
+ "version": "3.99.0",
4
4
  "description": "45 specialized judges that evaluate AI-generated code for security, cost, and quality.",
5
5
  "mcpName": "io.github.KevinRabun/judges",
6
6
  "type": "module",
package/server.json CHANGED
@@ -7,12 +7,12 @@
7
7
  "url": "https://github.com/kevinrabun/judges",
8
8
  "source": "github"
9
9
  },
10
- "version": "3.98.0",
10
+ "version": "3.99.0",
11
11
  "packages": [
12
12
  {
13
13
  "registryType": "npm",
14
14
  "identifier": "@kevinrabun/judges",
15
- "version": "3.98.0",
15
+ "version": "3.99.0",
16
16
  "transport": {
17
17
  "type": "stdio"
18
18
  }