ghostpatch 1.0.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 (138) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +213 -0
  3. package/__tests__/detectors.test.ts +224 -0
  4. package/__tests__/rules.test.ts +117 -0
  5. package/__tests__/scanner.test.ts +222 -0
  6. package/dist/ai/anthropic.d.ts +11 -0
  7. package/dist/ai/anthropic.d.ts.map +1 -0
  8. package/dist/ai/anthropic.js +76 -0
  9. package/dist/ai/anthropic.js.map +1 -0
  10. package/dist/ai/huggingface.d.ts +12 -0
  11. package/dist/ai/huggingface.d.ts.map +1 -0
  12. package/dist/ai/huggingface.js +95 -0
  13. package/dist/ai/huggingface.js.map +1 -0
  14. package/dist/ai/openai.d.ts +11 -0
  15. package/dist/ai/openai.d.ts.map +1 -0
  16. package/dist/ai/openai.js +71 -0
  17. package/dist/ai/openai.js.map +1 -0
  18. package/dist/ai/prompts.d.ts +5 -0
  19. package/dist/ai/prompts.d.ts.map +1 -0
  20. package/dist/ai/prompts.js +101 -0
  21. package/dist/ai/prompts.js.map +1 -0
  22. package/dist/ai/provider.d.ts +9 -0
  23. package/dist/ai/provider.d.ts.map +1 -0
  24. package/dist/ai/provider.js +66 -0
  25. package/dist/ai/provider.js.map +1 -0
  26. package/dist/cli/index.d.ts +3 -0
  27. package/dist/cli/index.d.ts.map +1 -0
  28. package/dist/cli/index.js +318 -0
  29. package/dist/cli/index.js.map +1 -0
  30. package/dist/core/reporter.d.ts +7 -0
  31. package/dist/core/reporter.d.ts.map +1 -0
  32. package/dist/core/reporter.js +366 -0
  33. package/dist/core/reporter.js.map +1 -0
  34. package/dist/core/rules.d.ts +8 -0
  35. package/dist/core/rules.d.ts.map +1 -0
  36. package/dist/core/rules.js +1077 -0
  37. package/dist/core/rules.js.map +1 -0
  38. package/dist/core/scanner.d.ts +6 -0
  39. package/dist/core/scanner.d.ts.map +1 -0
  40. package/dist/core/scanner.js +217 -0
  41. package/dist/core/scanner.js.map +1 -0
  42. package/dist/core/severity.d.ts +100 -0
  43. package/dist/core/severity.d.ts.map +1 -0
  44. package/dist/core/severity.js +52 -0
  45. package/dist/core/severity.js.map +1 -0
  46. package/dist/detectors/auth.d.ts +3 -0
  47. package/dist/detectors/auth.d.ts.map +1 -0
  48. package/dist/detectors/auth.js +138 -0
  49. package/dist/detectors/auth.js.map +1 -0
  50. package/dist/detectors/crypto.d.ts +3 -0
  51. package/dist/detectors/crypto.d.ts.map +1 -0
  52. package/dist/detectors/crypto.js +128 -0
  53. package/dist/detectors/crypto.js.map +1 -0
  54. package/dist/detectors/dependency.d.ts +4 -0
  55. package/dist/detectors/dependency.d.ts.map +1 -0
  56. package/dist/detectors/dependency.js +267 -0
  57. package/dist/detectors/dependency.js.map +1 -0
  58. package/dist/detectors/deserialize.d.ts +3 -0
  59. package/dist/detectors/deserialize.d.ts.map +1 -0
  60. package/dist/detectors/deserialize.js +107 -0
  61. package/dist/detectors/deserialize.js.map +1 -0
  62. package/dist/detectors/injection.d.ts +3 -0
  63. package/dist/detectors/injection.d.ts.map +1 -0
  64. package/dist/detectors/injection.js +158 -0
  65. package/dist/detectors/injection.js.map +1 -0
  66. package/dist/detectors/misconfig.d.ts +3 -0
  67. package/dist/detectors/misconfig.d.ts.map +1 -0
  68. package/dist/detectors/misconfig.js +153 -0
  69. package/dist/detectors/misconfig.js.map +1 -0
  70. package/dist/detectors/pathtraversal.d.ts +3 -0
  71. package/dist/detectors/pathtraversal.d.ts.map +1 -0
  72. package/dist/detectors/pathtraversal.js +90 -0
  73. package/dist/detectors/pathtraversal.js.map +1 -0
  74. package/dist/detectors/prototype.d.ts +3 -0
  75. package/dist/detectors/prototype.d.ts.map +1 -0
  76. package/dist/detectors/prototype.js +79 -0
  77. package/dist/detectors/prototype.js.map +1 -0
  78. package/dist/detectors/secrets.d.ts +4 -0
  79. package/dist/detectors/secrets.d.ts.map +1 -0
  80. package/dist/detectors/secrets.js +137 -0
  81. package/dist/detectors/secrets.js.map +1 -0
  82. package/dist/detectors/ssrf.d.ts +3 -0
  83. package/dist/detectors/ssrf.d.ts.map +1 -0
  84. package/dist/detectors/ssrf.js +78 -0
  85. package/dist/detectors/ssrf.js.map +1 -0
  86. package/dist/detectors/zeroday.d.ts +9 -0
  87. package/dist/detectors/zeroday.d.ts.map +1 -0
  88. package/dist/detectors/zeroday.js +77 -0
  89. package/dist/detectors/zeroday.js.map +1 -0
  90. package/dist/index.d.ts +10 -0
  91. package/dist/index.d.ts.map +1 -0
  92. package/dist/index.js +42 -0
  93. package/dist/index.js.map +1 -0
  94. package/dist/mcp/server.d.ts +2 -0
  95. package/dist/mcp/server.d.ts.map +1 -0
  96. package/dist/mcp/server.js +358 -0
  97. package/dist/mcp/server.js.map +1 -0
  98. package/dist/utils/config.d.ts +4 -0
  99. package/dist/utils/config.d.ts.map +1 -0
  100. package/dist/utils/config.js +97 -0
  101. package/dist/utils/config.js.map +1 -0
  102. package/dist/utils/fingerprint.d.ts +5 -0
  103. package/dist/utils/fingerprint.d.ts.map +1 -0
  104. package/dist/utils/fingerprint.js +55 -0
  105. package/dist/utils/fingerprint.js.map +1 -0
  106. package/dist/utils/languages.d.ts +8 -0
  107. package/dist/utils/languages.d.ts.map +1 -0
  108. package/dist/utils/languages.js +128 -0
  109. package/dist/utils/languages.js.map +1 -0
  110. package/package.json +53 -0
  111. package/src/ai/anthropic.ts +82 -0
  112. package/src/ai/huggingface.ts +111 -0
  113. package/src/ai/openai.ts +75 -0
  114. package/src/ai/prompts.ts +100 -0
  115. package/src/ai/provider.ts +68 -0
  116. package/src/cli/index.ts +314 -0
  117. package/src/core/reporter.ts +356 -0
  118. package/src/core/rules.ts +1089 -0
  119. package/src/core/scanner.ts +201 -0
  120. package/src/core/severity.ts +140 -0
  121. package/src/detectors/auth.ts +152 -0
  122. package/src/detectors/crypto.ts +128 -0
  123. package/src/detectors/dependency.ts +240 -0
  124. package/src/detectors/deserialize.ts +106 -0
  125. package/src/detectors/injection.ts +172 -0
  126. package/src/detectors/misconfig.ts +152 -0
  127. package/src/detectors/pathtraversal.ts +89 -0
  128. package/src/detectors/prototype.ts +77 -0
  129. package/src/detectors/secrets.ts +138 -0
  130. package/src/detectors/ssrf.ts +77 -0
  131. package/src/detectors/zeroday.ts +93 -0
  132. package/src/index.ts +24 -0
  133. package/src/mcp/server.ts +379 -0
  134. package/src/utils/config.ts +64 -0
  135. package/src/utils/fingerprint.ts +21 -0
  136. package/src/utils/languages.ts +95 -0
  137. package/tsconfig.json +20 -0
  138. package/vitest.config.ts +8 -0
@@ -0,0 +1,358 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.startMCPServer = startMCPServer;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const scanner_1 = require("../core/scanner");
40
+ const reporter_1 = require("../core/reporter");
41
+ const severity_1 = require("../core/severity");
42
+ const languages_1 = require("../utils/languages");
43
+ const provider_1 = require("../ai/provider");
44
+ const dependency_1 = require("../detectors/dependency");
45
+ // Cache for scan results
46
+ let lastScanResult = null;
47
+ const TOOLS = [
48
+ {
49
+ name: 'ghostpatch_scan',
50
+ description: 'Run a full security scan on a project directory. Returns findings with severity, CWE codes, and remediation advice.',
51
+ inputSchema: {
52
+ type: 'object',
53
+ properties: {
54
+ path: { type: 'string', description: 'Directory or file path to scan (default: current directory)' },
55
+ severity: { type: 'string', enum: ['critical', 'high', 'medium', 'low', 'info'], description: 'Minimum severity level to report' },
56
+ output: { type: 'string', enum: ['json', 'terminal', 'sarif'], description: 'Output format' },
57
+ },
58
+ },
59
+ },
60
+ {
61
+ name: 'ghostpatch_scan_file',
62
+ description: 'Scan a single file for security vulnerabilities.',
63
+ inputSchema: {
64
+ type: 'object',
65
+ properties: {
66
+ path: { type: 'string', description: 'Path to the file to scan' },
67
+ content: { type: 'string', description: 'File content (if not reading from disk)' },
68
+ },
69
+ required: ['path'],
70
+ },
71
+ },
72
+ {
73
+ name: 'ghostpatch_findings',
74
+ description: 'Get current scan findings with optional filters.',
75
+ inputSchema: {
76
+ type: 'object',
77
+ properties: {
78
+ severity: { type: 'string', enum: ['critical', 'high', 'medium', 'low', 'info'] },
79
+ file: { type: 'string', description: 'Filter by file path (substring match)' },
80
+ ruleId: { type: 'string', description: 'Filter by rule ID' },
81
+ limit: { type: 'number', description: 'Maximum results to return', default: 50 },
82
+ },
83
+ },
84
+ },
85
+ {
86
+ name: 'ghostpatch_finding',
87
+ description: 'Get detailed information about a specific finding by its ID.',
88
+ inputSchema: {
89
+ type: 'object',
90
+ properties: {
91
+ id: { type: 'string', description: 'Finding ID' },
92
+ },
93
+ required: ['id'],
94
+ },
95
+ },
96
+ {
97
+ name: 'ghostpatch_secrets',
98
+ description: 'Scan for hardcoded secrets, API keys, tokens, and credentials.',
99
+ inputSchema: {
100
+ type: 'object',
101
+ properties: {
102
+ path: { type: 'string', description: 'Path to scan' },
103
+ },
104
+ },
105
+ },
106
+ {
107
+ name: 'ghostpatch_dependencies',
108
+ description: 'Check project dependencies for known vulnerabilities (npm audit, pip, etc.).',
109
+ inputSchema: {
110
+ type: 'object',
111
+ properties: {
112
+ path: { type: 'string', description: 'Project directory path' },
113
+ },
114
+ },
115
+ },
116
+ {
117
+ name: 'ghostpatch_ai_analyze',
118
+ description: 'Run AI-powered deep security analysis on code. Uses HuggingFace (free), Anthropic, or OpenAI.',
119
+ inputSchema: {
120
+ type: 'object',
121
+ properties: {
122
+ code: { type: 'string', description: 'Code to analyze' },
123
+ file: { type: 'string', description: 'File path for context' },
124
+ provider: { type: 'string', enum: ['huggingface', 'anthropic', 'openai'], description: 'AI provider' },
125
+ },
126
+ required: ['code'],
127
+ },
128
+ },
129
+ {
130
+ name: 'ghostpatch_status',
131
+ description: 'Get scanner status, configuration, and stats from last scan.',
132
+ inputSchema: {
133
+ type: 'object',
134
+ properties: {},
135
+ },
136
+ },
137
+ ];
138
+ async function handleToolCall(name, args) {
139
+ switch (name) {
140
+ case 'ghostpatch_scan': {
141
+ const target = args.path || process.cwd();
142
+ const result = await (0, scanner_1.scan)(target, {
143
+ severity: args.severity,
144
+ });
145
+ lastScanResult = result;
146
+ if (args.output === 'json' || args.output === 'sarif') {
147
+ return (0, reporter_1.generateReport)(result, args.output);
148
+ }
149
+ return {
150
+ target: result.target,
151
+ filesScanned: result.filesScanned,
152
+ duration: `${result.durationMs}ms`,
153
+ summary: result.summary,
154
+ findings: result.findings.slice(0, 100).map(formatFindingForMCP),
155
+ };
156
+ }
157
+ case 'ghostpatch_scan_file': {
158
+ const filePath = path.resolve(args.path);
159
+ const content = args.content || fs.readFileSync(filePath, 'utf-8');
160
+ const language = (0, languages_1.detectLanguage)(filePath) || 'generic';
161
+ const findings = (0, scanner_1.scanFile)(filePath, content, language);
162
+ return {
163
+ file: filePath,
164
+ language,
165
+ findings: findings.map(formatFindingForMCP),
166
+ total: findings.length,
167
+ };
168
+ }
169
+ case 'ghostpatch_findings': {
170
+ if (!lastScanResult) {
171
+ return { error: 'No scan results available. Run ghostpatch_scan first.' };
172
+ }
173
+ let findings = lastScanResult.findings;
174
+ if (args.severity) {
175
+ const severityOrder = { critical: 5, high: 4, medium: 3, low: 2, info: 1 };
176
+ const minLevel = severityOrder[args.severity] || 0;
177
+ findings = findings.filter(f => (severityOrder[f.severity] || 0) >= minLevel);
178
+ }
179
+ if (args.file) {
180
+ findings = findings.filter(f => f.filePath.includes(args.file));
181
+ }
182
+ if (args.ruleId) {
183
+ findings = findings.filter(f => f.ruleId === args.ruleId);
184
+ }
185
+ const limit = args.limit || 50;
186
+ return {
187
+ total: findings.length,
188
+ showing: Math.min(findings.length, limit),
189
+ findings: findings.slice(0, limit).map(formatFindingForMCP),
190
+ };
191
+ }
192
+ case 'ghostpatch_finding': {
193
+ if (!lastScanResult) {
194
+ return { error: 'No scan results available. Run ghostpatch_scan first.' };
195
+ }
196
+ const finding = lastScanResult.findings.find(f => f.id === args.id);
197
+ if (!finding) {
198
+ return { error: `Finding not found: ${args.id}` };
199
+ }
200
+ return finding;
201
+ }
202
+ case 'ghostpatch_secrets': {
203
+ const target = args.path || process.cwd();
204
+ const result = await (0, scanner_1.scan)(target, { severity: severity_1.Severity.LOW });
205
+ const secretsFindings = result.findings.filter(f => f.ruleId.startsWith('SEC-') ||
206
+ f.title.toLowerCase().includes('secret') ||
207
+ f.title.toLowerCase().includes('key') ||
208
+ f.title.toLowerCase().includes('token') ||
209
+ f.title.toLowerCase().includes('password'));
210
+ return {
211
+ total: secretsFindings.length,
212
+ findings: secretsFindings.map(formatFindingForMCP),
213
+ };
214
+ }
215
+ case 'ghostpatch_dependencies': {
216
+ const target = args.path || process.cwd();
217
+ const result = await (0, scanner_1.scan)(target, { severity: severity_1.Severity.LOW });
218
+ const depFindings = result.findings.filter(f => f.ruleId.startsWith('DEP-') || f.owasp === 'A06');
219
+ // Also try npm audit
220
+ const npmFindings = (0, dependency_1.runNpmAudit)(target);
221
+ return {
222
+ total: depFindings.length + npmFindings.length,
223
+ staticAnalysis: depFindings.map(formatFindingForMCP),
224
+ npmAudit: npmFindings.map(formatFindingForMCP),
225
+ };
226
+ }
227
+ case 'ghostpatch_ai_analyze': {
228
+ const provider = (0, provider_1.getAvailableProvider)(args.provider);
229
+ if (!provider) {
230
+ return { error: 'No AI provider available. Set HF_TOKEN, ANTHROPIC_API_KEY, or OPENAI_API_KEY.' };
231
+ }
232
+ const findings = await provider.analyze(args.code, args.file ? `File: ${args.file}` : 'Code snippet');
233
+ return {
234
+ provider: provider.name,
235
+ findings,
236
+ total: findings.length,
237
+ };
238
+ }
239
+ case 'ghostpatch_status': {
240
+ return {
241
+ version: '1.0.0',
242
+ lastScan: lastScanResult ? {
243
+ target: lastScanResult.target,
244
+ time: lastScanResult.startTime.toISOString(),
245
+ filesScanned: lastScanResult.filesScanned,
246
+ findingsTotal: lastScanResult.summary.total,
247
+ summary: lastScanResult.summary.bySeverity,
248
+ } : null,
249
+ aiProviders: {
250
+ huggingface: 'available (free)',
251
+ anthropic: process.env.ANTHROPIC_API_KEY ? 'configured' : 'not configured',
252
+ openai: process.env.OPENAI_API_KEY ? 'configured' : 'not configured',
253
+ },
254
+ };
255
+ }
256
+ default:
257
+ throw new Error(`Unknown tool: ${name}`);
258
+ }
259
+ }
260
+ function formatFindingForMCP(f) {
261
+ return {
262
+ id: f.id,
263
+ ruleId: f.ruleId,
264
+ title: f.title,
265
+ severity: f.severity,
266
+ confidence: f.confidence,
267
+ file: f.filePath,
268
+ line: f.line,
269
+ description: f.description,
270
+ cwe: f.cwe,
271
+ owasp: f.owasp,
272
+ remediation: f.remediation,
273
+ aiEnhanced: f.aiEnhanced || false,
274
+ };
275
+ }
276
+ // ============================================================
277
+ // MCP Server (stdio transport)
278
+ // ============================================================
279
+ async function startMCPServer() {
280
+ const readline = await Promise.resolve().then(() => __importStar(require('readline')));
281
+ const rl = readline.createInterface({
282
+ input: process.stdin,
283
+ output: process.stdout,
284
+ terminal: false,
285
+ });
286
+ function send(response) {
287
+ const json = JSON.stringify(response);
288
+ process.stdout.write(json + '\n');
289
+ }
290
+ rl.on('line', async (line) => {
291
+ let request;
292
+ try {
293
+ request = JSON.parse(line);
294
+ }
295
+ catch {
296
+ return;
297
+ }
298
+ try {
299
+ switch (request.method) {
300
+ case 'initialize':
301
+ send({
302
+ jsonrpc: '2.0',
303
+ id: request.id,
304
+ result: {
305
+ protocolVersion: '2024-11-05',
306
+ capabilities: { tools: {} },
307
+ serverInfo: {
308
+ name: 'ghostpatch',
309
+ version: '1.0.0',
310
+ },
311
+ },
312
+ });
313
+ break;
314
+ case 'notifications/initialized':
315
+ // No response needed for notifications
316
+ break;
317
+ case 'tools/list':
318
+ send({
319
+ jsonrpc: '2.0',
320
+ id: request.id,
321
+ result: { tools: TOOLS },
322
+ });
323
+ break;
324
+ case 'tools/call': {
325
+ const { name, arguments: args } = request.params;
326
+ const result = await handleToolCall(name, args || {});
327
+ send({
328
+ jsonrpc: '2.0',
329
+ id: request.id,
330
+ result: {
331
+ content: [{
332
+ type: 'text',
333
+ text: typeof result === 'string' ? result : JSON.stringify(result, null, 2),
334
+ }],
335
+ },
336
+ });
337
+ break;
338
+ }
339
+ default:
340
+ send({
341
+ jsonrpc: '2.0',
342
+ id: request.id,
343
+ error: { code: -32601, message: `Method not found: ${request.method}` },
344
+ });
345
+ }
346
+ }
347
+ catch (err) {
348
+ send({
349
+ jsonrpc: '2.0',
350
+ id: request.id,
351
+ error: { code: -32603, message: err.message },
352
+ });
353
+ }
354
+ });
355
+ // Keep the server running
356
+ process.stderr.write('GhostPatch MCP server started (stdio)\n');
357
+ }
358
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqSA,wCAqFC;AA1XD,uCAAyB;AACzB,2CAA6B;AAC7B,6CAAiD;AACjD,+CAAkD;AAClD,+CAAiE;AACjE,kDAAoD;AACpD,6CAAsD;AAEtD,wDAAsD;AAiBtD,yBAAyB;AACzB,IAAI,cAAc,GAAsB,IAAI,CAAC;AAE7C,MAAM,KAAK,GAAG;IACZ;QACE,IAAI,EAAE,iBAAiB;QACvB,WAAW,EAAE,qHAAqH;QAClI,WAAW,EAAE;YACX,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,6DAA6D,EAAE;gBACpG,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,CAAC,EAAE,WAAW,EAAE,kCAAkC,EAAE;gBAClI,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,MAAM,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE,WAAW,EAAE,eAAe,EAAE;aAC9F;SACF;KACF;IACD;QACE,IAAI,EAAE,sBAAsB;QAC5B,WAAW,EAAE,kDAAkD;QAC/D,WAAW,EAAE;YACX,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,0BAA0B,EAAE;gBACjE,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,yCAAyC,EAAE;aACpF;YACD,QAAQ,EAAE,CAAC,MAAM,CAAC;SACnB;KACF;IACD;QACE,IAAI,EAAE,qBAAqB;QAC3B,WAAW,EAAE,kDAAkD;QAC/D,WAAW,EAAE;YACX,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,CAAC,EAAE;gBACjF,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,uCAAuC,EAAE;gBAC9E,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,mBAAmB,EAAE;gBAC5D,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,2BAA2B,EAAE,OAAO,EAAE,EAAE,EAAE;aACjF;SACF;KACF;IACD;QACE,IAAI,EAAE,oBAAoB;QAC1B,WAAW,EAAE,8DAA8D;QAC3E,WAAW,EAAE;YACX,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,YAAY,EAAE;aAClD;YACD,QAAQ,EAAE,CAAC,IAAI,CAAC;SACjB;KACF;IACD;QACE,IAAI,EAAE,oBAAoB;QAC1B,WAAW,EAAE,gEAAgE;QAC7E,WAAW,EAAE;YACX,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,cAAc,EAAE;aACtD;SACF;KACF;IACD;QACE,IAAI,EAAE,yBAAyB;QAC/B,WAAW,EAAE,8EAA8E;QAC3F,WAAW,EAAE;YACX,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,wBAAwB,EAAE;aAChE;SACF;KACF;IACD;QACE,IAAI,EAAE,uBAAuB;QAC7B,WAAW,EAAE,+FAA+F;QAC5G,WAAW,EAAE;YACX,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,iBAAiB,EAAE;gBACxD,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,uBAAuB,EAAE;gBAC9D,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,aAAa,EAAE,WAAW,EAAE,QAAQ,CAAC,EAAE,WAAW,EAAE,aAAa,EAAE;aACvG;YACD,QAAQ,EAAE,CAAC,MAAM,CAAC;SACnB;KACF;IACD;QACE,IAAI,EAAE,mBAAmB;QACzB,WAAW,EAAE,8DAA8D;QAC3E,WAAW,EAAE;YACX,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE,EAAE;SACf;KACF;CACF,CAAC;AAEF,KAAK,UAAU,cAAc,CAAC,IAAY,EAAE,IAAS;IACnD,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,iBAAiB,CAAC,CAAC,CAAC;YACvB,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;YAC1C,MAAM,MAAM,GAAG,MAAM,IAAA,cAAI,EAAC,MAAM,EAAE;gBAChC,QAAQ,EAAE,IAAI,CAAC,QAAoB;aACpC,CAAC,CAAC;YACH,cAAc,GAAG,MAAM,CAAC;YAExB,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,IAAI,IAAI,CAAC,MAAM,KAAK,OAAO,EAAE,CAAC;gBACtD,OAAO,IAAA,yBAAc,EAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7C,CAAC;YAED,OAAO;gBACL,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,YAAY,EAAE,MAAM,CAAC,YAAY;gBACjC,QAAQ,EAAE,GAAG,MAAM,CAAC,UAAU,IAAI;gBAClC,OAAO,EAAE,MAAM,CAAC,OAAO;gBACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC;aACjE,CAAC;QACJ,CAAC;QAED,KAAK,sBAAsB,CAAC,CAAC,CAAC;YAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACzC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YACnE,MAAM,QAAQ,GAAG,IAAA,0BAAc,EAAC,QAAQ,CAAC,IAAI,SAAS,CAAC;YACvD,MAAM,QAAQ,GAAG,IAAA,kBAAQ,EAAC,QAAQ,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;YAEvD,OAAO;gBACL,IAAI,EAAE,QAAQ;gBACd,QAAQ;gBACR,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,mBAAmB,CAAC;gBAC3C,KAAK,EAAE,QAAQ,CAAC,MAAM;aACvB,CAAC;QACJ,CAAC;QAED,KAAK,qBAAqB,CAAC,CAAC,CAAC;YAC3B,IAAI,CAAC,cAAc,EAAE,CAAC;gBACpB,OAAO,EAAE,KAAK,EAAE,uDAAuD,EAAE,CAAC;YAC5E,CAAC;YAED,IAAI,QAAQ,GAAG,cAAc,CAAC,QAAQ,CAAC;YAEvC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,MAAM,aAAa,GAA2B,EAAE,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC;gBACnG,MAAM,QAAQ,GAAG,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;gBACnD,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC;YAChF,CAAC;YAED,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YAClE,CAAC;YAED,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChB,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,CAAC,CAAC;YAC5D,CAAC;YAED,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC;YAC/B,OAAO;gBACL,KAAK,EAAE,QAAQ,CAAC,MAAM;gBACtB,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,MAAM,EAAE,KAAK,CAAC;gBACzC,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC;aAC5D,CAAC;QACJ,CAAC;QAED,KAAK,oBAAoB,CAAC,CAAC,CAAC;YAC1B,IAAI,CAAC,cAAc,EAAE,CAAC;gBACpB,OAAO,EAAE,KAAK,EAAE,uDAAuD,EAAE,CAAC;YAC5E,CAAC;YAED,MAAM,OAAO,GAAG,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;YACpE,IAAI,CAAC,OAAO,EAAE,CAAC;gBACb,OAAO,EAAE,KAAK,EAAE,sBAAsB,IAAI,CAAC,EAAE,EAAE,EAAE,CAAC;YACpD,CAAC;YAED,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,KAAK,oBAAoB,CAAC,CAAC,CAAC;YAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;YAC1C,MAAM,MAAM,GAAG,MAAM,IAAA,cAAI,EAAC,MAAM,EAAE,EAAE,QAAQ,EAAE,mBAAQ,CAAC,GAAG,EAAE,CAAC,CAAC;YAC9D,MAAM,eAAe,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CACjD,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC;gBAC3B,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC;gBACxC,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC;gBACrC,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC;gBACvC,CAAC,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,CAC3C,CAAC;YAEF,OAAO;gBACL,KAAK,EAAE,eAAe,CAAC,MAAM;gBAC7B,QAAQ,EAAE,eAAe,CAAC,GAAG,CAAC,mBAAmB,CAAC;aACnD,CAAC;QACJ,CAAC;QAED,KAAK,yBAAyB,CAAC,CAAC,CAAC;YAC/B,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;YAC1C,MAAM,MAAM,GAAG,MAAM,IAAA,cAAI,EAAC,MAAM,EAAE,EAAE,QAAQ,EAAE,mBAAQ,CAAC,GAAG,EAAE,CAAC,CAAC;YAC9D,MAAM,WAAW,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAC7C,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CACjD,CAAC;YAEF,qBAAqB;YACrB,MAAM,WAAW,GAAG,IAAA,wBAAW,EAAC,MAAM,CAAC,CAAC;YAExC,OAAO;gBACL,KAAK,EAAE,WAAW,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM;gBAC9C,cAAc,EAAE,WAAW,CAAC,GAAG,CAAC,mBAAmB,CAAC;gBACpD,QAAQ,EAAE,WAAW,CAAC,GAAG,CAAC,mBAAmB,CAAC;aAC/C,CAAC;QACJ,CAAC;QAED,KAAK,uBAAuB,CAAC,CAAC,CAAC;YAC7B,MAAM,QAAQ,GAAG,IAAA,+BAAoB,EAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACrD,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,OAAO,EAAE,KAAK,EAAE,+EAA+E,EAAE,CAAC;YACpG,CAAC;YAED,MAAM,QAAQ,GAAG,MAAM,QAAQ,CAAC,OAAO,CACrC,IAAI,CAAC,IAAI,EACT,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,cAAc,CAClD,CAAC;YAEF,OAAO;gBACL,QAAQ,EAAE,QAAQ,CAAC,IAAI;gBACvB,QAAQ;gBACR,KAAK,EAAE,QAAQ,CAAC,MAAM;aACvB,CAAC;QACJ,CAAC;QAED,KAAK,mBAAmB,CAAC,CAAC,CAAC;YACzB,OAAO;gBACL,OAAO,EAAE,OAAO;gBAChB,QAAQ,EAAE,cAAc,CAAC,CAAC,CAAC;oBACzB,MAAM,EAAE,cAAc,CAAC,MAAM;oBAC7B,IAAI,EAAE,cAAc,CAAC,SAAS,CAAC,WAAW,EAAE;oBAC5C,YAAY,EAAE,cAAc,CAAC,YAAY;oBACzC,aAAa,EAAE,cAAc,CAAC,OAAO,CAAC,KAAK;oBAC3C,OAAO,EAAE,cAAc,CAAC,OAAO,CAAC,UAAU;iBAC3C,CAAC,CAAC,CAAC,IAAI;gBACR,WAAW,EAAE;oBACX,WAAW,EAAE,kBAAkB;oBAC/B,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,gBAAgB;oBAC1E,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,gBAAgB;iBACrE;aACF,CAAC;QACJ,CAAC;QAED;YACE,MAAM,IAAI,KAAK,CAAC,iBAAiB,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;AACH,CAAC;AAED,SAAS,mBAAmB,CAAC,CAAU;IACrC,OAAO;QACL,EAAE,EAAE,CAAC,CAAC,EAAE;QACR,MAAM,EAAE,CAAC,CAAC,MAAM;QAChB,KAAK,EAAE,CAAC,CAAC,KAAK;QACd,QAAQ,EAAE,CAAC,CAAC,QAAQ;QACpB,UAAU,EAAE,CAAC,CAAC,UAAU;QACxB,IAAI,EAAE,CAAC,CAAC,QAAQ;QAChB,IAAI,EAAE,CAAC,CAAC,IAAI;QACZ,WAAW,EAAE,CAAC,CAAC,WAAW;QAC1B,GAAG,EAAE,CAAC,CAAC,GAAG;QACV,KAAK,EAAE,CAAC,CAAC,KAAK;QACd,WAAW,EAAE,CAAC,CAAC,WAAW;QAC1B,UAAU,EAAE,CAAC,CAAC,UAAU,IAAI,KAAK;KAClC,CAAC;AACJ,CAAC;AAED,+DAA+D;AAC/D,+BAA+B;AAC/B,+DAA+D;AACxD,KAAK,UAAU,cAAc;IAClC,MAAM,QAAQ,GAAG,wDAAa,UAAU,GAAC,CAAC;IAE1C,MAAM,EAAE,GAAG,QAAQ,CAAC,eAAe,CAAC;QAClC,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,QAAQ,EAAE,KAAK;KAChB,CAAC,CAAC;IAEH,SAAS,IAAI,CAAC,QAAqB;QACjC,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACtC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,IAAY,EAAE,EAAE;QACnC,IAAI,OAAmB,CAAC;QACxB,IAAI,CAAC;YACH,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;QAAC,MAAM,CAAC;YACP,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,QAAQ,OAAO,CAAC,MAAM,EAAE,CAAC;gBACvB,KAAK,YAAY;oBACf,IAAI,CAAC;wBACH,OAAO,EAAE,KAAK;wBACd,EAAE,EAAE,OAAO,CAAC,EAAE;wBACd,MAAM,EAAE;4BACN,eAAe,EAAE,YAAY;4BAC7B,YAAY,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;4BAC3B,UAAU,EAAE;gCACV,IAAI,EAAE,YAAY;gCAClB,OAAO,EAAE,OAAO;6BACjB;yBACF;qBACF,CAAC,CAAC;oBACH,MAAM;gBAER,KAAK,2BAA2B;oBAC9B,uCAAuC;oBACvC,MAAM;gBAER,KAAK,YAAY;oBACf,IAAI,CAAC;wBACH,OAAO,EAAE,KAAK;wBACd,EAAE,EAAE,OAAO,CAAC,EAAE;wBACd,MAAM,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE;qBACzB,CAAC,CAAC;oBACH,MAAM;gBAER,KAAK,YAAY,CAAC,CAAC,CAAC;oBAClB,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;oBACjD,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC;oBACtD,IAAI,CAAC;wBACH,OAAO,EAAE,KAAK;wBACd,EAAE,EAAE,OAAO,CAAC,EAAE;wBACd,MAAM,EAAE;4BACN,OAAO,EAAE,CAAC;oCACR,IAAI,EAAE,MAAM;oCACZ,IAAI,EAAE,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;iCAC5E,CAAC;yBACH;qBACF,CAAC,CAAC;oBACH,MAAM;gBACR,CAAC;gBAED;oBACE,IAAI,CAAC;wBACH,OAAO,EAAE,KAAK;wBACd,EAAE,EAAE,OAAO,CAAC,EAAE;wBACd,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,qBAAqB,OAAO,CAAC,MAAM,EAAE,EAAE;qBACxE,CAAC,CAAC;YACP,CAAC;QACH,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,IAAI,CAAC;gBACH,OAAO,EAAE,KAAK;gBACd,EAAE,EAAE,OAAO,CAAC,EAAE;gBACd,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,CAAC,OAAO,EAAE;aAC9C,CAAC,CAAC;QACL,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,0BAA0B;IAC1B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,yCAAyC,CAAC,CAAC;AAClE,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { GhostPatchConfig } from '../core/severity';
2
+ export declare function loadConfig(configPath?: string, basePath?: string): GhostPatchConfig;
3
+ export declare function getDefaultConfig(): GhostPatchConfig;
4
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/utils/config.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAY,MAAM,kBAAkB,CAAC;AAkB9D,wBAAgB,UAAU,CAAC,UAAU,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,gBAAgB,CAsBnF;AAmBD,wBAAgB,gBAAgB,IAAI,gBAAgB,CAEnD"}
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.loadConfig = loadConfig;
37
+ exports.getDefaultConfig = getDefaultConfig;
38
+ const fs = __importStar(require("fs"));
39
+ const path = __importStar(require("path"));
40
+ const severity_1 = require("../core/severity");
41
+ const languages_1 = require("./languages");
42
+ const DEFAULT_CONFIG = {
43
+ exclude: languages_1.DEFAULT_EXCLUDE,
44
+ severity: severity_1.Severity.LOW,
45
+ ai: {
46
+ provider: 'huggingface',
47
+ model: 'auto',
48
+ },
49
+ rules: {
50
+ disabled: [],
51
+ custom: [],
52
+ },
53
+ maxFileSize: 1048576, // 1MB
54
+ languages: 'auto',
55
+ };
56
+ function loadConfig(configPath, basePath) {
57
+ const searchPaths = configPath
58
+ ? [configPath]
59
+ : [
60
+ path.join(basePath || process.cwd(), '.ghostpatch.json'),
61
+ path.join(basePath || process.cwd(), '.ghostpatchrc'),
62
+ path.join(basePath || process.cwd(), 'ghostpatch.config.json'),
63
+ ];
64
+ for (const p of searchPaths) {
65
+ try {
66
+ if (fs.existsSync(p)) {
67
+ const content = fs.readFileSync(p, 'utf-8');
68
+ const userConfig = JSON.parse(content);
69
+ return mergeConfig(DEFAULT_CONFIG, userConfig);
70
+ }
71
+ }
72
+ catch {
73
+ // Skip invalid config files
74
+ }
75
+ }
76
+ return { ...DEFAULT_CONFIG };
77
+ }
78
+ function mergeConfig(defaults, user) {
79
+ return {
80
+ exclude: user.exclude || defaults.exclude,
81
+ severity: user.severity || defaults.severity,
82
+ ai: {
83
+ ...defaults.ai,
84
+ ...(user.ai || {}),
85
+ },
86
+ rules: {
87
+ disabled: user.rules?.disabled || defaults.rules.disabled,
88
+ custom: user.rules?.custom || defaults.rules.custom,
89
+ },
90
+ maxFileSize: user.maxFileSize || defaults.maxFileSize,
91
+ languages: user.languages || defaults.languages,
92
+ };
93
+ }
94
+ function getDefaultConfig() {
95
+ return { ...DEFAULT_CONFIG };
96
+ }
97
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/utils/config.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA,gCAsBC;AAmBD,4CAEC;AA/DD,uCAAyB;AACzB,2CAA6B;AAC7B,+CAA8D;AAC9D,2CAA8C;AAE9C,MAAM,cAAc,GAAqB;IACvC,OAAO,EAAE,2BAAe;IACxB,QAAQ,EAAE,mBAAQ,CAAC,GAAG;IACtB,EAAE,EAAE;QACF,QAAQ,EAAE,aAAa;QACvB,KAAK,EAAE,MAAM;KACd;IACD,KAAK,EAAE;QACL,QAAQ,EAAE,EAAE;QACZ,MAAM,EAAE,EAAE;KACX;IACD,WAAW,EAAE,OAAO,EAAE,MAAM;IAC5B,SAAS,EAAE,MAAM;CAClB,CAAC;AAEF,SAAgB,UAAU,CAAC,UAAmB,EAAE,QAAiB;IAC/D,MAAM,WAAW,GAAG,UAAU;QAC5B,CAAC,CAAC,CAAC,UAAU,CAAC;QACd,CAAC,CAAC;YACE,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,OAAO,CAAC,GAAG,EAAE,EAAE,kBAAkB,CAAC;YACxD,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,OAAO,CAAC,GAAG,EAAE,EAAE,eAAe,CAAC;YACrD,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,OAAO,CAAC,GAAG,EAAE,EAAE,wBAAwB,CAAC;SAC/D,CAAC;IAEN,KAAK,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC;QAC5B,IAAI,CAAC;YACH,IAAI,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;gBACrB,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;gBAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBACvC,OAAO,WAAW,CAAC,cAAc,EAAE,UAAU,CAAC,CAAC;YACjD,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,4BAA4B;QAC9B,CAAC;IACH,CAAC;IAED,OAAO,EAAE,GAAG,cAAc,EAAE,CAAC;AAC/B,CAAC;AAED,SAAS,WAAW,CAAC,QAA0B,EAAE,IAA+B;IAC9E,OAAO;QACL,OAAO,EAAE,IAAI,CAAC,OAAO,IAAI,QAAQ,CAAC,OAAO;QACzC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,QAAQ;QAC5C,EAAE,EAAE;YACF,GAAG,QAAQ,CAAC,EAAE;YACd,GAAG,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC;SACnB;QACD,KAAK,EAAE;YACL,QAAQ,EAAE,IAAI,CAAC,KAAK,EAAE,QAAQ,IAAI,QAAQ,CAAC,KAAK,CAAC,QAAQ;YACzD,MAAM,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,IAAI,QAAQ,CAAC,KAAK,CAAC,MAAM;SACpD;QACD,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,QAAQ,CAAC,WAAW;QACrD,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,QAAQ,CAAC,SAAS;KAChD,CAAC;AACJ,CAAC;AAED,SAAgB,gBAAgB;IAC9B,OAAO,EAAE,GAAG,cAAc,EAAE,CAAC;AAC/B,CAAC"}
@@ -0,0 +1,5 @@
1
+ export declare function generateFingerprint(...parts: string[]): string;
2
+ export declare function deduplicateFindings<T extends {
3
+ fingerprint: string;
4
+ }>(findings: T[]): T[];
5
+ //# sourceMappingURL=fingerprint.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fingerprint.d.ts","sourceRoot":"","sources":["../../src/utils/fingerprint.ts"],"names":[],"mappings":"AAEA,wBAAgB,mBAAmB,CAAC,GAAG,KAAK,EAAE,MAAM,EAAE,GAAG,MAAM,CAI9D;AAED,wBAAgB,mBAAmB,CAAC,CAAC,SAAS;IAAE,WAAW,EAAE,MAAM,CAAA;CAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,GAAG,CAAC,EAAE,CAYzF"}
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.generateFingerprint = generateFingerprint;
37
+ exports.deduplicateFindings = deduplicateFindings;
38
+ const crypto = __importStar(require("crypto"));
39
+ function generateFingerprint(...parts) {
40
+ const hash = crypto.createHash('sha256');
41
+ hash.update(parts.join('::'));
42
+ return hash.digest('hex').substring(0, 16);
43
+ }
44
+ function deduplicateFindings(findings) {
45
+ const seen = new Set();
46
+ const result = [];
47
+ for (const finding of findings) {
48
+ if (!seen.has(finding.fingerprint)) {
49
+ seen.add(finding.fingerprint);
50
+ result.push(finding);
51
+ }
52
+ }
53
+ return result;
54
+ }
55
+ //# sourceMappingURL=fingerprint.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fingerprint.js","sourceRoot":"","sources":["../../src/utils/fingerprint.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,kDAIC;AAED,kDAYC;AApBD,+CAAiC;AAEjC,SAAgB,mBAAmB,CAAC,GAAG,KAAe;IACpD,MAAM,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IACzC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9B,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;AAC7C,CAAC;AAED,SAAgB,mBAAmB,CAAoC,QAAa;IAClF,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;IAC/B,MAAM,MAAM,GAAQ,EAAE,CAAC;IAEvB,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;QAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAC9B,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC"}
@@ -0,0 +1,8 @@
1
+ export declare const LANGUAGE_MAP: Record<string, string>;
2
+ export declare const SUPPORTED_LANGUAGES: string[];
3
+ export declare function detectLanguage(filePath: string): string | null;
4
+ export declare function isSupportedFile(filePath: string): boolean;
5
+ export declare const DEFAULT_EXCLUDE: string[];
6
+ export declare const CONFIG_FILES: string[];
7
+ export declare function isConfigFile(filePath: string): boolean;
8
+ //# sourceMappingURL=languages.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"languages.d.ts","sourceRoot":"","sources":["../../src/utils/languages.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAmC/C,CAAC;AAEF,eAAO,MAAM,mBAAmB,UAI/B,CAAC;AAEF,wBAAgB,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAG9D;AAED,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAEzD;AAED,eAAO,MAAM,eAAe,UAwB3B,CAAC;AAEF,eAAO,MAAM,YAAY,UASxB,CAAC;AAEF,wBAAgB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAGtD"}