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.
Files changed (166) hide show
  1. package/dist/__tests__/audit-trail.test.d.ts +7 -0
  2. package/dist/__tests__/audit-trail.test.d.ts.map +1 -0
  3. package/dist/__tests__/audit-trail.test.js +336 -0
  4. package/dist/__tests__/audit-trail.test.js.map +1 -0
  5. package/dist/__tests__/property-test-helpers.d.ts +1 -1
  6. package/dist/action/pr-comment.test.js +9 -0
  7. package/dist/action/pr-comment.test.js.map +1 -1
  8. package/dist/action/sarif-upload.test.js +9 -0
  9. package/dist/action/sarif-upload.test.js.map +1 -1
  10. package/dist/autofix/ast/__tests__/typescript.test.d.ts +5 -0
  11. package/dist/autofix/ast/__tests__/typescript.test.d.ts.map +1 -0
  12. package/dist/autofix/ast/__tests__/typescript.test.js +210 -0
  13. package/dist/autofix/ast/__tests__/typescript.test.js.map +1 -0
  14. package/dist/autofix/ast/index.d.ts +11 -0
  15. package/dist/autofix/ast/index.d.ts.map +1 -0
  16. package/dist/autofix/ast/index.js +11 -0
  17. package/dist/autofix/ast/index.js.map +1 -0
  18. package/dist/autofix/ast/types.d.ts +77 -0
  19. package/dist/autofix/ast/types.d.ts.map +1 -0
  20. package/dist/autofix/ast/types.js +9 -0
  21. package/dist/autofix/ast/types.js.map +1 -0
  22. package/dist/autofix/ast/typescript.d.ts +17 -0
  23. package/dist/autofix/ast/typescript.d.ts.map +1 -0
  24. package/dist/autofix/ast/typescript.js +427 -0
  25. package/dist/autofix/ast/typescript.js.map +1 -0
  26. package/dist/autofix/constitution.schema.d.ts +21 -21
  27. package/dist/autofix/index.d.ts +1 -0
  28. package/dist/autofix/index.d.ts.map +1 -1
  29. package/dist/autofix/index.js +2 -0
  30. package/dist/autofix/index.js.map +1 -1
  31. package/dist/config/flags.d.ts +6 -6
  32. package/dist/history/store.d.ts +55 -1
  33. package/dist/history/store.d.ts.map +1 -1
  34. package/dist/history/store.js +152 -4
  35. package/dist/history/store.js.map +1 -1
  36. package/dist/history/types.d.ts +9 -5
  37. package/dist/history/types.d.ts.map +1 -1
  38. package/dist/history/verify.d.ts.map +1 -1
  39. package/dist/history/verify.js +5 -3
  40. package/dist/history/verify.js.map +1 -1
  41. package/dist/index.d.ts.map +1 -1
  42. package/dist/index.js +627 -0
  43. package/dist/index.js.map +1 -1
  44. package/dist/integrations/siem/datadog.d.ts +44 -0
  45. package/dist/integrations/siem/datadog.d.ts.map +1 -0
  46. package/dist/integrations/siem/datadog.js +211 -0
  47. package/dist/integrations/siem/datadog.js.map +1 -0
  48. package/dist/integrations/siem/format.d.ts +59 -0
  49. package/dist/integrations/siem/format.d.ts.map +1 -0
  50. package/dist/integrations/siem/format.js +360 -0
  51. package/dist/integrations/siem/format.js.map +1 -0
  52. package/dist/integrations/siem/index.d.ts +56 -0
  53. package/dist/integrations/siem/index.d.ts.map +1 -0
  54. package/dist/integrations/siem/index.js +117 -0
  55. package/dist/integrations/siem/index.js.map +1 -0
  56. package/dist/integrations/siem/sentinel.d.ts +53 -0
  57. package/dist/integrations/siem/sentinel.d.ts.map +1 -0
  58. package/dist/integrations/siem/sentinel.js +231 -0
  59. package/dist/integrations/siem/sentinel.js.map +1 -0
  60. package/dist/integrations/siem/splunk.d.ts +46 -0
  61. package/dist/integrations/siem/splunk.d.ts.map +1 -0
  62. package/dist/integrations/siem/splunk.js +210 -0
  63. package/dist/integrations/siem/splunk.js.map +1 -0
  64. package/dist/integrations/siem/types.d.ts +210 -0
  65. package/dist/integrations/siem/types.d.ts.map +1 -0
  66. package/dist/integrations/siem/types.js +9 -0
  67. package/dist/integrations/siem/types.js.map +1 -0
  68. package/dist/persistence/__tests__/persistence.test.d.ts +5 -0
  69. package/dist/persistence/__tests__/persistence.test.d.ts.map +1 -0
  70. package/dist/persistence/__tests__/persistence.test.js +369 -0
  71. package/dist/persistence/__tests__/persistence.test.js.map +1 -0
  72. package/dist/persistence/db.d.ts +15 -0
  73. package/dist/persistence/db.d.ts.map +1 -0
  74. package/dist/persistence/db.js +79 -0
  75. package/dist/persistence/db.js.map +1 -0
  76. package/dist/persistence/index.d.ts +66 -0
  77. package/dist/persistence/index.d.ts.map +1 -0
  78. package/dist/persistence/index.js +143 -0
  79. package/dist/persistence/index.js.map +1 -0
  80. package/dist/persistence/migrations/index.d.ts +10 -0
  81. package/dist/persistence/migrations/index.d.ts.map +1 -0
  82. package/dist/persistence/migrations/index.js +125 -0
  83. package/dist/persistence/migrations/index.js.map +1 -0
  84. package/dist/persistence/repositories/findings.d.ts +41 -0
  85. package/dist/persistence/repositories/findings.d.ts.map +1 -0
  86. package/dist/persistence/repositories/findings.js +238 -0
  87. package/dist/persistence/repositories/findings.js.map +1 -0
  88. package/dist/persistence/repositories/projects.d.ts +22 -0
  89. package/dist/persistence/repositories/projects.d.ts.map +1 -0
  90. package/dist/persistence/repositories/projects.js +71 -0
  91. package/dist/persistence/repositories/projects.js.map +1 -0
  92. package/dist/persistence/repositories/scans.d.ts +30 -0
  93. package/dist/persistence/repositories/scans.d.ts.map +1 -0
  94. package/dist/persistence/repositories/scans.js +107 -0
  95. package/dist/persistence/repositories/scans.js.map +1 -0
  96. package/dist/persistence/repositories/trends.d.ts +42 -0
  97. package/dist/persistence/repositories/trends.d.ts.map +1 -0
  98. package/dist/persistence/repositories/trends.js +178 -0
  99. package/dist/persistence/repositories/trends.js.map +1 -0
  100. package/dist/persistence/types.d.ts +105 -0
  101. package/dist/persistence/types.d.ts.map +1 -0
  102. package/dist/persistence/types.js +13 -0
  103. package/dist/persistence/types.js.map +1 -0
  104. package/dist/plugins/types.d.ts +2 -2
  105. package/dist/scanners/ai-code/types.d.ts +12 -12
  106. package/dist/scanners/cache.d.ts.map +1 -1
  107. package/dist/scanners/cache.js +9 -0
  108. package/dist/scanners/cache.js.map +1 -1
  109. package/dist/scanners/dast.d.ts +40 -0
  110. package/dist/scanners/dast.d.ts.map +1 -0
  111. package/dist/scanners/dast.js +228 -0
  112. package/dist/scanners/dast.js.map +1 -0
  113. package/dist/scanners/deploy/types.d.ts +19 -19
  114. package/dist/scanners/detection/__tests__/detection.test.d.ts +5 -0
  115. package/dist/scanners/detection/__tests__/detection.test.d.ts.map +1 -0
  116. package/dist/scanners/detection/__tests__/detection.test.js +265 -0
  117. package/dist/scanners/detection/__tests__/detection.test.js.map +1 -0
  118. package/dist/scanners/detection/engines/ast-query.d.ts +23 -0
  119. package/dist/scanners/detection/engines/ast-query.d.ts.map +1 -0
  120. package/dist/scanners/detection/engines/ast-query.js +232 -0
  121. package/dist/scanners/detection/engines/ast-query.js.map +1 -0
  122. package/dist/scanners/detection/engines/data-flow.d.ts +12 -0
  123. package/dist/scanners/detection/engines/data-flow.d.ts.map +1 -0
  124. package/dist/scanners/detection/engines/data-flow.js +269 -0
  125. package/dist/scanners/detection/engines/data-flow.js.map +1 -0
  126. package/dist/scanners/detection/index.d.ts +29 -0
  127. package/dist/scanners/detection/index.d.ts.map +1 -0
  128. package/dist/scanners/detection/index.js +140 -0
  129. package/dist/scanners/detection/index.js.map +1 -0
  130. package/dist/scanners/detection/rules/builtin.d.ts +14 -0
  131. package/dist/scanners/detection/rules/builtin.d.ts.map +1 -0
  132. package/dist/scanners/detection/rules/builtin.js +307 -0
  133. package/dist/scanners/detection/rules/builtin.js.map +1 -0
  134. package/dist/scanners/detection/rules/loader.d.ts +19 -0
  135. package/dist/scanners/detection/rules/loader.d.ts.map +1 -0
  136. package/dist/scanners/detection/rules/loader.js +111 -0
  137. package/dist/scanners/detection/rules/loader.js.map +1 -0
  138. package/dist/scanners/detection/types.d.ts +171 -0
  139. package/dist/scanners/detection/types.d.ts.map +1 -0
  140. package/dist/scanners/detection/types.js +36 -0
  141. package/dist/scanners/detection/types.js.map +1 -0
  142. package/dist/scanners/index.d.ts +13 -5
  143. package/dist/scanners/index.d.ts.map +1 -1
  144. package/dist/scanners/index.js +197 -15
  145. package/dist/scanners/index.js.map +1 -1
  146. package/dist/scanners/index.test.js +6 -6
  147. package/dist/scanners/index.test.js.map +1 -1
  148. package/dist/scanners/openapi.d.ts +20 -0
  149. package/dist/scanners/openapi.d.ts.map +1 -0
  150. package/dist/scanners/openapi.js +226 -0
  151. package/dist/scanners/openapi.js.map +1 -0
  152. package/dist/scanners/runtime/types.d.ts +4 -4
  153. package/dist/scanners/rust.d.ts +22 -0
  154. package/dist/scanners/rust.d.ts.map +1 -0
  155. package/dist/scanners/rust.js +239 -0
  156. package/dist/scanners/rust.js.map +1 -0
  157. package/dist/scanners/scale/types.d.ts +19 -19
  158. package/dist/scanners/terraform.d.ts +23 -0
  159. package/dist/scanners/terraform.d.ts.map +1 -0
  160. package/dist/scanners/terraform.js +207 -0
  161. package/dist/scanners/terraform.js.map +1 -0
  162. package/dist/scanners/types.d.ts +1 -1
  163. package/dist/scanners/types.d.ts.map +1 -1
  164. package/dist/scanners/types.js +9 -0
  165. package/dist/scanners/types.js.map +1 -1
  166. 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":"AAAA;;;;;;;GAOG;AAEH,OAAO,EAAE,OAAO,EAAE,IAAI,EAA0B,MAAM,UAAU,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAI5B,MAAM,OAAO,GAAG,IAAI,OAAO,CAAC;IAC1B,qBAAqB,EAAE,KAAK;IAC5B,4BAA4B,EAAE,IAAI;CACnC,CAAC,CAAC;AAmBH,SAAS,YAAY,CAAC,OAAe;IACnC,MAAM,KAAK,GAAkB,EAAE,CAAC;IAChC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEV,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;QAC1B,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACjD,MAAM,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC;YACpB,IAAI,GAAG,GAAG,KAAK,CAAC;YAChB,OAAO,GAAG,GAAG,OAAO,CAAC,MAAM,IAAI,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBACjE,GAAG,EAAE,CAAC;YACR,CAAC;YACD,IAAI,GAAG,GAAG,KAAK,EAAE,CAAC;gBAChB,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC;gBACnG,CAAC,GAAG,GAAG,CAAC;gBACR,SAAS;YACX,CAAC;QACH,CAAC;QAED,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,EAAE,CAAC;YACtC,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;YAC/C,CAAC,IAAI,CAAC,CAAC;YACP,SAAS;QACX,CAAC;QAED,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,OAAO,UAAU,GAAG,OAAO,CAAC,MAAM,IAAI,OAAO,CAAC,UAAU,CAAC,KAAK,GAAG,IAAI,OAAO,CAAC,KAAK,CAAC,UAAU,EAAE,UAAU,GAAG,CAAC,CAAC,KAAK,KAAK,EAAE,CAAC;YACzH,UAAU,EAAE,CAAC;QACf,CAAC;QACD,IAAI,UAAU,GAAG,CAAC,EAAE,CAAC;YACnB,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,EAAE,CAAC,CAAC;YACrE,CAAC,GAAG,UAAU,CAAC;QACjB,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,YAAY,CAAC,IAAY,EAAE,KAAoB;IACtD,MAAM,QAAQ,GAA2B,EAAE,CAAC;IAC5C,IAAI,OAAO,GAAG,CAAC,CAAC;IAEhB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACtC,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAEtB,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YAClC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC;YAC7C,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;gBACnC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;YAC1C,CAAC;YACD,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC;QAC5D,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YACnC,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YAC9B,IAAI,MAAc,CAAC;YAEnB,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACvB,CAAC;iBAAM,IAAI,QAAQ,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;gBACvC,MAAM,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;gBAC1C,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;gBAC5C,IAAI,MAAM,KAAK,CAAC,CAAC,EAAE,CAAC;oBAClB,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;gBAC1C,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;YACvB,CAAC;YAED,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC;YACpD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC;YACjC,CAAC;YACD,OAAO,GAAG,MAAM,CAAC;QACnB,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;YACpC,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC;YACxB,CAAC;iBAAM,IAAI,QAAQ,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;gBACvC,MAAM,WAAW,GAAG,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;gBAC1C,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;gBAC/C,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE,CAAC;oBACf,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;gBAC1C,CAAC;gBACD,OAAO,GAAG,GAAG,CAAC;YAChB,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;AACrC,CAAC;AAED,SAAS,mBAAmB,CAAC,UAAsB,EAAE,OAAe;IAClE,MAAM,OAAO,GAAe,EAAE,CAAC;IAC/B,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;IAEpC,UAAU,CAAC,iBAAiB,CAAC,CAAC,IAAI,EAAE,EAAE;QACpC,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC5B,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAEzC,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;gBACnB,OAAO,CAAC,IAAI,CAAC;oBACX,IAAI;oBACJ,IAAI,EAAE,UAAU,CAAC,WAAW,EAAE;oBAC9B,IAAI,EAAE,IAAI,CAAC,kBAAkB,EAAE;oBAC/B,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC;oBAC/D,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE;oBAChC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC;oBACzD,IAAI;oBACJ,QAAQ,EAAE,MAAM,CAAC,QAAQ;iBAC1B,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,kBAAkB,CAAC,UAAsB,EAAE,OAAe;IACjE,MAAM,OAAO,GAAe,EAAE,CAAC;IAC/B,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;IAEpC,UAAU,CAAC,iBAAiB,CAAC,CAAC,IAAI,EAAE,EAAE;QACpC,IAAI,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,EAAE,CAAC;YAClF,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC5B,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAEzC,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;gBACnB,OAAO,CAAC,IAAI,CAAC;oBACX,IAAI;oBACJ,IAAI,EAAE,UAAU,CAAC,WAAW,EAAE;oBAC9B,IAAI,EAAE,IAAI,CAAC,kBAAkB,EAAE;oBAC/B,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC;oBAC/D,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE;oBAChC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC;oBACzD,IAAI;oBACJ,QAAQ,EAAE,MAAM,CAAC,QAAQ;iBAC1B,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS,eAAe,CAAC,UAAsB,EAAE,OAAe;IAC9D,MAAM,OAAO,GAAe,EAAE,CAAC;IAC/B,MAAM,KAAK,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;IAEpC,UAAU,CAAC,iBAAiB,CAAC,CAAC,IAAI,EAAE,EAAE;QACpC,IAAI,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC,OAAO,EAAE,KAAK,GAAG,EAAE,CAAC;YAC/E,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC5B,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAEzC,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;gBACnB,OAAO,CAAC,IAAI,CAAC;oBACX,IAAI;oBACJ,IAAI,EAAE,UAAU,CAAC,WAAW,EAAE;oBAC9B,IAAI,EAAE,IAAI,CAAC,kBAAkB,EAAE;oBAC/B,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC;oBAC/D,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE;oBAChC,SAAS,EAAE,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC;oBACzD,IAAI;oBACJ,QAAQ,EAAE,MAAM,CAAC,QAAQ;iBAC1B,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,QAAQ,CAC5B,QAAgB,EAChB,MAAsB;IAEtB,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QAClD,MAAM,UAAU,GAAG,OAAO,CAAC,gBAAgB,CACzC,SAAS,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,EAC/D,OAAO,EACP,EAAE,SAAS,EAAE,IAAI,EAAE,CACpB,CAAC;QAEF,IAAI,OAAO,GAAe,EAAE,CAAC;QAC7B,MAAM,OAAO,GAAG,MAAM,CAAC,OAAO,CAAC;QAE/B,IAAI,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACnD,OAAO,GAAG,mBAAmB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QACrD,CAAC;aAAM,IAAI,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1D,OAAO,GAAG,kBAAkB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QACpD,CAAC;aAAM,IAAI,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACjC,OAAO,GAAG,eAAe,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QACjD,CAAC;aAAM,CAAC;YACN,OAAO,GAAG;gBACR,GAAG,mBAAmB,CAAC,UAAU,EAAE,OAAO,CAAC;gBAC3C,GAAG,kBAAkB,CAAC,UAAU,EAAE,OAAO,CAAC;aAC3C,CAAC;QACJ,CAAC;QAED,UAAU,CAAC,MAAM,EAAE,CAAC;QAEpB,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,iBAAiB,CACrC,WAAmB,EACnB,KAAsB,EACtB,KAAgB;IAEhB,MAAM,OAAO,GAAqB,EAAE,CAAC;IAErC,MAAM,WAAW,GAAG,KAAK,IAAI,CAAC,MAAM,IAAI,CAAC,sBAAsB,EAAE;QAC/D,GAAG,EAAE,WAAW;QAChB,MAAM,EAAE,CAAC,oBAAoB,EAAE,YAAY,EAAE,aAAa,EAAE,YAAY,CAAC;QACzE,QAAQ,EAAE,IAAI;KACf,CAAC,CAAC,CAAC;IAEJ,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ;YAAE,SAAS;QAErC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;QAErC,KAAK,MAAM,IAAI,IAAI,WAAW,EAAE,CAAC;YAC/B,MAAM,UAAU,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;YAEhD,KAAK,MAAM,KAAK,IAAI,UAAU,EAAE,CAAC;gBAC/B,OAAO,CAAC,IAAI,CAAC;oBACX,MAAM,EAAE,IAAI,CAAC,EAAE;oBACf,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,MAAM,EAAE,KAAK,CAAC,MAAM;oBACpB,OAAO,EAAE,KAAK,CAAC,OAAO;oBACtB,SAAS,EAAE,KAAK,CAAC,SAAS;oBAC1B,OAAO,EAAE,IAAI,CAAC,WAAW;oBACzB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,QAAQ,EAAE,KAAK,CAAC,IAAI;oBACpB,MAAM,EAAE,IAAI,CAAC,MAAM;oBACnB,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;iBACxC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -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"}