vaspera 2.11.0 → 2.12.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/dist/__tests__/audit-trail.test.d.ts +7 -0
- package/dist/__tests__/audit-trail.test.d.ts.map +1 -0
- package/dist/__tests__/audit-trail.test.js +336 -0
- package/dist/__tests__/audit-trail.test.js.map +1 -0
- package/dist/__tests__/property-test-helpers.d.ts +1 -1
- package/dist/action/pr-comment.test.js +1 -0
- package/dist/action/pr-comment.test.js.map +1 -1
- package/dist/action/sarif-upload.test.js +1 -0
- package/dist/action/sarif-upload.test.js.map +1 -1
- package/dist/autofix/ast/__tests__/typescript.test.d.ts +5 -0
- package/dist/autofix/ast/__tests__/typescript.test.d.ts.map +1 -0
- package/dist/autofix/ast/__tests__/typescript.test.js +210 -0
- package/dist/autofix/ast/__tests__/typescript.test.js.map +1 -0
- package/dist/autofix/ast/index.d.ts +11 -0
- package/dist/autofix/ast/index.d.ts.map +1 -0
- package/dist/autofix/ast/index.js +11 -0
- package/dist/autofix/ast/index.js.map +1 -0
- package/dist/autofix/ast/types.d.ts +77 -0
- package/dist/autofix/ast/types.d.ts.map +1 -0
- package/dist/autofix/ast/types.js +9 -0
- package/dist/autofix/ast/types.js.map +1 -0
- package/dist/autofix/ast/typescript.d.ts +17 -0
- package/dist/autofix/ast/typescript.d.ts.map +1 -0
- package/dist/autofix/ast/typescript.js +427 -0
- package/dist/autofix/ast/typescript.js.map +1 -0
- package/dist/autofix/constitution.schema.d.ts +21 -21
- package/dist/autofix/index.d.ts +1 -0
- package/dist/autofix/index.d.ts.map +1 -1
- package/dist/autofix/index.js +2 -0
- package/dist/autofix/index.js.map +1 -1
- package/dist/config/flags.d.ts +6 -6
- package/dist/history/store.d.ts +55 -1
- package/dist/history/store.d.ts.map +1 -1
- package/dist/history/store.js +152 -4
- package/dist/history/store.js.map +1 -1
- package/dist/history/types.d.ts +9 -5
- package/dist/history/types.d.ts.map +1 -1
- package/dist/history/verify.d.ts.map +1 -1
- package/dist/history/verify.js +5 -3
- package/dist/history/verify.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +627 -0
- package/dist/index.js.map +1 -1
- package/dist/integrations/siem/datadog.d.ts +44 -0
- package/dist/integrations/siem/datadog.d.ts.map +1 -0
- package/dist/integrations/siem/datadog.js +211 -0
- package/dist/integrations/siem/datadog.js.map +1 -0
- package/dist/integrations/siem/format.d.ts +59 -0
- package/dist/integrations/siem/format.d.ts.map +1 -0
- package/dist/integrations/siem/format.js +360 -0
- package/dist/integrations/siem/format.js.map +1 -0
- package/dist/integrations/siem/index.d.ts +56 -0
- package/dist/integrations/siem/index.d.ts.map +1 -0
- package/dist/integrations/siem/index.js +117 -0
- package/dist/integrations/siem/index.js.map +1 -0
- package/dist/integrations/siem/sentinel.d.ts +53 -0
- package/dist/integrations/siem/sentinel.d.ts.map +1 -0
- package/dist/integrations/siem/sentinel.js +231 -0
- package/dist/integrations/siem/sentinel.js.map +1 -0
- package/dist/integrations/siem/splunk.d.ts +46 -0
- package/dist/integrations/siem/splunk.d.ts.map +1 -0
- package/dist/integrations/siem/splunk.js +210 -0
- package/dist/integrations/siem/splunk.js.map +1 -0
- package/dist/integrations/siem/types.d.ts +210 -0
- package/dist/integrations/siem/types.d.ts.map +1 -0
- package/dist/integrations/siem/types.js +9 -0
- package/dist/integrations/siem/types.js.map +1 -0
- package/dist/persistence/__tests__/persistence.test.d.ts +5 -0
- package/dist/persistence/__tests__/persistence.test.d.ts.map +1 -0
- package/dist/persistence/__tests__/persistence.test.js +369 -0
- package/dist/persistence/__tests__/persistence.test.js.map +1 -0
- package/dist/persistence/db.d.ts +15 -0
- package/dist/persistence/db.d.ts.map +1 -0
- package/dist/persistence/db.js +79 -0
- package/dist/persistence/db.js.map +1 -0
- package/dist/persistence/index.d.ts +66 -0
- package/dist/persistence/index.d.ts.map +1 -0
- package/dist/persistence/index.js +143 -0
- package/dist/persistence/index.js.map +1 -0
- package/dist/persistence/migrations/index.d.ts +10 -0
- package/dist/persistence/migrations/index.d.ts.map +1 -0
- package/dist/persistence/migrations/index.js +125 -0
- package/dist/persistence/migrations/index.js.map +1 -0
- package/dist/persistence/repositories/findings.d.ts +41 -0
- package/dist/persistence/repositories/findings.d.ts.map +1 -0
- package/dist/persistence/repositories/findings.js +238 -0
- package/dist/persistence/repositories/findings.js.map +1 -0
- package/dist/persistence/repositories/projects.d.ts +22 -0
- package/dist/persistence/repositories/projects.d.ts.map +1 -0
- package/dist/persistence/repositories/projects.js +71 -0
- package/dist/persistence/repositories/projects.js.map +1 -0
- package/dist/persistence/repositories/scans.d.ts +30 -0
- package/dist/persistence/repositories/scans.d.ts.map +1 -0
- package/dist/persistence/repositories/scans.js +107 -0
- package/dist/persistence/repositories/scans.js.map +1 -0
- package/dist/persistence/repositories/trends.d.ts +42 -0
- package/dist/persistence/repositories/trends.d.ts.map +1 -0
- package/dist/persistence/repositories/trends.js +178 -0
- package/dist/persistence/repositories/trends.js.map +1 -0
- package/dist/persistence/types.d.ts +105 -0
- package/dist/persistence/types.d.ts.map +1 -0
- package/dist/persistence/types.js +13 -0
- package/dist/persistence/types.js.map +1 -0
- package/dist/plugins/types.d.ts +2 -2
- package/dist/scanners/ai-code/types.d.ts +12 -12
- package/dist/scanners/cache.d.ts.map +1 -1
- package/dist/scanners/cache.js +1 -0
- package/dist/scanners/cache.js.map +1 -1
- package/dist/scanners/deploy/types.d.ts +13 -13
- package/dist/scanners/detection/__tests__/detection.test.d.ts +5 -0
- package/dist/scanners/detection/__tests__/detection.test.d.ts.map +1 -0
- package/dist/scanners/detection/__tests__/detection.test.js +265 -0
- package/dist/scanners/detection/__tests__/detection.test.js.map +1 -0
- package/dist/scanners/detection/engines/ast-query.d.ts +23 -0
- package/dist/scanners/detection/engines/ast-query.d.ts.map +1 -0
- package/dist/scanners/detection/engines/ast-query.js +232 -0
- package/dist/scanners/detection/engines/ast-query.js.map +1 -0
- package/dist/scanners/detection/engines/data-flow.d.ts +12 -0
- package/dist/scanners/detection/engines/data-flow.d.ts.map +1 -0
- package/dist/scanners/detection/engines/data-flow.js +269 -0
- package/dist/scanners/detection/engines/data-flow.js.map +1 -0
- package/dist/scanners/detection/index.d.ts +29 -0
- package/dist/scanners/detection/index.d.ts.map +1 -0
- package/dist/scanners/detection/index.js +140 -0
- package/dist/scanners/detection/index.js.map +1 -0
- package/dist/scanners/detection/rules/builtin.d.ts +14 -0
- package/dist/scanners/detection/rules/builtin.d.ts.map +1 -0
- package/dist/scanners/detection/rules/builtin.js +307 -0
- package/dist/scanners/detection/rules/builtin.js.map +1 -0
- package/dist/scanners/detection/rules/loader.d.ts +19 -0
- package/dist/scanners/detection/rules/loader.d.ts.map +1 -0
- package/dist/scanners/detection/rules/loader.js +111 -0
- package/dist/scanners/detection/rules/loader.js.map +1 -0
- package/dist/scanners/detection/types.d.ts +171 -0
- package/dist/scanners/detection/types.d.ts.map +1 -0
- package/dist/scanners/detection/types.js +36 -0
- package/dist/scanners/detection/types.js.map +1 -0
- package/dist/scanners/index.d.ts +9 -1
- package/dist/scanners/index.d.ts.map +1 -1
- package/dist/scanners/index.js +64 -0
- package/dist/scanners/index.js.map +1 -1
- package/dist/scanners/index.test.js +6 -6
- package/dist/scanners/index.test.js.map +1 -1
- package/dist/scanners/scale/types.d.ts +3 -3
- package/dist/scanners/types.d.ts +1 -1
- package/dist/scanners/types.d.ts.map +1 -1
- package/dist/scanners/types.js +1 -0
- package/dist/scanners/types.js.map +1 -1
- package/package.json +5 -1
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* AST Query Engine
|
|
3
|
+
*
|
|
4
|
+
* Pattern-based AST matching using ts-morph for TypeScript/JavaScript.
|
|
5
|
+
* Supports parameterized patterns with capture groups.
|
|
6
|
+
*
|
|
7
|
+
* @module scanners/detection/engines/ast-query
|
|
8
|
+
*/
|
|
9
|
+
import { Project, Node } from "ts-morph";
|
|
10
|
+
import { readFile } from "fs/promises";
|
|
11
|
+
import { glob } from "glob";
|
|
12
|
+
const project = new Project({
|
|
13
|
+
useInMemoryFileSystem: false,
|
|
14
|
+
skipFileDependencyResolution: true,
|
|
15
|
+
});
|
|
16
|
+
function parsePattern(pattern) {
|
|
17
|
+
const parts = [];
|
|
18
|
+
let i = 0;
|
|
19
|
+
while (i < pattern.length) {
|
|
20
|
+
if (pattern[i] === "$" && i + 1 < pattern.length) {
|
|
21
|
+
const start = i + 1;
|
|
22
|
+
let end = start;
|
|
23
|
+
while (end < pattern.length && /[a-zA-Z0-9_]/.test(pattern[end])) {
|
|
24
|
+
end++;
|
|
25
|
+
}
|
|
26
|
+
if (end > start) {
|
|
27
|
+
parts.push({ type: "capture", value: pattern.slice(start, end), name: pattern.slice(start, end) });
|
|
28
|
+
i = end;
|
|
29
|
+
continue;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
if (pattern.slice(i, i + 3) === "...") {
|
|
33
|
+
parts.push({ type: "wildcard", value: "..." });
|
|
34
|
+
i += 3;
|
|
35
|
+
continue;
|
|
36
|
+
}
|
|
37
|
+
let literalEnd = i;
|
|
38
|
+
while (literalEnd < pattern.length && pattern[literalEnd] !== "$" && pattern.slice(literalEnd, literalEnd + 3) !== "...") {
|
|
39
|
+
literalEnd++;
|
|
40
|
+
}
|
|
41
|
+
if (literalEnd > i) {
|
|
42
|
+
parts.push({ type: "literal", value: pattern.slice(i, literalEnd) });
|
|
43
|
+
i = literalEnd;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
return parts;
|
|
47
|
+
}
|
|
48
|
+
function matchPattern(text, parts) {
|
|
49
|
+
const captures = {};
|
|
50
|
+
let textIdx = 0;
|
|
51
|
+
for (let i = 0; i < parts.length; i++) {
|
|
52
|
+
const part = parts[i];
|
|
53
|
+
if (part.type === "literal") {
|
|
54
|
+
const literal = part.value.trim();
|
|
55
|
+
const remaining = text.slice(textIdx).trim();
|
|
56
|
+
if (!remaining.startsWith(literal)) {
|
|
57
|
+
return { matched: false, captures: {} };
|
|
58
|
+
}
|
|
59
|
+
textIdx = text.indexOf(literal, textIdx) + literal.length;
|
|
60
|
+
}
|
|
61
|
+
else if (part.type === "capture") {
|
|
62
|
+
const nextPart = parts[i + 1];
|
|
63
|
+
let endIdx;
|
|
64
|
+
if (!nextPart) {
|
|
65
|
+
endIdx = text.length;
|
|
66
|
+
}
|
|
67
|
+
else if (nextPart.type === "literal") {
|
|
68
|
+
const nextLiteral = nextPart.value.trim();
|
|
69
|
+
endIdx = text.indexOf(nextLiteral, textIdx);
|
|
70
|
+
if (endIdx === -1) {
|
|
71
|
+
return { matched: false, captures: {} };
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
endIdx = text.length;
|
|
76
|
+
}
|
|
77
|
+
const captured = text.slice(textIdx, endIdx).trim();
|
|
78
|
+
if (part.name) {
|
|
79
|
+
captures[part.name] = captured;
|
|
80
|
+
}
|
|
81
|
+
textIdx = endIdx;
|
|
82
|
+
}
|
|
83
|
+
else if (part.type === "wildcard") {
|
|
84
|
+
const nextPart = parts[i + 1];
|
|
85
|
+
if (!nextPart) {
|
|
86
|
+
textIdx = text.length;
|
|
87
|
+
}
|
|
88
|
+
else if (nextPart.type === "literal") {
|
|
89
|
+
const nextLiteral = nextPart.value.trim();
|
|
90
|
+
const idx = text.indexOf(nextLiteral, textIdx);
|
|
91
|
+
if (idx === -1) {
|
|
92
|
+
return { matched: false, captures: {} };
|
|
93
|
+
}
|
|
94
|
+
textIdx = idx;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
return { matched: true, captures };
|
|
99
|
+
}
|
|
100
|
+
function findCallExpressions(sourceFile, pattern) {
|
|
101
|
+
const matches = [];
|
|
102
|
+
const parts = parsePattern(pattern);
|
|
103
|
+
sourceFile.forEachDescendant((node) => {
|
|
104
|
+
if (Node.isCallExpression(node)) {
|
|
105
|
+
const text = node.getText();
|
|
106
|
+
const result = matchPattern(text, parts);
|
|
107
|
+
if (result.matched) {
|
|
108
|
+
matches.push({
|
|
109
|
+
node,
|
|
110
|
+
file: sourceFile.getFilePath(),
|
|
111
|
+
line: node.getStartLineNumber(),
|
|
112
|
+
column: node.getStartLinePos() - node.getStartLinePos(true) + 1,
|
|
113
|
+
endLine: node.getEndLineNumber(),
|
|
114
|
+
endColumn: node.getEnd() - node.getStartLinePos(true) + 1,
|
|
115
|
+
text,
|
|
116
|
+
captures: result.captures,
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
return matches;
|
|
122
|
+
}
|
|
123
|
+
function findPropertyAccess(sourceFile, pattern) {
|
|
124
|
+
const matches = [];
|
|
125
|
+
const parts = parsePattern(pattern);
|
|
126
|
+
sourceFile.forEachDescendant((node) => {
|
|
127
|
+
if (Node.isPropertyAccessExpression(node) || Node.isElementAccessExpression(node)) {
|
|
128
|
+
const text = node.getText();
|
|
129
|
+
const result = matchPattern(text, parts);
|
|
130
|
+
if (result.matched) {
|
|
131
|
+
matches.push({
|
|
132
|
+
node,
|
|
133
|
+
file: sourceFile.getFilePath(),
|
|
134
|
+
line: node.getStartLineNumber(),
|
|
135
|
+
column: node.getStartLinePos() - node.getStartLinePos(true) + 1,
|
|
136
|
+
endLine: node.getEndLineNumber(),
|
|
137
|
+
endColumn: node.getEnd() - node.getStartLinePos(true) + 1,
|
|
138
|
+
text,
|
|
139
|
+
captures: result.captures,
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
});
|
|
144
|
+
return matches;
|
|
145
|
+
}
|
|
146
|
+
function findAssignments(sourceFile, pattern) {
|
|
147
|
+
const matches = [];
|
|
148
|
+
const parts = parsePattern(pattern);
|
|
149
|
+
sourceFile.forEachDescendant((node) => {
|
|
150
|
+
if (Node.isBinaryExpression(node) && node.getOperatorToken().getText() === "=") {
|
|
151
|
+
const text = node.getText();
|
|
152
|
+
const result = matchPattern(text, parts);
|
|
153
|
+
if (result.matched) {
|
|
154
|
+
matches.push({
|
|
155
|
+
node,
|
|
156
|
+
file: sourceFile.getFilePath(),
|
|
157
|
+
line: node.getStartLineNumber(),
|
|
158
|
+
column: node.getStartLinePos() - node.getStartLinePos(true) + 1,
|
|
159
|
+
endLine: node.getEndLineNumber(),
|
|
160
|
+
endColumn: node.getEnd() - node.getStartLinePos(true) + 1,
|
|
161
|
+
text,
|
|
162
|
+
captures: result.captures,
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
});
|
|
167
|
+
return matches;
|
|
168
|
+
}
|
|
169
|
+
export async function queryAST(filePath, config) {
|
|
170
|
+
try {
|
|
171
|
+
const content = await readFile(filePath, "utf-8");
|
|
172
|
+
const sourceFile = project.createSourceFile(`query_${Date.now()}_${Math.random().toString(36).slice(2)}.ts`, content, { overwrite: true });
|
|
173
|
+
let matches = [];
|
|
174
|
+
const pattern = config.pattern;
|
|
175
|
+
if (pattern.includes("(") && pattern.includes(")")) {
|
|
176
|
+
matches = findCallExpressions(sourceFile, pattern);
|
|
177
|
+
}
|
|
178
|
+
else if (pattern.includes(".") || pattern.includes("[")) {
|
|
179
|
+
matches = findPropertyAccess(sourceFile, pattern);
|
|
180
|
+
}
|
|
181
|
+
else if (pattern.includes("=")) {
|
|
182
|
+
matches = findAssignments(sourceFile, pattern);
|
|
183
|
+
}
|
|
184
|
+
else {
|
|
185
|
+
matches = [
|
|
186
|
+
...findCallExpressions(sourceFile, pattern),
|
|
187
|
+
...findPropertyAccess(sourceFile, pattern),
|
|
188
|
+
];
|
|
189
|
+
}
|
|
190
|
+
sourceFile.delete();
|
|
191
|
+
return matches.map((m) => ({ ...m, file: filePath }));
|
|
192
|
+
}
|
|
193
|
+
catch {
|
|
194
|
+
return [];
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
export async function runASTQueryEngine(projectPath, rules, files) {
|
|
198
|
+
const matches = [];
|
|
199
|
+
const targetFiles = files || (await glob("**/*.{ts,tsx,js,jsx}", {
|
|
200
|
+
cwd: projectPath,
|
|
201
|
+
ignore: ["**/node_modules/**", "**/dist/**", "**/build/**", "**/.git/**"],
|
|
202
|
+
absolute: true,
|
|
203
|
+
}));
|
|
204
|
+
for (const rule of rules) {
|
|
205
|
+
if (!rule.engines.astQuery)
|
|
206
|
+
continue;
|
|
207
|
+
const config = rule.engines.astQuery;
|
|
208
|
+
for (const file of targetFiles) {
|
|
209
|
+
const astMatches = await queryAST(file, config);
|
|
210
|
+
for (const match of astMatches) {
|
|
211
|
+
matches.push({
|
|
212
|
+
ruleId: rule.id,
|
|
213
|
+
file: match.file,
|
|
214
|
+
line: match.line,
|
|
215
|
+
column: match.column,
|
|
216
|
+
endLine: match.endLine,
|
|
217
|
+
endColumn: match.endColumn,
|
|
218
|
+
message: rule.description,
|
|
219
|
+
severity: rule.severity,
|
|
220
|
+
confidence: rule.confidence,
|
|
221
|
+
category: rule.category,
|
|
222
|
+
evidence: match.text,
|
|
223
|
+
cweIds: rule.cweIds,
|
|
224
|
+
owaspRefs: rule.owaspRefs,
|
|
225
|
+
autofixPatternId: rule.autofixPatternId,
|
|
226
|
+
});
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
return matches;
|
|
231
|
+
}
|
|
232
|
+
//# sourceMappingURL=ast-query.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ast-query.js","sourceRoot":"","sources":["../../../../src/scanners/detection/engines/ast-query.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Data Flow (Taint Tracking) Engine
|
|
3
|
+
*
|
|
4
|
+
* Tracks how untrusted data flows from sources to sinks.
|
|
5
|
+
* Core of security vulnerability detection.
|
|
6
|
+
*
|
|
7
|
+
* @module scanners/detection/engines/data-flow
|
|
8
|
+
*/
|
|
9
|
+
import type { DataFlowConfig, TaintPath, DetectionMatch, DetectionRule } from "../types.js";
|
|
10
|
+
export declare function analyzeDataFlow(filePath: string, config: DataFlowConfig): Promise<TaintPath[]>;
|
|
11
|
+
export declare function runDataFlowEngine(projectPath: string, rules: DetectionRule[], files?: string[]): Promise<DetectionMatch[]>;
|
|
12
|
+
//# sourceMappingURL=data-flow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-flow.d.ts","sourceRoot":"","sources":["../../../../src/scanners/detection/engines/data-flow.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAKH,OAAO,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,cAAc,EAAE,aAAa,EAAqC,MAAM,aAAa,CAAC;AA4Q/H,wBAAsB,eAAe,CACnC,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,cAAc,GACrB,OAAO,CAAC,SAAS,EAAE,CAAC,CAqBtB;AAED,wBAAsB,iBAAiB,CACrC,WAAW,EAAE,MAAM,EACnB,KAAK,EAAE,aAAa,EAAE,EACtB,KAAK,CAAC,EAAE,MAAM,EAAE,GACf,OAAO,CAAC,cAAc,EAAE,CAAC,CAsC3B"}
|
|
@@ -0,0 +1,269 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Data Flow (Taint Tracking) Engine
|
|
3
|
+
*
|
|
4
|
+
* Tracks how untrusted data flows from sources to sinks.
|
|
5
|
+
* Core of security vulnerability detection.
|
|
6
|
+
*
|
|
7
|
+
* @module scanners/detection/engines/data-flow
|
|
8
|
+
*/
|
|
9
|
+
import { Project, Node } from "ts-morph";
|
|
10
|
+
import { readFile } from "fs/promises";
|
|
11
|
+
import { glob } from "glob";
|
|
12
|
+
const project = new Project({
|
|
13
|
+
useInMemoryFileSystem: false,
|
|
14
|
+
skipFileDependencyResolution: true,
|
|
15
|
+
});
|
|
16
|
+
function matchesPattern(text, pattern) {
|
|
17
|
+
const normalizedPattern = pattern
|
|
18
|
+
.replace(/\$[a-zA-Z_][a-zA-Z0-9_]*/g, ".*")
|
|
19
|
+
.replace(/\{[^}]+\}/g, "[^.]+")
|
|
20
|
+
.replace(/\./g, "\\.")
|
|
21
|
+
.replace(/\(/g, "\\(")
|
|
22
|
+
.replace(/\)/g, "\\)")
|
|
23
|
+
.replace(/\*/g, ".*");
|
|
24
|
+
try {
|
|
25
|
+
const regex = new RegExp(normalizedPattern);
|
|
26
|
+
return regex.test(text);
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
return text.includes(pattern.replace(/[${}]/g, ""));
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
function findSources(sourceFile, sources) {
|
|
33
|
+
const found = [];
|
|
34
|
+
sourceFile.forEachDescendant((node) => {
|
|
35
|
+
const text = node.getText();
|
|
36
|
+
for (const source of sources) {
|
|
37
|
+
if (matchesPattern(text, source.pattern)) {
|
|
38
|
+
found.push({
|
|
39
|
+
type: "source",
|
|
40
|
+
expression: text,
|
|
41
|
+
file: sourceFile.getFilePath(),
|
|
42
|
+
line: node.getStartLineNumber(),
|
|
43
|
+
column: node.getStartLinePos() - node.getStartLinePos(true) + 1,
|
|
44
|
+
pattern: source.pattern,
|
|
45
|
+
});
|
|
46
|
+
if (Node.isPropertyAccessExpression(node) || Node.isElementAccessExpression(node)) {
|
|
47
|
+
const parent = node.getParent();
|
|
48
|
+
if (parent && Node.isVariableDeclaration(parent)) {
|
|
49
|
+
found[found.length - 1].variable = parent.getName();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
return found;
|
|
56
|
+
}
|
|
57
|
+
function findSinks(sourceFile, sinks) {
|
|
58
|
+
const found = [];
|
|
59
|
+
sourceFile.forEachDescendant((node) => {
|
|
60
|
+
if (!Node.isCallExpression(node))
|
|
61
|
+
return;
|
|
62
|
+
const text = node.getText();
|
|
63
|
+
const expression = node.getExpression().getText();
|
|
64
|
+
for (const sink of sinks) {
|
|
65
|
+
if (matchesPattern(expression, sink.pattern) || matchesPattern(text, sink.pattern)) {
|
|
66
|
+
found.push({
|
|
67
|
+
type: "sink",
|
|
68
|
+
expression: text,
|
|
69
|
+
file: sourceFile.getFilePath(),
|
|
70
|
+
line: node.getStartLineNumber(),
|
|
71
|
+
column: node.getStartLinePos() - node.getStartLinePos(true) + 1,
|
|
72
|
+
pattern: sink.pattern,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
return found;
|
|
78
|
+
}
|
|
79
|
+
function findSanitizers(sourceFile, sanitizers) {
|
|
80
|
+
const found = [];
|
|
81
|
+
sourceFile.forEachDescendant((node) => {
|
|
82
|
+
if (!Node.isCallExpression(node))
|
|
83
|
+
return;
|
|
84
|
+
const text = node.getText();
|
|
85
|
+
for (const sanitizer of sanitizers) {
|
|
86
|
+
if (matchesPattern(text, sanitizer.pattern)) {
|
|
87
|
+
found.push({
|
|
88
|
+
type: "sanitizer",
|
|
89
|
+
expression: text,
|
|
90
|
+
file: sourceFile.getFilePath(),
|
|
91
|
+
line: node.getStartLineNumber(),
|
|
92
|
+
column: node.getStartLinePos() - node.getStartLinePos(true) + 1,
|
|
93
|
+
pattern: sanitizer.pattern,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
return found;
|
|
99
|
+
}
|
|
100
|
+
function extractVariablesFromExpression(expr) {
|
|
101
|
+
const identifiers = [];
|
|
102
|
+
const identifierRegex = /\b([a-zA-Z_][a-zA-Z0-9_]*)\b/g;
|
|
103
|
+
let match;
|
|
104
|
+
while ((match = identifierRegex.exec(expr)) !== null) {
|
|
105
|
+
const id = match[1];
|
|
106
|
+
if (!["const", "let", "var", "function", "async", "await", "return", "if", "else", "for", "while", "true", "false", "null", "undefined"].includes(id)) {
|
|
107
|
+
identifiers.push(id);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
return identifiers;
|
|
111
|
+
}
|
|
112
|
+
function traceTaintFlow(sourceFile, sources, sinks, sanitizers) {
|
|
113
|
+
const paths = [];
|
|
114
|
+
const taintedVars = new Set();
|
|
115
|
+
for (const source of sources) {
|
|
116
|
+
if (source.variable) {
|
|
117
|
+
taintedVars.add(source.variable);
|
|
118
|
+
}
|
|
119
|
+
const sourceVars = extractVariablesFromExpression(source.expression);
|
|
120
|
+
for (const v of sourceVars) {
|
|
121
|
+
if (v.includes("req") || v.includes("params") || v.includes("query") || v.includes("body") || v.includes("input")) {
|
|
122
|
+
taintedVars.add(v);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
sourceFile.forEachDescendant((node) => {
|
|
127
|
+
if (Node.isVariableDeclaration(node)) {
|
|
128
|
+
const init = node.getInitializer();
|
|
129
|
+
if (init) {
|
|
130
|
+
const initText = init.getText();
|
|
131
|
+
const initVars = extractVariablesFromExpression(initText);
|
|
132
|
+
for (const v of initVars) {
|
|
133
|
+
if (taintedVars.has(v)) {
|
|
134
|
+
taintedVars.add(node.getName());
|
|
135
|
+
break;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
if (Node.isBinaryExpression(node) && node.getOperatorToken().getText() === "=") {
|
|
141
|
+
const left = node.getLeft();
|
|
142
|
+
const right = node.getRight();
|
|
143
|
+
if (Node.isIdentifier(left)) {
|
|
144
|
+
const rightVars = extractVariablesFromExpression(right.getText());
|
|
145
|
+
for (const v of rightVars) {
|
|
146
|
+
if (taintedVars.has(v)) {
|
|
147
|
+
taintedVars.add(left.getText());
|
|
148
|
+
break;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
const sanitizerLines = new Set(sanitizers.map((s) => s.line));
|
|
155
|
+
for (const sink of sinks) {
|
|
156
|
+
const sinkVars = extractVariablesFromExpression(sink.expression);
|
|
157
|
+
let isTainted = false;
|
|
158
|
+
for (const v of sinkVars) {
|
|
159
|
+
if (taintedVars.has(v)) {
|
|
160
|
+
isTainted = true;
|
|
161
|
+
break;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
if (!isTainted)
|
|
165
|
+
continue;
|
|
166
|
+
let sanitized = false;
|
|
167
|
+
let sanitizerPattern;
|
|
168
|
+
for (const sanitizer of sanitizers) {
|
|
169
|
+
if (sanitizer.line < sink.line) {
|
|
170
|
+
const sanitizerVars = extractVariablesFromExpression(sanitizer.expression);
|
|
171
|
+
for (const v of sanitizerVars) {
|
|
172
|
+
if (sinkVars.includes(v)) {
|
|
173
|
+
sanitized = true;
|
|
174
|
+
sanitizerPattern = sanitizer.pattern;
|
|
175
|
+
break;
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
for (const source of sources) {
|
|
181
|
+
const sourceVars = source.variable
|
|
182
|
+
? [source.variable]
|
|
183
|
+
: extractVariablesFromExpression(source.expression);
|
|
184
|
+
let connected = false;
|
|
185
|
+
for (const sv of sourceVars) {
|
|
186
|
+
if (taintedVars.has(sv)) {
|
|
187
|
+
for (const sinkVar of sinkVars) {
|
|
188
|
+
if (taintedVars.has(sinkVar)) {
|
|
189
|
+
connected = true;
|
|
190
|
+
break;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
if (!connected)
|
|
196
|
+
continue;
|
|
197
|
+
paths.push({
|
|
198
|
+
source: {
|
|
199
|
+
pattern: source.pattern || source.expression,
|
|
200
|
+
file: source.file,
|
|
201
|
+
line: source.line,
|
|
202
|
+
column: source.column,
|
|
203
|
+
expression: source.expression,
|
|
204
|
+
},
|
|
205
|
+
sink: {
|
|
206
|
+
pattern: sink.pattern || sink.expression,
|
|
207
|
+
file: sink.file,
|
|
208
|
+
line: sink.line,
|
|
209
|
+
column: sink.column,
|
|
210
|
+
expression: sink.expression,
|
|
211
|
+
},
|
|
212
|
+
intermediateNodes: [],
|
|
213
|
+
sanitized,
|
|
214
|
+
sanitizer: sanitizerPattern,
|
|
215
|
+
});
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
return paths;
|
|
219
|
+
}
|
|
220
|
+
export async function analyzeDataFlow(filePath, config) {
|
|
221
|
+
try {
|
|
222
|
+
const content = await readFile(filePath, "utf-8");
|
|
223
|
+
const sourceFile = project.createSourceFile(`dataflow_${Date.now()}_${Math.random().toString(36).slice(2)}.ts`, content, { overwrite: true });
|
|
224
|
+
const sources = findSources(sourceFile, config.sources);
|
|
225
|
+
const sinks = findSinks(sourceFile, config.sinks);
|
|
226
|
+
const sanitizers = config.sanitizers ? findSanitizers(sourceFile, config.sanitizers) : [];
|
|
227
|
+
const paths = traceTaintFlow(sourceFile, sources, sinks, sanitizers);
|
|
228
|
+
sourceFile.delete();
|
|
229
|
+
return paths.filter((p) => !p.sanitized);
|
|
230
|
+
}
|
|
231
|
+
catch {
|
|
232
|
+
return [];
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
export async function runDataFlowEngine(projectPath, rules, files) {
|
|
236
|
+
const matches = [];
|
|
237
|
+
const targetFiles = files || (await glob("**/*.{ts,tsx,js,jsx}", {
|
|
238
|
+
cwd: projectPath,
|
|
239
|
+
ignore: ["**/node_modules/**", "**/dist/**", "**/build/**", "**/.git/**"],
|
|
240
|
+
absolute: true,
|
|
241
|
+
}));
|
|
242
|
+
for (const rule of rules) {
|
|
243
|
+
if (!rule.engines.dataFlow)
|
|
244
|
+
continue;
|
|
245
|
+
const config = rule.engines.dataFlow;
|
|
246
|
+
for (const file of targetFiles) {
|
|
247
|
+
const paths = await analyzeDataFlow(file, config);
|
|
248
|
+
for (const path of paths) {
|
|
249
|
+
matches.push({
|
|
250
|
+
ruleId: rule.id,
|
|
251
|
+
file: path.sink.file,
|
|
252
|
+
line: path.sink.line,
|
|
253
|
+
column: path.sink.column,
|
|
254
|
+
message: `${rule.description} - Tainted data flows from ${path.source.expression} to ${path.sink.expression}`,
|
|
255
|
+
severity: rule.severity,
|
|
256
|
+
confidence: rule.confidence,
|
|
257
|
+
category: rule.category,
|
|
258
|
+
evidence: path.sink.expression,
|
|
259
|
+
taintPath: path,
|
|
260
|
+
cweIds: rule.cweIds,
|
|
261
|
+
owaspRefs: rule.owaspRefs,
|
|
262
|
+
autofixPatternId: rule.autofixPatternId,
|
|
263
|
+
});
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
return matches;
|
|
268
|
+
}
|
|
269
|
+
//# sourceMappingURL=data-flow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"data-flow.js","sourceRoot":"","sources":["../../../../src/scanners/detection/engines/data-flow.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Detection Engine
|
|
3
|
+
*
|
|
4
|
+
* Proprietary security detection engine for Vaspera.
|
|
5
|
+
* Combines AST query, data flow, and control flow analysis
|
|
6
|
+
* for high-confidence vulnerability detection.
|
|
7
|
+
*
|
|
8
|
+
* @module scanners/detection
|
|
9
|
+
*/
|
|
10
|
+
import type { DetectionContext, DetectionResult } from "./types.js";
|
|
11
|
+
import { getBuiltinRules, getBuiltinRulesByCategory, getBuiltinRuleById, BUILTIN_RULES } from "./rules/builtin.js";
|
|
12
|
+
export * from "./types.js";
|
|
13
|
+
export { queryAST, type ASTMatch } from "./engines/ast-query.js";
|
|
14
|
+
export { analyzeDataFlow } from "./engines/data-flow.js";
|
|
15
|
+
export { loadRulesFromDirectory, loadRuleFromYAML, createRule, RuleValidationError } from "./rules/loader.js";
|
|
16
|
+
export { getBuiltinRules, getBuiltinRuleById, getBuiltinRulesByCategory, BUILTIN_RULES };
|
|
17
|
+
export declare function runDetection(context: DetectionContext): Promise<DetectionResult>;
|
|
18
|
+
export declare function runDetectionWithCustomRules(context: DetectionContext, customRulesDir?: string): Promise<DetectionResult>;
|
|
19
|
+
export declare function listAvailableRules(): {
|
|
20
|
+
id: string;
|
|
21
|
+
name: string;
|
|
22
|
+
category: string;
|
|
23
|
+
severity: string;
|
|
24
|
+
enabled: boolean;
|
|
25
|
+
}[];
|
|
26
|
+
export declare function getDetectionCategories(): string[];
|
|
27
|
+
export declare function enableRule(ruleId: string): boolean;
|
|
28
|
+
export declare function disableRule(ruleId: string): boolean;
|
|
29
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/scanners/detection/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,KAAK,EAAE,gBAAgB,EAAE,eAAe,EAAiC,MAAM,YAAY,CAAC;AAGnG,OAAO,EAAE,eAAe,EAAE,yBAAyB,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAGnH,cAAc,YAAY,CAAC;AAC3B,OAAO,EAAE,QAAQ,EAAE,KAAK,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAC9G,OAAO,EAAE,eAAe,EAAE,kBAAkB,EAAE,yBAAyB,EAAE,aAAa,EAAE,CAAC;AAEzF,wBAAsB,YAAY,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,eAAe,CAAC,CA0EtF;AAiBD,wBAAsB,2BAA2B,CAC/C,OAAO,EAAE,gBAAgB,EACzB,cAAc,CAAC,EAAE,MAAM,GACtB,OAAO,CAAC,eAAe,CAAC,CAa1B;AAED,wBAAgB,kBAAkB,IAAI;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,OAAO,CAAA;CAAE,EAAE,CAQzH;AAED,wBAAgB,sBAAsB,IAAI,MAAM,EAAE,CAGjD;AAED,wBAAgB,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAOlD;AAED,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAOnD"}
|