circle-ir 3.1.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 (194) hide show
  1. package/LICENSE +15 -0
  2. package/README.md +200 -0
  3. package/configs/sinks/code_injection.yaml +672 -0
  4. package/configs/sinks/command.yaml +917 -0
  5. package/configs/sinks/deserialization.yaml +105 -0
  6. package/configs/sinks/ldap.yaml +136 -0
  7. package/configs/sinks/nodejs.json +629 -0
  8. package/configs/sinks/path.yaml +715 -0
  9. package/configs/sinks/python.json +501 -0
  10. package/configs/sinks/rust.json +339 -0
  11. package/configs/sinks/sql.yaml +233 -0
  12. package/configs/sinks/ssrf.yaml +160 -0
  13. package/configs/sinks/xpath.yaml +121 -0
  14. package/configs/sinks/xss.yaml +727 -0
  15. package/configs/sources/db_sources.yaml +90 -0
  16. package/configs/sources/env_sources.yaml +94 -0
  17. package/configs/sources/express.json +197 -0
  18. package/configs/sources/file_sources.yaml +164 -0
  19. package/configs/sources/http_sources.yaml +379 -0
  20. package/configs/sources/io_sources.yaml +519 -0
  21. package/configs/sources/network_sources.yaml +99 -0
  22. package/configs/sources/python.json +230 -0
  23. package/configs/sources/rust.json +286 -0
  24. package/configs/sources/spring.yaml +70 -0
  25. package/dist/analysis/advisory-db.d.ts +86 -0
  26. package/dist/analysis/advisory-db.js +104 -0
  27. package/dist/analysis/advisory-db.js.map +1 -0
  28. package/dist/analysis/cargo-parser.d.ts +42 -0
  29. package/dist/analysis/cargo-parser.js +102 -0
  30. package/dist/analysis/cargo-parser.js.map +1 -0
  31. package/dist/analysis/config-loader.d.ts +37 -0
  32. package/dist/analysis/config-loader.js +1561 -0
  33. package/dist/analysis/config-loader.js.map +1 -0
  34. package/dist/analysis/constant-propagation/ast-utils.d.ts +25 -0
  35. package/dist/analysis/constant-propagation/ast-utils.js +34 -0
  36. package/dist/analysis/constant-propagation/ast-utils.js.map +1 -0
  37. package/dist/analysis/constant-propagation/evaluator.d.ts +32 -0
  38. package/dist/analysis/constant-propagation/evaluator.js +296 -0
  39. package/dist/analysis/constant-propagation/evaluator.js.map +1 -0
  40. package/dist/analysis/constant-propagation/index.d.ts +62 -0
  41. package/dist/analysis/constant-propagation/index.js +152 -0
  42. package/dist/analysis/constant-propagation/index.js.map +1 -0
  43. package/dist/analysis/constant-propagation/patterns.d.ts +8 -0
  44. package/dist/analysis/constant-propagation/patterns.js +126 -0
  45. package/dist/analysis/constant-propagation/patterns.js.map +1 -0
  46. package/dist/analysis/constant-propagation/propagator.d.ts +180 -0
  47. package/dist/analysis/constant-propagation/propagator.js +1985 -0
  48. package/dist/analysis/constant-propagation/propagator.js.map +1 -0
  49. package/dist/analysis/constant-propagation/types.d.ts +63 -0
  50. package/dist/analysis/constant-propagation/types.js +5 -0
  51. package/dist/analysis/constant-propagation/types.js.map +1 -0
  52. package/dist/analysis/constant-propagation.d.ts +9 -0
  53. package/dist/analysis/constant-propagation.js +18 -0
  54. package/dist/analysis/constant-propagation.js.map +1 -0
  55. package/dist/analysis/dependency-scanner.d.ts +79 -0
  56. package/dist/analysis/dependency-scanner.js +122 -0
  57. package/dist/analysis/dependency-scanner.js.map +1 -0
  58. package/dist/analysis/dfg-verifier.d.ts +116 -0
  59. package/dist/analysis/dfg-verifier.js +399 -0
  60. package/dist/analysis/dfg-verifier.js.map +1 -0
  61. package/dist/analysis/findings.d.ts +11 -0
  62. package/dist/analysis/findings.js +228 -0
  63. package/dist/analysis/findings.js.map +1 -0
  64. package/dist/analysis/index.d.ts +16 -0
  65. package/dist/analysis/index.js +18 -0
  66. package/dist/analysis/index.js.map +1 -0
  67. package/dist/analysis/interprocedural.d.ts +99 -0
  68. package/dist/analysis/interprocedural.js +526 -0
  69. package/dist/analysis/interprocedural.js.map +1 -0
  70. package/dist/analysis/path-finder.d.ts +133 -0
  71. package/dist/analysis/path-finder.js +354 -0
  72. package/dist/analysis/path-finder.js.map +1 -0
  73. package/dist/analysis/rules.d.ts +75 -0
  74. package/dist/analysis/rules.js +332 -0
  75. package/dist/analysis/rules.js.map +1 -0
  76. package/dist/analysis/semver.d.ts +27 -0
  77. package/dist/analysis/semver.js +127 -0
  78. package/dist/analysis/semver.js.map +1 -0
  79. package/dist/analysis/taint-matcher.d.ts +15 -0
  80. package/dist/analysis/taint-matcher.js +634 -0
  81. package/dist/analysis/taint-matcher.js.map +1 -0
  82. package/dist/analysis/taint-propagation.d.ts +67 -0
  83. package/dist/analysis/taint-propagation.js +298 -0
  84. package/dist/analysis/taint-propagation.js.map +1 -0
  85. package/dist/analysis/unresolved.d.ts +14 -0
  86. package/dist/analysis/unresolved.js +202 -0
  87. package/dist/analysis/unresolved.js.map +1 -0
  88. package/dist/analyzer.d.ts +43 -0
  89. package/dist/analyzer.js +1010 -0
  90. package/dist/analyzer.js.map +1 -0
  91. package/dist/browser/circle-ir.js +16576 -0
  92. package/dist/browser.d.ts +38 -0
  93. package/dist/browser.js +38 -0
  94. package/dist/browser.js.map +1 -0
  95. package/dist/core/circle-ir-core.cjs +13626 -0
  96. package/dist/core/circle-ir-core.d.ts +59 -0
  97. package/dist/core/circle-ir-core.js +13591 -0
  98. package/dist/core/extractors/calls.d.ts +13 -0
  99. package/dist/core/extractors/calls.js +1429 -0
  100. package/dist/core/extractors/calls.js.map +1 -0
  101. package/dist/core/extractors/cfg.d.ts +9 -0
  102. package/dist/core/extractors/cfg.js +519 -0
  103. package/dist/core/extractors/cfg.js.map +1 -0
  104. package/dist/core/extractors/dfg.d.ts +12 -0
  105. package/dist/core/extractors/dfg.js +1081 -0
  106. package/dist/core/extractors/dfg.js.map +1 -0
  107. package/dist/core/extractors/exports.d.ts +14 -0
  108. package/dist/core/extractors/exports.js +80 -0
  109. package/dist/core/extractors/exports.js.map +1 -0
  110. package/dist/core/extractors/imports.d.ts +9 -0
  111. package/dist/core/extractors/imports.js +739 -0
  112. package/dist/core/extractors/imports.js.map +1 -0
  113. package/dist/core/extractors/index.d.ts +10 -0
  114. package/dist/core/extractors/index.js +11 -0
  115. package/dist/core/extractors/index.js.map +1 -0
  116. package/dist/core/extractors/meta.d.ts +10 -0
  117. package/dist/core/extractors/meta.js +109 -0
  118. package/dist/core/extractors/meta.js.map +1 -0
  119. package/dist/core/extractors/types.d.ts +10 -0
  120. package/dist/core/extractors/types.js +1479 -0
  121. package/dist/core/extractors/types.js.map +1 -0
  122. package/dist/core/index.d.ts +5 -0
  123. package/dist/core/index.js +8 -0
  124. package/dist/core/index.js.map +1 -0
  125. package/dist/core/parser.d.ts +84 -0
  126. package/dist/core/parser.js +250 -0
  127. package/dist/core/parser.js.map +1 -0
  128. package/dist/core-lib.d.ts +59 -0
  129. package/dist/core-lib.js +62 -0
  130. package/dist/core-lib.js.map +1 -0
  131. package/dist/index.d.ts +15 -0
  132. package/dist/index.js +20 -0
  133. package/dist/index.js.map +1 -0
  134. package/dist/languages/index.d.ts +11 -0
  135. package/dist/languages/index.js +14 -0
  136. package/dist/languages/index.js.map +1 -0
  137. package/dist/languages/plugins/base.d.ts +44 -0
  138. package/dist/languages/plugins/base.js +82 -0
  139. package/dist/languages/plugins/base.js.map +1 -0
  140. package/dist/languages/plugins/index.d.ts +14 -0
  141. package/dist/languages/plugins/index.js +25 -0
  142. package/dist/languages/plugins/index.js.map +1 -0
  143. package/dist/languages/plugins/java.d.ts +49 -0
  144. package/dist/languages/plugins/java.js +402 -0
  145. package/dist/languages/plugins/java.js.map +1 -0
  146. package/dist/languages/plugins/javascript.d.ts +48 -0
  147. package/dist/languages/plugins/javascript.js +445 -0
  148. package/dist/languages/plugins/javascript.js.map +1 -0
  149. package/dist/languages/plugins/python.d.ts +47 -0
  150. package/dist/languages/plugins/python.js +480 -0
  151. package/dist/languages/plugins/python.js.map +1 -0
  152. package/dist/languages/plugins/rust.d.ts +47 -0
  153. package/dist/languages/plugins/rust.js +405 -0
  154. package/dist/languages/plugins/rust.js.map +1 -0
  155. package/dist/languages/registry.d.ts +30 -0
  156. package/dist/languages/registry.js +80 -0
  157. package/dist/languages/registry.js.map +1 -0
  158. package/dist/languages/types.d.ts +184 -0
  159. package/dist/languages/types.js +8 -0
  160. package/dist/languages/types.js.map +1 -0
  161. package/dist/resolution/cross-file.d.ts +146 -0
  162. package/dist/resolution/cross-file.js +439 -0
  163. package/dist/resolution/cross-file.js.map +1 -0
  164. package/dist/resolution/index.d.ts +12 -0
  165. package/dist/resolution/index.js +10 -0
  166. package/dist/resolution/index.js.map +1 -0
  167. package/dist/resolution/symbol-table.d.ts +136 -0
  168. package/dist/resolution/symbol-table.js +336 -0
  169. package/dist/resolution/symbol-table.js.map +1 -0
  170. package/dist/resolution/type-hierarchy.d.ts +124 -0
  171. package/dist/resolution/type-hierarchy.js +515 -0
  172. package/dist/resolution/type-hierarchy.js.map +1 -0
  173. package/dist/types/config.d.ts +45 -0
  174. package/dist/types/config.js +5 -0
  175. package/dist/types/config.js.map +1 -0
  176. package/dist/types/index.d.ts +392 -0
  177. package/dist/types/index.js +7 -0
  178. package/dist/types/index.js.map +1 -0
  179. package/dist/utils/logger.d.ts +85 -0
  180. package/dist/utils/logger.js +198 -0
  181. package/dist/utils/logger.js.map +1 -0
  182. package/dist/wasm/tree-sitter-java.wasm +0 -0
  183. package/dist/wasm/tree-sitter-javascript.wasm +0 -0
  184. package/dist/wasm/tree-sitter-python.wasm +0 -0
  185. package/dist/wasm/tree-sitter-rust.wasm +0 -0
  186. package/dist/wasm/web-tree-sitter.wasm +0 -0
  187. package/docs/SPEC.md +1021 -0
  188. package/examples/browser-example.html +610 -0
  189. package/examples/node-example.ts +215 -0
  190. package/package.json +107 -0
  191. package/wasm/tree-sitter-java.wasm +0 -0
  192. package/wasm/tree-sitter-javascript.wasm +0 -0
  193. package/wasm/tree-sitter-python.wasm +0 -0
  194. package/wasm/tree-sitter-rust.wasm +0 -0
@@ -0,0 +1,48 @@
1
+ /**
2
+ * JavaScript/TypeScript Language Plugin
3
+ *
4
+ * Provides JS/TS-specific AST handling, taint patterns, and framework detection.
5
+ */
6
+ import type { Node as SyntaxNode } from 'web-tree-sitter';
7
+ import type { TypeInfo, CallInfo, ImportInfo } from '../../types/index.js';
8
+ import type { LanguageNodeTypes, ExtractionContext, FrameworkInfo, TaintSourcePattern, TaintSinkPattern } from '../types.js';
9
+ import { BaseLanguagePlugin } from './base.js';
10
+ /**
11
+ * JavaScript/TypeScript language plugin implementation.
12
+ * Handles both JavaScript and TypeScript since they share the same tree-sitter grammar.
13
+ */
14
+ export declare class JavaScriptPlugin extends BaseLanguagePlugin {
15
+ readonly id: "javascript";
16
+ readonly name = "JavaScript/TypeScript";
17
+ readonly extensions: string[];
18
+ readonly wasmPath = "tree-sitter-typescript.wasm";
19
+ readonly nodeTypes: LanguageNodeTypes;
20
+ /**
21
+ * Detect JavaScript frameworks from imports.
22
+ */
23
+ detectFramework(context: ExtractionContext): FrameworkInfo | undefined;
24
+ /**
25
+ * JavaScript/TypeScript taint source patterns.
26
+ */
27
+ getBuiltinSources(): TaintSourcePattern[];
28
+ /**
29
+ * JavaScript/TypeScript taint sink patterns.
30
+ */
31
+ getBuiltinSinks(): TaintSinkPattern[];
32
+ /**
33
+ * Get receiver type from a call expression.
34
+ */
35
+ getReceiverType(node: SyntaxNode, context: ExtractionContext): string | undefined;
36
+ /**
37
+ * Check if node is a JavaScript string literal.
38
+ */
39
+ isStringLiteral(node: SyntaxNode): boolean;
40
+ /**
41
+ * Get string value from JavaScript string literal.
42
+ */
43
+ getStringValue(node: SyntaxNode): string | undefined;
44
+ extractTypes(context: ExtractionContext): TypeInfo[];
45
+ extractCalls(context: ExtractionContext): CallInfo[];
46
+ extractImports(context: ExtractionContext): ImportInfo[];
47
+ extractPackage(context: ExtractionContext): string | undefined;
48
+ }
@@ -0,0 +1,445 @@
1
+ /**
2
+ * JavaScript/TypeScript Language Plugin
3
+ *
4
+ * Provides JS/TS-specific AST handling, taint patterns, and framework detection.
5
+ */
6
+ import { BaseLanguagePlugin } from './base.js';
7
+ /**
8
+ * JavaScript/TypeScript language plugin implementation.
9
+ * Handles both JavaScript and TypeScript since they share the same tree-sitter grammar.
10
+ */
11
+ export class JavaScriptPlugin extends BaseLanguagePlugin {
12
+ id = 'javascript';
13
+ name = 'JavaScript/TypeScript';
14
+ extensions = ['.js', '.jsx', '.ts', '.tsx', '.mjs', '.cjs'];
15
+ wasmPath = 'tree-sitter-typescript.wasm';
16
+ nodeTypes = {
17
+ // Type declarations
18
+ classDeclaration: ['class_declaration', 'class'],
19
+ interfaceDeclaration: ['interface_declaration'],
20
+ enumDeclaration: ['enum_declaration'],
21
+ functionDeclaration: ['function_declaration', 'function', 'arrow_function'],
22
+ methodDeclaration: ['method_definition'],
23
+ // Expressions
24
+ methodCall: ['call_expression'],
25
+ functionCall: ['call_expression'],
26
+ assignment: ['assignment_expression'],
27
+ variableDeclaration: ['lexical_declaration', 'variable_declaration'],
28
+ // Parameters and arguments
29
+ parameter: ['formal_parameters', 'required_parameter', 'optional_parameter'],
30
+ argument: ['arguments'],
31
+ // Annotations/decorators
32
+ annotation: [],
33
+ decorator: ['decorator'],
34
+ // Imports
35
+ importStatement: ['import_statement'],
36
+ // Control flow
37
+ ifStatement: ['if_statement'],
38
+ forStatement: ['for_statement', 'for_in_statement', 'for_of_statement'],
39
+ whileStatement: ['while_statement'],
40
+ tryStatement: ['try_statement'],
41
+ returnStatement: ['return_statement'],
42
+ };
43
+ /**
44
+ * Detect JavaScript frameworks from imports.
45
+ */
46
+ detectFramework(context) {
47
+ const indicators = [];
48
+ let framework;
49
+ let confidence = 0;
50
+ for (const imp of context.imports) {
51
+ const path = imp.from_package || imp.imported_name;
52
+ // Express.js
53
+ if (path === 'express' || path.startsWith('express/')) {
54
+ framework = 'express';
55
+ confidence = Math.max(confidence, 0.95);
56
+ indicators.push(`import: ${path}`);
57
+ }
58
+ // Fastify
59
+ if (path === 'fastify' || path.startsWith('fastify/')) {
60
+ framework = 'fastify';
61
+ confidence = Math.max(confidence, 0.95);
62
+ indicators.push(`import: ${path}`);
63
+ }
64
+ // Koa
65
+ if (path === 'koa' || path.startsWith('koa/')) {
66
+ framework = 'koa';
67
+ confidence = Math.max(confidence, 0.95);
68
+ indicators.push(`import: ${path}`);
69
+ }
70
+ // Hapi
71
+ if (path === '@hapi/hapi' || path.startsWith('@hapi/')) {
72
+ framework = 'hapi';
73
+ confidence = Math.max(confidence, 0.95);
74
+ indicators.push(`import: ${path}`);
75
+ }
76
+ // NestJS
77
+ if (path.startsWith('@nestjs/')) {
78
+ framework = 'nestjs';
79
+ confidence = Math.max(confidence, 0.95);
80
+ indicators.push(`import: ${path}`);
81
+ }
82
+ // React
83
+ if (path === 'react' || path.startsWith('react/')) {
84
+ framework = framework || 'react';
85
+ confidence = Math.max(confidence, 0.8);
86
+ indicators.push(`import: ${path}`);
87
+ }
88
+ // Next.js
89
+ if (path === 'next' || path.startsWith('next/')) {
90
+ framework = 'nextjs';
91
+ confidence = Math.max(confidence, 0.9);
92
+ indicators.push(`import: ${path}`);
93
+ }
94
+ }
95
+ if (framework) {
96
+ return { name: framework, confidence, indicators };
97
+ }
98
+ return undefined;
99
+ }
100
+ /**
101
+ * JavaScript/TypeScript taint source patterns.
102
+ */
103
+ getBuiltinSources() {
104
+ return [
105
+ // Express.js request object
106
+ {
107
+ method: 'query',
108
+ type: 'http_param',
109
+ severity: 'high',
110
+ confidence: 0.95,
111
+ returnTainted: true,
112
+ },
113
+ {
114
+ method: 'body',
115
+ type: 'http_body',
116
+ severity: 'high',
117
+ confidence: 0.95,
118
+ returnTainted: true,
119
+ },
120
+ {
121
+ method: 'params',
122
+ type: 'http_path',
123
+ severity: 'high',
124
+ confidence: 0.95,
125
+ returnTainted: true,
126
+ },
127
+ {
128
+ method: 'headers',
129
+ type: 'http_header',
130
+ severity: 'high',
131
+ confidence: 0.9,
132
+ returnTainted: true,
133
+ },
134
+ {
135
+ method: 'cookies',
136
+ type: 'http_cookie',
137
+ severity: 'high',
138
+ confidence: 0.9,
139
+ returnTainted: true,
140
+ },
141
+ // URL/URLSearchParams
142
+ {
143
+ method: 'get',
144
+ class: 'URLSearchParams',
145
+ type: 'http_param',
146
+ severity: 'high',
147
+ confidence: 0.85,
148
+ returnTainted: true,
149
+ },
150
+ // DOM sources (for browser code)
151
+ {
152
+ method: 'location',
153
+ type: 'url_param',
154
+ severity: 'high',
155
+ confidence: 0.9,
156
+ returnTainted: true,
157
+ },
158
+ {
159
+ method: 'document.URL',
160
+ type: 'url_param',
161
+ severity: 'high',
162
+ confidence: 0.9,
163
+ returnTainted: true,
164
+ },
165
+ {
166
+ method: 'document.referrer',
167
+ type: 'url_param',
168
+ severity: 'medium',
169
+ confidence: 0.85,
170
+ returnTainted: true,
171
+ },
172
+ // Node.js process
173
+ {
174
+ method: 'argv',
175
+ class: 'process',
176
+ type: 'cli_arg',
177
+ severity: 'medium',
178
+ confidence: 0.9,
179
+ returnTainted: true,
180
+ },
181
+ {
182
+ method: 'env',
183
+ class: 'process',
184
+ type: 'env_var',
185
+ severity: 'medium',
186
+ confidence: 0.85,
187
+ returnTainted: true,
188
+ },
189
+ // File system
190
+ {
191
+ method: 'readFileSync',
192
+ class: 'fs',
193
+ type: 'file_input',
194
+ severity: 'medium',
195
+ confidence: 0.8,
196
+ returnTainted: true,
197
+ },
198
+ {
199
+ method: 'readFile',
200
+ class: 'fs',
201
+ type: 'file_input',
202
+ severity: 'medium',
203
+ confidence: 0.8,
204
+ returnTainted: true,
205
+ },
206
+ ];
207
+ }
208
+ /**
209
+ * JavaScript/TypeScript taint sink patterns.
210
+ */
211
+ getBuiltinSinks() {
212
+ return [
213
+ // Command Injection
214
+ {
215
+ method: 'exec',
216
+ class: 'child_process',
217
+ type: 'command_injection',
218
+ cwe: 'CWE-78',
219
+ severity: 'critical',
220
+ argPositions: [0],
221
+ },
222
+ {
223
+ method: 'execSync',
224
+ class: 'child_process',
225
+ type: 'command_injection',
226
+ cwe: 'CWE-78',
227
+ severity: 'critical',
228
+ argPositions: [0],
229
+ },
230
+ {
231
+ method: 'spawn',
232
+ class: 'child_process',
233
+ type: 'command_injection',
234
+ cwe: 'CWE-78',
235
+ severity: 'critical',
236
+ argPositions: [0, 1],
237
+ },
238
+ // Code Injection
239
+ {
240
+ method: 'eval',
241
+ type: 'code_injection',
242
+ cwe: 'CWE-94',
243
+ severity: 'critical',
244
+ argPositions: [0],
245
+ },
246
+ {
247
+ method: 'Function',
248
+ type: 'code_injection',
249
+ cwe: 'CWE-94',
250
+ severity: 'critical',
251
+ argPositions: [0],
252
+ },
253
+ {
254
+ method: 'setTimeout',
255
+ type: 'code_injection',
256
+ cwe: 'CWE-94',
257
+ severity: 'high',
258
+ argPositions: [0], // When first arg is string
259
+ },
260
+ {
261
+ method: 'setInterval',
262
+ type: 'code_injection',
263
+ cwe: 'CWE-94',
264
+ severity: 'high',
265
+ argPositions: [0], // When first arg is string
266
+ },
267
+ // Path Traversal
268
+ {
269
+ method: 'readFileSync',
270
+ class: 'fs',
271
+ type: 'path_traversal',
272
+ cwe: 'CWE-22',
273
+ severity: 'high',
274
+ argPositions: [0],
275
+ },
276
+ {
277
+ method: 'writeFileSync',
278
+ class: 'fs',
279
+ type: 'path_traversal',
280
+ cwe: 'CWE-22',
281
+ severity: 'high',
282
+ argPositions: [0],
283
+ },
284
+ {
285
+ method: 'createReadStream',
286
+ class: 'fs',
287
+ type: 'path_traversal',
288
+ cwe: 'CWE-22',
289
+ severity: 'high',
290
+ argPositions: [0],
291
+ },
292
+ // XSS (DOM)
293
+ {
294
+ method: 'innerHTML',
295
+ type: 'xss',
296
+ cwe: 'CWE-79',
297
+ severity: 'high',
298
+ argPositions: [0],
299
+ },
300
+ {
301
+ method: 'outerHTML',
302
+ type: 'xss',
303
+ cwe: 'CWE-79',
304
+ severity: 'high',
305
+ argPositions: [0],
306
+ },
307
+ {
308
+ method: 'document.write',
309
+ type: 'xss',
310
+ cwe: 'CWE-79',
311
+ severity: 'high',
312
+ argPositions: [0],
313
+ },
314
+ // SQL Injection
315
+ {
316
+ method: 'query',
317
+ type: 'sql_injection',
318
+ cwe: 'CWE-89',
319
+ severity: 'critical',
320
+ argPositions: [0],
321
+ },
322
+ {
323
+ method: 'raw',
324
+ type: 'sql_injection',
325
+ cwe: 'CWE-89',
326
+ severity: 'critical',
327
+ argPositions: [0],
328
+ },
329
+ // SSRF
330
+ {
331
+ method: 'fetch',
332
+ type: 'ssrf',
333
+ cwe: 'CWE-918',
334
+ severity: 'high',
335
+ argPositions: [0],
336
+ },
337
+ {
338
+ method: 'get',
339
+ class: 'axios',
340
+ type: 'ssrf',
341
+ cwe: 'CWE-918',
342
+ severity: 'high',
343
+ argPositions: [0],
344
+ },
345
+ {
346
+ method: 'request',
347
+ class: 'http',
348
+ type: 'ssrf',
349
+ cwe: 'CWE-918',
350
+ severity: 'high',
351
+ argPositions: [0],
352
+ },
353
+ // NoSQL Injection
354
+ {
355
+ method: 'find',
356
+ type: 'nosql_injection',
357
+ cwe: 'CWE-943',
358
+ severity: 'high',
359
+ argPositions: [0],
360
+ },
361
+ {
362
+ method: 'findOne',
363
+ type: 'nosql_injection',
364
+ cwe: 'CWE-943',
365
+ severity: 'high',
366
+ argPositions: [0],
367
+ },
368
+ // Prototype Pollution (JS-specific)
369
+ {
370
+ method: 'merge',
371
+ type: 'prototype_pollution',
372
+ cwe: 'CWE-1321',
373
+ severity: 'high',
374
+ argPositions: [0, 1],
375
+ },
376
+ {
377
+ method: 'extend',
378
+ type: 'prototype_pollution',
379
+ cwe: 'CWE-1321',
380
+ severity: 'high',
381
+ argPositions: [0, 1],
382
+ },
383
+ ];
384
+ }
385
+ /**
386
+ * Get receiver type from a call expression.
387
+ */
388
+ getReceiverType(node, context) {
389
+ if (node.type !== 'call_expression')
390
+ return undefined;
391
+ const callee = node.childForFieldName('function');
392
+ if (!callee)
393
+ return undefined;
394
+ // For member expressions like obj.method()
395
+ if (callee.type === 'member_expression') {
396
+ const object = callee.childForFieldName('object');
397
+ if (object) {
398
+ return object.text;
399
+ }
400
+ }
401
+ return undefined;
402
+ }
403
+ /**
404
+ * Check if node is a JavaScript string literal.
405
+ */
406
+ isStringLiteral(node) {
407
+ return node.type === 'string' ||
408
+ node.type === 'template_string' ||
409
+ node.type === 'string_fragment';
410
+ }
411
+ /**
412
+ * Get string value from JavaScript string literal.
413
+ */
414
+ getStringValue(node) {
415
+ if (!this.isStringLiteral(node))
416
+ return undefined;
417
+ const text = node.text;
418
+ // Handle template strings
419
+ if (text.startsWith('`') && text.endsWith('`')) {
420
+ return text.slice(1, -1);
421
+ }
422
+ // Handle regular strings
423
+ if ((text.startsWith('"') && text.endsWith('"')) ||
424
+ (text.startsWith("'") && text.endsWith("'"))) {
425
+ return text.slice(1, -1);
426
+ }
427
+ return text;
428
+ }
429
+ // Extraction methods - delegate to existing extractors for now
430
+ extractTypes(context) {
431
+ return [];
432
+ }
433
+ extractCalls(context) {
434
+ return [];
435
+ }
436
+ extractImports(context) {
437
+ return [];
438
+ }
439
+ extractPackage(context) {
440
+ // JavaScript doesn't have package declarations
441
+ // Could look for package.json in parent directories
442
+ return undefined;
443
+ }
444
+ }
445
+ //# sourceMappingURL=javascript.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"javascript.js","sourceRoot":"","sources":["../../../src/languages/plugins/javascript.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAeH,OAAO,EAAE,kBAAkB,EAAE,MAAM,WAAW,CAAC;AAE/C;;;GAGG;AACH,MAAM,OAAO,gBAAiB,SAAQ,kBAAkB;IAC7C,EAAE,GAAG,YAAqB,CAAC;IAC3B,IAAI,GAAG,uBAAuB,CAAC;IAC/B,UAAU,GAAG,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IAC5D,QAAQ,GAAG,6BAA6B,CAAC;IAEzC,SAAS,GAAsB;QACtC,oBAAoB;QACpB,gBAAgB,EAAE,CAAC,mBAAmB,EAAE,OAAO,CAAC;QAChD,oBAAoB,EAAE,CAAC,uBAAuB,CAAC;QAC/C,eAAe,EAAE,CAAC,kBAAkB,CAAC;QACrC,mBAAmB,EAAE,CAAC,sBAAsB,EAAE,UAAU,EAAE,gBAAgB,CAAC;QAC3E,iBAAiB,EAAE,CAAC,mBAAmB,CAAC;QAExC,cAAc;QACd,UAAU,EAAE,CAAC,iBAAiB,CAAC;QAC/B,YAAY,EAAE,CAAC,iBAAiB,CAAC;QACjC,UAAU,EAAE,CAAC,uBAAuB,CAAC;QACrC,mBAAmB,EAAE,CAAC,qBAAqB,EAAE,sBAAsB,CAAC;QAEpE,2BAA2B;QAC3B,SAAS,EAAE,CAAC,mBAAmB,EAAE,oBAAoB,EAAE,oBAAoB,CAAC;QAC5E,QAAQ,EAAE,CAAC,WAAW,CAAC;QAEvB,yBAAyB;QACzB,UAAU,EAAE,EAAE;QACd,SAAS,EAAE,CAAC,WAAW,CAAC;QAExB,UAAU;QACV,eAAe,EAAE,CAAC,kBAAkB,CAAC;QAErC,eAAe;QACf,WAAW,EAAE,CAAC,cAAc,CAAC;QAC7B,YAAY,EAAE,CAAC,eAAe,EAAE,kBAAkB,EAAE,kBAAkB,CAAC;QACvE,cAAc,EAAE,CAAC,iBAAiB,CAAC;QACnC,YAAY,EAAE,CAAC,eAAe,CAAC;QAC/B,eAAe,EAAE,CAAC,kBAAkB,CAAC;KACtC,CAAC;IAEF;;OAEG;IACH,eAAe,CAAC,OAA0B;QACxC,MAAM,UAAU,GAAa,EAAE,CAAC;QAChC,IAAI,SAA6B,CAAC;QAClC,IAAI,UAAU,GAAG,CAAC,CAAC;QAEnB,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;YAClC,MAAM,IAAI,GAAG,GAAG,CAAC,YAAY,IAAI,GAAG,CAAC,aAAa,CAAC;YAEnD,aAAa;YACb,IAAI,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;gBACtD,SAAS,GAAG,SAAS,CAAC;gBACtB,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;gBACxC,UAAU,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YACrC,CAAC;YAED,UAAU;YACV,IAAI,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;gBACtD,SAAS,GAAG,SAAS,CAAC;gBACtB,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;gBACxC,UAAU,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YACrC,CAAC;YAED,MAAM;YACN,IAAI,IAAI,KAAK,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC9C,SAAS,GAAG,KAAK,CAAC;gBAClB,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;gBACxC,UAAU,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YACrC,CAAC;YAED,OAAO;YACP,IAAI,IAAI,KAAK,YAAY,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACvD,SAAS,GAAG,MAAM,CAAC;gBACnB,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;gBACxC,UAAU,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YACrC,CAAC;YAED,SAAS;YACT,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC;gBAChC,SAAS,GAAG,QAAQ,CAAC;gBACrB,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;gBACxC,UAAU,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YACrC,CAAC;YAED,QAAQ;YACR,IAAI,IAAI,KAAK,OAAO,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAClD,SAAS,GAAG,SAAS,IAAI,OAAO,CAAC;gBACjC,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;gBACvC,UAAU,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YACrC,CAAC;YAED,UAAU;YACV,IAAI,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;gBAChD,SAAS,GAAG,QAAQ,CAAC;gBACrB,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;gBACvC,UAAU,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC;YACrC,CAAC;QACH,CAAC;QAED,IAAI,SAAS,EAAE,CAAC;YACd,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAE,CAAC;QACrD,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;OAEG;IACH,iBAAiB;QACf,OAAO;YACL,4BAA4B;YAC5B;gBACE,MAAM,EAAE,OAAO;gBACf,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,IAAI;gBAChB,aAAa,EAAE,IAAI;aACpB;YACD;gBACE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,WAAW;gBACjB,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,IAAI;gBAChB,aAAa,EAAE,IAAI;aACpB;YACD;gBACE,MAAM,EAAE,QAAQ;gBAChB,IAAI,EAAE,WAAW;gBACjB,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,IAAI;gBAChB,aAAa,EAAE,IAAI;aACpB;YACD;gBACE,MAAM,EAAE,SAAS;gBACjB,IAAI,EAAE,aAAa;gBACnB,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,GAAG;gBACf,aAAa,EAAE,IAAI;aACpB;YACD;gBACE,MAAM,EAAE,SAAS;gBACjB,IAAI,EAAE,aAAa;gBACnB,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,GAAG;gBACf,aAAa,EAAE,IAAI;aACpB;YAED,sBAAsB;YACtB;gBACE,MAAM,EAAE,KAAK;gBACb,KAAK,EAAE,iBAAiB;gBACxB,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,IAAI;gBAChB,aAAa,EAAE,IAAI;aACpB;YAED,iCAAiC;YACjC;gBACE,MAAM,EAAE,UAAU;gBAClB,IAAI,EAAE,WAAW;gBACjB,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,GAAG;gBACf,aAAa,EAAE,IAAI;aACpB;YACD;gBACE,MAAM,EAAE,cAAc;gBACtB,IAAI,EAAE,WAAW;gBACjB,QAAQ,EAAE,MAAM;gBAChB,UAAU,EAAE,GAAG;gBACf,aAAa,EAAE,IAAI;aACpB;YACD;gBACE,MAAM,EAAE,mBAAmB;gBAC3B,IAAI,EAAE,WAAW;gBACjB,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,IAAI;gBAChB,aAAa,EAAE,IAAI;aACpB;YAED,kBAAkB;YAClB;gBACE,MAAM,EAAE,MAAM;gBACd,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,SAAS;gBACf,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,GAAG;gBACf,aAAa,EAAE,IAAI;aACpB;YACD;gBACE,MAAM,EAAE,KAAK;gBACb,KAAK,EAAE,SAAS;gBAChB,IAAI,EAAE,SAAS;gBACf,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,IAAI;gBAChB,aAAa,EAAE,IAAI;aACpB;YAED,cAAc;YACd;gBACE,MAAM,EAAE,cAAc;gBACtB,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,GAAG;gBACf,aAAa,EAAE,IAAI;aACpB;YACD;gBACE,MAAM,EAAE,UAAU;gBAClB,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,YAAY;gBAClB,QAAQ,EAAE,QAAQ;gBAClB,UAAU,EAAE,GAAG;gBACf,aAAa,EAAE,IAAI;aACpB;SACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,eAAe;QACb,OAAO;YACL,oBAAoB;YACpB;gBACE,MAAM,EAAE,MAAM;gBACd,KAAK,EAAE,eAAe;gBACtB,IAAI,EAAE,mBAAmB;gBACzB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,UAAU;gBACpB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,UAAU;gBAClB,KAAK,EAAE,eAAe;gBACtB,IAAI,EAAE,mBAAmB;gBACzB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,UAAU;gBACpB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,OAAO;gBACf,KAAK,EAAE,eAAe;gBACtB,IAAI,EAAE,mBAAmB;gBACzB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,UAAU;gBACpB,YAAY,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;aACrB;YAED,iBAAiB;YACjB;gBACE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,gBAAgB;gBACtB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,UAAU;gBACpB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,UAAU;gBAClB,IAAI,EAAE,gBAAgB;gBACtB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,UAAU;gBACpB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,YAAY;gBACpB,IAAI,EAAE,gBAAgB;gBACtB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC,EAAG,2BAA2B;aAChD;YACD;gBACE,MAAM,EAAE,aAAa;gBACrB,IAAI,EAAE,gBAAgB;gBACtB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC,EAAG,2BAA2B;aAChD;YAED,iBAAiB;YACjB;gBACE,MAAM,EAAE,cAAc;gBACtB,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,gBAAgB;gBACtB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,eAAe;gBACvB,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,gBAAgB;gBACtB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,kBAAkB;gBAC1B,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,gBAAgB;gBACtB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YAED,YAAY;YACZ;gBACE,MAAM,EAAE,WAAW;gBACnB,IAAI,EAAE,KAAK;gBACX,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,WAAW;gBACnB,IAAI,EAAE,KAAK;gBACX,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,gBAAgB;gBACxB,IAAI,EAAE,KAAK;gBACX,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YAED,gBAAgB;YAChB;gBACE,MAAM,EAAE,OAAO;gBACf,IAAI,EAAE,eAAe;gBACrB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,UAAU;gBACpB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,KAAK;gBACb,IAAI,EAAE,eAAe;gBACrB,GAAG,EAAE,QAAQ;gBACb,QAAQ,EAAE,UAAU;gBACpB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YAED,OAAO;YACP;gBACE,MAAM,EAAE,OAAO;gBACf,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,SAAS;gBACd,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,KAAK;gBACb,KAAK,EAAE,OAAO;gBACd,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,SAAS;gBACd,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,SAAS;gBACjB,KAAK,EAAE,MAAM;gBACb,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,SAAS;gBACd,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YAED,kBAAkB;YAClB;gBACE,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,iBAAiB;gBACvB,GAAG,EAAE,SAAS;gBACd,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YACD;gBACE,MAAM,EAAE,SAAS;gBACjB,IAAI,EAAE,iBAAiB;gBACvB,GAAG,EAAE,SAAS;gBACd,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,CAAC;aAClB;YAED,oCAAoC;YACpC;gBACE,MAAM,EAAE,OAAO;gBACf,IAAI,EAAE,qBAAqB;gBAC3B,GAAG,EAAE,UAAU;gBACf,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;aACrB;YACD;gBACE,MAAM,EAAE,QAAQ;gBAChB,IAAI,EAAE,qBAAqB;gBAC3B,GAAG,EAAE,UAAU;gBACf,QAAQ,EAAE,MAAM;gBAChB,YAAY,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;aACrB;SACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,IAAgB,EAAE,OAA0B;QAC1D,IAAI,IAAI,CAAC,IAAI,KAAK,iBAAiB;YAAE,OAAO,SAAS,CAAC;QAEtD,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAClD,IAAI,CAAC,MAAM;YAAE,OAAO,SAAS,CAAC;QAE9B,2CAA2C;QAC3C,IAAI,MAAM,CAAC,IAAI,KAAK,mBAAmB,EAAE,CAAC;YACxC,MAAM,MAAM,GAAG,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;YAClD,IAAI,MAAM,EAAE,CAAC;gBACX,OAAO,MAAM,CAAC,IAAI,CAAC;YACrB,CAAC;QACH,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;OAEG;IACH,eAAe,CAAC,IAAgB;QAC9B,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ;YACtB,IAAI,CAAC,IAAI,KAAK,iBAAiB;YAC/B,IAAI,CAAC,IAAI,KAAK,iBAAiB,CAAC;IACzC,CAAC;IAED;;OAEG;IACH,cAAc,CAAC,IAAgB;QAC7B,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;YAAE,OAAO,SAAS,CAAC;QAElD,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QAEvB,0BAA0B;QAC1B,IAAI,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YAC/C,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;QAED,yBAAyB;QACzB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAC5C,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;YACjD,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3B,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,+DAA+D;IAE/D,YAAY,CAAC,OAA0B;QACrC,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,YAAY,CAAC,OAA0B;QACrC,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,cAAc,CAAC,OAA0B;QACvC,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,cAAc,CAAC,OAA0B;QACvC,+CAA+C;QAC/C,oDAAoD;QACpD,OAAO,SAAS,CAAC;IACnB,CAAC;CACF"}
@@ -0,0 +1,47 @@
1
+ /**
2
+ * Python Language Plugin
3
+ *
4
+ * Provides Python-specific AST handling, taint patterns, and framework detection.
5
+ */
6
+ import type { Node as SyntaxNode } from 'web-tree-sitter';
7
+ import type { TypeInfo, CallInfo, ImportInfo } from '../../types/index.js';
8
+ import type { LanguageNodeTypes, ExtractionContext, FrameworkInfo, TaintSourcePattern, TaintSinkPattern } from '../types.js';
9
+ import { BaseLanguagePlugin } from './base.js';
10
+ /**
11
+ * Python language plugin implementation.
12
+ */
13
+ export declare class PythonPlugin extends BaseLanguagePlugin {
14
+ readonly id: "python";
15
+ readonly name = "Python";
16
+ readonly extensions: string[];
17
+ readonly wasmPath = "tree-sitter-python.wasm";
18
+ readonly nodeTypes: LanguageNodeTypes;
19
+ /**
20
+ * Detect Python frameworks from imports.
21
+ */
22
+ detectFramework(context: ExtractionContext): FrameworkInfo | undefined;
23
+ /**
24
+ * Python taint source patterns.
25
+ */
26
+ getBuiltinSources(): TaintSourcePattern[];
27
+ /**
28
+ * Python taint sink patterns.
29
+ */
30
+ getBuiltinSinks(): TaintSinkPattern[];
31
+ /**
32
+ * Get receiver type from a call expression.
33
+ */
34
+ getReceiverType(node: SyntaxNode, context: ExtractionContext): string | undefined;
35
+ /**
36
+ * Check if node is a Python string literal.
37
+ */
38
+ isStringLiteral(node: SyntaxNode): boolean;
39
+ /**
40
+ * Get string value from Python string literal.
41
+ */
42
+ getStringValue(node: SyntaxNode): string | undefined;
43
+ extractTypes(context: ExtractionContext): TypeInfo[];
44
+ extractCalls(context: ExtractionContext): CallInfo[];
45
+ extractImports(context: ExtractionContext): ImportInfo[];
46
+ extractPackage(context: ExtractionContext): string | undefined;
47
+ }