@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.
- package/CHANGELOG.md +46 -0
- package/README.md +5 -4
- package/dist/api.d.ts +5 -2
- package/dist/api.d.ts.map +1 -1
- package/dist/api.js +5 -1
- package/dist/api.js.map +1 -1
- package/dist/ast/structural-parser.js +3 -3
- package/dist/ast/structural-parser.js.map +1 -1
- package/dist/calibration.d.ts +35 -0
- package/dist/calibration.d.ts.map +1 -1
- package/dist/calibration.js +52 -0
- package/dist/calibration.js.map +1 -1
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +307 -16
- package/dist/cli.js.map +1 -1
- package/dist/commands/benchmark-languages.js +4 -4
- package/dist/commands/benchmark.d.ts +2 -1
- package/dist/commands/benchmark.d.ts.map +1 -1
- package/dist/commands/benchmark.js +67 -2
- package/dist/commands/benchmark.js.map +1 -1
- package/dist/commands/calibration-dashboard.d.ts.map +1 -1
- package/dist/commands/calibration-dashboard.js +198 -0
- package/dist/commands/calibration-dashboard.js.map +1 -1
- package/dist/commands/calibration-share.d.ts +31 -0
- package/dist/commands/calibration-share.d.ts.map +1 -0
- package/dist/commands/calibration-share.js +183 -0
- package/dist/commands/calibration-share.js.map +1 -0
- package/dist/commands/compliance-report.d.ts +35 -0
- package/dist/commands/compliance-report.d.ts.map +1 -0
- package/dist/commands/compliance-report.js +162 -0
- package/dist/commands/compliance-report.js.map +1 -0
- package/dist/commands/diff.d.ts.map +1 -1
- package/dist/commands/diff.js +8 -3
- package/dist/commands/diff.js.map +1 -1
- package/dist/commands/feedback-rules.d.ts +29 -0
- package/dist/commands/feedback-rules.d.ts.map +1 -0
- package/dist/commands/feedback-rules.js +174 -0
- package/dist/commands/feedback-rules.js.map +1 -0
- package/dist/commands/feedback.d.ts +12 -0
- package/dist/commands/feedback.d.ts.map +1 -1
- package/dist/commands/feedback.js +16 -0
- package/dist/commands/feedback.js.map +1 -1
- package/dist/commands/fix.d.ts.map +1 -1
- package/dist/commands/fix.js +33 -1
- package/dist/commands/fix.js.map +1 -1
- package/dist/commands/governance.d.ts +32 -0
- package/dist/commands/governance.d.ts.map +1 -0
- package/dist/commands/governance.js +203 -0
- package/dist/commands/governance.js.map +1 -0
- package/dist/commands/help.d.ts +8 -0
- package/dist/commands/help.d.ts.map +1 -0
- package/dist/commands/help.js +303 -0
- package/dist/commands/help.js.map +1 -0
- package/dist/commands/hook.d.ts.map +1 -1
- package/dist/commands/hook.js +17 -20
- package/dist/commands/hook.js.map +1 -1
- package/dist/commands/llm-benchmark.d.ts +119 -0
- package/dist/commands/llm-benchmark.d.ts.map +1 -0
- package/dist/commands/llm-benchmark.js +396 -0
- package/dist/commands/llm-benchmark.js.map +1 -0
- package/dist/commands/metrics-dashboard.d.ts +22 -0
- package/dist/commands/metrics-dashboard.d.ts.map +1 -0
- package/dist/commands/metrics-dashboard.js +335 -0
- package/dist/commands/metrics-dashboard.js.map +1 -0
- package/dist/commands/metrics.d.ts +58 -0
- package/dist/commands/metrics.d.ts.map +1 -0
- package/dist/commands/metrics.js +242 -0
- package/dist/commands/metrics.js.map +1 -0
- package/dist/commands/onboard.d.ts +13 -0
- package/dist/commands/onboard.d.ts.map +1 -0
- package/dist/commands/onboard.js +179 -0
- package/dist/commands/onboard.js.map +1 -0
- package/dist/commands/org-metrics.d.ts +24 -0
- package/dist/commands/org-metrics.d.ts.map +1 -0
- package/dist/commands/org-metrics.js +238 -0
- package/dist/commands/org-metrics.js.map +1 -0
- package/dist/commands/override.d.ts +62 -0
- package/dist/commands/override.d.ts.map +1 -0
- package/dist/commands/override.js +264 -0
- package/dist/commands/override.js.map +1 -0
- package/dist/commands/parity.d.ts +31 -0
- package/dist/commands/parity.d.ts.map +1 -0
- package/dist/commands/parity.js +213 -0
- package/dist/commands/parity.js.map +1 -0
- package/dist/commands/plugin-search.d.ts +40 -0
- package/dist/commands/plugin-search.d.ts.map +1 -0
- package/dist/commands/plugin-search.js +328 -0
- package/dist/commands/plugin-search.js.map +1 -0
- package/dist/commands/plugins.d.ts +13 -0
- package/dist/commands/plugins.d.ts.map +1 -0
- package/dist/commands/plugins.js +105 -0
- package/dist/commands/plugins.js.map +1 -0
- package/dist/commands/review.js +1 -1
- package/dist/commands/review.js.map +1 -1
- package/dist/commands/snapshot.d.ts +27 -0
- package/dist/commands/snapshot.d.ts.map +1 -1
- package/dist/commands/snapshot.js +99 -0
- package/dist/commands/snapshot.js.map +1 -1
- package/dist/commands/trace.d.ts +65 -0
- package/dist/commands/trace.d.ts.map +1 -0
- package/dist/commands/trace.js +246 -0
- package/dist/commands/trace.js.map +1 -0
- package/dist/commands/trust-ramp.d.ts +30 -0
- package/dist/commands/trust-ramp.d.ts.map +1 -0
- package/dist/commands/trust-ramp.js +190 -0
- package/dist/commands/trust-ramp.js.map +1 -0
- package/dist/config.d.ts +5 -0
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +65 -0
- package/dist/config.js.map +1 -1
- package/dist/data-adapter.d.ts +124 -0
- package/dist/data-adapter.d.ts.map +1 -0
- package/dist/data-adapter.js +213 -0
- package/dist/data-adapter.js.map +1 -0
- package/dist/evaluators/accessibility.js +1 -1
- package/dist/evaluators/accessibility.js.map +1 -1
- package/dist/evaluators/ai-code-safety.d.ts.map +1 -1
- package/dist/evaluators/ai-code-safety.js +1 -4
- package/dist/evaluators/ai-code-safety.js.map +1 -1
- package/dist/evaluators/cost-effectiveness.js +1 -1
- package/dist/evaluators/cost-effectiveness.js.map +1 -1
- package/dist/evaluators/false-positive-review.js +4 -4
- package/dist/evaluators/false-positive-review.js.map +1 -1
- package/dist/evaluators/iac-security.js +1 -1
- package/dist/evaluators/iac-security.js.map +1 -1
- package/dist/evaluators/index.d.ts.map +1 -1
- package/dist/evaluators/index.js +59 -10
- package/dist/evaluators/index.js.map +1 -1
- package/dist/evaluators/intent-alignment.d.ts +4 -0
- package/dist/evaluators/intent-alignment.d.ts.map +1 -1
- package/dist/evaluators/intent-alignment.js +163 -0
- package/dist/evaluators/intent-alignment.js.map +1 -1
- package/dist/evaluators/logic-review.js +1 -1
- package/dist/evaluators/logic-review.js.map +1 -1
- package/dist/evaluators/maintainability.js +1 -1
- package/dist/evaluators/maintainability.js.map +1 -1
- package/dist/evaluators/over-engineering.js +3 -3
- package/dist/evaluators/over-engineering.js.map +1 -1
- package/dist/evaluators/project.d.ts +12 -0
- package/dist/evaluators/project.d.ts.map +1 -1
- package/dist/evaluators/project.js +86 -0
- package/dist/evaluators/project.js.map +1 -1
- package/dist/evaluators/security.js +2 -2
- package/dist/evaluators/security.js.map +1 -1
- package/dist/evaluators/ux.js +1 -1
- package/dist/evaluators/ux.js.map +1 -1
- package/dist/finding-lifecycle.d.ts +9 -0
- package/dist/finding-lifecycle.d.ts.map +1 -1
- package/dist/finding-lifecycle.js +15 -0
- package/dist/finding-lifecycle.js.map +1 -1
- package/dist/fix-history.d.ts +9 -0
- package/dist/fix-history.d.ts.map +1 -1
- package/dist/fix-history.js +15 -0
- package/dist/fix-history.js.map +1 -1
- package/dist/formatters/sarif.d.ts +3 -0
- package/dist/formatters/sarif.d.ts.map +1 -1
- package/dist/formatters/sarif.js +36 -12
- package/dist/formatters/sarif.js.map +1 -1
- package/dist/github-app.d.ts +16 -1
- package/dist/github-app.d.ts.map +1 -1
- package/dist/github-app.js +85 -2
- package/dist/github-app.js.map +1 -1
- package/dist/index.js +5 -0
- package/dist/index.js.map +1 -1
- package/dist/judge-registry.d.ts +157 -0
- package/dist/judge-registry.d.ts.map +1 -0
- package/dist/judge-registry.js +273 -0
- package/dist/judge-registry.js.map +1 -0
- package/dist/judges/accessibility.d.ts.map +1 -1
- package/dist/judges/accessibility.js +4 -0
- package/dist/judges/accessibility.js.map +1 -1
- package/dist/judges/agent-instructions.d.ts.map +1 -1
- package/dist/judges/agent-instructions.js +4 -0
- package/dist/judges/agent-instructions.js.map +1 -1
- package/dist/judges/ai-code-safety.d.ts.map +1 -1
- package/dist/judges/ai-code-safety.js +4 -0
- package/dist/judges/ai-code-safety.js.map +1 -1
- package/dist/judges/api-contract.d.ts.map +1 -1
- package/dist/judges/api-contract.js +4 -0
- package/dist/judges/api-contract.js.map +1 -1
- package/dist/judges/api-design.d.ts.map +1 -1
- package/dist/judges/api-design.js +4 -0
- package/dist/judges/api-design.js.map +1 -1
- package/dist/judges/authentication.d.ts.map +1 -1
- package/dist/judges/authentication.js +4 -0
- package/dist/judges/authentication.js.map +1 -1
- package/dist/judges/backwards-compatibility.d.ts.map +1 -1
- package/dist/judges/backwards-compatibility.js +4 -0
- package/dist/judges/backwards-compatibility.js.map +1 -1
- package/dist/judges/caching.d.ts.map +1 -1
- package/dist/judges/caching.js +4 -0
- package/dist/judges/caching.js.map +1 -1
- package/dist/judges/ci-cd.d.ts.map +1 -1
- package/dist/judges/ci-cd.js +4 -0
- package/dist/judges/ci-cd.js.map +1 -1
- package/dist/judges/cloud-readiness.d.ts.map +1 -1
- package/dist/judges/cloud-readiness.js +4 -0
- package/dist/judges/cloud-readiness.js.map +1 -1
- package/dist/judges/code-structure.d.ts.map +1 -1
- package/dist/judges/code-structure.js +4 -0
- package/dist/judges/code-structure.js.map +1 -1
- package/dist/judges/compliance.d.ts.map +1 -1
- package/dist/judges/compliance.js +4 -0
- package/dist/judges/compliance.js.map +1 -1
- package/dist/judges/concurrency.d.ts.map +1 -1
- package/dist/judges/concurrency.js +4 -0
- package/dist/judges/concurrency.js.map +1 -1
- package/dist/judges/configuration-management.d.ts.map +1 -1
- package/dist/judges/configuration-management.js +4 -0
- package/dist/judges/configuration-management.js.map +1 -1
- package/dist/judges/cost-effectiveness.d.ts.map +1 -1
- package/dist/judges/cost-effectiveness.js +4 -0
- package/dist/judges/cost-effectiveness.js.map +1 -1
- package/dist/judges/cybersecurity.d.ts.map +1 -1
- package/dist/judges/cybersecurity.js +4 -0
- package/dist/judges/cybersecurity.js.map +1 -1
- package/dist/judges/data-security.d.ts.map +1 -1
- package/dist/judges/data-security.js +4 -0
- package/dist/judges/data-security.js.map +1 -1
- package/dist/judges/data-sovereignty.d.ts.map +1 -1
- package/dist/judges/data-sovereignty.js +4 -0
- package/dist/judges/data-sovereignty.js.map +1 -1
- package/dist/judges/database.d.ts.map +1 -1
- package/dist/judges/database.js +4 -0
- package/dist/judges/database.js.map +1 -1
- package/dist/judges/dependency-health.d.ts.map +1 -1
- package/dist/judges/dependency-health.js +4 -0
- package/dist/judges/dependency-health.js.map +1 -1
- package/dist/judges/documentation.d.ts.map +1 -1
- package/dist/judges/documentation.js +4 -0
- package/dist/judges/documentation.js.map +1 -1
- package/dist/judges/error-handling.d.ts.map +1 -1
- package/dist/judges/error-handling.js +4 -0
- package/dist/judges/error-handling.js.map +1 -1
- package/dist/judges/ethics-bias.d.ts.map +1 -1
- package/dist/judges/ethics-bias.js +4 -0
- package/dist/judges/ethics-bias.js.map +1 -1
- package/dist/judges/false-positive-review.d.ts.map +1 -1
- package/dist/judges/false-positive-review.js +2 -0
- package/dist/judges/false-positive-review.js.map +1 -1
- package/dist/judges/framework-safety.d.ts.map +1 -1
- package/dist/judges/framework-safety.js +4 -0
- package/dist/judges/framework-safety.js.map +1 -1
- package/dist/judges/hallucination-detection.d.ts.map +1 -1
- package/dist/judges/hallucination-detection.js +4 -0
- package/dist/judges/hallucination-detection.js.map +1 -1
- package/dist/judges/iac-security.d.ts.map +1 -1
- package/dist/judges/iac-security.js +4 -0
- package/dist/judges/iac-security.js.map +1 -1
- package/dist/judges/index.d.ts +59 -0
- package/dist/judges/index.d.ts.map +1 -1
- package/dist/judges/index.js +65 -189
- package/dist/judges/index.js.map +1 -1
- package/dist/judges/intent-alignment.d.ts.map +1 -1
- package/dist/judges/intent-alignment.js +4 -0
- package/dist/judges/intent-alignment.js.map +1 -1
- package/dist/judges/internationalization.d.ts.map +1 -1
- package/dist/judges/internationalization.js +4 -0
- package/dist/judges/internationalization.js.map +1 -1
- package/dist/judges/logging-privacy.d.ts.map +1 -1
- package/dist/judges/logging-privacy.js +4 -0
- package/dist/judges/logging-privacy.js.map +1 -1
- package/dist/judges/logic-review.d.ts.map +1 -1
- package/dist/judges/logic-review.js +4 -0
- package/dist/judges/logic-review.js.map +1 -1
- package/dist/judges/maintainability.d.ts.map +1 -1
- package/dist/judges/maintainability.js +4 -0
- package/dist/judges/maintainability.js.map +1 -1
- package/dist/judges/model-fingerprint.d.ts.map +1 -1
- package/dist/judges/model-fingerprint.js +4 -0
- package/dist/judges/model-fingerprint.js.map +1 -1
- package/dist/judges/multi-turn-coherence.d.ts.map +1 -1
- package/dist/judges/multi-turn-coherence.js +4 -0
- package/dist/judges/multi-turn-coherence.js.map +1 -1
- package/dist/judges/observability.d.ts.map +1 -1
- package/dist/judges/observability.js +4 -0
- package/dist/judges/observability.js.map +1 -1
- package/dist/judges/over-engineering.d.ts.map +1 -1
- package/dist/judges/over-engineering.js +4 -0
- package/dist/judges/over-engineering.js.map +1 -1
- package/dist/judges/performance.d.ts.map +1 -1
- package/dist/judges/performance.js +4 -0
- package/dist/judges/performance.js.map +1 -1
- package/dist/judges/portability.d.ts.map +1 -1
- package/dist/judges/portability.js +4 -0
- package/dist/judges/portability.js.map +1 -1
- package/dist/judges/rate-limiting.d.ts.map +1 -1
- package/dist/judges/rate-limiting.js +4 -0
- package/dist/judges/rate-limiting.js.map +1 -1
- package/dist/judges/reliability.d.ts.map +1 -1
- package/dist/judges/reliability.js +4 -0
- package/dist/judges/reliability.js.map +1 -1
- package/dist/judges/scalability.d.ts.map +1 -1
- package/dist/judges/scalability.js +4 -0
- package/dist/judges/scalability.js.map +1 -1
- package/dist/judges/security.d.ts.map +1 -1
- package/dist/judges/security.js +4 -0
- package/dist/judges/security.js.map +1 -1
- package/dist/judges/software-practices.d.ts.map +1 -1
- package/dist/judges/software-practices.js +4 -0
- package/dist/judges/software-practices.js.map +1 -1
- package/dist/judges/testing.d.ts.map +1 -1
- package/dist/judges/testing.js +4 -0
- package/dist/judges/testing.js.map +1 -1
- package/dist/judges/ux.d.ts.map +1 -1
- package/dist/judges/ux.js +4 -0
- package/dist/judges/ux.js.map +1 -1
- package/dist/plugins.d.ts +8 -51
- package/dist/plugins.d.ts.map +1 -1
- package/dist/plugins.js +16 -125
- package/dist/plugins.js.map +1 -1
- package/dist/security-ids.d.ts +24 -0
- package/dist/security-ids.d.ts.map +1 -0
- package/dist/security-ids.js +240 -0
- package/dist/security-ids.js.map +1 -0
- package/dist/tools/prompts.d.ts +4 -0
- package/dist/tools/prompts.d.ts.map +1 -1
- package/dist/tools/prompts.js +6 -4
- package/dist/tools/prompts.js.map +1 -1
- package/dist/tools/register-scaffold.d.ts +3 -0
- package/dist/tools/register-scaffold.d.ts.map +1 -0
- package/dist/tools/register-scaffold.js +399 -0
- package/dist/tools/register-scaffold.js.map +1 -0
- package/dist/tools/register.d.ts +1 -1
- package/dist/tools/register.d.ts.map +1 -1
- package/dist/tools/register.js +3 -1
- package/dist/tools/register.js.map +1 -1
- package/dist/types.d.ts +75 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +3 -2
- 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"}
|