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.
- package/LICENSE +21 -0
- package/README.md +213 -0
- package/__tests__/detectors.test.ts +224 -0
- package/__tests__/rules.test.ts +117 -0
- package/__tests__/scanner.test.ts +222 -0
- package/dist/ai/anthropic.d.ts +11 -0
- package/dist/ai/anthropic.d.ts.map +1 -0
- package/dist/ai/anthropic.js +76 -0
- package/dist/ai/anthropic.js.map +1 -0
- package/dist/ai/huggingface.d.ts +12 -0
- package/dist/ai/huggingface.d.ts.map +1 -0
- package/dist/ai/huggingface.js +95 -0
- package/dist/ai/huggingface.js.map +1 -0
- package/dist/ai/openai.d.ts +11 -0
- package/dist/ai/openai.d.ts.map +1 -0
- package/dist/ai/openai.js +71 -0
- package/dist/ai/openai.js.map +1 -0
- package/dist/ai/prompts.d.ts +5 -0
- package/dist/ai/prompts.d.ts.map +1 -0
- package/dist/ai/prompts.js +101 -0
- package/dist/ai/prompts.js.map +1 -0
- package/dist/ai/provider.d.ts +9 -0
- package/dist/ai/provider.d.ts.map +1 -0
- package/dist/ai/provider.js +66 -0
- package/dist/ai/provider.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +318 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/core/reporter.d.ts +7 -0
- package/dist/core/reporter.d.ts.map +1 -0
- package/dist/core/reporter.js +366 -0
- package/dist/core/reporter.js.map +1 -0
- package/dist/core/rules.d.ts +8 -0
- package/dist/core/rules.d.ts.map +1 -0
- package/dist/core/rules.js +1077 -0
- package/dist/core/rules.js.map +1 -0
- package/dist/core/scanner.d.ts +6 -0
- package/dist/core/scanner.d.ts.map +1 -0
- package/dist/core/scanner.js +217 -0
- package/dist/core/scanner.js.map +1 -0
- package/dist/core/severity.d.ts +100 -0
- package/dist/core/severity.d.ts.map +1 -0
- package/dist/core/severity.js +52 -0
- package/dist/core/severity.js.map +1 -0
- package/dist/detectors/auth.d.ts +3 -0
- package/dist/detectors/auth.d.ts.map +1 -0
- package/dist/detectors/auth.js +138 -0
- package/dist/detectors/auth.js.map +1 -0
- package/dist/detectors/crypto.d.ts +3 -0
- package/dist/detectors/crypto.d.ts.map +1 -0
- package/dist/detectors/crypto.js +128 -0
- package/dist/detectors/crypto.js.map +1 -0
- package/dist/detectors/dependency.d.ts +4 -0
- package/dist/detectors/dependency.d.ts.map +1 -0
- package/dist/detectors/dependency.js +267 -0
- package/dist/detectors/dependency.js.map +1 -0
- package/dist/detectors/deserialize.d.ts +3 -0
- package/dist/detectors/deserialize.d.ts.map +1 -0
- package/dist/detectors/deserialize.js +107 -0
- package/dist/detectors/deserialize.js.map +1 -0
- package/dist/detectors/injection.d.ts +3 -0
- package/dist/detectors/injection.d.ts.map +1 -0
- package/dist/detectors/injection.js +158 -0
- package/dist/detectors/injection.js.map +1 -0
- package/dist/detectors/misconfig.d.ts +3 -0
- package/dist/detectors/misconfig.d.ts.map +1 -0
- package/dist/detectors/misconfig.js +153 -0
- package/dist/detectors/misconfig.js.map +1 -0
- package/dist/detectors/pathtraversal.d.ts +3 -0
- package/dist/detectors/pathtraversal.d.ts.map +1 -0
- package/dist/detectors/pathtraversal.js +90 -0
- package/dist/detectors/pathtraversal.js.map +1 -0
- package/dist/detectors/prototype.d.ts +3 -0
- package/dist/detectors/prototype.d.ts.map +1 -0
- package/dist/detectors/prototype.js +79 -0
- package/dist/detectors/prototype.js.map +1 -0
- package/dist/detectors/secrets.d.ts +4 -0
- package/dist/detectors/secrets.d.ts.map +1 -0
- package/dist/detectors/secrets.js +137 -0
- package/dist/detectors/secrets.js.map +1 -0
- package/dist/detectors/ssrf.d.ts +3 -0
- package/dist/detectors/ssrf.d.ts.map +1 -0
- package/dist/detectors/ssrf.js +78 -0
- package/dist/detectors/ssrf.js.map +1 -0
- package/dist/detectors/zeroday.d.ts +9 -0
- package/dist/detectors/zeroday.d.ts.map +1 -0
- package/dist/detectors/zeroday.js +77 -0
- package/dist/detectors/zeroday.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +42 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/server.d.ts +2 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +358 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/utils/config.d.ts +4 -0
- package/dist/utils/config.d.ts.map +1 -0
- package/dist/utils/config.js +97 -0
- package/dist/utils/config.js.map +1 -0
- package/dist/utils/fingerprint.d.ts +5 -0
- package/dist/utils/fingerprint.d.ts.map +1 -0
- package/dist/utils/fingerprint.js +55 -0
- package/dist/utils/fingerprint.js.map +1 -0
- package/dist/utils/languages.d.ts +8 -0
- package/dist/utils/languages.d.ts.map +1 -0
- package/dist/utils/languages.js +128 -0
- package/dist/utils/languages.js.map +1 -0
- package/package.json +53 -0
- package/src/ai/anthropic.ts +82 -0
- package/src/ai/huggingface.ts +111 -0
- package/src/ai/openai.ts +75 -0
- package/src/ai/prompts.ts +100 -0
- package/src/ai/provider.ts +68 -0
- package/src/cli/index.ts +314 -0
- package/src/core/reporter.ts +356 -0
- package/src/core/rules.ts +1089 -0
- package/src/core/scanner.ts +201 -0
- package/src/core/severity.ts +140 -0
- package/src/detectors/auth.ts +152 -0
- package/src/detectors/crypto.ts +128 -0
- package/src/detectors/dependency.ts +240 -0
- package/src/detectors/deserialize.ts +106 -0
- package/src/detectors/injection.ts +172 -0
- package/src/detectors/misconfig.ts +152 -0
- package/src/detectors/pathtraversal.ts +89 -0
- package/src/detectors/prototype.ts +77 -0
- package/src/detectors/secrets.ts +138 -0
- package/src/detectors/ssrf.ts +77 -0
- package/src/detectors/zeroday.ts +93 -0
- package/src/index.ts +24 -0
- package/src/mcp/server.ts +379 -0
- package/src/utils/config.ts +64 -0
- package/src/utils/fingerprint.ts +21 -0
- package/src/utils/languages.ts +95 -0
- package/tsconfig.json +20 -0
- 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":"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"}
|
|
@@ -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 @@
|
|
|
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"}
|