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 @@
|
|
|
1
|
+
{"version":3,"file":"rules.js","sourceRoot":"","sources":["../../src/core/rules.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Finding, ScanResult, ScanOptions } from './severity';
|
|
2
|
+
import * as zerodayDetector from '../detectors/zeroday';
|
|
3
|
+
export declare function scan(target: string, options?: ScanOptions): Promise<ScanResult>;
|
|
4
|
+
export declare function scanFile(filePath: string, content: string, language: string): Finding[];
|
|
5
|
+
export declare function scanWithAI(findings: Finding[], files: Map<string, string>, provider: zerodayDetector.AIProvider): Promise<Finding[]>;
|
|
6
|
+
//# sourceMappingURL=scanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../../src/core/scanner.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,UAAU,EAAe,WAAW,EAA8B,MAAM,YAAY,CAAC;AAevG,OAAO,KAAK,eAAe,MAAM,sBAAsB,CAAC;AAexD,wBAAsB,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,GAAE,WAAgB,GAAG,OAAO,CAAC,UAAU,CAAC,CAiGzF;AAED,wBAAgB,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,EAAE,CAavF;AAED,wBAAsB,UAAU,CAC9B,QAAQ,EAAE,OAAO,EAAE,EACnB,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,EAC1B,QAAQ,EAAE,eAAe,CAAC,UAAU,GACnC,OAAO,CAAC,OAAO,EAAE,CAAC,CAgBpB"}
|
|
@@ -0,0 +1,217 @@
|
|
|
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
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.scan = scan;
|
|
40
|
+
exports.scanFile = scanFile;
|
|
41
|
+
exports.scanWithAI = scanWithAI;
|
|
42
|
+
const fs = __importStar(require("fs"));
|
|
43
|
+
const path = __importStar(require("path"));
|
|
44
|
+
const glob_1 = require("glob");
|
|
45
|
+
const micromatch_1 = __importDefault(require("micromatch"));
|
|
46
|
+
const severity_1 = require("./severity");
|
|
47
|
+
const languages_1 = require("../utils/languages");
|
|
48
|
+
const config_1 = require("../utils/config");
|
|
49
|
+
const fingerprint_1 = require("../utils/fingerprint");
|
|
50
|
+
const injectionDetector = __importStar(require("../detectors/injection"));
|
|
51
|
+
const authDetector = __importStar(require("../detectors/auth"));
|
|
52
|
+
const cryptoDetector = __importStar(require("../detectors/crypto"));
|
|
53
|
+
const secretsDetector = __importStar(require("../detectors/secrets"));
|
|
54
|
+
const ssrfDetector = __importStar(require("../detectors/ssrf"));
|
|
55
|
+
const pathTraversalDetector = __importStar(require("../detectors/pathtraversal"));
|
|
56
|
+
const prototypeDetector = __importStar(require("../detectors/prototype"));
|
|
57
|
+
const deserializeDetector = __importStar(require("../detectors/deserialize"));
|
|
58
|
+
const dependencyDetector = __importStar(require("../detectors/dependency"));
|
|
59
|
+
const misconfigDetector = __importStar(require("../detectors/misconfig"));
|
|
60
|
+
const zerodayDetector = __importStar(require("../detectors/zeroday"));
|
|
61
|
+
const ALL_DETECTORS = [
|
|
62
|
+
injectionDetector,
|
|
63
|
+
authDetector,
|
|
64
|
+
cryptoDetector,
|
|
65
|
+
secretsDetector,
|
|
66
|
+
ssrfDetector,
|
|
67
|
+
pathTraversalDetector,
|
|
68
|
+
prototypeDetector,
|
|
69
|
+
deserializeDetector,
|
|
70
|
+
dependencyDetector,
|
|
71
|
+
misconfigDetector,
|
|
72
|
+
];
|
|
73
|
+
async function scan(target, options = {}) {
|
|
74
|
+
const startTime = new Date();
|
|
75
|
+
const resolvedTarget = path.resolve(target || '.');
|
|
76
|
+
const config = (0, config_1.loadConfig)(options.configPath, resolvedTarget);
|
|
77
|
+
const minSeverity = options.severity || config.severity || severity_1.Severity.LOW;
|
|
78
|
+
const excludePatterns = options.exclude || config.exclude || languages_1.DEFAULT_EXCLUDE;
|
|
79
|
+
const maxFileSize = options.maxFileSize || config.maxFileSize || 1048576;
|
|
80
|
+
let files = [];
|
|
81
|
+
const stat = fs.statSync(resolvedTarget);
|
|
82
|
+
if (stat.isFile()) {
|
|
83
|
+
files = [resolvedTarget];
|
|
84
|
+
}
|
|
85
|
+
else if (stat.isDirectory()) {
|
|
86
|
+
const allFiles = await (0, glob_1.glob)('**/*', {
|
|
87
|
+
cwd: resolvedTarget,
|
|
88
|
+
nodir: true,
|
|
89
|
+
absolute: true,
|
|
90
|
+
ignore: excludePatterns,
|
|
91
|
+
});
|
|
92
|
+
files = allFiles.filter(f => {
|
|
93
|
+
const relative = path.relative(resolvedTarget, f);
|
|
94
|
+
return !micromatch_1.default.isMatch(relative, excludePatterns);
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
// Filter by supported languages and file size
|
|
98
|
+
let filesScanned = 0;
|
|
99
|
+
let filesSkipped = 0;
|
|
100
|
+
let allFindings = [];
|
|
101
|
+
const scanPromises = files.map(async (filePath) => {
|
|
102
|
+
try {
|
|
103
|
+
const fileStat = fs.statSync(filePath);
|
|
104
|
+
if (fileStat.size > maxFileSize) {
|
|
105
|
+
filesSkipped++;
|
|
106
|
+
return [];
|
|
107
|
+
}
|
|
108
|
+
const language = (0, languages_1.detectLanguage)(filePath);
|
|
109
|
+
const isConfig = (0, languages_1.isConfigFile)(filePath);
|
|
110
|
+
if (!language && !isConfig) {
|
|
111
|
+
filesSkipped++;
|
|
112
|
+
return [];
|
|
113
|
+
}
|
|
114
|
+
filesScanned++;
|
|
115
|
+
const content = fs.readFileSync(filePath, 'utf-8');
|
|
116
|
+
return scanFile(filePath, content, language || 'generic');
|
|
117
|
+
}
|
|
118
|
+
catch {
|
|
119
|
+
filesSkipped++;
|
|
120
|
+
return [];
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
const results = await Promise.all(scanPromises);
|
|
124
|
+
allFindings = results.flat();
|
|
125
|
+
// Run zero-day suspicious pattern detection
|
|
126
|
+
if (options.ai !== false) {
|
|
127
|
+
for (const filePath of files) {
|
|
128
|
+
try {
|
|
129
|
+
const language = (0, languages_1.detectLanguage)(filePath);
|
|
130
|
+
if (!language)
|
|
131
|
+
continue;
|
|
132
|
+
const content = fs.readFileSync(filePath, 'utf-8');
|
|
133
|
+
const suspiciousFindings = zerodayDetector.detectSuspiciousPatterns(content, filePath, language);
|
|
134
|
+
allFindings.push(...suspiciousFindings);
|
|
135
|
+
}
|
|
136
|
+
catch {
|
|
137
|
+
// Skip files that can't be read
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
// Deduplicate
|
|
142
|
+
allFindings = (0, fingerprint_1.deduplicateFindings)(allFindings);
|
|
143
|
+
// Filter by severity
|
|
144
|
+
allFindings = allFindings.filter(f => (0, severity_1.meetsMinSeverity)(f.severity, minSeverity));
|
|
145
|
+
// Sort by severity (critical first)
|
|
146
|
+
const severityOrder = { critical: 0, high: 1, medium: 2, low: 3, info: 4 };
|
|
147
|
+
allFindings.sort((a, b) => severityOrder[a.severity] - severityOrder[b.severity]);
|
|
148
|
+
const endTime = new Date();
|
|
149
|
+
return {
|
|
150
|
+
target: resolvedTarget,
|
|
151
|
+
startTime,
|
|
152
|
+
endTime,
|
|
153
|
+
durationMs: endTime.getTime() - startTime.getTime(),
|
|
154
|
+
filesScanned,
|
|
155
|
+
filesSkipped,
|
|
156
|
+
findings: allFindings,
|
|
157
|
+
summary: buildSummary(allFindings),
|
|
158
|
+
aiEnabled: options.ai || false,
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
function scanFile(filePath, content, language) {
|
|
162
|
+
const findings = [];
|
|
163
|
+
for (const detector of ALL_DETECTORS) {
|
|
164
|
+
try {
|
|
165
|
+
const detectorFindings = detector.detect(content, filePath, language);
|
|
166
|
+
findings.push(...detectorFindings);
|
|
167
|
+
}
|
|
168
|
+
catch {
|
|
169
|
+
// Skip detector errors
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
return findings;
|
|
173
|
+
}
|
|
174
|
+
async function scanWithAI(findings, files, provider) {
|
|
175
|
+
const aiFindings = [];
|
|
176
|
+
for (const [filePath, content] of files) {
|
|
177
|
+
const language = (0, languages_1.detectLanguage)(filePath);
|
|
178
|
+
if (!language)
|
|
179
|
+
continue;
|
|
180
|
+
try {
|
|
181
|
+
const results = await zerodayDetector.analyzeWithAI(content, filePath, language, provider);
|
|
182
|
+
aiFindings.push(...results);
|
|
183
|
+
}
|
|
184
|
+
catch {
|
|
185
|
+
// AI analysis failed for this file
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
return [...findings, ...aiFindings];
|
|
189
|
+
}
|
|
190
|
+
function buildSummary(findings) {
|
|
191
|
+
const bySeverity = {
|
|
192
|
+
[severity_1.Severity.CRITICAL]: 0,
|
|
193
|
+
[severity_1.Severity.HIGH]: 0,
|
|
194
|
+
[severity_1.Severity.MEDIUM]: 0,
|
|
195
|
+
[severity_1.Severity.LOW]: 0,
|
|
196
|
+
[severity_1.Severity.INFO]: 0,
|
|
197
|
+
};
|
|
198
|
+
const byCategory = {};
|
|
199
|
+
const fileCount = {};
|
|
200
|
+
for (const f of findings) {
|
|
201
|
+
bySeverity[f.severity]++;
|
|
202
|
+
const cat = f.owasp || 'other';
|
|
203
|
+
byCategory[cat] = (byCategory[cat] || 0) + 1;
|
|
204
|
+
fileCount[f.filePath] = (fileCount[f.filePath] || 0) + 1;
|
|
205
|
+
}
|
|
206
|
+
const topFiles = Object.entries(fileCount)
|
|
207
|
+
.map(([file, count]) => ({ file, count }))
|
|
208
|
+
.sort((a, b) => b.count - a.count)
|
|
209
|
+
.slice(0, 10);
|
|
210
|
+
return {
|
|
211
|
+
total: findings.length,
|
|
212
|
+
bySeverity,
|
|
213
|
+
byCategory,
|
|
214
|
+
topFiles,
|
|
215
|
+
};
|
|
216
|
+
}
|
|
217
|
+
//# sourceMappingURL=scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanner.js","sourceRoot":"","sources":["../../src/core/scanner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
export declare enum Severity {
|
|
2
|
+
CRITICAL = "critical",
|
|
3
|
+
HIGH = "high",
|
|
4
|
+
MEDIUM = "medium",
|
|
5
|
+
LOW = "low",
|
|
6
|
+
INFO = "info"
|
|
7
|
+
}
|
|
8
|
+
export declare const SEVERITY_ORDER: Record<Severity, number>;
|
|
9
|
+
export declare const SEVERITY_COLORS: Record<Severity, string>;
|
|
10
|
+
export declare const SEVERITY_ICONS: Record<Severity, string>;
|
|
11
|
+
export declare function severityFromString(s: string): Severity;
|
|
12
|
+
export declare function meetsMinSeverity(severity: Severity, minSeverity: Severity): boolean;
|
|
13
|
+
export interface Finding {
|
|
14
|
+
id: string;
|
|
15
|
+
ruleId: string;
|
|
16
|
+
title: string;
|
|
17
|
+
description: string;
|
|
18
|
+
severity: Severity;
|
|
19
|
+
confidence: 'high' | 'medium' | 'low';
|
|
20
|
+
filePath: string;
|
|
21
|
+
line: number;
|
|
22
|
+
column?: number;
|
|
23
|
+
endLine?: number;
|
|
24
|
+
endColumn?: number;
|
|
25
|
+
codeSnippet: string;
|
|
26
|
+
cwe?: string;
|
|
27
|
+
owasp?: string;
|
|
28
|
+
remediation?: string;
|
|
29
|
+
aiEnhanced?: boolean;
|
|
30
|
+
fingerprint: string;
|
|
31
|
+
}
|
|
32
|
+
export interface AIFinding {
|
|
33
|
+
title: string;
|
|
34
|
+
description: string;
|
|
35
|
+
severity: Severity;
|
|
36
|
+
confidence: 'high' | 'medium' | 'low';
|
|
37
|
+
line?: number;
|
|
38
|
+
cwe?: string;
|
|
39
|
+
remediation?: string;
|
|
40
|
+
}
|
|
41
|
+
export interface ScanResult {
|
|
42
|
+
target: string;
|
|
43
|
+
startTime: Date;
|
|
44
|
+
endTime: Date;
|
|
45
|
+
durationMs: number;
|
|
46
|
+
filesScanned: number;
|
|
47
|
+
filesSkipped: number;
|
|
48
|
+
findings: Finding[];
|
|
49
|
+
summary: ScanSummary;
|
|
50
|
+
aiEnabled: boolean;
|
|
51
|
+
}
|
|
52
|
+
export interface ScanSummary {
|
|
53
|
+
total: number;
|
|
54
|
+
bySeverity: Record<Severity, number>;
|
|
55
|
+
byCategory: Record<string, number>;
|
|
56
|
+
topFiles: Array<{
|
|
57
|
+
file: string;
|
|
58
|
+
count: number;
|
|
59
|
+
}>;
|
|
60
|
+
}
|
|
61
|
+
export interface Rule {
|
|
62
|
+
id: string;
|
|
63
|
+
name: string;
|
|
64
|
+
severity: Severity;
|
|
65
|
+
confidence: 'high' | 'medium' | 'low';
|
|
66
|
+
cwe?: string;
|
|
67
|
+
owasp?: string;
|
|
68
|
+
pattern: RegExp;
|
|
69
|
+
antiPattern?: RegExp;
|
|
70
|
+
languages: string[];
|
|
71
|
+
description: string;
|
|
72
|
+
remediation: string;
|
|
73
|
+
}
|
|
74
|
+
export interface ScanOptions {
|
|
75
|
+
target?: string;
|
|
76
|
+
output?: 'terminal' | 'json' | 'sarif' | 'html';
|
|
77
|
+
severity?: Severity;
|
|
78
|
+
ai?: boolean;
|
|
79
|
+
provider?: 'huggingface' | 'anthropic' | 'openai';
|
|
80
|
+
fix?: boolean;
|
|
81
|
+
quiet?: boolean;
|
|
82
|
+
exclude?: string[];
|
|
83
|
+
maxFileSize?: number;
|
|
84
|
+
configPath?: string;
|
|
85
|
+
}
|
|
86
|
+
export interface GhostPatchConfig {
|
|
87
|
+
exclude: string[];
|
|
88
|
+
severity: Severity;
|
|
89
|
+
ai: {
|
|
90
|
+
provider: string;
|
|
91
|
+
model: string;
|
|
92
|
+
};
|
|
93
|
+
rules: {
|
|
94
|
+
disabled: string[];
|
|
95
|
+
custom: Rule[];
|
|
96
|
+
};
|
|
97
|
+
maxFileSize: number;
|
|
98
|
+
languages: string | string[];
|
|
99
|
+
}
|
|
100
|
+
//# sourceMappingURL=severity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"severity.d.ts","sourceRoot":"","sources":["../../src/core/severity.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SEVERITY_ICONS = exports.SEVERITY_COLORS = exports.SEVERITY_ORDER = exports.Severity = void 0;
|
|
4
|
+
exports.severityFromString = severityFromString;
|
|
5
|
+
exports.meetsMinSeverity = meetsMinSeverity;
|
|
6
|
+
var Severity;
|
|
7
|
+
(function (Severity) {
|
|
8
|
+
Severity["CRITICAL"] = "critical";
|
|
9
|
+
Severity["HIGH"] = "high";
|
|
10
|
+
Severity["MEDIUM"] = "medium";
|
|
11
|
+
Severity["LOW"] = "low";
|
|
12
|
+
Severity["INFO"] = "info";
|
|
13
|
+
})(Severity || (exports.Severity = Severity = {}));
|
|
14
|
+
exports.SEVERITY_ORDER = {
|
|
15
|
+
[Severity.CRITICAL]: 5,
|
|
16
|
+
[Severity.HIGH]: 4,
|
|
17
|
+
[Severity.MEDIUM]: 3,
|
|
18
|
+
[Severity.LOW]: 2,
|
|
19
|
+
[Severity.INFO]: 1,
|
|
20
|
+
};
|
|
21
|
+
exports.SEVERITY_COLORS = {
|
|
22
|
+
[Severity.CRITICAL]: '\x1b[41m\x1b[37m',
|
|
23
|
+
[Severity.HIGH]: '\x1b[31m',
|
|
24
|
+
[Severity.MEDIUM]: '\x1b[33m',
|
|
25
|
+
[Severity.LOW]: '\x1b[36m',
|
|
26
|
+
[Severity.INFO]: '\x1b[90m',
|
|
27
|
+
};
|
|
28
|
+
exports.SEVERITY_ICONS = {
|
|
29
|
+
[Severity.CRITICAL]: '[!!!]',
|
|
30
|
+
[Severity.HIGH]: '[!!]',
|
|
31
|
+
[Severity.MEDIUM]: '[!]',
|
|
32
|
+
[Severity.LOW]: '[~]',
|
|
33
|
+
[Severity.INFO]: '[i]',
|
|
34
|
+
};
|
|
35
|
+
function severityFromString(s) {
|
|
36
|
+
const lower = s.toLowerCase();
|
|
37
|
+
if (lower in Severity)
|
|
38
|
+
return lower;
|
|
39
|
+
const map = {
|
|
40
|
+
crit: Severity.CRITICAL,
|
|
41
|
+
error: Severity.HIGH,
|
|
42
|
+
warn: Severity.MEDIUM,
|
|
43
|
+
warning: Severity.MEDIUM,
|
|
44
|
+
note: Severity.LOW,
|
|
45
|
+
information: Severity.INFO,
|
|
46
|
+
};
|
|
47
|
+
return map[lower] ?? Severity.MEDIUM;
|
|
48
|
+
}
|
|
49
|
+
function meetsMinSeverity(severity, minSeverity) {
|
|
50
|
+
return exports.SEVERITY_ORDER[severity] >= exports.SEVERITY_ORDER[minSeverity];
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=severity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"severity.js","sourceRoot":"","sources":["../../src/core/severity.ts"],"names":[],"mappings":";;;AAgCA,gDAYC;AAED,4CAEC;AAhDD,IAAY,QAMX;AAND,WAAY,QAAQ;IAClB,iCAAqB,CAAA;IACrB,yBAAa,CAAA;IACb,6BAAiB,CAAA;IACjB,uBAAW,CAAA;IACX,yBAAa,CAAA;AACf,CAAC,EANW,QAAQ,wBAAR,QAAQ,QAMnB;AAEY,QAAA,cAAc,GAA6B;IACtD,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;IACtB,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;IAClB,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;IACpB,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;IACjB,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;CACnB,CAAC;AAEW,QAAA,eAAe,GAA6B;IACvD,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,kBAAkB;IACvC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU;IAC3B,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,UAAU;IAC7B,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,UAAU;IAC1B,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,UAAU;CAC5B,CAAC;AAEW,QAAA,cAAc,GAA6B;IACtD,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO;IAC5B,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM;IACvB,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,KAAK;IACxB,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,KAAK;IACrB,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,KAAK;CACvB,CAAC;AAEF,SAAgB,kBAAkB,CAAC,CAAS;IAC1C,MAAM,KAAK,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;IAC9B,IAAI,KAAK,IAAI,QAAQ;QAAE,OAAO,KAAiB,CAAC;IAChD,MAAM,GAAG,GAA6B;QACpC,IAAI,EAAE,QAAQ,CAAC,QAAQ;QACvB,KAAK,EAAE,QAAQ,CAAC,IAAI;QACpB,IAAI,EAAE,QAAQ,CAAC,MAAM;QACrB,OAAO,EAAE,QAAQ,CAAC,MAAM;QACxB,IAAI,EAAE,QAAQ,CAAC,GAAG;QAClB,WAAW,EAAE,QAAQ,CAAC,IAAI;KAC3B,CAAC;IACF,OAAO,GAAG,CAAC,KAAK,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC;AACvC,CAAC;AAED,SAAgB,gBAAgB,CAAC,QAAkB,EAAE,WAAqB;IACxE,OAAO,sBAAc,CAAC,QAAQ,CAAC,IAAI,sBAAc,CAAC,WAAW,CAAC,CAAC;AACjE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/detectors/auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAY,MAAM,kBAAkB,CAAC;AAsGrD,wBAAgB,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,EAAE,CAqCrF"}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.detect = detect;
|
|
4
|
+
const severity_1 = require("../core/severity");
|
|
5
|
+
const fingerprint_1 = require("../utils/fingerprint");
|
|
6
|
+
const PATTERNS = [
|
|
7
|
+
{
|
|
8
|
+
id: 'AUTH-BYPASS-NONE-ALG', name: 'JWT None Algorithm', severity: severity_1.Severity.CRITICAL, confidence: 'high',
|
|
9
|
+
cwe: 'CWE-345', pattern: /algorithms?\s*:\s*\[?\s*['"]none['"]/i,
|
|
10
|
+
languages: ['javascript', 'typescript'],
|
|
11
|
+
description: 'JWT accepts "none" algorithm, allowing signature bypass.',
|
|
12
|
+
remediation: 'Explicitly set allowed algorithms: algorithms: ["HS256"] or ["RS256"].',
|
|
13
|
+
},
|
|
14
|
+
{
|
|
15
|
+
id: 'AUTH-HARDCODED-JWT', name: 'Hardcoded JWT Secret', severity: severity_1.Severity.CRITICAL, confidence: 'high',
|
|
16
|
+
cwe: 'CWE-798', pattern: /(?:jwt|jsonwebtoken)\.(?:sign|verify)\s*\([^)]*,\s*['"][^'"]{4,}['"]/i,
|
|
17
|
+
languages: ['javascript', 'typescript'],
|
|
18
|
+
description: 'JWT signing secret hardcoded in source code.',
|
|
19
|
+
remediation: 'Use environment variables for JWT secrets.',
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
id: 'AUTH-NO-EXPIRY', name: 'JWT Without Expiration', severity: severity_1.Severity.MEDIUM, confidence: 'medium',
|
|
23
|
+
cwe: 'CWE-613', pattern: /jwt\.sign\s*\(\s*\{[^}]*\}\s*,/,
|
|
24
|
+
antiPattern: /(?:expiresIn|exp\s*:|maxAge)/i,
|
|
25
|
+
languages: ['javascript', 'typescript'],
|
|
26
|
+
description: 'JWT created without expiration time.',
|
|
27
|
+
remediation: 'Set token expiration: jwt.sign(payload, secret, { expiresIn: "1h" }).',
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
id: 'AUTH-WEAK-PASSWORD', name: 'Weak Password Policy', severity: severity_1.Severity.MEDIUM, confidence: 'medium',
|
|
31
|
+
cwe: 'CWE-521', pattern: /(?:password|passwd).*(?:min|length|minLength)\s*[:=<]\s*[1-7]\b/i,
|
|
32
|
+
languages: ['javascript', 'typescript', 'python', 'java', 'php', 'ruby', 'csharp', 'go'],
|
|
33
|
+
description: 'Password minimum length is too short.',
|
|
34
|
+
remediation: 'Enforce minimum 8-character passwords, ideally 12+.',
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
id: 'AUTH-PLAINTEXT-PASS', name: 'Password Stored Without Hashing', severity: severity_1.Severity.CRITICAL, confidence: 'medium',
|
|
38
|
+
cwe: 'CWE-256', pattern: /(?:user|account).*(?:password|passwd)\s*[:=]\s*(?:req\.|request\.|input\.|body\.)/i,
|
|
39
|
+
antiPattern: /(?:hash|bcrypt|scrypt|argon|pbkdf|encrypt|crypt)/i,
|
|
40
|
+
languages: ['javascript', 'typescript', 'python', 'java', 'php', 'ruby'],
|
|
41
|
+
description: 'Password from user input may be stored without hashing.',
|
|
42
|
+
remediation: 'Hash passwords with bcrypt, scrypt, or argon2 before storage.',
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
id: 'AUTH-SESSION-FIXATION', name: 'Session Fixation', severity: severity_1.Severity.HIGH, confidence: 'low',
|
|
46
|
+
cwe: 'CWE-384', pattern: /(?:login|authenticate|signIn)\s*(?:=|:|\().*(?:session|cookie)/i,
|
|
47
|
+
antiPattern: /(?:regenerate|destroy|invalidate|new.*session)/i,
|
|
48
|
+
languages: ['javascript', 'typescript', 'python', 'java', 'php'],
|
|
49
|
+
description: 'Login handler may not regenerate session ID.',
|
|
50
|
+
remediation: 'Regenerate session ID after successful authentication.',
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
id: 'AUTH-DEFAULT-CREDS', name: 'Default Credentials', severity: severity_1.Severity.CRITICAL, confidence: 'high',
|
|
54
|
+
cwe: 'CWE-798', pattern: /(?:password|passwd|pwd)\s*[:=]\s*['"](?:admin|password|123456|root|default|test|guest|letmein|welcome|12345678|qwerty|abc123)['"]/i,
|
|
55
|
+
antiPattern: /(?:test|spec|mock|example|placeholder)/i,
|
|
56
|
+
languages: ['javascript', 'typescript', 'python', 'java', 'php', 'ruby', 'go', 'csharp'],
|
|
57
|
+
description: 'Default or commonly guessed password found in code.',
|
|
58
|
+
remediation: 'Remove hardcoded credentials. Use environment variables or secret management.',
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
id: 'AUTH-NO-LOCKOUT', name: 'Missing Account Lockout', severity: severity_1.Severity.MEDIUM, confidence: 'low',
|
|
62
|
+
cwe: 'CWE-307', pattern: /(?:login|authenticate|signIn)\s*(?:=|:|\().*(?:password|credential)/i,
|
|
63
|
+
antiPattern: /(?:lockout|maxAttempts|failedAttempts|brute|throttle|rateLimit|delay)/i,
|
|
64
|
+
languages: ['javascript', 'typescript', 'python', 'java', 'php'],
|
|
65
|
+
description: 'Login function without brute force protection.',
|
|
66
|
+
remediation: 'Implement account lockout after N failed attempts.',
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
id: 'AUTH-PASS-IN-URL', name: 'Password in URL', severity: severity_1.Severity.HIGH, confidence: 'high',
|
|
70
|
+
cwe: 'CWE-598', pattern: /(?:url|href|redirect|link|location).*[?&](?:password|passwd|pwd|secret|token)=/i,
|
|
71
|
+
languages: ['javascript', 'typescript', 'python', 'java', 'php', 'ruby', 'go', 'csharp'],
|
|
72
|
+
description: 'Sensitive credential sent in URL query parameter.',
|
|
73
|
+
remediation: 'Send credentials in request body or headers.',
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
id: 'AUTH-MISSING-MIDDLEWARE', name: 'Route Without Auth Middleware', severity: severity_1.Severity.HIGH, confidence: 'medium',
|
|
77
|
+
cwe: 'CWE-862', pattern: /(?:app|router)\.(get|post|put|delete|patch)\s*\(\s*['"]\/(?:admin|api\/admin|dashboard|settings|users?\/\w|account)/i,
|
|
78
|
+
antiPattern: /(?:auth|protect|guard|session|verify|middleware|isAuthenticated|requireAuth|passport)/i,
|
|
79
|
+
languages: ['javascript', 'typescript'],
|
|
80
|
+
description: 'Sensitive route may lack authentication middleware.',
|
|
81
|
+
remediation: 'Add authentication middleware before the route handler.',
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
id: 'AUTH-PRIVILEGE-ESCALATION', name: 'Privilege Escalation Risk', severity: severity_1.Severity.CRITICAL, confidence: 'medium',
|
|
85
|
+
cwe: 'CWE-269', pattern: /(?:role|isAdmin|is_admin|permission|privilege)\s*=\s*(?:req\.|request\.|params|body|query|input)/i,
|
|
86
|
+
languages: ['javascript', 'typescript', 'python', 'java', 'php'],
|
|
87
|
+
description: 'User role or admin status set from user-controlled input.',
|
|
88
|
+
remediation: 'Derive roles from server-side session data, never from user input.',
|
|
89
|
+
},
|
|
90
|
+
];
|
|
91
|
+
function detect(content, filePath, language) {
|
|
92
|
+
const findings = [];
|
|
93
|
+
const lines = content.split('\n');
|
|
94
|
+
for (const pat of PATTERNS) {
|
|
95
|
+
if (!pat.languages.includes(language))
|
|
96
|
+
continue;
|
|
97
|
+
for (let i = 0; i < lines.length; i++) {
|
|
98
|
+
const line = lines[i];
|
|
99
|
+
if (pat.pattern.test(line)) {
|
|
100
|
+
if (pat.antiPattern) {
|
|
101
|
+
const contextStart = Math.max(0, i - 5);
|
|
102
|
+
const contextEnd = Math.min(lines.length, i + 6);
|
|
103
|
+
const context = lines.slice(contextStart, contextEnd).join('\n');
|
|
104
|
+
if (pat.antiPattern.test(context))
|
|
105
|
+
continue;
|
|
106
|
+
}
|
|
107
|
+
findings.push({
|
|
108
|
+
id: `${pat.id}-${filePath}:${i + 1}`,
|
|
109
|
+
ruleId: pat.id,
|
|
110
|
+
title: pat.name,
|
|
111
|
+
description: pat.description,
|
|
112
|
+
severity: pat.severity,
|
|
113
|
+
confidence: pat.confidence,
|
|
114
|
+
filePath,
|
|
115
|
+
line: i + 1,
|
|
116
|
+
codeSnippet: getSnippet(lines, i),
|
|
117
|
+
cwe: pat.cwe,
|
|
118
|
+
owasp: 'A07',
|
|
119
|
+
remediation: pat.remediation,
|
|
120
|
+
fingerprint: (0, fingerprint_1.generateFingerprint)(pat.id, filePath, line.trim()),
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
return findings;
|
|
126
|
+
}
|
|
127
|
+
function getSnippet(lines, index, context = 2) {
|
|
128
|
+
const start = Math.max(0, index - context);
|
|
129
|
+
const end = Math.min(lines.length, index + context + 1);
|
|
130
|
+
return lines.slice(start, end)
|
|
131
|
+
.map((l, i) => {
|
|
132
|
+
const lineNum = start + i + 1;
|
|
133
|
+
const marker = (start + i === index) ? '>' : ' ';
|
|
134
|
+
return `${marker} ${lineNum} | ${l}`;
|
|
135
|
+
})
|
|
136
|
+
.join('\n');
|
|
137
|
+
}
|
|
138
|
+
//# sourceMappingURL=auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/detectors/auth.ts"],"names":[],"mappings":"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"}
|