@kevinrabun/judges 3.38.0 → 3.40.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 (331) hide show
  1. package/CHANGELOG.md +46 -0
  2. package/README.md +5 -4
  3. package/dist/api.d.ts +5 -2
  4. package/dist/api.d.ts.map +1 -1
  5. package/dist/api.js +5 -1
  6. package/dist/api.js.map +1 -1
  7. package/dist/ast/structural-parser.js +3 -3
  8. package/dist/ast/structural-parser.js.map +1 -1
  9. package/dist/calibration.d.ts +35 -0
  10. package/dist/calibration.d.ts.map +1 -1
  11. package/dist/calibration.js +52 -0
  12. package/dist/calibration.js.map +1 -1
  13. package/dist/cli.d.ts.map +1 -1
  14. package/dist/cli.js +307 -16
  15. package/dist/cli.js.map +1 -1
  16. package/dist/commands/benchmark-languages.js +4 -4
  17. package/dist/commands/benchmark.d.ts +2 -1
  18. package/dist/commands/benchmark.d.ts.map +1 -1
  19. package/dist/commands/benchmark.js +67 -2
  20. package/dist/commands/benchmark.js.map +1 -1
  21. package/dist/commands/calibration-dashboard.d.ts.map +1 -1
  22. package/dist/commands/calibration-dashboard.js +198 -0
  23. package/dist/commands/calibration-dashboard.js.map +1 -1
  24. package/dist/commands/calibration-share.d.ts +31 -0
  25. package/dist/commands/calibration-share.d.ts.map +1 -0
  26. package/dist/commands/calibration-share.js +183 -0
  27. package/dist/commands/calibration-share.js.map +1 -0
  28. package/dist/commands/compliance-report.d.ts +35 -0
  29. package/dist/commands/compliance-report.d.ts.map +1 -0
  30. package/dist/commands/compliance-report.js +162 -0
  31. package/dist/commands/compliance-report.js.map +1 -0
  32. package/dist/commands/diff.d.ts.map +1 -1
  33. package/dist/commands/diff.js +8 -3
  34. package/dist/commands/diff.js.map +1 -1
  35. package/dist/commands/feedback-rules.d.ts +29 -0
  36. package/dist/commands/feedback-rules.d.ts.map +1 -0
  37. package/dist/commands/feedback-rules.js +174 -0
  38. package/dist/commands/feedback-rules.js.map +1 -0
  39. package/dist/commands/feedback.d.ts +12 -0
  40. package/dist/commands/feedback.d.ts.map +1 -1
  41. package/dist/commands/feedback.js +16 -0
  42. package/dist/commands/feedback.js.map +1 -1
  43. package/dist/commands/fix.d.ts.map +1 -1
  44. package/dist/commands/fix.js +33 -1
  45. package/dist/commands/fix.js.map +1 -1
  46. package/dist/commands/governance.d.ts +32 -0
  47. package/dist/commands/governance.d.ts.map +1 -0
  48. package/dist/commands/governance.js +203 -0
  49. package/dist/commands/governance.js.map +1 -0
  50. package/dist/commands/help.d.ts +8 -0
  51. package/dist/commands/help.d.ts.map +1 -0
  52. package/dist/commands/help.js +303 -0
  53. package/dist/commands/help.js.map +1 -0
  54. package/dist/commands/hook.d.ts.map +1 -1
  55. package/dist/commands/hook.js +17 -20
  56. package/dist/commands/hook.js.map +1 -1
  57. package/dist/commands/llm-benchmark.d.ts +119 -0
  58. package/dist/commands/llm-benchmark.d.ts.map +1 -0
  59. package/dist/commands/llm-benchmark.js +396 -0
  60. package/dist/commands/llm-benchmark.js.map +1 -0
  61. package/dist/commands/metrics-dashboard.d.ts +22 -0
  62. package/dist/commands/metrics-dashboard.d.ts.map +1 -0
  63. package/dist/commands/metrics-dashboard.js +335 -0
  64. package/dist/commands/metrics-dashboard.js.map +1 -0
  65. package/dist/commands/metrics.d.ts +58 -0
  66. package/dist/commands/metrics.d.ts.map +1 -0
  67. package/dist/commands/metrics.js +242 -0
  68. package/dist/commands/metrics.js.map +1 -0
  69. package/dist/commands/onboard.d.ts +13 -0
  70. package/dist/commands/onboard.d.ts.map +1 -0
  71. package/dist/commands/onboard.js +179 -0
  72. package/dist/commands/onboard.js.map +1 -0
  73. package/dist/commands/org-metrics.d.ts +24 -0
  74. package/dist/commands/org-metrics.d.ts.map +1 -0
  75. package/dist/commands/org-metrics.js +238 -0
  76. package/dist/commands/org-metrics.js.map +1 -0
  77. package/dist/commands/override.d.ts +62 -0
  78. package/dist/commands/override.d.ts.map +1 -0
  79. package/dist/commands/override.js +264 -0
  80. package/dist/commands/override.js.map +1 -0
  81. package/dist/commands/parity.d.ts +31 -0
  82. package/dist/commands/parity.d.ts.map +1 -0
  83. package/dist/commands/parity.js +213 -0
  84. package/dist/commands/parity.js.map +1 -0
  85. package/dist/commands/plugin-search.d.ts +40 -0
  86. package/dist/commands/plugin-search.d.ts.map +1 -0
  87. package/dist/commands/plugin-search.js +328 -0
  88. package/dist/commands/plugin-search.js.map +1 -0
  89. package/dist/commands/plugins.d.ts +13 -0
  90. package/dist/commands/plugins.d.ts.map +1 -0
  91. package/dist/commands/plugins.js +105 -0
  92. package/dist/commands/plugins.js.map +1 -0
  93. package/dist/commands/review.js +1 -1
  94. package/dist/commands/review.js.map +1 -1
  95. package/dist/commands/snapshot.d.ts +27 -0
  96. package/dist/commands/snapshot.d.ts.map +1 -1
  97. package/dist/commands/snapshot.js +99 -0
  98. package/dist/commands/snapshot.js.map +1 -1
  99. package/dist/commands/trace.d.ts +65 -0
  100. package/dist/commands/trace.d.ts.map +1 -0
  101. package/dist/commands/trace.js +246 -0
  102. package/dist/commands/trace.js.map +1 -0
  103. package/dist/commands/trust-ramp.d.ts +30 -0
  104. package/dist/commands/trust-ramp.d.ts.map +1 -0
  105. package/dist/commands/trust-ramp.js +190 -0
  106. package/dist/commands/trust-ramp.js.map +1 -0
  107. package/dist/config.d.ts +5 -0
  108. package/dist/config.d.ts.map +1 -1
  109. package/dist/config.js +65 -0
  110. package/dist/config.js.map +1 -1
  111. package/dist/data-adapter.d.ts +124 -0
  112. package/dist/data-adapter.d.ts.map +1 -0
  113. package/dist/data-adapter.js +213 -0
  114. package/dist/data-adapter.js.map +1 -0
  115. package/dist/evaluators/accessibility.js +1 -1
  116. package/dist/evaluators/accessibility.js.map +1 -1
  117. package/dist/evaluators/ai-code-safety.d.ts.map +1 -1
  118. package/dist/evaluators/ai-code-safety.js +1 -4
  119. package/dist/evaluators/ai-code-safety.js.map +1 -1
  120. package/dist/evaluators/cost-effectiveness.js +1 -1
  121. package/dist/evaluators/cost-effectiveness.js.map +1 -1
  122. package/dist/evaluators/false-positive-review.js +4 -4
  123. package/dist/evaluators/false-positive-review.js.map +1 -1
  124. package/dist/evaluators/iac-security.js +1 -1
  125. package/dist/evaluators/iac-security.js.map +1 -1
  126. package/dist/evaluators/index.d.ts.map +1 -1
  127. package/dist/evaluators/index.js +59 -10
  128. package/dist/evaluators/index.js.map +1 -1
  129. package/dist/evaluators/intent-alignment.d.ts +4 -0
  130. package/dist/evaluators/intent-alignment.d.ts.map +1 -1
  131. package/dist/evaluators/intent-alignment.js +163 -0
  132. package/dist/evaluators/intent-alignment.js.map +1 -1
  133. package/dist/evaluators/logic-review.js +1 -1
  134. package/dist/evaluators/logic-review.js.map +1 -1
  135. package/dist/evaluators/maintainability.js +1 -1
  136. package/dist/evaluators/maintainability.js.map +1 -1
  137. package/dist/evaluators/over-engineering.js +3 -3
  138. package/dist/evaluators/over-engineering.js.map +1 -1
  139. package/dist/evaluators/project.d.ts +12 -0
  140. package/dist/evaluators/project.d.ts.map +1 -1
  141. package/dist/evaluators/project.js +86 -0
  142. package/dist/evaluators/project.js.map +1 -1
  143. package/dist/evaluators/security.js +2 -2
  144. package/dist/evaluators/security.js.map +1 -1
  145. package/dist/evaluators/ux.js +1 -1
  146. package/dist/evaluators/ux.js.map +1 -1
  147. package/dist/finding-lifecycle.d.ts +9 -0
  148. package/dist/finding-lifecycle.d.ts.map +1 -1
  149. package/dist/finding-lifecycle.js +15 -0
  150. package/dist/finding-lifecycle.js.map +1 -1
  151. package/dist/fix-history.d.ts +9 -0
  152. package/dist/fix-history.d.ts.map +1 -1
  153. package/dist/fix-history.js +15 -0
  154. package/dist/fix-history.js.map +1 -1
  155. package/dist/formatters/sarif.d.ts +3 -0
  156. package/dist/formatters/sarif.d.ts.map +1 -1
  157. package/dist/formatters/sarif.js +36 -12
  158. package/dist/formatters/sarif.js.map +1 -1
  159. package/dist/github-app.d.ts +16 -1
  160. package/dist/github-app.d.ts.map +1 -1
  161. package/dist/github-app.js +85 -2
  162. package/dist/github-app.js.map +1 -1
  163. package/dist/index.js +5 -0
  164. package/dist/index.js.map +1 -1
  165. package/dist/judge-registry.d.ts +157 -0
  166. package/dist/judge-registry.d.ts.map +1 -0
  167. package/dist/judge-registry.js +273 -0
  168. package/dist/judge-registry.js.map +1 -0
  169. package/dist/judges/accessibility.d.ts.map +1 -1
  170. package/dist/judges/accessibility.js +4 -0
  171. package/dist/judges/accessibility.js.map +1 -1
  172. package/dist/judges/agent-instructions.d.ts.map +1 -1
  173. package/dist/judges/agent-instructions.js +4 -0
  174. package/dist/judges/agent-instructions.js.map +1 -1
  175. package/dist/judges/ai-code-safety.d.ts.map +1 -1
  176. package/dist/judges/ai-code-safety.js +4 -0
  177. package/dist/judges/ai-code-safety.js.map +1 -1
  178. package/dist/judges/api-contract.d.ts.map +1 -1
  179. package/dist/judges/api-contract.js +4 -0
  180. package/dist/judges/api-contract.js.map +1 -1
  181. package/dist/judges/api-design.d.ts.map +1 -1
  182. package/dist/judges/api-design.js +4 -0
  183. package/dist/judges/api-design.js.map +1 -1
  184. package/dist/judges/authentication.d.ts.map +1 -1
  185. package/dist/judges/authentication.js +4 -0
  186. package/dist/judges/authentication.js.map +1 -1
  187. package/dist/judges/backwards-compatibility.d.ts.map +1 -1
  188. package/dist/judges/backwards-compatibility.js +4 -0
  189. package/dist/judges/backwards-compatibility.js.map +1 -1
  190. package/dist/judges/caching.d.ts.map +1 -1
  191. package/dist/judges/caching.js +4 -0
  192. package/dist/judges/caching.js.map +1 -1
  193. package/dist/judges/ci-cd.d.ts.map +1 -1
  194. package/dist/judges/ci-cd.js +4 -0
  195. package/dist/judges/ci-cd.js.map +1 -1
  196. package/dist/judges/cloud-readiness.d.ts.map +1 -1
  197. package/dist/judges/cloud-readiness.js +4 -0
  198. package/dist/judges/cloud-readiness.js.map +1 -1
  199. package/dist/judges/code-structure.d.ts.map +1 -1
  200. package/dist/judges/code-structure.js +4 -0
  201. package/dist/judges/code-structure.js.map +1 -1
  202. package/dist/judges/compliance.d.ts.map +1 -1
  203. package/dist/judges/compliance.js +4 -0
  204. package/dist/judges/compliance.js.map +1 -1
  205. package/dist/judges/concurrency.d.ts.map +1 -1
  206. package/dist/judges/concurrency.js +4 -0
  207. package/dist/judges/concurrency.js.map +1 -1
  208. package/dist/judges/configuration-management.d.ts.map +1 -1
  209. package/dist/judges/configuration-management.js +4 -0
  210. package/dist/judges/configuration-management.js.map +1 -1
  211. package/dist/judges/cost-effectiveness.d.ts.map +1 -1
  212. package/dist/judges/cost-effectiveness.js +4 -0
  213. package/dist/judges/cost-effectiveness.js.map +1 -1
  214. package/dist/judges/cybersecurity.d.ts.map +1 -1
  215. package/dist/judges/cybersecurity.js +4 -0
  216. package/dist/judges/cybersecurity.js.map +1 -1
  217. package/dist/judges/data-security.d.ts.map +1 -1
  218. package/dist/judges/data-security.js +4 -0
  219. package/dist/judges/data-security.js.map +1 -1
  220. package/dist/judges/data-sovereignty.d.ts.map +1 -1
  221. package/dist/judges/data-sovereignty.js +4 -0
  222. package/dist/judges/data-sovereignty.js.map +1 -1
  223. package/dist/judges/database.d.ts.map +1 -1
  224. package/dist/judges/database.js +4 -0
  225. package/dist/judges/database.js.map +1 -1
  226. package/dist/judges/dependency-health.d.ts.map +1 -1
  227. package/dist/judges/dependency-health.js +4 -0
  228. package/dist/judges/dependency-health.js.map +1 -1
  229. package/dist/judges/documentation.d.ts.map +1 -1
  230. package/dist/judges/documentation.js +4 -0
  231. package/dist/judges/documentation.js.map +1 -1
  232. package/dist/judges/error-handling.d.ts.map +1 -1
  233. package/dist/judges/error-handling.js +4 -0
  234. package/dist/judges/error-handling.js.map +1 -1
  235. package/dist/judges/ethics-bias.d.ts.map +1 -1
  236. package/dist/judges/ethics-bias.js +4 -0
  237. package/dist/judges/ethics-bias.js.map +1 -1
  238. package/dist/judges/false-positive-review.d.ts.map +1 -1
  239. package/dist/judges/false-positive-review.js +2 -0
  240. package/dist/judges/false-positive-review.js.map +1 -1
  241. package/dist/judges/framework-safety.d.ts.map +1 -1
  242. package/dist/judges/framework-safety.js +4 -0
  243. package/dist/judges/framework-safety.js.map +1 -1
  244. package/dist/judges/hallucination-detection.d.ts.map +1 -1
  245. package/dist/judges/hallucination-detection.js +4 -0
  246. package/dist/judges/hallucination-detection.js.map +1 -1
  247. package/dist/judges/iac-security.d.ts.map +1 -1
  248. package/dist/judges/iac-security.js +4 -0
  249. package/dist/judges/iac-security.js.map +1 -1
  250. package/dist/judges/index.d.ts +59 -0
  251. package/dist/judges/index.d.ts.map +1 -1
  252. package/dist/judges/index.js +65 -189
  253. package/dist/judges/index.js.map +1 -1
  254. package/dist/judges/intent-alignment.d.ts.map +1 -1
  255. package/dist/judges/intent-alignment.js +4 -0
  256. package/dist/judges/intent-alignment.js.map +1 -1
  257. package/dist/judges/internationalization.d.ts.map +1 -1
  258. package/dist/judges/internationalization.js +4 -0
  259. package/dist/judges/internationalization.js.map +1 -1
  260. package/dist/judges/logging-privacy.d.ts.map +1 -1
  261. package/dist/judges/logging-privacy.js +4 -0
  262. package/dist/judges/logging-privacy.js.map +1 -1
  263. package/dist/judges/logic-review.d.ts.map +1 -1
  264. package/dist/judges/logic-review.js +4 -0
  265. package/dist/judges/logic-review.js.map +1 -1
  266. package/dist/judges/maintainability.d.ts.map +1 -1
  267. package/dist/judges/maintainability.js +4 -0
  268. package/dist/judges/maintainability.js.map +1 -1
  269. package/dist/judges/model-fingerprint.d.ts.map +1 -1
  270. package/dist/judges/model-fingerprint.js +4 -0
  271. package/dist/judges/model-fingerprint.js.map +1 -1
  272. package/dist/judges/multi-turn-coherence.d.ts.map +1 -1
  273. package/dist/judges/multi-turn-coherence.js +4 -0
  274. package/dist/judges/multi-turn-coherence.js.map +1 -1
  275. package/dist/judges/observability.d.ts.map +1 -1
  276. package/dist/judges/observability.js +4 -0
  277. package/dist/judges/observability.js.map +1 -1
  278. package/dist/judges/over-engineering.d.ts.map +1 -1
  279. package/dist/judges/over-engineering.js +4 -0
  280. package/dist/judges/over-engineering.js.map +1 -1
  281. package/dist/judges/performance.d.ts.map +1 -1
  282. package/dist/judges/performance.js +4 -0
  283. package/dist/judges/performance.js.map +1 -1
  284. package/dist/judges/portability.d.ts.map +1 -1
  285. package/dist/judges/portability.js +4 -0
  286. package/dist/judges/portability.js.map +1 -1
  287. package/dist/judges/rate-limiting.d.ts.map +1 -1
  288. package/dist/judges/rate-limiting.js +4 -0
  289. package/dist/judges/rate-limiting.js.map +1 -1
  290. package/dist/judges/reliability.d.ts.map +1 -1
  291. package/dist/judges/reliability.js +4 -0
  292. package/dist/judges/reliability.js.map +1 -1
  293. package/dist/judges/scalability.d.ts.map +1 -1
  294. package/dist/judges/scalability.js +4 -0
  295. package/dist/judges/scalability.js.map +1 -1
  296. package/dist/judges/security.d.ts.map +1 -1
  297. package/dist/judges/security.js +4 -0
  298. package/dist/judges/security.js.map +1 -1
  299. package/dist/judges/software-practices.d.ts.map +1 -1
  300. package/dist/judges/software-practices.js +4 -0
  301. package/dist/judges/software-practices.js.map +1 -1
  302. package/dist/judges/testing.d.ts.map +1 -1
  303. package/dist/judges/testing.js +4 -0
  304. package/dist/judges/testing.js.map +1 -1
  305. package/dist/judges/ux.d.ts.map +1 -1
  306. package/dist/judges/ux.js +4 -0
  307. package/dist/judges/ux.js.map +1 -1
  308. package/dist/plugins.d.ts +8 -51
  309. package/dist/plugins.d.ts.map +1 -1
  310. package/dist/plugins.js +16 -125
  311. package/dist/plugins.js.map +1 -1
  312. package/dist/security-ids.d.ts +24 -0
  313. package/dist/security-ids.d.ts.map +1 -0
  314. package/dist/security-ids.js +240 -0
  315. package/dist/security-ids.js.map +1 -0
  316. package/dist/tools/prompts.d.ts +4 -0
  317. package/dist/tools/prompts.d.ts.map +1 -1
  318. package/dist/tools/prompts.js +6 -4
  319. package/dist/tools/prompts.js.map +1 -1
  320. package/dist/tools/register-scaffold.d.ts +3 -0
  321. package/dist/tools/register-scaffold.d.ts.map +1 -0
  322. package/dist/tools/register-scaffold.js +399 -0
  323. package/dist/tools/register-scaffold.js.map +1 -0
  324. package/dist/tools/register.d.ts +1 -1
  325. package/dist/tools/register.d.ts.map +1 -1
  326. package/dist/tools/register.js +3 -1
  327. package/dist/tools/register.js.map +1 -1
  328. package/dist/types.d.ts +75 -0
  329. package/dist/types.d.ts.map +1 -1
  330. package/package.json +3 -2
  331. package/server.json +2 -2
@@ -0,0 +1,264 @@
1
+ /**
2
+ * `judges override` — Structured exception/override workflow for gating.
3
+ *
4
+ * When the PR gate blocks a merge, developers can log a justified override
5
+ * rather than disabling the entire check. Overrides are tracked in an
6
+ * auditable log (.judges-overrides.json) with required justification.
7
+ *
8
+ * Usage:
9
+ * judges override add --rule SEC-001 --reason "Mitigated by WAF" --approver "jane@co.com"
10
+ * judges override list # Show active overrides
11
+ * judges override revoke --rule SEC-001 # Revoke an override
12
+ * judges override check --file src/app.ts # Check if findings have applicable overrides
13
+ */
14
+ import { existsSync, readFileSync, writeFileSync, mkdirSync } from "fs";
15
+ import { resolve, dirname } from "path";
16
+ // ─── Store I/O ──────────────────────────────────────────────────────────────
17
+ const OVERRIDE_FILE = ".judges-overrides.json";
18
+ function createEmptyStore() {
19
+ const now = new Date().toISOString();
20
+ return { version: 1, overrides: [], metadata: { createdAt: now, lastUpdated: now } };
21
+ }
22
+ export function loadOverrideStore(dir = ".") {
23
+ const filePath = resolve(dir, OVERRIDE_FILE);
24
+ if (!existsSync(filePath))
25
+ return createEmptyStore();
26
+ try {
27
+ const raw = JSON.parse(readFileSync(filePath, "utf-8"));
28
+ if (raw.version === 1 && Array.isArray(raw.overrides))
29
+ return raw;
30
+ return createEmptyStore();
31
+ }
32
+ catch {
33
+ return createEmptyStore();
34
+ }
35
+ }
36
+ export function saveOverrideStore(store, dir = ".") {
37
+ const filePath = resolve(dir, OVERRIDE_FILE);
38
+ const d = dirname(filePath);
39
+ if (!existsSync(d))
40
+ mkdirSync(d, { recursive: true });
41
+ store.metadata.lastUpdated = new Date().toISOString();
42
+ writeFileSync(filePath, JSON.stringify(store, null, 2) + "\n", "utf-8");
43
+ }
44
+ // ─── Override Logic ─────────────────────────────────────────────────────────
45
+ /**
46
+ * Check if a finding's rule ID matches an active, non-expired override.
47
+ */
48
+ export function isOverridden(ruleId, filePath, store) {
49
+ const now = new Date().toISOString();
50
+ for (const o of store.overrides) {
51
+ if (!o.active)
52
+ continue;
53
+ if (o.expiresAt && o.expiresAt < now)
54
+ continue;
55
+ // Match exact rule ID or wildcard prefix (e.g. "SEC-*")
56
+ const matches = o.ruleId === ruleId || (o.ruleId.endsWith("-*") && ruleId.startsWith(o.ruleId.slice(0, -1)));
57
+ if (!matches)
58
+ continue;
59
+ // If file scope is specified, check it
60
+ if (o.filePaths && o.filePaths.length > 0 && filePath) {
61
+ const fileMatches = o.filePaths.some((pattern) => {
62
+ if (pattern.includes("*")) {
63
+ const re = new RegExp("^" + pattern.replace(/\*/g, ".*") + "$");
64
+ return re.test(filePath);
65
+ }
66
+ return filePath.includes(pattern);
67
+ });
68
+ if (!fileMatches)
69
+ continue;
70
+ }
71
+ return o;
72
+ }
73
+ return undefined;
74
+ }
75
+ /**
76
+ * Apply overrides to a list of findings — returns findings with overridden
77
+ * ones removed, plus the list of overridden findings for audit.
78
+ */
79
+ export function applyOverrides(findings, store, filePath) {
80
+ const active = [];
81
+ const overridden = [];
82
+ for (const f of findings) {
83
+ const match = isOverridden(f.ruleId, filePath, store);
84
+ if (match) {
85
+ overridden.push({ finding: f, override: match });
86
+ }
87
+ else {
88
+ active.push(f);
89
+ }
90
+ }
91
+ return { active, overridden };
92
+ }
93
+ // ─── CLI Command ────────────────────────────────────────────────────────────
94
+ export function runOverride(argv) {
95
+ const subcommand = argv[3] || "list";
96
+ const store = loadOverrideStore();
97
+ switch (subcommand) {
98
+ case "add": {
99
+ let ruleId = "";
100
+ let reason = "";
101
+ let approver = "";
102
+ let expiresAt = "";
103
+ const filePaths = [];
104
+ for (let i = 4; i < argv.length; i++) {
105
+ switch (argv[i]) {
106
+ case "--rule":
107
+ case "-r":
108
+ ruleId = argv[++i] || "";
109
+ break;
110
+ case "--reason":
111
+ reason = argv[++i] || "";
112
+ break;
113
+ case "--approver":
114
+ approver = argv[++i] || "";
115
+ break;
116
+ case "--expires":
117
+ expiresAt = argv[++i] || "";
118
+ break;
119
+ case "--file":
120
+ case "-f":
121
+ filePaths.push(argv[++i] || "");
122
+ break;
123
+ }
124
+ }
125
+ if (!ruleId) {
126
+ console.error('Error: --rule is required. Example: judges override add --rule SEC-001 --reason "Mitigated by WAF"');
127
+ process.exit(1);
128
+ }
129
+ if (!reason) {
130
+ console.error("Error: --reason is required. Overrides must have a justification.");
131
+ process.exit(1);
132
+ }
133
+ const override = {
134
+ ruleId,
135
+ reason,
136
+ approver: approver || undefined,
137
+ filePaths: filePaths.length > 0 ? filePaths : undefined,
138
+ createdAt: new Date().toISOString(),
139
+ expiresAt: expiresAt || undefined,
140
+ active: true,
141
+ };
142
+ store.overrides.push(override);
143
+ saveOverrideStore(store);
144
+ console.log("");
145
+ console.log(" ✅ Override added:");
146
+ console.log(` Rule : ${ruleId}`);
147
+ console.log(` Reason : ${reason}`);
148
+ if (approver)
149
+ console.log(` Approver : ${approver}`);
150
+ if (expiresAt)
151
+ console.log(` Expires : ${expiresAt}`);
152
+ if (filePaths.length > 0)
153
+ console.log(` Scope : ${filePaths.join(", ")}`);
154
+ console.log("");
155
+ break;
156
+ }
157
+ case "list": {
158
+ const now = new Date().toISOString();
159
+ const active = store.overrides.filter((o) => o.active && (!o.expiresAt || o.expiresAt >= now));
160
+ const expired = store.overrides.filter((o) => o.active && o.expiresAt && o.expiresAt < now);
161
+ const revoked = store.overrides.filter((o) => !o.active);
162
+ console.log("");
163
+ console.log("╔══════════════════════════════════════════════════════════════╗");
164
+ console.log("║ Judges Panel — Override Registry ║");
165
+ console.log("╚══════════════════════════════════════════════════════════════╝");
166
+ console.log("");
167
+ if (active.length === 0 && expired.length === 0 && revoked.length === 0) {
168
+ console.log(" No overrides registered.\n");
169
+ break;
170
+ }
171
+ if (active.length > 0) {
172
+ console.log(` Active Overrides (${active.length}):`);
173
+ console.log(" " + "─".repeat(58));
174
+ for (const o of active) {
175
+ console.log(` ${o.ruleId.padEnd(14)} ${o.reason.slice(0, 50)}`);
176
+ if (o.approver)
177
+ console.log(`${"".padEnd(16)} Approver: ${o.approver}`);
178
+ if (o.expiresAt)
179
+ console.log(`${"".padEnd(16)} Expires: ${o.expiresAt}`);
180
+ }
181
+ console.log("");
182
+ }
183
+ if (expired.length > 0) {
184
+ console.log(` Expired Overrides (${expired.length}):`);
185
+ for (const o of expired) {
186
+ console.log(` ${o.ruleId.padEnd(14)} expired ${o.expiresAt}`);
187
+ }
188
+ console.log("");
189
+ }
190
+ if (revoked.length > 0) {
191
+ console.log(` Revoked Overrides (${revoked.length}):`);
192
+ for (const o of revoked) {
193
+ console.log(` ${o.ruleId.padEnd(14)} revoked ${o.revokedAt || "unknown"}`);
194
+ }
195
+ console.log("");
196
+ }
197
+ break;
198
+ }
199
+ case "revoke": {
200
+ let ruleId = "";
201
+ let revokedBy = "";
202
+ for (let i = 4; i < argv.length; i++) {
203
+ switch (argv[i]) {
204
+ case "--rule":
205
+ case "-r":
206
+ ruleId = argv[++i] || "";
207
+ break;
208
+ case "--by":
209
+ revokedBy = argv[++i] || "";
210
+ break;
211
+ }
212
+ }
213
+ if (!ruleId) {
214
+ console.error("Error: --rule is required. Example: judges override revoke --rule SEC-001");
215
+ process.exit(1);
216
+ }
217
+ let revoked = 0;
218
+ for (const o of store.overrides) {
219
+ if (o.ruleId === ruleId && o.active) {
220
+ o.active = false;
221
+ o.revokedAt = new Date().toISOString();
222
+ o.revokedBy = revokedBy || undefined;
223
+ revoked++;
224
+ }
225
+ }
226
+ if (revoked > 0) {
227
+ saveOverrideStore(store);
228
+ console.log(` ✅ Revoked ${revoked} override(s) for ${ruleId}\n`);
229
+ }
230
+ else {
231
+ console.log(` No active overrides found for ${ruleId}\n`);
232
+ }
233
+ break;
234
+ }
235
+ case "check": {
236
+ let filePath = "";
237
+ for (let i = 4; i < argv.length; i++) {
238
+ if (argv[i] === "--file" || argv[i] === "-f")
239
+ filePath = argv[++i] || "";
240
+ else if (!argv[i].startsWith("-"))
241
+ filePath = argv[i];
242
+ }
243
+ const now = new Date().toISOString();
244
+ const active = store.overrides.filter((o) => o.active && (!o.expiresAt || o.expiresAt >= now));
245
+ if (active.length === 0) {
246
+ console.log(" No active overrides.\n");
247
+ break;
248
+ }
249
+ console.log(`\n Active overrides${filePath ? ` for ${filePath}` : ""}:`);
250
+ for (const o of active) {
251
+ const scopeMatch = !o.filePaths || o.filePaths.length === 0 || !filePath || o.filePaths.some((p) => filePath.includes(p));
252
+ const status = scopeMatch ? "✅ applies" : "⬜ out of scope";
253
+ console.log(` ${o.ruleId.padEnd(14)} ${status} — ${o.reason.slice(0, 50)}`);
254
+ }
255
+ console.log("");
256
+ break;
257
+ }
258
+ default:
259
+ console.error(`Unknown override subcommand: ${subcommand}`);
260
+ console.error("Usage: judges override <add|list|revoke|check>");
261
+ process.exit(1);
262
+ }
263
+ }
264
+ //# sourceMappingURL=override.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"override.js","sourceRoot":"","sources":["../../src/commands/override.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ /**
2
+ * `judges parity` — Language pattern parity audit.
3
+ *
4
+ * Audits the language-pattern library to identify gaps where a pattern
5
+ * concept exists for some languages but not others, helping maintainers
6
+ * prioritise pattern-writing effort.
7
+ *
8
+ * Usage:
9
+ * judges parity # text table
10
+ * judges parity --json # JSON output
11
+ * judges parity --lang python # filter to one language
12
+ */
13
+ import type { LangFamily } from "../types.js";
14
+ export interface PatternEntry {
15
+ name: string;
16
+ languages: LangFamily[];
17
+ missingLanguages: LangFamily[];
18
+ coverage: number;
19
+ }
20
+ export interface ParityReport {
21
+ patterns: PatternEntry[];
22
+ languageCoverage: Record<string, {
23
+ covered: number;
24
+ total: number;
25
+ pct: number;
26
+ }>;
27
+ overallCoverage: number;
28
+ }
29
+ export declare function analyzePatternParity(filterLang?: LangFamily): ParityReport;
30
+ export declare function runParity(argv: string[]): void;
31
+ //# sourceMappingURL=parity.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parity.d.ts","sourceRoot":"","sources":["../../src/commands/parity.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAK9C,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,UAAU,EAAE,CAAC;IACxB,gBAAgB,EAAE,UAAU,EAAE,CAAC;IAC/B,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,EAAE,YAAY,EAAE,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC,MAAM,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAClF,eAAe,EAAE,MAAM,CAAC;CACzB;AAmGD,wBAAgB,oBAAoB,CAAC,UAAU,CAAC,EAAE,UAAU,GAAG,YAAY,CAyD1E;AA2CD,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAuB9C"}
@@ -0,0 +1,213 @@
1
+ /**
2
+ * `judges parity` — Language pattern parity audit.
3
+ *
4
+ * Audits the language-pattern library to identify gaps where a pattern
5
+ * concept exists for some languages but not others, helping maintainers
6
+ * prioritise pattern-writing effort.
7
+ *
8
+ * Usage:
9
+ * judges parity # text table
10
+ * judges parity --json # JSON output
11
+ * judges parity --lang python # filter to one language
12
+ */
13
+ import * as LP from "../language-patterns.js";
14
+ // ─── Core Languages (excluding IaC-only and "unknown") ─────────────────────
15
+ const CORE_LANGUAGES = [
16
+ "javascript",
17
+ "typescript",
18
+ "python",
19
+ "rust",
20
+ "csharp",
21
+ "java",
22
+ "go",
23
+ "cpp",
24
+ "php",
25
+ "ruby",
26
+ "kotlin",
27
+ "swift",
28
+ "dart",
29
+ "bash",
30
+ ];
31
+ const IAC_LANGUAGES = ["terraform", "bicep", "arm"];
32
+ // ─── Pattern Catalogue ─────────────────────────────────────────────────────
33
+ function getPatternCatalogue() {
34
+ const catalogue = [];
35
+ // Core language patterns
36
+ const corePatterns = [
37
+ ["ENV_ACCESS", LP.ENV_ACCESS],
38
+ ["HARDCODED_ENV", LP.HARDCODED_ENV],
39
+ ["FUNCTION_DEF", LP.FUNCTION_DEF],
40
+ ["TRY_CATCH", LP.TRY_CATCH],
41
+ ["EMPTY_CATCH", LP.EMPTY_CATCH],
42
+ ["GENERIC_CATCH", LP.GENERIC_CATCH],
43
+ ["PANIC_UNWRAP", LP.PANIC_UNWRAP],
44
+ ["WEAK_TYPE", LP.WEAK_TYPE],
45
+ ["ASYNC_FUNCTION", LP.ASYNC_FUNCTION],
46
+ ["MISSING_AWAIT", LP.MISSING_AWAIT],
47
+ ["SHARED_MUTABLE", LP.SHARED_MUTABLE],
48
+ ["WILDCARD_IMPORT", LP.WILDCARD_IMPORT],
49
+ ["DEPRECATED_IMPORT", LP.DEPRECATED_IMPORT],
50
+ ["SQL_INJECTION", LP.SQL_INJECTION],
51
+ ["COMMAND_INJECTION", LP.COMMAND_INJECTION],
52
+ ["HARDCODED_PASSWORD", LP.HARDCODED_PASSWORD],
53
+ ["HARDCODED_API_KEY", LP.HARDCODED_API_KEY],
54
+ ["HARDCODED_SECRET", LP.HARDCODED_SECRET],
55
+ ["WEAK_HASH", LP.WEAK_HASH],
56
+ ["EVAL_USAGE", LP.EVAL_USAGE],
57
+ ["TLS_DISABLED", LP.TLS_DISABLED],
58
+ ["CORS_WILDCARD", LP.CORS_WILDCARD],
59
+ ["HTTP_ROUTE", LP.HTTP_ROUTE],
60
+ ["CONSOLE_LOG", LP.CONSOLE_LOG],
61
+ ["STRUCTURED_LOG", LP.STRUCTURED_LOG],
62
+ ["TEST_FUNCTION", LP.TEST_FUNCTION],
63
+ ["ASSERTION", LP.ASSERTION],
64
+ ["DOC_COMMENT", LP.DOC_COMMENT],
65
+ ["FOR_LOOP", LP.FOR_LOOP],
66
+ ["CLASS_DEF", LP.CLASS_DEF],
67
+ ["INPUT_VALIDATION", LP.INPUT_VALIDATION],
68
+ ["MUTEX", LP.MUTEX],
69
+ ["DB_QUERY", LP.DB_QUERY],
70
+ ["HTTP_CLIENT", LP.HTTP_CLIENT],
71
+ ["MAGIC_NUMBER", LP.MAGIC_NUMBER],
72
+ ["TODO_FIXME", LP.TODO_FIXME],
73
+ ["LINTER_DISABLE", LP.LINTER_DISABLE],
74
+ ["UNSAFE_DESERIALIZATION", LP.UNSAFE_DESERIALIZATION],
75
+ ["RESOURCE_LEAK", LP.RESOURCE_LEAK],
76
+ ["DEPRECATED_API", LP.DEPRECATED_API],
77
+ ];
78
+ for (const [name, obj] of corePatterns) {
79
+ catalogue.push({ name, obj, isIaC: false });
80
+ }
81
+ // IaC patterns
82
+ const iacPatterns = [
83
+ ["IAC_RESOURCE_DEF", LP.IAC_RESOURCE_DEF],
84
+ ["IAC_HARDCODED_SECRET", LP.IAC_HARDCODED_SECRET],
85
+ ["IAC_MISSING_ENCRYPTION", LP.IAC_MISSING_ENCRYPTION],
86
+ ["IAC_PUBLIC_ACCESS", LP.IAC_PUBLIC_ACCESS],
87
+ ["IAC_OPEN_NETWORK", LP.IAC_OPEN_NETWORK],
88
+ ["IAC_OVERPERMISSIVE_IAM", LP.IAC_OVERPERMISSIVE_IAM],
89
+ ["IAC_MISSING_HTTPS", LP.IAC_MISSING_HTTPS],
90
+ ["IAC_MISSING_LOGGING", LP.IAC_MISSING_LOGGING],
91
+ ["IAC_MISSING_TAGS_CHECK", LP.IAC_MISSING_TAGS_CHECK],
92
+ ["IAC_HARDCODED_LOCATION", LP.IAC_HARDCODED_LOCATION],
93
+ ["IAC_INSECURE_DEFAULT", LP.IAC_INSECURE_DEFAULT],
94
+ ["IAC_MISSING_BACKUP", LP.IAC_MISSING_BACKUP],
95
+ ];
96
+ for (const [name, obj] of iacPatterns) {
97
+ catalogue.push({ name, obj, isIaC: true });
98
+ }
99
+ return catalogue;
100
+ }
101
+ // ─── Parity Analysis ───────────────────────────────────────────────────────
102
+ export function analyzePatternParity(filterLang) {
103
+ const catalogue = getPatternCatalogue();
104
+ const patterns = [];
105
+ const langCounters = {};
106
+ for (const { name, obj, isIaC } of catalogue) {
107
+ const targetLangs = isIaC ? IAC_LANGUAGES : CORE_LANGUAGES;
108
+ const keys = Object.keys(obj);
109
+ // Resolve "jsts" shorthand to javascript + typescript
110
+ const covered = new Set();
111
+ for (const key of keys) {
112
+ if (key === "jsts") {
113
+ covered.add("javascript");
114
+ covered.add("typescript");
115
+ }
116
+ else {
117
+ covered.add(key);
118
+ }
119
+ }
120
+ const presentLangs = targetLangs.filter((l) => covered.has(l));
121
+ const missingLangs = targetLangs.filter((l) => !covered.has(l));
122
+ const coverage = presentLangs.length / targetLangs.length;
123
+ patterns.push({
124
+ name,
125
+ languages: presentLangs,
126
+ missingLanguages: missingLangs,
127
+ coverage,
128
+ });
129
+ for (const lang of targetLangs) {
130
+ if (!langCounters[lang])
131
+ langCounters[lang] = { covered: 0, total: 0 };
132
+ langCounters[lang].total++;
133
+ if (covered.has(lang))
134
+ langCounters[lang].covered++;
135
+ }
136
+ }
137
+ // Build per-language summaries
138
+ const languageCoverage = {};
139
+ for (const [lang, c] of Object.entries(langCounters)) {
140
+ if (filterLang && lang !== filterLang)
141
+ continue;
142
+ languageCoverage[lang] = {
143
+ covered: c.covered,
144
+ total: c.total,
145
+ pct: Math.round((c.covered / c.total) * 100),
146
+ };
147
+ }
148
+ const totalPairs = patterns.reduce((s, p) => s + p.languages.length, 0);
149
+ const maxPairs = patterns.reduce((s, p) => s + p.languages.length + p.missingLanguages.length, 0);
150
+ const overallCoverage = maxPairs > 0 ? Math.round((totalPairs / maxPairs) * 100) : 100;
151
+ // Sort: least coverage first
152
+ patterns.sort((a, b) => a.coverage - b.coverage);
153
+ return { patterns, languageCoverage, overallCoverage };
154
+ }
155
+ // ─── Formatters ─────────────────────────────────────────────────────────────
156
+ function formatParityText(report) {
157
+ const lines = [];
158
+ lines.push("╔══════════════════════════════════════════════════════════════╗");
159
+ lines.push("║ Judges Panel — Language Parity Audit ║");
160
+ lines.push("╚══════════════════════════════════════════════════════════════╝");
161
+ lines.push("");
162
+ lines.push(` Overall coverage: ${report.overallCoverage}%`);
163
+ lines.push("");
164
+ // Per-language coverage
165
+ lines.push(" Language Coverage:");
166
+ lines.push(" " + "─".repeat(50));
167
+ const langEntries = Object.entries(report.languageCoverage).sort((a, b) => a[1].pct - b[1].pct);
168
+ for (const [lang, c] of langEntries) {
169
+ const bar = "█".repeat(Math.round(c.pct / 5)) + "░".repeat(20 - Math.round(c.pct / 5));
170
+ lines.push(` ${lang.padEnd(14)} ${bar} ${String(c.pct).padStart(3)}% (${c.covered}/${c.total})`);
171
+ }
172
+ // Gaps list (patterns with < 100% coverage)
173
+ const gaps = report.patterns.filter((p) => p.coverage < 1);
174
+ if (gaps.length > 0) {
175
+ lines.push("");
176
+ lines.push(" Patterns with missing language support:");
177
+ lines.push(" " + "─".repeat(50));
178
+ for (const g of gaps) {
179
+ const pct = Math.round(g.coverage * 100);
180
+ lines.push(` ${g.name.padEnd(28)} ${String(pct).padStart(3)}% missing: ${g.missingLanguages.join(", ")}`);
181
+ }
182
+ }
183
+ else {
184
+ lines.push("");
185
+ lines.push(" ✅ All patterns have full language coverage!");
186
+ }
187
+ lines.push("");
188
+ return lines.join("\n");
189
+ }
190
+ // ─── CLI Command ────────────────────────────────────────────────────────────
191
+ export function runParity(argv) {
192
+ let format = "text";
193
+ let filterLang;
194
+ for (let i = 3; i < argv.length; i++) {
195
+ switch (argv[i]) {
196
+ case "--json":
197
+ format = "json";
198
+ break;
199
+ case "--lang":
200
+ case "-l":
201
+ filterLang = (argv[++i] || "unknown");
202
+ break;
203
+ }
204
+ }
205
+ const report = analyzePatternParity(filterLang);
206
+ if (format === "json") {
207
+ console.log(JSON.stringify(report, null, 2));
208
+ }
209
+ else {
210
+ console.log(formatParityText(report));
211
+ }
212
+ }
213
+ //# sourceMappingURL=parity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parity.js","sourceRoot":"","sources":["../../src/commands/parity.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,40 @@
1
+ /**
2
+ * `judges plugin search` — Plugin discovery from a curated registry.
3
+ *
4
+ * Uses a local JSON registry file (bundled with judges) to list available
5
+ * community and official plugins. No network calls — the registry is
6
+ * versioned alongside the codebase and updated when judges is updated.
7
+ *
8
+ * Usage:
9
+ * judges plugin search List all plugins
10
+ * judges plugin search security Search by keyword
11
+ * judges plugin search --category custom Filter by category
12
+ */
13
+ export interface PluginEntry {
14
+ /** Plugin npm package name or repo URL */
15
+ name: string;
16
+ /** Short description */
17
+ description: string;
18
+ /** Plugin version */
19
+ version: string;
20
+ /** Author or org */
21
+ author: string;
22
+ /** Category tags */
23
+ categories: string[];
24
+ /** Install command */
25
+ install: string;
26
+ /** Link to documentation or source */
27
+ url?: string;
28
+ /** Whether this is an official (first-party) plugin */
29
+ official?: boolean;
30
+ }
31
+ export interface PluginRegistry {
32
+ /** Registry format version */
33
+ version: string;
34
+ /** Last updated timestamp */
35
+ updatedAt: string;
36
+ /** Available plugins */
37
+ plugins: PluginEntry[];
38
+ }
39
+ export declare function runPluginSearch(argv: string[]): void;
40
+ //# sourceMappingURL=plugin-search.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"plugin-search.d.ts","sourceRoot":"","sources":["../../src/commands/plugin-search.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AASH,MAAM,WAAW,WAAW;IAC1B,0CAA0C;IAC1C,IAAI,EAAE,MAAM,CAAC;IACb,wBAAwB;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,qBAAqB;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,oBAAoB;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,oBAAoB;IACpB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,sBAAsB;IACtB,OAAO,EAAE,MAAM,CAAC;IAChB,sCAAsC;IACtC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,uDAAuD;IACvD,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,cAAc;IAC7B,8BAA8B;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,6BAA6B;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,wBAAwB;IACxB,OAAO,EAAE,WAAW,EAAE,CAAC;CACxB;AA8ID,wBAAgB,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAsDpD"}