vaspera 2.10.1 → 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 +9 -0
- package/dist/action/pr-comment.test.js.map +1 -1
- package/dist/action/sarif-upload.test.js +9 -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 +9 -0
- package/dist/scanners/cache.js.map +1 -1
- package/dist/scanners/dast.d.ts +40 -0
- package/dist/scanners/dast.d.ts.map +1 -0
- package/dist/scanners/dast.js +228 -0
- package/dist/scanners/dast.js.map +1 -0
- package/dist/scanners/deploy/types.d.ts +19 -19
- 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 +13 -5
- package/dist/scanners/index.d.ts.map +1 -1
- package/dist/scanners/index.js +197 -15
- 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/openapi.d.ts +20 -0
- package/dist/scanners/openapi.d.ts.map +1 -0
- package/dist/scanners/openapi.js +226 -0
- package/dist/scanners/openapi.js.map +1 -0
- package/dist/scanners/runtime/types.d.ts +4 -4
- package/dist/scanners/rust.d.ts +22 -0
- package/dist/scanners/rust.d.ts.map +1 -0
- package/dist/scanners/rust.js +239 -0
- package/dist/scanners/rust.js.map +1 -0
- package/dist/scanners/scale/types.d.ts +19 -19
- package/dist/scanners/terraform.d.ts +23 -0
- package/dist/scanners/terraform.d.ts.map +1 -0
- package/dist/scanners/terraform.js +207 -0
- package/dist/scanners/terraform.js.map +1 -0
- package/dist/scanners/types.d.ts +1 -1
- package/dist/scanners/types.d.ts.map +1 -1
- package/dist/scanners/types.js +9 -0
- package/dist/scanners/types.js.map +1 -1
- package/package.json +5 -1
|
@@ -0,0 +1,265 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Detection Engine Tests
|
|
3
|
+
*/
|
|
4
|
+
import { describe, it, expect, beforeEach, afterEach } from "vitest";
|
|
5
|
+
import { mkdtemp, rm, writeFile, mkdir } from "fs/promises";
|
|
6
|
+
import { join } from "path";
|
|
7
|
+
import { tmpdir } from "os";
|
|
8
|
+
import { runDetection, getBuiltinRules, getBuiltinRuleById, getBuiltinRulesByCategory, listAvailableRules, getDetectionCategories, BUILTIN_RULES, } from "../index.js";
|
|
9
|
+
import { queryAST } from "../engines/ast-query.js";
|
|
10
|
+
import { analyzeDataFlow } from "../engines/data-flow.js";
|
|
11
|
+
import { createRule, loadRuleFromYAML, RuleValidationError } from "../rules/loader.js";
|
|
12
|
+
describe("Detection Engine", () => {
|
|
13
|
+
let tempDir;
|
|
14
|
+
beforeEach(async () => {
|
|
15
|
+
tempDir = await mkdtemp(join(tmpdir(), `detection-test-${Math.random().toString(36).slice(2, 8)}-`));
|
|
16
|
+
});
|
|
17
|
+
afterEach(async () => {
|
|
18
|
+
await rm(tempDir, { recursive: true, force: true });
|
|
19
|
+
});
|
|
20
|
+
describe("Built-in Rules", () => {
|
|
21
|
+
it("has all expected built-in rules", () => {
|
|
22
|
+
const rules = getBuiltinRules();
|
|
23
|
+
expect(rules.length).toBeGreaterThan(0);
|
|
24
|
+
const categories = new Set(rules.map((r) => r.category));
|
|
25
|
+
expect(categories.has("idor")).toBe(true);
|
|
26
|
+
expect(categories.has("ssrf")).toBe(true);
|
|
27
|
+
expect(categories.has("sql-injection")).toBe(true);
|
|
28
|
+
});
|
|
29
|
+
it("can retrieve rule by ID", () => {
|
|
30
|
+
const rule = getBuiltinRuleById("vaspera:idor:user-controlled-id");
|
|
31
|
+
expect(rule).toBeDefined();
|
|
32
|
+
expect(rule?.name).toContain("User-Controlled ID");
|
|
33
|
+
});
|
|
34
|
+
it("can retrieve rules by category", () => {
|
|
35
|
+
const idorRules = getBuiltinRulesByCategory("idor");
|
|
36
|
+
expect(idorRules.length).toBeGreaterThan(0);
|
|
37
|
+
expect(idorRules.every((r) => r.category === "idor")).toBe(true);
|
|
38
|
+
});
|
|
39
|
+
it("lists available rules with metadata", () => {
|
|
40
|
+
const list = listAvailableRules();
|
|
41
|
+
expect(list.length).toBe(BUILTIN_RULES.length);
|
|
42
|
+
expect(list[0]).toHaveProperty("id");
|
|
43
|
+
expect(list[0]).toHaveProperty("name");
|
|
44
|
+
expect(list[0]).toHaveProperty("category");
|
|
45
|
+
expect(list[0]).toHaveProperty("severity");
|
|
46
|
+
});
|
|
47
|
+
it("returns detection categories", () => {
|
|
48
|
+
const categories = getDetectionCategories();
|
|
49
|
+
expect(categories).toContain("idor");
|
|
50
|
+
expect(categories).toContain("ssrf");
|
|
51
|
+
expect(categories).toContain("xss");
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
describe("Rule Loader", () => {
|
|
55
|
+
it("creates a valid rule programmatically", () => {
|
|
56
|
+
const rule = createRule({
|
|
57
|
+
id: "test:custom:rule",
|
|
58
|
+
name: "Custom Test Rule",
|
|
59
|
+
description: "A test rule",
|
|
60
|
+
category: "test",
|
|
61
|
+
severity: "medium",
|
|
62
|
+
confidence: 75,
|
|
63
|
+
engines: {
|
|
64
|
+
astQuery: { pattern: "test($arg)" },
|
|
65
|
+
},
|
|
66
|
+
});
|
|
67
|
+
expect(rule.id).toBe("test:custom:rule");
|
|
68
|
+
expect(rule.enabled).toBe(true);
|
|
69
|
+
});
|
|
70
|
+
it("loads rule from YAML", async () => {
|
|
71
|
+
const yamlContent = `
|
|
72
|
+
id: test:yaml:rule
|
|
73
|
+
name: YAML Test Rule
|
|
74
|
+
description: A rule loaded from YAML
|
|
75
|
+
category: test
|
|
76
|
+
severity: high
|
|
77
|
+
confidence: 80
|
|
78
|
+
engines:
|
|
79
|
+
astQuery:
|
|
80
|
+
pattern: "dangerousFunction($input)"
|
|
81
|
+
cweIds:
|
|
82
|
+
- CWE-123
|
|
83
|
+
`;
|
|
84
|
+
const yamlPath = join(tempDir, "test-rule.yaml");
|
|
85
|
+
await writeFile(yamlPath, yamlContent, "utf-8");
|
|
86
|
+
const rule = await loadRuleFromYAML(yamlPath);
|
|
87
|
+
expect(rule.id).toBe("test:yaml:rule");
|
|
88
|
+
expect(rule.severity).toBe("high");
|
|
89
|
+
expect(rule.cweIds).toContain("CWE-123");
|
|
90
|
+
});
|
|
91
|
+
it("throws on invalid rule", () => {
|
|
92
|
+
expect(() => createRule({
|
|
93
|
+
id: "test:invalid",
|
|
94
|
+
name: "Invalid",
|
|
95
|
+
description: "Missing engines",
|
|
96
|
+
category: "test",
|
|
97
|
+
severity: "high",
|
|
98
|
+
confidence: 80,
|
|
99
|
+
engines: {},
|
|
100
|
+
})).toThrow(RuleValidationError);
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
describe("AST Query Engine", () => {
|
|
104
|
+
it("matches function calls", async () => {
|
|
105
|
+
const code = `
|
|
106
|
+
function handler(req: Request) {
|
|
107
|
+
const user = findById(req.params.id);
|
|
108
|
+
return user;
|
|
109
|
+
}
|
|
110
|
+
`;
|
|
111
|
+
const filePath = join(tempDir, "query-test.ts");
|
|
112
|
+
await writeFile(filePath, code, "utf-8");
|
|
113
|
+
const matches = await queryAST(filePath, {
|
|
114
|
+
pattern: "findById($id)",
|
|
115
|
+
});
|
|
116
|
+
expect(matches.length).toBeGreaterThan(0);
|
|
117
|
+
expect(matches[0].text).toContain("findById");
|
|
118
|
+
});
|
|
119
|
+
it("captures pattern variables", async () => {
|
|
120
|
+
const code = `
|
|
121
|
+
fetch(userProvidedUrl);
|
|
122
|
+
axios.get(req.body.callback);
|
|
123
|
+
`;
|
|
124
|
+
const filePath = join(tempDir, "capture-test.ts");
|
|
125
|
+
await writeFile(filePath, code, "utf-8");
|
|
126
|
+
const matches = await queryAST(filePath, {
|
|
127
|
+
pattern: "fetch($url)",
|
|
128
|
+
});
|
|
129
|
+
expect(matches.length).toBeGreaterThan(0);
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
describe("Data Flow Engine", () => {
|
|
133
|
+
it("runs data flow analysis without error", async () => {
|
|
134
|
+
const code = `
|
|
135
|
+
function handler(req: Request, res: Response) {
|
|
136
|
+
const userId = req.params.id;
|
|
137
|
+
const user = db.users.findById(userId);
|
|
138
|
+
return res.json(user);
|
|
139
|
+
}
|
|
140
|
+
`;
|
|
141
|
+
const filePath = join(tempDir, "dataflow-test.ts");
|
|
142
|
+
await writeFile(filePath, code, "utf-8");
|
|
143
|
+
const paths = await analyzeDataFlow(filePath, {
|
|
144
|
+
sources: [{ pattern: "req.params.$id" }],
|
|
145
|
+
sinks: [{ pattern: "findById($source)" }],
|
|
146
|
+
});
|
|
147
|
+
expect(Array.isArray(paths)).toBe(true);
|
|
148
|
+
});
|
|
149
|
+
it("respects sanitizers", async () => {
|
|
150
|
+
const code = `
|
|
151
|
+
function handler(req: Request) {
|
|
152
|
+
const id = req.params.id;
|
|
153
|
+
const safeId = validateId(id);
|
|
154
|
+
return db.findById(safeId);
|
|
155
|
+
}
|
|
156
|
+
`;
|
|
157
|
+
const filePath = join(tempDir, "sanitized-test.ts");
|
|
158
|
+
await writeFile(filePath, code, "utf-8");
|
|
159
|
+
const paths = await analyzeDataFlow(filePath, {
|
|
160
|
+
sources: [{ pattern: "req.params.$id" }],
|
|
161
|
+
sinks: [{ pattern: "findById($source)" }],
|
|
162
|
+
sanitizers: [{ pattern: "validateId($input)" }],
|
|
163
|
+
});
|
|
164
|
+
expect(paths.filter((p) => !p.sanitized).length).toBe(0);
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
describe("Full Detection Run", () => {
|
|
168
|
+
it("runs detection on project", async () => {
|
|
169
|
+
const srcDir = join(tempDir, "src");
|
|
170
|
+
await mkdir(srcDir, { recursive: true });
|
|
171
|
+
const code = `
|
|
172
|
+
export function getResource(req: Request) {
|
|
173
|
+
const id = req.params.id;
|
|
174
|
+
return db.resources.findById(id);
|
|
175
|
+
}
|
|
176
|
+
`;
|
|
177
|
+
await writeFile(join(srcDir, "handler.ts"), code, "utf-8");
|
|
178
|
+
const result = await runDetection({
|
|
179
|
+
projectPath: tempDir,
|
|
180
|
+
files: [join(srcDir, "handler.ts")],
|
|
181
|
+
});
|
|
182
|
+
expect(result.success).toBe(true);
|
|
183
|
+
expect(result.filesAnalyzed).toBe(1);
|
|
184
|
+
expect(result.rulesEvaluated).toBeGreaterThan(0);
|
|
185
|
+
});
|
|
186
|
+
it("returns empty for no matches", async () => {
|
|
187
|
+
const code = `
|
|
188
|
+
export function safeFunction() {
|
|
189
|
+
return "hello world";
|
|
190
|
+
}
|
|
191
|
+
`;
|
|
192
|
+
const filePath = join(tempDir, "safe.ts");
|
|
193
|
+
await writeFile(filePath, code, "utf-8");
|
|
194
|
+
const result = await runDetection({
|
|
195
|
+
projectPath: tempDir,
|
|
196
|
+
files: [filePath],
|
|
197
|
+
});
|
|
198
|
+
expect(result.success).toBe(true);
|
|
199
|
+
expect(result.matches.length).toBe(0);
|
|
200
|
+
});
|
|
201
|
+
it("handles SSRF detection", async () => {
|
|
202
|
+
const code = `
|
|
203
|
+
async function fetchWebhook(req: Request) {
|
|
204
|
+
const url = req.body.webhookUrl;
|
|
205
|
+
const response = await fetch(url);
|
|
206
|
+
return response.json();
|
|
207
|
+
}
|
|
208
|
+
`;
|
|
209
|
+
const filePath = join(tempDir, "ssrf.ts");
|
|
210
|
+
await writeFile(filePath, code, "utf-8");
|
|
211
|
+
const ssrfRules = getBuiltinRulesByCategory("ssrf");
|
|
212
|
+
const result = await runDetection({
|
|
213
|
+
projectPath: tempDir,
|
|
214
|
+
files: [filePath],
|
|
215
|
+
rules: ssrfRules,
|
|
216
|
+
});
|
|
217
|
+
expect(result.rulesEvaluated).toBe(ssrfRules.length);
|
|
218
|
+
});
|
|
219
|
+
it("handles SQL injection detection", async () => {
|
|
220
|
+
const code = `
|
|
221
|
+
async function getUsers(req: Request) {
|
|
222
|
+
const name = req.query.name;
|
|
223
|
+
const result = await db.query(\`SELECT * FROM users WHERE name = '\${name}'\`);
|
|
224
|
+
return result;
|
|
225
|
+
}
|
|
226
|
+
`;
|
|
227
|
+
const filePath = join(tempDir, "sqli.ts");
|
|
228
|
+
await writeFile(filePath, code, "utf-8");
|
|
229
|
+
const sqliRules = getBuiltinRulesByCategory("sql-injection");
|
|
230
|
+
const result = await runDetection({
|
|
231
|
+
projectPath: tempDir,
|
|
232
|
+
files: [filePath],
|
|
233
|
+
rules: sqliRules,
|
|
234
|
+
});
|
|
235
|
+
expect(result.rulesEvaluated).toBe(sqliRules.length);
|
|
236
|
+
});
|
|
237
|
+
});
|
|
238
|
+
describe("Detection Match Format", () => {
|
|
239
|
+
it("includes required fields in matches", async () => {
|
|
240
|
+
const code = `
|
|
241
|
+
function handler(req: Request) {
|
|
242
|
+
const url = req.body.url;
|
|
243
|
+
fetch(url);
|
|
244
|
+
}
|
|
245
|
+
`;
|
|
246
|
+
const filePath = join(tempDir, "match-format.ts");
|
|
247
|
+
await writeFile(filePath, code, "utf-8");
|
|
248
|
+
const result = await runDetection({
|
|
249
|
+
projectPath: tempDir,
|
|
250
|
+
files: [filePath],
|
|
251
|
+
});
|
|
252
|
+
if (result.matches.length > 0) {
|
|
253
|
+
const match = result.matches[0];
|
|
254
|
+
expect(match).toHaveProperty("ruleId");
|
|
255
|
+
expect(match).toHaveProperty("file");
|
|
256
|
+
expect(match).toHaveProperty("line");
|
|
257
|
+
expect(match).toHaveProperty("message");
|
|
258
|
+
expect(match).toHaveProperty("severity");
|
|
259
|
+
expect(match).toHaveProperty("confidence");
|
|
260
|
+
expect(match).toHaveProperty("category");
|
|
261
|
+
}
|
|
262
|
+
});
|
|
263
|
+
});
|
|
264
|
+
});
|
|
265
|
+
//# sourceMappingURL=detection.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detection.test.js","sourceRoot":"","sources":["../../../../src/scanners/detection/__tests__/detection.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
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 { Node } from "ts-morph";
|
|
10
|
+
import type { ASTQueryConfig, DetectionMatch, DetectionRule } from "../types.js";
|
|
11
|
+
export interface ASTMatch {
|
|
12
|
+
node: Node;
|
|
13
|
+
file: string;
|
|
14
|
+
line: number;
|
|
15
|
+
column: number;
|
|
16
|
+
endLine: number;
|
|
17
|
+
endColumn: number;
|
|
18
|
+
text: string;
|
|
19
|
+
captures: Record<string, string>;
|
|
20
|
+
}
|
|
21
|
+
export declare function queryAST(filePath: string, config: ASTQueryConfig): Promise<ASTMatch[]>;
|
|
22
|
+
export declare function runASTQueryEngine(projectPath: string, rules: DetectionRule[], files?: string[]): Promise<DetectionMatch[]>;
|
|
23
|
+
//# sourceMappingURL=ast-query.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ast-query.d.ts","sourceRoot":"","sources":["../../../../src/scanners/detection/engines/ast-query.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAW,IAAI,EAA0B,MAAM,UAAU,CAAC;AAIjE,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAOjF,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,IAAI,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAClC;AAmLD,wBAAsB,QAAQ,CAC5B,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,cAAc,GACrB,OAAO,CAAC,QAAQ,EAAE,CAAC,CA+BrB;AAED,wBAAsB,iBAAiB,CACrC,WAAW,EAAE,MAAM,EACnB,KAAK,EAAE,aAAa,EAAE,EACtB,KAAK,CAAC,EAAE,MAAM,EAAE,GACf,OAAO,CAAC,cAAc,EAAE,CAAC,CAuC3B"}
|
|
@@ -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"}
|