@kevinrabun/judges 3.42.0 → 3.44.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 (74) hide show
  1. package/CHANGELOG.md +25 -0
  2. package/dist/cli.d.ts.map +1 -1
  3. package/dist/cli.js +112 -0
  4. package/dist/cli.js.map +1 -1
  5. package/dist/commands/assign-findings.d.ts +37 -0
  6. package/dist/commands/assign-findings.d.ts.map +1 -0
  7. package/dist/commands/assign-findings.js +178 -0
  8. package/dist/commands/assign-findings.js.map +1 -0
  9. package/dist/commands/burndown.d.ts +27 -0
  10. package/dist/commands/burndown.d.ts.map +1 -0
  11. package/dist/commands/burndown.js +180 -0
  12. package/dist/commands/burndown.js.map +1 -0
  13. package/dist/commands/ci-template.d.ts +15 -0
  14. package/dist/commands/ci-template.d.ts.map +1 -0
  15. package/dist/commands/ci-template.js +212 -0
  16. package/dist/commands/ci-template.js.map +1 -0
  17. package/dist/commands/false-negatives.d.ts +35 -0
  18. package/dist/commands/false-negatives.d.ts.map +1 -0
  19. package/dist/commands/false-negatives.js +166 -0
  20. package/dist/commands/false-negatives.js.map +1 -0
  21. package/dist/commands/hook-install.d.ts +22 -0
  22. package/dist/commands/hook-install.d.ts.map +1 -0
  23. package/dist/commands/hook-install.js +143 -0
  24. package/dist/commands/hook-install.js.map +1 -0
  25. package/dist/commands/kb.d.ts +41 -0
  26. package/dist/commands/kb.d.ts.map +1 -0
  27. package/dist/commands/kb.js +231 -0
  28. package/dist/commands/kb.js.map +1 -0
  29. package/dist/commands/noise-advisor.d.ts +30 -0
  30. package/dist/commands/noise-advisor.d.ts.map +1 -0
  31. package/dist/commands/noise-advisor.js +171 -0
  32. package/dist/commands/noise-advisor.js.map +1 -0
  33. package/dist/commands/policy-audit.d.ts +53 -0
  34. package/dist/commands/policy-audit.d.ts.map +1 -0
  35. package/dist/commands/policy-audit.js +161 -0
  36. package/dist/commands/policy-audit.js.map +1 -0
  37. package/dist/commands/recommend.d.ts +21 -0
  38. package/dist/commands/recommend.d.ts.map +1 -0
  39. package/dist/commands/recommend.js +283 -0
  40. package/dist/commands/recommend.js.map +1 -0
  41. package/dist/commands/regression-alert.d.ts +32 -0
  42. package/dist/commands/regression-alert.d.ts.map +1 -0
  43. package/dist/commands/regression-alert.js +216 -0
  44. package/dist/commands/regression-alert.js.map +1 -0
  45. package/dist/commands/remediation.d.ts +21 -0
  46. package/dist/commands/remediation.d.ts.map +1 -0
  47. package/dist/commands/remediation.js +257 -0
  48. package/dist/commands/remediation.js.map +1 -0
  49. package/dist/commands/report-template.d.ts +17 -0
  50. package/dist/commands/report-template.d.ts.map +1 -0
  51. package/dist/commands/report-template.js +291 -0
  52. package/dist/commands/report-template.js.map +1 -0
  53. package/dist/commands/review-queue.d.ts +34 -0
  54. package/dist/commands/review-queue.d.ts.map +1 -0
  55. package/dist/commands/review-queue.js +226 -0
  56. package/dist/commands/review-queue.js.map +1 -0
  57. package/dist/commands/rule-owner.d.ts +31 -0
  58. package/dist/commands/rule-owner.d.ts.map +1 -0
  59. package/dist/commands/rule-owner.js +182 -0
  60. package/dist/commands/rule-owner.js.map +1 -0
  61. package/dist/commands/sla-track.d.ts +57 -0
  62. package/dist/commands/sla-track.d.ts.map +1 -0
  63. package/dist/commands/sla-track.js +269 -0
  64. package/dist/commands/sla-track.js.map +1 -0
  65. package/dist/commands/suppress.d.ts +40 -0
  66. package/dist/commands/suppress.d.ts.map +1 -0
  67. package/dist/commands/suppress.js +209 -0
  68. package/dist/commands/suppress.js.map +1 -0
  69. package/dist/commands/ticket-sync.d.ts +26 -0
  70. package/dist/commands/ticket-sync.d.ts.map +1 -0
  71. package/dist/commands/ticket-sync.js +236 -0
  72. package/dist/commands/ticket-sync.js.map +1 -0
  73. package/package.json +1 -1
  74. package/server.json +2 -2
@@ -0,0 +1,35 @@
1
+ /**
2
+ * False-negative report — collect and analyze cases where Judges
3
+ * missed a real vulnerability or bug that was later found manually.
4
+ *
5
+ * Builds a local feedback database (.judges-false-negatives.json)
6
+ * that helps teams understand blind spots and request new rules.
7
+ */
8
+ export interface FalseNegativeEntry {
9
+ id: string;
10
+ timestamp: string;
11
+ file: string;
12
+ line?: number;
13
+ category: string;
14
+ description: string;
15
+ severity: string;
16
+ expectedRule?: string;
17
+ language: string;
18
+ codeSnippet?: string;
19
+ reportedBy?: string;
20
+ status: "open" | "rule-added" | "wont-fix" | "duplicate";
21
+ }
22
+ export interface FalseNegativeDb {
23
+ entries: FalseNegativeEntry[];
24
+ version: string;
25
+ }
26
+ export declare function addFalseNegative(entry: Omit<FalseNegativeEntry, "id" | "timestamp" | "status">): FalseNegativeEntry;
27
+ export declare function getFalseNegativeStats(db: FalseNegativeDb): {
28
+ total: number;
29
+ open: number;
30
+ byCategory: Record<string, number>;
31
+ bySeverity: Record<string, number>;
32
+ byLanguage: Record<string, number>;
33
+ };
34
+ export declare function runFalseNegativeReport(argv: string[]): void;
35
+ //# sourceMappingURL=false-negatives.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"false-negatives.d.ts","sourceRoot":"","sources":["../../src/commands/false-negatives.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAMH,MAAM,WAAW,kBAAkB;IACjC,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,MAAM,GAAG,YAAY,GAAG,UAAU,GAAG,WAAW,CAAC;CAC1D;AAED,MAAM,WAAW,eAAe;IAC9B,OAAO,EAAE,kBAAkB,EAAE,CAAC;IAC9B,OAAO,EAAE,MAAM,CAAC;CACjB;AAuBD,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,EAAE,IAAI,GAAG,WAAW,GAAG,QAAQ,CAAC,GAAG,kBAAkB,CAcnH;AAED,wBAAgB,qBAAqB,CAAC,EAAE,EAAE,eAAe,GAAG;IAC1D,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACnC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACnC,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACpC,CAaA;AAID,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CA2G3D"}
@@ -0,0 +1,166 @@
1
+ /**
2
+ * False-negative report — collect and analyze cases where Judges
3
+ * missed a real vulnerability or bug that was later found manually.
4
+ *
5
+ * Builds a local feedback database (.judges-false-negatives.json)
6
+ * that helps teams understand blind spots and request new rules.
7
+ */
8
+ import { createHash } from "crypto";
9
+ // ─── Database ───────────────────────────────────────────────────────────────
10
+ const DB_FILE = ".judges-false-negatives.json";
11
+ function loadDb() {
12
+ const { readFileSync, existsSync } = require("fs");
13
+ if (existsSync(DB_FILE)) {
14
+ try {
15
+ return JSON.parse(readFileSync(DB_FILE, "utf-8"));
16
+ }
17
+ catch {
18
+ /* corrupt */
19
+ }
20
+ }
21
+ return { entries: [], version: "1.0" };
22
+ }
23
+ function saveDb(db) {
24
+ const { writeFileSync } = require("fs");
25
+ writeFileSync(DB_FILE, JSON.stringify(db, null, 2), "utf-8");
26
+ }
27
+ export function addFalseNegative(entry) {
28
+ const db = loadDb();
29
+ const fn = {
30
+ ...entry,
31
+ id: createHash("sha256")
32
+ .update(Date.now().toString() + entry.file + entry.description)
33
+ .digest("hex")
34
+ .slice(0, 10),
35
+ timestamp: new Date().toISOString(),
36
+ status: "open",
37
+ };
38
+ db.entries.push(fn);
39
+ saveDb(db);
40
+ return fn;
41
+ }
42
+ export function getFalseNegativeStats(db) {
43
+ const open = db.entries.filter((e) => e.status === "open").length;
44
+ const byCategory = {};
45
+ const bySeverity = {};
46
+ const byLanguage = {};
47
+ for (const e of db.entries) {
48
+ byCategory[e.category] = (byCategory[e.category] || 0) + 1;
49
+ bySeverity[e.severity] = (bySeverity[e.severity] || 0) + 1;
50
+ byLanguage[e.language] = (byLanguage[e.language] || 0) + 1;
51
+ }
52
+ return { total: db.entries.length, open, byCategory, bySeverity, byLanguage };
53
+ }
54
+ // ─── CLI ────────────────────────────────────────────────────────────────────
55
+ export function runFalseNegativeReport(argv) {
56
+ if (argv.includes("--help") || argv.includes("-h")) {
57
+ console.log(`
58
+ judges false-negatives — Report and track missed vulnerabilities
59
+
60
+ Usage:
61
+ judges false-negatives Show report
62
+ judges false-negatives --add --file src/app.ts \\
63
+ --line 42 --category injection --severity high \\
64
+ --description "SQL injection via user input" Add a missed finding
65
+ judges false-negatives --resolve <id> Mark as resolved
66
+
67
+ Options:
68
+ --add Add a new false-negative report
69
+ --file <path> File where the issue was found
70
+ --line <n> Line number
71
+ --category <cat> Category (injection, auth, crypto, xss, etc.)
72
+ --severity <level> Severity (critical, high, medium, low)
73
+ --description <text> Description of what was missed
74
+ --language <lang> Language (auto-detected from file)
75
+ --resolve <id> Mark entry as resolved
76
+ --format json JSON output
77
+ --help, -h Show this help
78
+
79
+ This builds a local feedback database that helps identify blind spots
80
+ in the current rule set, informing future rule development.
81
+ `);
82
+ return;
83
+ }
84
+ const format = argv.find((_a, i) => argv[i - 1] === "--format") || "text";
85
+ if (argv.includes("--add")) {
86
+ const file = argv.find((_a, i) => argv[i - 1] === "--file") || "";
87
+ const lineStr = argv.find((_a, i) => argv[i - 1] === "--line");
88
+ const category = argv.find((_a, i) => argv[i - 1] === "--category") || "unknown";
89
+ const severity = argv.find((_a, i) => argv[i - 1] === "--severity") || "medium";
90
+ const description = argv.find((_a, i) => argv[i - 1] === "--description") || "";
91
+ const language = argv.find((_a, i) => argv[i - 1] === "--language") || detectLanguage(file);
92
+ if (!file || !description) {
93
+ console.error("Error: --file and --description required");
94
+ process.exit(1);
95
+ }
96
+ const entry = addFalseNegative({
97
+ file,
98
+ line: lineStr ? parseInt(lineStr, 10) : undefined,
99
+ category,
100
+ severity,
101
+ description,
102
+ language,
103
+ });
104
+ console.log(` ✅ Added false-negative report: ${entry.id}`);
105
+ return;
106
+ }
107
+ const resolveId = argv.find((_a, i) => argv[i - 1] === "--resolve");
108
+ if (resolveId) {
109
+ const db = loadDb();
110
+ const entry = db.entries.find((e) => e.id === resolveId);
111
+ if (!entry) {
112
+ console.error(`Error: entry ${resolveId} not found`);
113
+ process.exit(1);
114
+ }
115
+ entry.status = "rule-added";
116
+ saveDb(db);
117
+ console.log(` ✅ Resolved: ${resolveId}`);
118
+ return;
119
+ }
120
+ // Show report
121
+ const db = loadDb();
122
+ if (db.entries.length === 0) {
123
+ console.log("\n No false-negative reports. Use --add to report a missed finding.\n");
124
+ return;
125
+ }
126
+ const stats = getFalseNegativeStats(db);
127
+ if (format === "json") {
128
+ console.log(JSON.stringify({ stats, entries: db.entries }, null, 2));
129
+ return;
130
+ }
131
+ console.log(`\n False-Negative Analysis\n`);
132
+ console.log(` Total: ${stats.total} | Open: ${stats.open}\n`);
133
+ console.log(" By Category:");
134
+ for (const [cat, count] of Object.entries(stats.byCategory).sort((a, b) => b[1] - a[1])) {
135
+ console.log(` ${cat.padEnd(20)} ${count}`);
136
+ }
137
+ console.log("\n By Severity:");
138
+ for (const [sev, count] of Object.entries(stats.bySeverity).sort((a, b) => b[1] - a[1])) {
139
+ console.log(` ${sev.padEnd(20)} ${count}`);
140
+ }
141
+ console.log("\n Recent entries:");
142
+ for (const e of db.entries.slice(-10)) {
143
+ const status = e.status === "open" ? "🔴" : "✅";
144
+ console.log(` ${status} ${e.id} ${e.severity.padEnd(8)} ${e.category.padEnd(15)} ${e.description.slice(0, 50)}`);
145
+ }
146
+ console.log("");
147
+ }
148
+ function detectLanguage(file) {
149
+ const { extname } = require("path");
150
+ const ext = extname(file).toLowerCase();
151
+ const map = {
152
+ ".ts": "typescript",
153
+ ".tsx": "typescript",
154
+ ".js": "javascript",
155
+ ".jsx": "javascript",
156
+ ".py": "python",
157
+ ".go": "go",
158
+ ".rs": "rust",
159
+ ".java": "java",
160
+ ".cs": "csharp",
161
+ ".rb": "ruby",
162
+ ".php": "php",
163
+ };
164
+ return map[ext] || "unknown";
165
+ }
166
+ //# sourceMappingURL=false-negatives.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"false-negatives.js","sourceRoot":"","sources":["../../src/commands/false-negatives.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Hook install — install and configure git hooks for pre-commit
3
+ * and pre-push evaluation with Judges.
4
+ *
5
+ * Supports husky, simple-git-hooks, and direct .git/hooks installation.
6
+ */
7
+ export interface HookConfig {
8
+ /** Hook type: pre-commit or pre-push */
9
+ hook: "pre-commit" | "pre-push";
10
+ /** Only evaluate staged files */
11
+ stagedOnly: boolean;
12
+ /** Fail on findings of this severity or higher */
13
+ failSeverity: string;
14
+ /** Timeout in seconds */
15
+ timeout: number;
16
+ /** Run in parallel */
17
+ parallel: boolean;
18
+ /** Use smart judge selection */
19
+ smartSelect: boolean;
20
+ }
21
+ export declare function runHookInstall(argv: string[]): void;
22
+ //# sourceMappingURL=hook-install.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hook-install.d.ts","sourceRoot":"","sources":["../../src/commands/hook-install.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,MAAM,WAAW,UAAU;IACzB,wCAAwC;IACxC,IAAI,EAAE,YAAY,GAAG,UAAU,CAAC;IAChC,iCAAiC;IACjC,UAAU,EAAE,OAAO,CAAC;IACpB,kDAAkD;IAClD,YAAY,EAAE,MAAM,CAAC;IACrB,yBAAyB;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,sBAAsB;IACtB,QAAQ,EAAE,OAAO,CAAC;IAClB,gCAAgC;IAChC,WAAW,EAAE,OAAO,CAAC;CACtB;AAoFD,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAoEnD"}
@@ -0,0 +1,143 @@
1
+ /**
2
+ * Hook install — install and configure git hooks for pre-commit
3
+ * and pre-push evaluation with Judges.
4
+ *
5
+ * Supports husky, simple-git-hooks, and direct .git/hooks installation.
6
+ */
7
+ // ─── Hook Scripts ───────────────────────────────────────────────────────────
8
+ function generateHookScript(config) {
9
+ const flags = [];
10
+ if (config.stagedOnly)
11
+ flags.push("--staged-only");
12
+ if (config.failSeverity !== "info")
13
+ flags.push(`--min-severity ${config.failSeverity}`);
14
+ flags.push("--fail-on-findings");
15
+ flags.push("--summary");
16
+ return `#!/bin/sh
17
+ # Judges ${config.hook} hook
18
+ # Auto-generated by: judges hook-install
19
+
20
+ # Skip if JUDGES_SKIP_HOOK is set
21
+ if [ -n "$JUDGES_SKIP_HOOK" ]; then
22
+ echo "Judges: hook skipped (JUDGES_SKIP_HOOK is set)"
23
+ exit 0
24
+ fi
25
+
26
+ # Timeout protection (${config.timeout}s)
27
+ timeout_cmd=""
28
+ if command -v timeout > /dev/null 2>&1; then
29
+ timeout_cmd="timeout ${config.timeout}"
30
+ fi
31
+
32
+ echo "🔍 Judges: evaluating..."
33
+ $timeout_cmd npx judges eval ${flags.join(" ")} 2>&1
34
+ exit_code=$?
35
+
36
+ if [ $exit_code -ne 0 ] && [ $exit_code -ne 124 ]; then
37
+ echo ""
38
+ echo "❌ Judges: findings detected. Fix or skip with JUDGES_SKIP_HOOK=1"
39
+ exit 1
40
+ fi
41
+
42
+ if [ $exit_code -eq 124 ]; then
43
+ echo "⚠️ Judges: evaluation timed out (${config.timeout}s). Proceeding."
44
+ fi
45
+ `;
46
+ }
47
+ // ─── Installation Methods ───────────────────────────────────────────────────
48
+ function installDirect(hookType, script) {
49
+ const { writeFileSync, mkdirSync, chmodSync, existsSync } = require("fs");
50
+ const { join } = require("path");
51
+ const hooksDir = join(".git", "hooks");
52
+ if (!existsSync(".git")) {
53
+ console.error("Error: not a git repository");
54
+ return false;
55
+ }
56
+ mkdirSync(hooksDir, { recursive: true });
57
+ const hookPath = join(hooksDir, hookType);
58
+ writeFileSync(hookPath, script, { mode: 0o755 });
59
+ try {
60
+ chmodSync(hookPath, 0o755);
61
+ }
62
+ catch {
63
+ /* Windows */
64
+ }
65
+ console.log(` ✅ Installed ${hookPath}`);
66
+ return true;
67
+ }
68
+ function installHusky(hookType, script) {
69
+ const { existsSync, writeFileSync, mkdirSync } = require("fs");
70
+ const { join } = require("path");
71
+ if (!existsSync(".husky")) {
72
+ console.log(" Husky directory not found. Creating .husky/");
73
+ mkdirSync(".husky", { recursive: true });
74
+ }
75
+ const hookPath = join(".husky", hookType);
76
+ writeFileSync(hookPath, script, { mode: 0o755 });
77
+ console.log(` ✅ Installed ${hookPath} (husky)`);
78
+ return true;
79
+ }
80
+ // ─── CLI ────────────────────────────────────────────────────────────────────
81
+ export function runHookInstall(argv) {
82
+ if (argv.includes("--help") || argv.includes("-h")) {
83
+ console.log(`
84
+ judges hook-install — Install git hooks for automatic code review
85
+
86
+ Usage:
87
+ judges hook-install Install pre-commit hook
88
+ judges hook-install --hook pre-push Install pre-push hook
89
+ judges hook-install --method husky Use husky for hook management
90
+
91
+ Options:
92
+ --hook <type> Hook type: pre-commit (default) or pre-push
93
+ --method <method> Installation: direct (default), husky
94
+ --severity <level> Fail on findings of this severity+ (default: high)
95
+ --timeout <seconds> Timeout in seconds (default: 60)
96
+ --no-staged-only Evaluate all files, not just staged
97
+ --uninstall Remove the hook
98
+ --show Show current hook script without installing
99
+ --help, -h Show this help
100
+
101
+ Environment:
102
+ JUDGES_SKIP_HOOK=1 Skip the hook for a single commit
103
+ `);
104
+ return;
105
+ }
106
+ const hookType = (argv.find((_a, i) => argv[i - 1] === "--hook") || "pre-commit");
107
+ const method = argv.find((_a, i) => argv[i - 1] === "--method") || "direct";
108
+ const severity = argv.find((_a, i) => argv[i - 1] === "--severity") || "high";
109
+ const timeoutStr = argv.find((_a, i) => argv[i - 1] === "--timeout");
110
+ const timeout = timeoutStr ? parseInt(timeoutStr, 10) : 60;
111
+ if (argv.includes("--uninstall")) {
112
+ const { unlinkSync, existsSync } = require("fs");
113
+ const { join } = require("path");
114
+ const paths = [join(".git", "hooks", hookType), join(".husky", hookType)];
115
+ for (const p of paths) {
116
+ if (existsSync(p)) {
117
+ unlinkSync(p);
118
+ console.log(` ✅ Removed ${p}`);
119
+ }
120
+ }
121
+ return;
122
+ }
123
+ const config = {
124
+ hook: hookType,
125
+ stagedOnly: !argv.includes("--no-staged-only"),
126
+ failSeverity: severity,
127
+ timeout,
128
+ parallel: true,
129
+ smartSelect: true,
130
+ };
131
+ const script = generateHookScript(config);
132
+ if (argv.includes("--show")) {
133
+ console.log(script);
134
+ return;
135
+ }
136
+ if (method === "husky") {
137
+ installHusky(hookType, script);
138
+ }
139
+ else {
140
+ installDirect(hookType, script);
141
+ }
142
+ }
143
+ //# sourceMappingURL=hook-install.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hook-install.js","sourceRoot":"","sources":["../../src/commands/hook-install.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,41 @@
1
+ /**
2
+ * Team knowledge base — store team decisions about rules, exceptions,
3
+ * known patterns, and contextual knowledge that informs evaluations.
4
+ *
5
+ * Stored locally in .judges-kb.json.
6
+ */
7
+ export interface KbEntry {
8
+ id: string;
9
+ /** Rule ID or prefix this applies to */
10
+ rulePattern: string;
11
+ /** Decision type */
12
+ decision: "not-applicable" | "accepted-risk" | "deferred" | "exception" | "custom-guidance";
13
+ /** Why the team made this decision */
14
+ reason: string;
15
+ /** Who approved this decision */
16
+ approvedBy: string;
17
+ /** When this decision was made */
18
+ createdIso: string;
19
+ /** Optional expiry date for temporary exceptions */
20
+ expiresIso?: string;
21
+ /** Scope (e.g., file glob or project area) */
22
+ scope?: string;
23
+ /** Tags for categorization */
24
+ tags?: string[];
25
+ /** Active or archived */
26
+ active: boolean;
27
+ }
28
+ export declare function addKbEntry(opts: {
29
+ rulePattern: string;
30
+ decision: KbEntry["decision"];
31
+ reason: string;
32
+ approvedBy: string;
33
+ scope?: string;
34
+ tags?: string[];
35
+ expiresIn?: number;
36
+ }): KbEntry;
37
+ export declare function archiveKbEntry(id: string): boolean;
38
+ export declare function searchKb(query: string): KbEntry[];
39
+ export declare function getApplicableEntries(ruleId: string): KbEntry[];
40
+ export declare function runKnowledgeBase(argv: string[]): void;
41
+ //# sourceMappingURL=kb.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kb.d.ts","sourceRoot":"","sources":["../../src/commands/kb.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAMH,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,wCAAwC;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,oBAAoB;IACpB,QAAQ,EAAE,gBAAgB,GAAG,eAAe,GAAG,UAAU,GAAG,WAAW,GAAG,iBAAiB,CAAC;IAC5F,sCAAsC;IACtC,MAAM,EAAE,MAAM,CAAC;IACf,iCAAiC;IACjC,UAAU,EAAE,MAAM,CAAC;IACnB,kCAAkC;IAClC,UAAU,EAAE,MAAM,CAAC;IACnB,oDAAoD;IACpD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,8CAA8C;IAC9C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,8BAA8B;IAC9B,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,yBAAyB;IACzB,MAAM,EAAE,OAAO,CAAC;CACjB;AAuBD,wBAAgB,UAAU,CAAC,IAAI,EAAE;IAC/B,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;IAC9B,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,GAAG,OAAO,CAqBV;AAED,wBAAgB,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAOlD;AAED,wBAAgB,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,EAAE,CAWjD;AAED,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,EAAE,CAQ9D;AAID,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAgKrD"}