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,480 @@
1
+ /**
2
+ * Python Language Plugin
3
+ *
4
+ * Provides Python-specific AST handling, taint patterns, and framework detection.
5
+ */
6
+ import { BaseLanguagePlugin } from './base.js';
7
+ /**
8
+ * Python language plugin implementation.
9
+ */
10
+ export class PythonPlugin extends BaseLanguagePlugin {
11
+ id = 'python';
12
+ name = 'Python';
13
+ extensions = ['.py', '.pyw'];
14
+ wasmPath = 'tree-sitter-python.wasm';
15
+ nodeTypes = {
16
+ // Type declarations
17
+ classDeclaration: ['class_definition'],
18
+ interfaceDeclaration: [], // Python doesn't have interfaces
19
+ enumDeclaration: [], // Python enums are classes
20
+ functionDeclaration: ['function_definition'],
21
+ methodDeclaration: ['function_definition'], // Methods are function_definition inside class
22
+ // Expressions
23
+ methodCall: ['call'],
24
+ functionCall: ['call'],
25
+ assignment: ['assignment', 'augmented_assignment'],
26
+ variableDeclaration: ['assignment'], // Python doesn't have explicit declarations
27
+ // Parameters and arguments
28
+ parameter: ['parameters', 'typed_parameter', 'default_parameter'],
29
+ argument: ['argument_list'],
30
+ // Annotations/decorators
31
+ annotation: [],
32
+ decorator: ['decorator'],
33
+ // Imports
34
+ importStatement: ['import_statement', 'import_from_statement'],
35
+ // Control flow
36
+ ifStatement: ['if_statement'],
37
+ forStatement: ['for_statement'],
38
+ whileStatement: ['while_statement'],
39
+ tryStatement: ['try_statement'],
40
+ returnStatement: ['return_statement'],
41
+ };
42
+ /**
43
+ * Detect Python frameworks from imports.
44
+ */
45
+ detectFramework(context) {
46
+ const indicators = [];
47
+ let framework;
48
+ let confidence = 0;
49
+ for (const imp of context.imports) {
50
+ const path = imp.from_package || imp.imported_name;
51
+ // Flask
52
+ if (path === 'flask' || path.startsWith('flask.')) {
53
+ framework = 'flask';
54
+ confidence = Math.max(confidence, 0.95);
55
+ indicators.push(`import: ${path}`);
56
+ }
57
+ // Django
58
+ if (path.startsWith('django.') || path === 'django') {
59
+ framework = 'django';
60
+ confidence = Math.max(confidence, 0.95);
61
+ indicators.push(`import: ${path}`);
62
+ }
63
+ // FastAPI
64
+ if (path === 'fastapi' || path.startsWith('fastapi.')) {
65
+ framework = 'fastapi';
66
+ confidence = Math.max(confidence, 0.95);
67
+ indicators.push(`import: ${path}`);
68
+ }
69
+ // Tornado
70
+ if (path.startsWith('tornado.')) {
71
+ framework = 'tornado';
72
+ confidence = Math.max(confidence, 0.9);
73
+ indicators.push(`import: ${path}`);
74
+ }
75
+ // aiohttp
76
+ if (path === 'aiohttp' || path.startsWith('aiohttp.')) {
77
+ framework = 'aiohttp';
78
+ confidence = Math.max(confidence, 0.9);
79
+ indicators.push(`import: ${path}`);
80
+ }
81
+ // Pyramid
82
+ if (path.startsWith('pyramid.')) {
83
+ framework = 'pyramid';
84
+ confidence = Math.max(confidence, 0.9);
85
+ indicators.push(`import: ${path}`);
86
+ }
87
+ }
88
+ if (framework) {
89
+ return { name: framework, confidence, indicators };
90
+ }
91
+ return undefined;
92
+ }
93
+ /**
94
+ * Python taint source patterns.
95
+ */
96
+ getBuiltinSources() {
97
+ return [
98
+ // Flask request object
99
+ {
100
+ method: 'args',
101
+ class: 'request',
102
+ type: 'http_param',
103
+ severity: 'high',
104
+ confidence: 0.95,
105
+ returnTainted: true,
106
+ },
107
+ {
108
+ method: 'form',
109
+ class: 'request',
110
+ type: 'http_body',
111
+ severity: 'high',
112
+ confidence: 0.95,
113
+ returnTainted: true,
114
+ },
115
+ {
116
+ method: 'json',
117
+ class: 'request',
118
+ type: 'http_body',
119
+ severity: 'high',
120
+ confidence: 0.95,
121
+ returnTainted: true,
122
+ },
123
+ {
124
+ method: 'data',
125
+ class: 'request',
126
+ type: 'http_body',
127
+ severity: 'high',
128
+ confidence: 0.95,
129
+ returnTainted: true,
130
+ },
131
+ {
132
+ method: 'headers',
133
+ class: 'request',
134
+ type: 'http_header',
135
+ severity: 'high',
136
+ confidence: 0.9,
137
+ returnTainted: true,
138
+ },
139
+ {
140
+ method: 'cookies',
141
+ class: 'request',
142
+ type: 'http_cookie',
143
+ severity: 'high',
144
+ confidence: 0.9,
145
+ returnTainted: true,
146
+ },
147
+ {
148
+ method: 'files',
149
+ class: 'request',
150
+ type: 'file_upload',
151
+ severity: 'high',
152
+ confidence: 0.9,
153
+ returnTainted: true,
154
+ },
155
+ // Django request object
156
+ {
157
+ method: 'GET',
158
+ class: 'request',
159
+ type: 'http_param',
160
+ severity: 'high',
161
+ confidence: 0.95,
162
+ returnTainted: true,
163
+ },
164
+ {
165
+ method: 'POST',
166
+ class: 'request',
167
+ type: 'http_body',
168
+ severity: 'high',
169
+ confidence: 0.95,
170
+ returnTainted: true,
171
+ },
172
+ {
173
+ method: 'META',
174
+ class: 'request',
175
+ type: 'http_header',
176
+ severity: 'high',
177
+ confidence: 0.9,
178
+ returnTainted: true,
179
+ },
180
+ // Standard library sources
181
+ {
182
+ method: 'input',
183
+ type: 'user_input',
184
+ severity: 'high',
185
+ confidence: 0.95,
186
+ returnTainted: true,
187
+ },
188
+ {
189
+ method: 'argv',
190
+ class: 'sys',
191
+ type: 'cli_arg',
192
+ severity: 'medium',
193
+ confidence: 0.9,
194
+ returnTainted: true,
195
+ },
196
+ {
197
+ method: 'environ',
198
+ class: 'os',
199
+ type: 'env_var',
200
+ severity: 'medium',
201
+ confidence: 0.85,
202
+ returnTainted: true,
203
+ },
204
+ {
205
+ method: 'getenv',
206
+ class: 'os',
207
+ type: 'env_var',
208
+ severity: 'medium',
209
+ confidence: 0.85,
210
+ returnTainted: true,
211
+ },
212
+ // File reading
213
+ {
214
+ method: 'read',
215
+ type: 'file_input',
216
+ severity: 'medium',
217
+ confidence: 0.8,
218
+ returnTainted: true,
219
+ },
220
+ {
221
+ method: 'readline',
222
+ type: 'file_input',
223
+ severity: 'medium',
224
+ confidence: 0.8,
225
+ returnTainted: true,
226
+ },
227
+ {
228
+ method: 'readlines',
229
+ type: 'file_input',
230
+ severity: 'medium',
231
+ confidence: 0.8,
232
+ returnTainted: true,
233
+ },
234
+ ];
235
+ }
236
+ /**
237
+ * Python taint sink patterns.
238
+ */
239
+ getBuiltinSinks() {
240
+ return [
241
+ // Command Injection
242
+ {
243
+ method: 'system',
244
+ class: 'os',
245
+ type: 'command_injection',
246
+ cwe: 'CWE-78',
247
+ severity: 'critical',
248
+ argPositions: [0],
249
+ },
250
+ {
251
+ method: 'popen',
252
+ class: 'os',
253
+ type: 'command_injection',
254
+ cwe: 'CWE-78',
255
+ severity: 'critical',
256
+ argPositions: [0],
257
+ },
258
+ {
259
+ method: 'run',
260
+ class: 'subprocess',
261
+ type: 'command_injection',
262
+ cwe: 'CWE-78',
263
+ severity: 'critical',
264
+ argPositions: [0],
265
+ },
266
+ {
267
+ method: 'call',
268
+ class: 'subprocess',
269
+ type: 'command_injection',
270
+ cwe: 'CWE-78',
271
+ severity: 'critical',
272
+ argPositions: [0],
273
+ },
274
+ {
275
+ method: 'Popen',
276
+ class: 'subprocess',
277
+ type: 'command_injection',
278
+ cwe: 'CWE-78',
279
+ severity: 'critical',
280
+ argPositions: [0],
281
+ },
282
+ // Code Injection
283
+ {
284
+ method: 'eval',
285
+ type: 'code_injection',
286
+ cwe: 'CWE-94',
287
+ severity: 'critical',
288
+ argPositions: [0],
289
+ },
290
+ {
291
+ method: 'exec',
292
+ type: 'code_injection',
293
+ cwe: 'CWE-94',
294
+ severity: 'critical',
295
+ argPositions: [0],
296
+ },
297
+ {
298
+ method: 'compile',
299
+ type: 'code_injection',
300
+ cwe: 'CWE-94',
301
+ severity: 'high',
302
+ argPositions: [0],
303
+ },
304
+ // SQL Injection
305
+ {
306
+ method: 'execute',
307
+ type: 'sql_injection',
308
+ cwe: 'CWE-89',
309
+ severity: 'critical',
310
+ argPositions: [0],
311
+ },
312
+ {
313
+ method: 'executemany',
314
+ type: 'sql_injection',
315
+ cwe: 'CWE-89',
316
+ severity: 'critical',
317
+ argPositions: [0],
318
+ },
319
+ {
320
+ method: 'raw',
321
+ type: 'sql_injection',
322
+ cwe: 'CWE-89',
323
+ severity: 'critical',
324
+ argPositions: [0],
325
+ },
326
+ // Path Traversal
327
+ {
328
+ method: 'open',
329
+ type: 'path_traversal',
330
+ cwe: 'CWE-22',
331
+ severity: 'high',
332
+ argPositions: [0],
333
+ },
334
+ {
335
+ method: 'read',
336
+ class: 'pathlib',
337
+ type: 'path_traversal',
338
+ cwe: 'CWE-22',
339
+ severity: 'high',
340
+ argPositions: [0],
341
+ },
342
+ // XSS (template injection)
343
+ {
344
+ method: 'Markup',
345
+ type: 'xss',
346
+ cwe: 'CWE-79',
347
+ severity: 'high',
348
+ argPositions: [0],
349
+ },
350
+ {
351
+ method: 'safe',
352
+ type: 'xss',
353
+ cwe: 'CWE-79',
354
+ severity: 'high',
355
+ argPositions: [0],
356
+ },
357
+ // SSRF
358
+ {
359
+ method: 'get',
360
+ class: 'requests',
361
+ type: 'ssrf',
362
+ cwe: 'CWE-918',
363
+ severity: 'high',
364
+ argPositions: [0],
365
+ },
366
+ {
367
+ method: 'post',
368
+ class: 'requests',
369
+ type: 'ssrf',
370
+ cwe: 'CWE-918',
371
+ severity: 'high',
372
+ argPositions: [0],
373
+ },
374
+ {
375
+ method: 'urlopen',
376
+ class: 'urllib',
377
+ type: 'ssrf',
378
+ cwe: 'CWE-918',
379
+ severity: 'high',
380
+ argPositions: [0],
381
+ },
382
+ // Deserialization
383
+ {
384
+ method: 'loads',
385
+ class: 'pickle',
386
+ type: 'deserialization',
387
+ cwe: 'CWE-502',
388
+ severity: 'critical',
389
+ argPositions: [0],
390
+ },
391
+ {
392
+ method: 'load',
393
+ class: 'pickle',
394
+ type: 'deserialization',
395
+ cwe: 'CWE-502',
396
+ severity: 'critical',
397
+ argPositions: [0],
398
+ },
399
+ {
400
+ method: 'safe_load',
401
+ class: 'yaml',
402
+ type: 'deserialization',
403
+ cwe: 'CWE-502',
404
+ severity: 'high',
405
+ argPositions: [0],
406
+ sanitizes: ['yaml_unsafe'], // safe_load is safe for YAML
407
+ },
408
+ {
409
+ method: 'load',
410
+ class: 'yaml',
411
+ type: 'deserialization',
412
+ cwe: 'CWE-502',
413
+ severity: 'critical',
414
+ argPositions: [0],
415
+ },
416
+ // LDAP Injection
417
+ {
418
+ method: 'search_s',
419
+ type: 'ldap_injection',
420
+ cwe: 'CWE-90',
421
+ severity: 'high',
422
+ argPositions: [1, 2],
423
+ },
424
+ ];
425
+ }
426
+ /**
427
+ * Get receiver type from a call expression.
428
+ */
429
+ getReceiverType(node, context) {
430
+ if (node.type !== 'call')
431
+ return undefined;
432
+ const func = node.childForFieldName('function');
433
+ if (!func)
434
+ return undefined;
435
+ // For attribute access like obj.method()
436
+ if (func.type === 'attribute') {
437
+ const object = func.childForFieldName('object');
438
+ if (object) {
439
+ return object.text;
440
+ }
441
+ }
442
+ return undefined;
443
+ }
444
+ /**
445
+ * Check if node is a Python string literal.
446
+ */
447
+ isStringLiteral(node) {
448
+ return node.type === 'string' ||
449
+ node.type === 'concatenated_string';
450
+ }
451
+ /**
452
+ * Get string value from Python string literal.
453
+ */
454
+ getStringValue(node) {
455
+ if (!this.isStringLiteral(node))
456
+ return undefined;
457
+ const text = node.text;
458
+ // Handle various Python string prefixes (f, r, b, etc.)
459
+ const match = text.match(/^[frbFRB]*['"`]{1,3}(.*)['"`]{1,3}$/s);
460
+ if (match) {
461
+ return match[1];
462
+ }
463
+ return text;
464
+ }
465
+ // Extraction methods - delegate to existing extractors for now
466
+ extractTypes(context) {
467
+ return [];
468
+ }
469
+ extractCalls(context) {
470
+ return [];
471
+ }
472
+ extractImports(context) {
473
+ return [];
474
+ }
475
+ extractPackage(context) {
476
+ // Python uses file path as module path
477
+ return undefined;
478
+ }
479
+ }
480
+ //# sourceMappingURL=python.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"python.js","sourceRoot":"","sources":["../../../src/languages/plugins/python.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,47 @@
1
+ /**
2
+ * Rust Language Plugin
3
+ *
4
+ * Provides Rust-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
+ * Rust language plugin implementation.
12
+ */
13
+ export declare class RustPlugin extends BaseLanguagePlugin {
14
+ readonly id: "rust";
15
+ readonly name = "Rust";
16
+ readonly extensions: string[];
17
+ readonly wasmPath = "tree-sitter-rust.wasm";
18
+ readonly nodeTypes: LanguageNodeTypes;
19
+ /**
20
+ * Detect Rust frameworks from imports.
21
+ */
22
+ detectFramework(context: ExtractionContext): FrameworkInfo | undefined;
23
+ /**
24
+ * Rust taint source patterns.
25
+ */
26
+ getBuiltinSources(): TaintSourcePattern[];
27
+ /**
28
+ * Rust 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 Rust string literal.
37
+ */
38
+ isStringLiteral(node: SyntaxNode): boolean;
39
+ /**
40
+ * Get string value from Rust 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
+ }