@kevinrabun/judges 3.98.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 (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-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-auto-triage.d.ts +5 -0
  10. package/dist/commands/finding-auto-triage.d.ts.map +1 -0
  11. package/dist/commands/finding-auto-triage.js +109 -0
  12. package/dist/commands/finding-auto-triage.js.map +1 -0
  13. package/dist/commands/finding-change-impact.d.ts +5 -0
  14. package/dist/commands/finding-change-impact.d.ts.map +1 -0
  15. package/dist/commands/finding-change-impact.js +108 -0
  16. package/dist/commands/finding-change-impact.js.map +1 -0
  17. package/dist/commands/finding-context-enrich.d.ts +5 -0
  18. package/dist/commands/finding-context-enrich.d.ts.map +1 -0
  19. package/dist/commands/finding-context-enrich.js +90 -0
  20. package/dist/commands/finding-context-enrich.js.map +1 -0
  21. package/dist/commands/finding-dismiss-workflow.d.ts +5 -0
  22. package/dist/commands/finding-dismiss-workflow.d.ts.map +1 -0
  23. package/dist/commands/finding-dismiss-workflow.js +120 -0
  24. package/dist/commands/finding-dismiss-workflow.js.map +1 -0
  25. package/dist/commands/finding-false-positive-learn.d.ts +5 -0
  26. package/dist/commands/finding-false-positive-learn.d.ts.map +1 -0
  27. package/dist/commands/finding-false-positive-learn.js +86 -0
  28. package/dist/commands/finding-false-positive-learn.js.map +1 -0
  29. package/dist/commands/finding-reachability-check.d.ts +5 -0
  30. package/dist/commands/finding-reachability-check.d.ts.map +1 -0
  31. package/dist/commands/finding-reachability-check.js +103 -0
  32. package/dist/commands/finding-reachability-check.js.map +1 -0
  33. package/dist/commands/review-audit-export.d.ts +5 -0
  34. package/dist/commands/review-audit-export.d.ts.map +1 -0
  35. package/dist/commands/review-audit-export.js +94 -0
  36. package/dist/commands/review-audit-export.js.map +1 -0
  37. package/dist/commands/review-data-retention.d.ts +5 -0
  38. package/dist/commands/review-data-retention.d.ts.map +1 -0
  39. package/dist/commands/review-data-retention.js +120 -0
  40. package/dist/commands/review-data-retention.js.map +1 -0
  41. package/dist/commands/review-deployment-gate.d.ts +5 -0
  42. package/dist/commands/review-deployment-gate.d.ts.map +1 -0
  43. package/dist/commands/review-deployment-gate.js +95 -0
  44. package/dist/commands/review-deployment-gate.js.map +1 -0
  45. package/dist/commands/review-environment-config.d.ts +5 -0
  46. package/dist/commands/review-environment-config.d.ts.map +1 -0
  47. package/dist/commands/review-environment-config.js +103 -0
  48. package/dist/commands/review-environment-config.js.map +1 -0
  49. package/dist/commands/review-multi-repo-sync.d.ts +5 -0
  50. package/dist/commands/review-multi-repo-sync.d.ts.map +1 -0
  51. package/dist/commands/review-multi-repo-sync.js +116 -0
  52. package/dist/commands/review-multi-repo-sync.js.map +1 -0
  53. package/dist/commands/review-permission-model.d.ts +5 -0
  54. package/dist/commands/review-permission-model.d.ts.map +1 -0
  55. package/dist/commands/review-permission-model.js +150 -0
  56. package/dist/commands/review-permission-model.js.map +1 -0
  57. package/dist/commands/review-pipeline-status.d.ts +5 -0
  58. package/dist/commands/review-pipeline-status.d.ts.map +1 -0
  59. package/dist/commands/review-pipeline-status.js +55 -0
  60. package/dist/commands/review-pipeline-status.js.map +1 -0
  61. package/dist/commands/review-repo-onboard.d.ts +5 -0
  62. package/dist/commands/review-repo-onboard.d.ts.map +1 -0
  63. package/dist/commands/review-repo-onboard.js +115 -0
  64. package/dist/commands/review-repo-onboard.js.map +1 -0
  65. package/dist/commands/review-review-comments.d.ts +5 -0
  66. package/dist/commands/review-review-comments.d.ts.map +1 -0
  67. package/dist/commands/review-review-comments.js +85 -0
  68. package/dist/commands/review-review-comments.js.map +1 -0
  69. package/dist/commands/review-session-replay.d.ts +5 -0
  70. package/dist/commands/review-session-replay.d.ts.map +1 -0
  71. package/dist/commands/review-session-replay.js +82 -0
  72. package/dist/commands/review-session-replay.js.map +1 -0
  73. package/dist/commands/review-stakeholder-report.d.ts +5 -0
  74. package/dist/commands/review-stakeholder-report.d.ts.map +1 -0
  75. package/dist/commands/review-stakeholder-report.js +76 -0
  76. package/dist/commands/review-stakeholder-report.js.map +1 -0
  77. package/package.json +1 -1
  78. 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-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":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAmB9C,+EAA+E;AAE/E,MAAM,UAAU,uBAAuB,CAAC,IAAc;IACpD,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;;;;;;;;;;;;CAYf,CAAC,CAAC;QACC,OAAO;IACT,CAAC;IAED,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;QAC3B,OAAO,CAAC,GAAG,CAAC,gCAAgC,SAAS,EAAE,CAAC,CAAC;QACzD,OAAO,CAAC,GAAG,CAAC,6EAA6E,CAAC,CAAC;QAC3F,OAAO;IACT,CAAC;IAED,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAkB,CAAC;IAE5E,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,mBAAmB,CAAC,CAAC;IACjC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;IAE5B,IAAI,KAAK,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjC,OAAO,CAAC,GAAG,CAAC,4BAA4B,CAAC,CAAC;IAC5C,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC;QAClH,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAEnC,KAAK,MAAM,CAAC,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;YAChC,MAAM,UAAU,GAAG,CAAC,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;YAC1F,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAC1G,CAAC;QACJ,CAAC;IACH,CAAC;IAED,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,MAAM,CAAC;IAC3E,MAAM,OAAO,GAAG,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,OAAO,CAAC,CAAC,MAAM,CAAC;IAC3E,OAAO,CAAC,GAAG,CAAC,eAAe,MAAM,cAAc,KAAK,CAAC,SAAS,CAAC,MAAM,GAAG,MAAM,GAAG,OAAO,cAAc,OAAO,EAAE,CAAC,CAAC;IACjH,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;AAC9B,CAAC"}
@@ -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"}