@grafema/core 0.1.0-alpha.5 → 0.2.0-beta

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 (530) hide show
  1. package/README.md +0 -1
  2. package/dist/Orchestrator.d.ts +31 -2
  3. package/dist/Orchestrator.d.ts.map +1 -1
  4. package/dist/Orchestrator.js +222 -27
  5. package/dist/config/ConfigLoader.d.ts +90 -0
  6. package/dist/config/ConfigLoader.d.ts.map +1 -0
  7. package/dist/config/ConfigLoader.js +249 -0
  8. package/dist/config/index.d.ts +6 -0
  9. package/dist/config/index.d.ts.map +1 -0
  10. package/dist/config/index.js +4 -0
  11. package/dist/core/ASTWorker.d.ts +11 -36
  12. package/dist/core/ASTWorker.d.ts.map +1 -1
  13. package/dist/core/ASTWorker.js +93 -99
  14. package/dist/core/CoverageAnalyzer.d.ts +65 -0
  15. package/dist/core/CoverageAnalyzer.d.ts.map +1 -0
  16. package/dist/core/CoverageAnalyzer.js +198 -0
  17. package/dist/core/FileExplainer.d.ts +101 -0
  18. package/dist/core/FileExplainer.d.ts.map +1 -0
  19. package/dist/core/FileExplainer.js +139 -0
  20. package/dist/core/FileNodeManager.d.ts +40 -0
  21. package/dist/core/FileNodeManager.d.ts.map +1 -0
  22. package/dist/core/FileNodeManager.js +84 -0
  23. package/dist/core/GraphFreshnessChecker.d.ts +33 -0
  24. package/dist/core/GraphFreshnessChecker.d.ts.map +1 -0
  25. package/dist/core/GraphFreshnessChecker.js +101 -0
  26. package/dist/core/HashUtils.d.ts +24 -0
  27. package/dist/core/HashUtils.d.ts.map +1 -0
  28. package/dist/core/HashUtils.js +45 -0
  29. package/dist/core/IncrementalReanalyzer.d.ts +36 -0
  30. package/dist/core/IncrementalReanalyzer.d.ts.map +1 -0
  31. package/dist/core/IncrementalReanalyzer.js +132 -0
  32. package/dist/core/NodeFactory.d.ts +266 -19
  33. package/dist/core/NodeFactory.d.ts.map +1 -1
  34. package/dist/core/NodeFactory.js +256 -21
  35. package/dist/core/ScopeTracker.d.ts +84 -0
  36. package/dist/core/ScopeTracker.d.ts.map +1 -0
  37. package/dist/core/ScopeTracker.js +116 -0
  38. package/dist/core/SemanticId.d.ts +90 -0
  39. package/dist/core/SemanticId.d.ts.map +1 -0
  40. package/dist/core/SemanticId.js +115 -0
  41. package/dist/core/VersionManager.d.ts.map +1 -1
  42. package/dist/core/VersionManager.js +3 -2
  43. package/dist/core/nodes/ArgumentExpressionNode.d.ts +43 -0
  44. package/dist/core/nodes/ArgumentExpressionNode.d.ts.map +1 -0
  45. package/dist/core/nodes/ArgumentExpressionNode.js +60 -0
  46. package/dist/core/nodes/ArrayLiteralNode.d.ts +27 -0
  47. package/dist/core/nodes/ArrayLiteralNode.d.ts.map +1 -0
  48. package/dist/core/nodes/ArrayLiteralNode.js +43 -0
  49. package/dist/core/nodes/BranchNode.d.ts +41 -0
  50. package/dist/core/nodes/BranchNode.d.ts.map +1 -0
  51. package/dist/core/nodes/BranchNode.js +82 -0
  52. package/dist/core/nodes/CallSiteNode.d.ts +30 -2
  53. package/dist/core/nodes/CallSiteNode.d.ts.map +1 -1
  54. package/dist/core/nodes/CallSiteNode.js +54 -4
  55. package/dist/core/nodes/CaseNode.d.ts +43 -0
  56. package/dist/core/nodes/CaseNode.d.ts.map +1 -0
  57. package/dist/core/nodes/CaseNode.js +81 -0
  58. package/dist/core/nodes/ClassNode.d.ts +34 -2
  59. package/dist/core/nodes/ClassNode.d.ts.map +1 -1
  60. package/dist/core/nodes/ClassNode.js +52 -4
  61. package/dist/core/nodes/ConstantNode.d.ts +2 -2
  62. package/dist/core/nodes/ConstantNode.d.ts.map +1 -1
  63. package/dist/core/nodes/ConstantNode.js +6 -4
  64. package/dist/core/nodes/ConstructorCallNode.d.ts +51 -0
  65. package/dist/core/nodes/ConstructorCallNode.d.ts.map +1 -0
  66. package/dist/core/nodes/ConstructorCallNode.js +171 -0
  67. package/dist/core/nodes/DatabaseQueryNode.d.ts +3 -2
  68. package/dist/core/nodes/DatabaseQueryNode.d.ts.map +1 -1
  69. package/dist/core/nodes/DatabaseQueryNode.js +5 -2
  70. package/dist/core/nodes/DecoratorNode.d.ts +42 -0
  71. package/dist/core/nodes/DecoratorNode.d.ts.map +1 -0
  72. package/dist/core/nodes/DecoratorNode.js +64 -0
  73. package/dist/core/nodes/EnumNode.d.ts +42 -0
  74. package/dist/core/nodes/EnumNode.d.ts.map +1 -0
  75. package/dist/core/nodes/EnumNode.js +56 -0
  76. package/dist/core/nodes/EventListenerNode.d.ts +4 -4
  77. package/dist/core/nodes/EventListenerNode.d.ts.map +1 -1
  78. package/dist/core/nodes/EventListenerNode.js +7 -4
  79. package/dist/core/nodes/ExportNode.d.ts +38 -2
  80. package/dist/core/nodes/ExportNode.d.ts.map +1 -1
  81. package/dist/core/nodes/ExportNode.js +54 -4
  82. package/dist/core/nodes/ExpressionNode.d.ts +97 -0
  83. package/dist/core/nodes/ExpressionNode.d.ts.map +1 -0
  84. package/dist/core/nodes/ExpressionNode.js +180 -0
  85. package/dist/core/nodes/ExternalModuleNode.d.ts +32 -0
  86. package/dist/core/nodes/ExternalModuleNode.d.ts.map +1 -0
  87. package/dist/core/nodes/ExternalModuleNode.js +49 -0
  88. package/dist/core/nodes/ExternalStdioNode.d.ts +13 -6
  89. package/dist/core/nodes/ExternalStdioNode.d.ts.map +1 -1
  90. package/dist/core/nodes/ExternalStdioNode.js +15 -8
  91. package/dist/core/nodes/FunctionNode.d.ts +36 -0
  92. package/dist/core/nodes/FunctionNode.d.ts.map +1 -1
  93. package/dist/core/nodes/FunctionNode.js +80 -1
  94. package/dist/core/nodes/HttpRequestNode.d.ts +4 -4
  95. package/dist/core/nodes/HttpRequestNode.d.ts.map +1 -1
  96. package/dist/core/nodes/HttpRequestNode.js +7 -4
  97. package/dist/core/nodes/ImportNode.d.ts +28 -6
  98. package/dist/core/nodes/ImportNode.d.ts.map +1 -1
  99. package/dist/core/nodes/ImportNode.js +43 -8
  100. package/dist/core/nodes/InterfaceNode.d.ts +46 -0
  101. package/dist/core/nodes/InterfaceNode.d.ts.map +1 -0
  102. package/dist/core/nodes/InterfaceNode.js +57 -0
  103. package/dist/core/nodes/IssueNode.d.ts +73 -0
  104. package/dist/core/nodes/IssueNode.d.ts.map +1 -0
  105. package/dist/core/nodes/IssueNode.js +129 -0
  106. package/dist/core/nodes/LiteralNode.d.ts +2 -2
  107. package/dist/core/nodes/LiteralNode.d.ts.map +1 -1
  108. package/dist/core/nodes/LiteralNode.js +6 -4
  109. package/dist/core/nodes/MethodCallNode.d.ts +32 -2
  110. package/dist/core/nodes/MethodCallNode.d.ts.map +1 -1
  111. package/dist/core/nodes/MethodCallNode.js +57 -4
  112. package/dist/core/nodes/MethodNode.d.ts +34 -2
  113. package/dist/core/nodes/MethodNode.d.ts.map +1 -1
  114. package/dist/core/nodes/MethodNode.js +55 -3
  115. package/dist/core/nodes/ModuleNode.d.ts +31 -0
  116. package/dist/core/nodes/ModuleNode.d.ts.map +1 -1
  117. package/dist/core/nodes/ModuleNode.js +37 -0
  118. package/dist/core/nodes/NetworkRequestNode.d.ts +54 -0
  119. package/dist/core/nodes/NetworkRequestNode.d.ts.map +1 -0
  120. package/dist/core/nodes/NetworkRequestNode.js +65 -0
  121. package/dist/core/nodes/ObjectLiteralNode.d.ts +27 -0
  122. package/dist/core/nodes/ObjectLiteralNode.d.ts.map +1 -0
  123. package/dist/core/nodes/ObjectLiteralNode.js +43 -0
  124. package/dist/core/nodes/ParameterNode.d.ts +2 -2
  125. package/dist/core/nodes/ParameterNode.d.ts.map +1 -1
  126. package/dist/core/nodes/ParameterNode.js +5 -3
  127. package/dist/core/nodes/ScopeNode.d.ts +31 -0
  128. package/dist/core/nodes/ScopeNode.d.ts.map +1 -1
  129. package/dist/core/nodes/ScopeNode.js +49 -0
  130. package/dist/core/nodes/TypeNode.d.ts +36 -0
  131. package/dist/core/nodes/TypeNode.d.ts.map +1 -0
  132. package/dist/core/nodes/TypeNode.js +55 -0
  133. package/dist/core/nodes/VariableDeclarationNode.d.ts +29 -2
  134. package/dist/core/nodes/VariableDeclarationNode.d.ts.map +1 -1
  135. package/dist/core/nodes/VariableDeclarationNode.js +48 -4
  136. package/dist/core/nodes/index.d.ts +15 -1
  137. package/dist/core/nodes/index.d.ts.map +1 -1
  138. package/dist/core/nodes/index.js +17 -0
  139. package/dist/data/builtins/BuiltinRegistry.d.ts +78 -0
  140. package/dist/data/builtins/BuiltinRegistry.d.ts.map +1 -0
  141. package/dist/data/builtins/BuiltinRegistry.js +110 -0
  142. package/dist/data/builtins/definitions.d.ts +28 -0
  143. package/dist/data/builtins/definitions.d.ts.map +1 -0
  144. package/dist/data/builtins/definitions.js +250 -0
  145. package/dist/data/builtins/index.d.ts +10 -0
  146. package/dist/data/builtins/index.d.ts.map +1 -0
  147. package/dist/data/builtins/index.js +8 -0
  148. package/dist/data/builtins/jsGlobals.d.ts +18 -0
  149. package/dist/data/builtins/jsGlobals.d.ts.map +1 -0
  150. package/dist/data/builtins/jsGlobals.js +26 -0
  151. package/dist/data/builtins/types.d.ts +34 -0
  152. package/dist/data/builtins/types.d.ts.map +1 -0
  153. package/dist/data/builtins/types.js +7 -0
  154. package/dist/data/globals/definitions.d.ts +27 -0
  155. package/dist/data/globals/definitions.d.ts.map +1 -0
  156. package/dist/data/globals/definitions.js +117 -0
  157. package/dist/data/globals/index.d.ts +36 -0
  158. package/dist/data/globals/index.d.ts.map +1 -0
  159. package/dist/data/globals/index.js +52 -0
  160. package/dist/diagnostics/DiagnosticCollector.d.ts +98 -0
  161. package/dist/diagnostics/DiagnosticCollector.d.ts.map +1 -0
  162. package/dist/diagnostics/DiagnosticCollector.js +129 -0
  163. package/dist/diagnostics/DiagnosticReporter.d.ts +100 -0
  164. package/dist/diagnostics/DiagnosticReporter.d.ts.map +1 -0
  165. package/dist/diagnostics/DiagnosticReporter.js +247 -0
  166. package/dist/diagnostics/DiagnosticWriter.d.ts +31 -0
  167. package/dist/diagnostics/DiagnosticWriter.d.ts.map +1 -0
  168. package/dist/diagnostics/DiagnosticWriter.js +43 -0
  169. package/dist/diagnostics/index.d.ts +14 -0
  170. package/dist/diagnostics/index.d.ts.map +1 -0
  171. package/dist/diagnostics/index.js +11 -0
  172. package/dist/errors/GrafemaError.d.ts +161 -0
  173. package/dist/errors/GrafemaError.d.ts.map +1 -0
  174. package/dist/errors/GrafemaError.js +181 -0
  175. package/dist/index.d.ts +73 -1
  176. package/dist/index.d.ts.map +1 -1
  177. package/dist/index.js +70 -1
  178. package/dist/logging/Logger.d.ts +48 -0
  179. package/dist/logging/Logger.d.ts.map +1 -0
  180. package/dist/logging/Logger.js +134 -0
  181. package/dist/plugins/Plugin.d.ts +5 -1
  182. package/dist/plugins/Plugin.d.ts.map +1 -1
  183. package/dist/plugins/Plugin.js +33 -0
  184. package/dist/plugins/analysis/DatabaseAnalyzer.d.ts.map +1 -1
  185. package/dist/plugins/analysis/DatabaseAnalyzer.js +14 -6
  186. package/dist/plugins/analysis/ExpressAnalyzer.d.ts.map +1 -1
  187. package/dist/plugins/analysis/ExpressAnalyzer.js +29 -19
  188. package/dist/plugins/analysis/ExpressResponseAnalyzer.d.ts +148 -0
  189. package/dist/plugins/analysis/ExpressResponseAnalyzer.d.ts.map +1 -0
  190. package/dist/plugins/analysis/ExpressResponseAnalyzer.js +495 -0
  191. package/dist/plugins/analysis/ExpressRouteAnalyzer.d.ts.map +1 -1
  192. package/dist/plugins/analysis/ExpressRouteAnalyzer.js +71 -29
  193. package/dist/plugins/analysis/FetchAnalyzer.d.ts +41 -0
  194. package/dist/plugins/analysis/FetchAnalyzer.d.ts.map +1 -1
  195. package/dist/plugins/analysis/FetchAnalyzer.js +187 -19
  196. package/dist/plugins/analysis/IncrementalAnalysisPlugin.d.ts +6 -3
  197. package/dist/plugins/analysis/IncrementalAnalysisPlugin.d.ts.map +1 -1
  198. package/dist/plugins/analysis/IncrementalAnalysisPlugin.js +76 -80
  199. package/dist/plugins/analysis/JSASTAnalyzer.d.ts +313 -19
  200. package/dist/plugins/analysis/JSASTAnalyzer.d.ts.map +1 -1
  201. package/dist/plugins/analysis/JSASTAnalyzer.js +3430 -503
  202. package/dist/plugins/analysis/ReactAnalyzer.d.ts.map +1 -1
  203. package/dist/plugins/analysis/ReactAnalyzer.js +56 -57
  204. package/dist/plugins/analysis/RustAnalyzer.d.ts.map +1 -1
  205. package/dist/plugins/analysis/RustAnalyzer.js +16 -11
  206. package/dist/plugins/analysis/SQLiteAnalyzer.d.ts.map +1 -1
  207. package/dist/plugins/analysis/SQLiteAnalyzer.js +11 -7
  208. package/dist/plugins/analysis/ServiceLayerAnalyzer.d.ts.map +1 -1
  209. package/dist/plugins/analysis/ServiceLayerAnalyzer.js +21 -9
  210. package/dist/plugins/analysis/SocketIOAnalyzer.d.ts +9 -0
  211. package/dist/plugins/analysis/SocketIOAnalyzer.d.ts.map +1 -1
  212. package/dist/plugins/analysis/SocketIOAnalyzer.js +117 -21
  213. package/dist/plugins/analysis/SystemDbAnalyzer.d.ts.map +1 -1
  214. package/dist/plugins/analysis/SystemDbAnalyzer.js +15 -5
  215. package/dist/plugins/analysis/ast/GraphBuilder.d.ts +207 -4
  216. package/dist/plugins/analysis/ast/GraphBuilder.d.ts.map +1 -1
  217. package/dist/plugins/analysis/ast/GraphBuilder.js +1527 -316
  218. package/dist/plugins/analysis/ast/IdGenerator.d.ts +105 -0
  219. package/dist/plugins/analysis/ast/IdGenerator.d.ts.map +1 -0
  220. package/dist/plugins/analysis/ast/IdGenerator.js +116 -0
  221. package/dist/plugins/analysis/ast/types.d.ts +470 -5
  222. package/dist/plugins/analysis/ast/types.d.ts.map +1 -1
  223. package/dist/plugins/analysis/ast/utils/createParameterNodes.d.ts +33 -0
  224. package/dist/plugins/analysis/ast/utils/createParameterNodes.d.ts.map +1 -0
  225. package/dist/plugins/analysis/ast/utils/createParameterNodes.js +89 -0
  226. package/dist/plugins/analysis/ast/utils/index.d.ts +6 -0
  227. package/dist/plugins/analysis/ast/utils/index.d.ts.map +1 -0
  228. package/dist/plugins/analysis/ast/utils/index.js +5 -0
  229. package/dist/plugins/analysis/ast/utils/location.d.ts +87 -0
  230. package/dist/plugins/analysis/ast/utils/location.d.ts.map +1 -0
  231. package/dist/plugins/analysis/ast/utils/location.js +78 -0
  232. package/dist/plugins/analysis/ast/visitors/ASTVisitor.d.ts +14 -5
  233. package/dist/plugins/analysis/ast/visitors/ASTVisitor.d.ts.map +1 -1
  234. package/dist/plugins/analysis/ast/visitors/ASTVisitor.js +6 -5
  235. package/dist/plugins/analysis/ast/visitors/CallExpressionVisitor.d.ts +100 -9
  236. package/dist/plugins/analysis/ast/visitors/CallExpressionVisitor.d.ts.map +1 -1
  237. package/dist/plugins/analysis/ast/visitors/CallExpressionVisitor.js +674 -125
  238. package/dist/plugins/analysis/ast/visitors/ClassVisitor.d.ts +4 -1
  239. package/dist/plugins/analysis/ast/visitors/ClassVisitor.d.ts.map +1 -1
  240. package/dist/plugins/analysis/ast/visitors/ClassVisitor.js +72 -32
  241. package/dist/plugins/analysis/ast/visitors/FunctionVisitor.d.ts +14 -1
  242. package/dist/plugins/analysis/ast/visitors/FunctionVisitor.d.ts.map +1 -1
  243. package/dist/plugins/analysis/ast/visitors/FunctionVisitor.js +190 -63
  244. package/dist/plugins/analysis/ast/visitors/ImportExportVisitor.d.ts +4 -0
  245. package/dist/plugins/analysis/ast/visitors/ImportExportVisitor.d.ts.map +1 -1
  246. package/dist/plugins/analysis/ast/visitors/ImportExportVisitor.js +112 -8
  247. package/dist/plugins/analysis/ast/visitors/TypeScriptVisitor.d.ts +12 -1
  248. package/dist/plugins/analysis/ast/visitors/TypeScriptVisitor.d.ts.map +1 -1
  249. package/dist/plugins/analysis/ast/visitors/TypeScriptVisitor.js +36 -14
  250. package/dist/plugins/analysis/ast/visitors/VariableVisitor.d.ts +20 -2
  251. package/dist/plugins/analysis/ast/visitors/VariableVisitor.d.ts.map +1 -1
  252. package/dist/plugins/analysis/ast/visitors/VariableVisitor.js +243 -45
  253. package/dist/plugins/discovery/MonorepoServiceDiscovery.d.ts.map +1 -1
  254. package/dist/plugins/discovery/MonorepoServiceDiscovery.js +3 -2
  255. package/dist/plugins/discovery/SimpleProjectDiscovery.d.ts.map +1 -1
  256. package/dist/plugins/discovery/SimpleProjectDiscovery.js +5 -1
  257. package/dist/plugins/discovery/WorkspaceDiscovery.d.ts +22 -0
  258. package/dist/plugins/discovery/WorkspaceDiscovery.d.ts.map +1 -0
  259. package/dist/plugins/discovery/WorkspaceDiscovery.js +141 -0
  260. package/dist/plugins/discovery/resolveSourceEntrypoint.d.ts +46 -0
  261. package/dist/plugins/discovery/resolveSourceEntrypoint.d.ts.map +1 -0
  262. package/dist/plugins/discovery/resolveSourceEntrypoint.js +86 -0
  263. package/dist/plugins/discovery/workspaces/detector.d.ts +21 -0
  264. package/dist/plugins/discovery/workspaces/detector.d.ts.map +1 -0
  265. package/dist/plugins/discovery/workspaces/detector.js +49 -0
  266. package/dist/plugins/discovery/workspaces/globResolver.d.ts +35 -0
  267. package/dist/plugins/discovery/workspaces/globResolver.d.ts.map +1 -0
  268. package/dist/plugins/discovery/workspaces/globResolver.js +184 -0
  269. package/dist/plugins/discovery/workspaces/index.d.ts +9 -0
  270. package/dist/plugins/discovery/workspaces/index.d.ts.map +1 -0
  271. package/dist/plugins/discovery/workspaces/index.js +8 -0
  272. package/dist/plugins/discovery/workspaces/parsers.d.ts +38 -0
  273. package/dist/plugins/discovery/workspaces/parsers.d.ts.map +1 -0
  274. package/dist/plugins/discovery/workspaces/parsers.js +80 -0
  275. package/dist/plugins/enrichment/AliasTracker.d.ts.map +1 -1
  276. package/dist/plugins/enrichment/AliasTracker.js +29 -8
  277. package/dist/plugins/enrichment/ArgumentParameterLinker.d.ts +32 -0
  278. package/dist/plugins/enrichment/ArgumentParameterLinker.d.ts.map +1 -0
  279. package/dist/plugins/enrichment/ArgumentParameterLinker.js +175 -0
  280. package/dist/plugins/enrichment/ClosureCaptureEnricher.d.ts +51 -0
  281. package/dist/plugins/enrichment/ClosureCaptureEnricher.d.ts.map +1 -0
  282. package/dist/plugins/enrichment/ClosureCaptureEnricher.js +205 -0
  283. package/dist/plugins/enrichment/ExternalCallResolver.d.ts +42 -0
  284. package/dist/plugins/enrichment/ExternalCallResolver.d.ts.map +1 -0
  285. package/dist/plugins/enrichment/ExternalCallResolver.js +213 -0
  286. package/dist/plugins/enrichment/FunctionCallResolver.d.ts +58 -0
  287. package/dist/plugins/enrichment/FunctionCallResolver.d.ts.map +1 -0
  288. package/dist/plugins/enrichment/FunctionCallResolver.js +340 -0
  289. package/dist/plugins/enrichment/HTTPConnectionEnricher.d.ts +16 -3
  290. package/dist/plugins/enrichment/HTTPConnectionEnricher.d.ts.map +1 -1
  291. package/dist/plugins/enrichment/HTTPConnectionEnricher.js +78 -27
  292. package/dist/plugins/enrichment/ImportExportLinker.d.ts.map +1 -1
  293. package/dist/plugins/enrichment/ImportExportLinker.js +23 -6
  294. package/dist/plugins/enrichment/MethodCallResolver.d.ts.map +1 -1
  295. package/dist/plugins/enrichment/MethodCallResolver.js +33 -13
  296. package/dist/plugins/enrichment/MountPointResolver.d.ts +14 -12
  297. package/dist/plugins/enrichment/MountPointResolver.d.ts.map +1 -1
  298. package/dist/plugins/enrichment/MountPointResolver.js +173 -147
  299. package/dist/plugins/enrichment/NodejsBuiltinsResolver.d.ts +44 -0
  300. package/dist/plugins/enrichment/NodejsBuiltinsResolver.d.ts.map +1 -0
  301. package/dist/plugins/enrichment/NodejsBuiltinsResolver.js +271 -0
  302. package/dist/plugins/enrichment/PrefixEvaluator.d.ts.map +1 -1
  303. package/dist/plugins/enrichment/PrefixEvaluator.js +16 -7
  304. package/dist/plugins/enrichment/RustFFIEnricher.d.ts.map +1 -1
  305. package/dist/plugins/enrichment/RustFFIEnricher.js +6 -5
  306. package/dist/plugins/enrichment/ValueDomainAnalyzer.d.ts +22 -27
  307. package/dist/plugins/enrichment/ValueDomainAnalyzer.d.ts.map +1 -1
  308. package/dist/plugins/enrichment/ValueDomainAnalyzer.js +185 -143
  309. package/dist/plugins/indexing/IncrementalModuleIndexer.d.ts.map +1 -1
  310. package/dist/plugins/indexing/IncrementalModuleIndexer.js +23 -14
  311. package/dist/plugins/indexing/JSModuleIndexer.d.ts +15 -0
  312. package/dist/plugins/indexing/JSModuleIndexer.d.ts.map +1 -1
  313. package/dist/plugins/indexing/JSModuleIndexer.js +121 -31
  314. package/dist/plugins/indexing/RustModuleIndexer.d.ts +1 -1
  315. package/dist/plugins/indexing/RustModuleIndexer.d.ts.map +1 -1
  316. package/dist/plugins/indexing/RustModuleIndexer.js +8 -7
  317. package/dist/plugins/indexing/ServiceDetector.d.ts +10 -0
  318. package/dist/plugins/indexing/ServiceDetector.d.ts.map +1 -1
  319. package/dist/plugins/indexing/ServiceDetector.js +28 -15
  320. package/dist/plugins/validation/BrokenImportValidator.d.ts +31 -0
  321. package/dist/plugins/validation/BrokenImportValidator.d.ts.map +1 -0
  322. package/dist/plugins/validation/BrokenImportValidator.js +249 -0
  323. package/dist/plugins/validation/CallResolverValidator.d.ts +21 -10
  324. package/dist/plugins/validation/CallResolverValidator.d.ts.map +1 -1
  325. package/dist/plugins/validation/CallResolverValidator.js +103 -77
  326. package/dist/plugins/validation/DataFlowValidator.d.ts.map +1 -1
  327. package/dist/plugins/validation/DataFlowValidator.js +62 -49
  328. package/dist/plugins/validation/EvalBanValidator.d.ts.map +1 -1
  329. package/dist/plugins/validation/EvalBanValidator.js +17 -16
  330. package/dist/plugins/validation/GraphConnectivityValidator.d.ts.map +1 -1
  331. package/dist/plugins/validation/GraphConnectivityValidator.js +44 -24
  332. package/dist/plugins/validation/NodeCreationValidator.d.ts +85 -0
  333. package/dist/plugins/validation/NodeCreationValidator.d.ts.map +1 -0
  334. package/dist/plugins/validation/NodeCreationValidator.js +415 -0
  335. package/dist/plugins/validation/SQLInjectionValidator.d.ts.map +1 -1
  336. package/dist/plugins/validation/SQLInjectionValidator.js +61 -19
  337. package/dist/plugins/validation/ShadowingDetector.d.ts.map +1 -1
  338. package/dist/plugins/validation/ShadowingDetector.js +6 -5
  339. package/dist/plugins/validation/TypeScriptDeadCodeValidator.d.ts.map +1 -1
  340. package/dist/plugins/validation/TypeScriptDeadCodeValidator.js +12 -11
  341. package/dist/plugins/vcs/GitPlugin.d.ts.map +1 -1
  342. package/dist/plugins/vcs/GitPlugin.js +10 -12
  343. package/dist/plugins/vcs/VCSPlugin.d.ts +3 -2
  344. package/dist/plugins/vcs/VCSPlugin.d.ts.map +1 -1
  345. package/dist/plugins/vcs/VCSPlugin.js +5 -5
  346. package/dist/queries/findCallsInFunction.d.ts +52 -0
  347. package/dist/queries/findCallsInFunction.d.ts.map +1 -0
  348. package/dist/queries/findCallsInFunction.js +135 -0
  349. package/dist/queries/findContainingFunction.d.ts +45 -0
  350. package/dist/queries/findContainingFunction.d.ts.map +1 -0
  351. package/dist/queries/findContainingFunction.js +54 -0
  352. package/dist/queries/index.d.ts +14 -0
  353. package/dist/queries/index.d.ts.map +1 -0
  354. package/dist/queries/index.js +11 -0
  355. package/dist/queries/traceValues.d.ts +70 -0
  356. package/dist/queries/traceValues.d.ts.map +1 -0
  357. package/dist/queries/traceValues.js +299 -0
  358. package/dist/queries/types.d.ts +163 -0
  359. package/dist/queries/types.d.ts.map +1 -0
  360. package/dist/queries/types.js +9 -0
  361. package/dist/schema/GraphSchemaExtractor.d.ts +53 -0
  362. package/dist/schema/GraphSchemaExtractor.d.ts.map +1 -0
  363. package/dist/schema/GraphSchemaExtractor.js +124 -0
  364. package/dist/schema/InterfaceSchemaExtractor.d.ts +73 -0
  365. package/dist/schema/InterfaceSchemaExtractor.d.ts.map +1 -0
  366. package/dist/schema/InterfaceSchemaExtractor.js +112 -0
  367. package/dist/schema/index.d.ts +5 -0
  368. package/dist/schema/index.d.ts.map +1 -0
  369. package/dist/schema/index.js +2 -0
  370. package/dist/storage/backends/RFDBServerBackend.d.ts +21 -34
  371. package/dist/storage/backends/RFDBServerBackend.d.ts.map +1 -1
  372. package/dist/storage/backends/RFDBServerBackend.js +72 -62
  373. package/dist/storage/backends/typeValidation.d.ts.map +1 -1
  374. package/dist/storage/backends/typeValidation.js +1 -0
  375. package/dist/validation/PathValidator.d.ts +1 -2
  376. package/dist/validation/PathValidator.d.ts.map +1 -1
  377. package/package.json +3 -3
  378. package/src/Orchestrator.ts +272 -27
  379. package/src/config/ConfigLoader.ts +354 -0
  380. package/src/config/index.ts +5 -0
  381. package/src/core/ASTWorker.ts +143 -139
  382. package/src/core/CoverageAnalyzer.ts +243 -0
  383. package/src/core/FileExplainer.ts +179 -0
  384. package/src/core/FileNodeManager.ts +100 -0
  385. package/src/core/GraphFreshnessChecker.ts +143 -0
  386. package/src/core/HashUtils.ts +48 -0
  387. package/src/core/IncrementalReanalyzer.ts +192 -0
  388. package/src/core/NodeFactory.ts +470 -23
  389. package/src/core/ScopeTracker.ts +154 -0
  390. package/src/core/SemanticId.ts +192 -0
  391. package/src/core/VersionManager.ts +3 -2
  392. package/src/core/nodes/ArgumentExpressionNode.ts +89 -0
  393. package/src/core/nodes/ArrayLiteralNode.ts +66 -0
  394. package/src/core/nodes/BranchNode.ts +113 -0
  395. package/src/core/nodes/CallSiteNode.ts +64 -4
  396. package/src/core/nodes/CaseNode.ts +123 -0
  397. package/src/core/nodes/ClassNode.ts +67 -4
  398. package/src/core/nodes/ConstantNode.ts +5 -4
  399. package/src/core/nodes/ConstructorCallNode.ts +217 -0
  400. package/src/core/nodes/DatabaseQueryNode.ts +5 -1
  401. package/src/core/nodes/DecoratorNode.ts +92 -0
  402. package/src/core/nodes/EnumNode.ts +87 -0
  403. package/src/core/nodes/EventListenerNode.ts +7 -4
  404. package/src/core/nodes/ExportNode.ts +74 -4
  405. package/src/core/nodes/ExpressionNode.ts +232 -0
  406. package/src/core/nodes/ExternalModuleNode.ts +65 -0
  407. package/src/core/nodes/ExternalStdioNode.ts +17 -9
  408. package/src/core/nodes/FunctionNode.ts +101 -1
  409. package/src/core/nodes/HttpRequestNode.ts +7 -4
  410. package/src/core/nodes/ImportNode.ts +62 -13
  411. package/src/core/nodes/InterfaceNode.ts +92 -0
  412. package/src/core/nodes/IssueNode.ts +177 -0
  413. package/src/core/nodes/LiteralNode.ts +5 -4
  414. package/src/core/nodes/MethodCallNode.ts +70 -4
  415. package/src/core/nodes/MethodNode.ts +68 -3
  416. package/src/core/nodes/ModuleNode.ts +50 -0
  417. package/src/core/nodes/NetworkRequestNode.ts +77 -0
  418. package/src/core/nodes/ObjectLiteralNode.ts +66 -0
  419. package/src/core/nodes/ParameterNode.ts +4 -3
  420. package/src/core/nodes/ScopeNode.ts +65 -0
  421. package/src/core/nodes/TypeNode.ts +79 -0
  422. package/src/core/nodes/VariableDeclarationNode.ts +58 -4
  423. package/src/core/nodes/index.ts +21 -1
  424. package/src/data/builtins/BuiltinRegistry.ts +124 -0
  425. package/src/data/builtins/definitions.ts +267 -0
  426. package/src/data/builtins/index.ts +10 -0
  427. package/src/data/builtins/jsGlobals.ts +28 -0
  428. package/src/data/builtins/types.ts +36 -0
  429. package/src/data/globals/definitions.ts +156 -0
  430. package/src/data/globals/index.ts +66 -0
  431. package/src/diagnostics/DiagnosticCollector.ts +163 -0
  432. package/src/diagnostics/DiagnosticReporter.ts +324 -0
  433. package/src/diagnostics/DiagnosticWriter.ts +50 -0
  434. package/src/diagnostics/index.ts +16 -0
  435. package/src/errors/GrafemaError.ts +239 -0
  436. package/src/index.ts +193 -1
  437. package/src/logging/Logger.ts +152 -0
  438. package/src/plugins/Plugin.ts +42 -0
  439. package/src/plugins/analysis/DatabaseAnalyzer.ts +16 -8
  440. package/src/plugins/analysis/ExpressAnalyzer.ts +33 -19
  441. package/src/plugins/analysis/ExpressResponseAnalyzer.ts +636 -0
  442. package/src/plugins/analysis/ExpressRouteAnalyzer.ts +76 -36
  443. package/src/plugins/analysis/FetchAnalyzer.ts +232 -21
  444. package/src/plugins/analysis/IncrementalAnalysisPlugin.ts +84 -101
  445. package/src/plugins/analysis/JSASTAnalyzer.ts +4265 -587
  446. package/src/plugins/analysis/ReactAnalyzer.ts +57 -57
  447. package/src/plugins/analysis/RustAnalyzer.ts +16 -11
  448. package/src/plugins/analysis/SQLiteAnalyzer.ts +13 -7
  449. package/src/plugins/analysis/ServiceLayerAnalyzer.ts +22 -16
  450. package/src/plugins/analysis/SocketIOAnalyzer.ts +151 -28
  451. package/src/plugins/analysis/SystemDbAnalyzer.ts +16 -11
  452. package/src/plugins/analysis/ast/GraphBuilder.ts +1947 -327
  453. package/src/plugins/analysis/ast/IdGenerator.ts +177 -0
  454. package/src/plugins/analysis/ast/types.ts +596 -6
  455. package/src/plugins/analysis/ast/utils/createParameterNodes.ts +104 -0
  456. package/src/plugins/analysis/ast/utils/index.ts +12 -0
  457. package/src/plugins/analysis/ast/utils/location.ts +103 -0
  458. package/src/plugins/analysis/ast/visitors/ASTVisitor.ts +19 -8
  459. package/src/plugins/analysis/ast/visitors/CallExpressionVisitor.ts +924 -83
  460. package/src/plugins/analysis/ast/visitors/ClassVisitor.ts +97 -44
  461. package/src/plugins/analysis/ast/visitors/FunctionVisitor.ts +234 -93
  462. package/src/plugins/analysis/ast/visitors/ImportExportVisitor.ts +124 -9
  463. package/src/plugins/analysis/ast/visitors/TypeScriptVisitor.ts +41 -14
  464. package/src/plugins/analysis/ast/visitors/VariableVisitor.ts +294 -49
  465. package/src/plugins/discovery/MonorepoServiceDiscovery.ts +3 -2
  466. package/src/plugins/discovery/SimpleProjectDiscovery.ts +6 -1
  467. package/src/plugins/discovery/WorkspaceDiscovery.ts +184 -0
  468. package/src/plugins/discovery/resolveSourceEntrypoint.ts +103 -0
  469. package/src/plugins/discovery/workspaces/detector.ts +63 -0
  470. package/src/plugins/discovery/workspaces/globResolver.ts +229 -0
  471. package/src/plugins/discovery/workspaces/index.ts +23 -0
  472. package/src/plugins/discovery/workspaces/parsers.ts +99 -0
  473. package/src/plugins/enrichment/AliasTracker.ts +35 -8
  474. package/src/plugins/enrichment/ArgumentParameterLinker.ts +240 -0
  475. package/src/plugins/enrichment/ClosureCaptureEnricher.ts +267 -0
  476. package/src/plugins/enrichment/ExternalCallResolver.ts +262 -0
  477. package/src/plugins/enrichment/FunctionCallResolver.ts +456 -0
  478. package/src/plugins/enrichment/HTTPConnectionEnricher.ts +84 -27
  479. package/src/plugins/enrichment/ImportExportLinker.ts +24 -6
  480. package/src/plugins/enrichment/MethodCallResolver.ts +39 -13
  481. package/src/plugins/enrichment/MountPointResolver.ts +208 -195
  482. package/src/plugins/enrichment/NodejsBuiltinsResolver.ts +365 -0
  483. package/src/plugins/enrichment/PrefixEvaluator.ts +16 -7
  484. package/src/plugins/enrichment/RustFFIEnricher.ts +6 -5
  485. package/src/plugins/enrichment/ValueDomainAnalyzer.ts +209 -189
  486. package/src/plugins/indexing/IncrementalModuleIndexer.ts +23 -14
  487. package/src/plugins/indexing/JSModuleIndexer.ts +140 -34
  488. package/src/plugins/indexing/RustModuleIndexer.ts +8 -7
  489. package/src/plugins/validation/BrokenImportValidator.ts +325 -0
  490. package/src/plugins/validation/CallResolverValidator.ts +131 -110
  491. package/src/plugins/validation/DataFlowValidator.ts +88 -67
  492. package/src/plugins/validation/EvalBanValidator.ts +17 -16
  493. package/src/plugins/validation/GraphConnectivityValidator.ts +58 -24
  494. package/src/plugins/validation/NodeCreationValidator.ts +554 -0
  495. package/src/plugins/validation/SQLInjectionValidator.ts +63 -20
  496. package/src/plugins/validation/ShadowingDetector.ts +6 -5
  497. package/src/plugins/validation/TypeScriptDeadCodeValidator.ts +12 -11
  498. package/src/plugins/vcs/GitPlugin.ts +40 -12
  499. package/src/plugins/vcs/VCSPlugin.ts +7 -5
  500. package/src/queries/README.md +46 -0
  501. package/src/queries/findCallsInFunction.ts +206 -0
  502. package/src/queries/findContainingFunction.ts +83 -0
  503. package/src/queries/index.ts +23 -0
  504. package/src/queries/traceValues.ts +398 -0
  505. package/src/queries/types.ts +187 -0
  506. package/src/schema/GraphSchemaExtractor.ts +177 -0
  507. package/src/schema/InterfaceSchemaExtractor.ts +173 -0
  508. package/src/schema/index.ts +5 -0
  509. package/src/storage/backends/RFDBServerBackend.ts +100 -98
  510. package/src/storage/backends/typeValidation.ts +1 -0
  511. package/src/validation/PathValidator.ts +1 -1
  512. package/dist/core/AnalysisWorker.d.ts +0 -14
  513. package/dist/core/AnalysisWorker.d.ts.map +0 -1
  514. package/dist/core/AnalysisWorker.js +0 -307
  515. package/dist/core/ParallelAnalyzer.d.ts +0 -120
  516. package/dist/core/ParallelAnalyzer.d.ts.map +0 -1
  517. package/dist/core/ParallelAnalyzer.js +0 -331
  518. package/dist/core/QueueWorker.d.ts +0 -12
  519. package/dist/core/QueueWorker.d.ts.map +0 -1
  520. package/dist/core/QueueWorker.js +0 -567
  521. package/dist/core/RFDBClient.d.ts +0 -179
  522. package/dist/core/RFDBClient.d.ts.map +0 -1
  523. package/dist/core/RFDBClient.js +0 -429
  524. package/dist/plugins/discovery/ZonServiceDiscovery.d.ts +0 -19
  525. package/dist/plugins/discovery/ZonServiceDiscovery.d.ts.map +0 -1
  526. package/dist/plugins/discovery/ZonServiceDiscovery.js +0 -204
  527. package/src/core/AnalysisWorker.ts +0 -410
  528. package/src/core/ParallelAnalyzer.ts +0 -476
  529. package/src/core/QueueWorker.ts +0 -780
  530. package/src/plugins/indexing/ServiceDetector.ts +0 -230
@@ -0,0 +1,83 @@
1
+ /**
2
+ * Find the FUNCTION, CLASS, or MODULE that contains a node.
3
+ *
4
+ * Graph structure (backward traversal):
5
+ * ```
6
+ * CALL <- CONTAINS <- SCOPE <- ... <- SCOPE <- HAS_SCOPE <- FUNCTION
7
+ * VARIABLE <- DECLARES <- SCOPE <- ... <- SCOPE <- HAS_SCOPE <- FUNCTION
8
+ * ```
9
+ *
10
+ * Algorithm:
11
+ * 1. BFS up the containment tree via CONTAINS and DECLARES edges
12
+ * 2. Also follow HAS_SCOPE edges (connects FUNCTION to its body SCOPE)
13
+ * 3. Stop when we find FUNCTION, CLASS, or MODULE
14
+ *
15
+ * @module queries/findContainingFunction
16
+ */
17
+
18
+ import type { CallerInfo } from './types.js';
19
+
20
+ /**
21
+ * Graph backend interface (minimal surface)
22
+ */
23
+ interface GraphBackend {
24
+ getNode(id: string): Promise<{
25
+ id: string;
26
+ type: string;
27
+ name: string;
28
+ file?: string;
29
+ line?: number;
30
+ } | null>;
31
+ getIncomingEdges(
32
+ nodeId: string,
33
+ edgeTypes: string[] | null
34
+ ): Promise<Array<{ src: string; dst: string; type: string }>>;
35
+ }
36
+
37
+ /**
38
+ * Find the FUNCTION, CLASS, or MODULE that contains a node.
39
+ *
40
+ * @param backend - Graph backend for queries
41
+ * @param nodeId - ID of the node to find container for
42
+ * @param maxDepth - Maximum traversal depth (default: 15)
43
+ * @returns CallerInfo or null if no container found
44
+ */
45
+ export async function findContainingFunction(
46
+ backend: GraphBackend,
47
+ nodeId: string,
48
+ maxDepth: number = 15
49
+ ): Promise<CallerInfo | null> {
50
+ const visited = new Set<string>();
51
+ const queue: Array<{ id: string; depth: number }> = [{ id: nodeId, depth: 0 }];
52
+
53
+ while (queue.length > 0) {
54
+ const { id, depth } = queue.shift()!;
55
+
56
+ if (visited.has(id) || depth > maxDepth) continue;
57
+ visited.add(id);
58
+
59
+ // Get incoming edges: CONTAINS, HAS_SCOPE, and DECLARES (for variables)
60
+ const edges = await backend.getIncomingEdges(id, ['CONTAINS', 'HAS_SCOPE', 'DECLARES']);
61
+
62
+ for (const edge of edges) {
63
+ const parentNode = await backend.getNode(edge.src);
64
+ if (!parentNode || visited.has(parentNode.id)) continue;
65
+
66
+ // Found container!
67
+ if (parentNode.type === 'FUNCTION' || parentNode.type === 'CLASS' || parentNode.type === 'MODULE') {
68
+ return {
69
+ id: parentNode.id,
70
+ name: parentNode.name || '<anonymous>',
71
+ type: parentNode.type,
72
+ file: parentNode.file,
73
+ line: parentNode.line,
74
+ };
75
+ }
76
+
77
+ // Continue searching
78
+ queue.push({ id: parentNode.id, depth: depth + 1 });
79
+ }
80
+ }
81
+
82
+ return null;
83
+ }
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Graph Query Utilities
3
+ *
4
+ * Shared utilities for querying the code graph.
5
+ * Used by MCP, CLI, and other tools.
6
+ *
7
+ * @module queries
8
+ */
9
+
10
+ export { findCallsInFunction } from './findCallsInFunction.js';
11
+ export { findContainingFunction } from './findContainingFunction.js';
12
+ export { traceValues, aggregateValues, NONDETERMINISTIC_PATTERNS, NONDETERMINISTIC_OBJECTS } from './traceValues.js';
13
+
14
+ export type { CallInfo, CallerInfo, FindCallsOptions } from './types.js';
15
+ export type {
16
+ TracedValue,
17
+ ValueSource,
18
+ UnknownReason,
19
+ TraceValuesOptions,
20
+ ValueSetResult,
21
+ TraceValuesGraphBackend,
22
+ NondeterministicPattern,
23
+ } from './types.js';
@@ -0,0 +1,398 @@
1
+ /**
2
+ * Value Tracing Utility (REG-244)
3
+ *
4
+ * Traces a node through ASSIGNED_FROM/DERIVES_FROM edges to find
5
+ * all possible literal values or mark as unknown.
6
+ *
7
+ * Graph structure:
8
+ * ```
9
+ * VARIABLE -[ASSIGNED_FROM]-> LITERAL (concrete value)
10
+ * VARIABLE -[ASSIGNED_FROM]-> PARAMETER (unknown: runtime input)
11
+ * VARIABLE -[ASSIGNED_FROM]-> CALL (unknown: function return)
12
+ * VARIABLE -[DERIVES_FROM]-> EXPRESSION (check nondeterministic patterns)
13
+ * VARIABLE -[ASSIGNED_FROM]-> VARIABLE (chain - recurse)
14
+ * ```
15
+ *
16
+ * Used by:
17
+ * - CLI trace command (sink-based tracing)
18
+ * - ValueDomainAnalyzer (computed member access resolution)
19
+ *
20
+ * @module queries/traceValues
21
+ */
22
+
23
+ import type {
24
+ TracedValue,
25
+ TraceValuesOptions,
26
+ TraceValuesGraphBackend,
27
+ ValueSetResult,
28
+ NondeterministicPattern,
29
+ UnknownReason,
30
+ } from './types.js';
31
+
32
+ // =============================================================================
33
+ // NONDETERMINISTIC PATTERNS (moved from ValueDomainAnalyzer)
34
+ // =============================================================================
35
+
36
+ /**
37
+ * Nondeterministic MemberExpression patterns.
38
+ * object.property combinations that represent external/user input.
39
+ */
40
+ export const NONDETERMINISTIC_PATTERNS: NondeterministicPattern[] = [
41
+ // Environment variables
42
+ { object: 'process', property: 'env' },
43
+ // HTTP request data (Express.js patterns)
44
+ { object: 'req', property: 'body' },
45
+ { object: 'req', property: 'query' },
46
+ { object: 'req', property: 'params' },
47
+ { object: 'req', property: 'headers' },
48
+ { object: 'req', property: 'cookies' },
49
+ { object: 'request', property: 'body' },
50
+ { object: 'request', property: 'query' },
51
+ { object: 'request', property: 'params' },
52
+ // Context patterns (Koa, etc.)
53
+ { object: 'ctx', property: 'request' },
54
+ { object: 'ctx', property: 'body' },
55
+ { object: 'ctx', property: 'query' },
56
+ { object: 'ctx', property: 'params' },
57
+ ];
58
+
59
+ /**
60
+ * Nondeterministic object prefixes.
61
+ * Any property access on these is nondeterministic.
62
+ */
63
+ export const NONDETERMINISTIC_OBJECTS: string[] = [
64
+ 'process.env', // process.env.ANY_VAR
65
+ 'req.body', // req.body.userId
66
+ 'req.query', // req.query.filter
67
+ 'req.params', // req.params.id
68
+ 'request.body',
69
+ 'ctx.request',
70
+ ];
71
+
72
+ // =============================================================================
73
+ // MAIN FUNCTION
74
+ // =============================================================================
75
+
76
+ /**
77
+ * Trace a node to all its possible literal values.
78
+ *
79
+ * Starting from the given node, follows ASSIGNED_FROM (and optionally
80
+ * DERIVES_FROM) edges backwards to find:
81
+ * - LITERAL nodes: concrete values
82
+ * - PARAMETER nodes: runtime inputs (unknown)
83
+ * - CALL nodes: function return values (unknown)
84
+ * - EXPRESSION nodes: checks for nondeterministic patterns
85
+ *
86
+ * @param backend - Graph backend for queries
87
+ * @param nodeId - Starting node ID
88
+ * @param options - Traversal options
89
+ * @returns Array of traced values with sources
90
+ *
91
+ * @example
92
+ * const values = await traceValues(backend, variableId);
93
+ * for (const v of values) {
94
+ * if (v.isUnknown) {
95
+ * console.log(`Unknown from ${v.source.file}:${v.source.line} (${v.reason})`);
96
+ * } else {
97
+ * console.log(`Value: ${v.value} from ${v.source.file}:${v.source.line}`);
98
+ * }
99
+ * }
100
+ */
101
+ export async function traceValues(
102
+ backend: TraceValuesGraphBackend,
103
+ nodeId: string,
104
+ options?: TraceValuesOptions
105
+ ): Promise<TracedValue[]> {
106
+ const results: TracedValue[] = [];
107
+ const visited = new Set<string>();
108
+
109
+ const maxDepth = options?.maxDepth ?? 10;
110
+ const followDerivesFrom = options?.followDerivesFrom ?? true;
111
+ const detectNondeterministic = options?.detectNondeterministic ?? true;
112
+
113
+ await traceRecursive(
114
+ backend,
115
+ nodeId,
116
+ visited,
117
+ 0,
118
+ maxDepth,
119
+ followDerivesFrom,
120
+ detectNondeterministic,
121
+ results
122
+ );
123
+
124
+ return results;
125
+ }
126
+
127
+ /**
128
+ * Recursive tracing function
129
+ */
130
+ async function traceRecursive(
131
+ backend: TraceValuesGraphBackend,
132
+ nodeId: string,
133
+ visited: Set<string>,
134
+ depth: number,
135
+ maxDepth: number,
136
+ followDerivesFrom: boolean,
137
+ detectNondeterministic: boolean,
138
+ results: TracedValue[]
139
+ ): Promise<void> {
140
+ // Cycle protection
141
+ if (visited.has(nodeId)) {
142
+ return;
143
+ }
144
+ visited.add(nodeId);
145
+
146
+ // Get node
147
+ const node = await backend.getNode(nodeId);
148
+ if (!node) {
149
+ return;
150
+ }
151
+
152
+ const nodeType = node.type || node.nodeType;
153
+ const source = {
154
+ id: node.id,
155
+ file: node.file || '',
156
+ line: node.line || 0,
157
+ };
158
+
159
+ // Depth protection - check after getting node for source info
160
+ if (depth > maxDepth) {
161
+ results.push({
162
+ value: undefined,
163
+ source,
164
+ isUnknown: true,
165
+ reason: 'max_depth',
166
+ });
167
+ return;
168
+ }
169
+
170
+ // Terminal: LITERAL - found concrete value
171
+ if (nodeType === 'LITERAL') {
172
+ results.push({
173
+ value: node.value,
174
+ source,
175
+ isUnknown: false,
176
+ });
177
+ return;
178
+ }
179
+
180
+ // Terminal: PARAMETER - runtime input
181
+ if (nodeType === 'PARAMETER') {
182
+ results.push({
183
+ value: undefined,
184
+ source,
185
+ isUnknown: true,
186
+ reason: 'parameter',
187
+ });
188
+ return;
189
+ }
190
+
191
+ // Terminal: CALL / METHOD_CALL - function return value
192
+ if (nodeType === 'CALL' || nodeType === 'METHOD_CALL') {
193
+ // Check for HTTP_RECEIVES edges (cross-service data flow)
194
+ const httpEdges = await backend.getOutgoingEdges(nodeId, ['HTTP_RECEIVES']);
195
+
196
+ if (httpEdges.length > 0) {
197
+ // Follow HTTP boundary to backend response
198
+ for (const edge of httpEdges) {
199
+ await traceRecursive(
200
+ backend,
201
+ edge.dst,
202
+ visited,
203
+ depth + 1,
204
+ maxDepth,
205
+ followDerivesFrom,
206
+ detectNondeterministic,
207
+ results
208
+ );
209
+ }
210
+ return; // Traced through HTTP boundary, don't mark as unknown
211
+ }
212
+
213
+ // Original behavior - mark as unknown
214
+ results.push({
215
+ value: undefined,
216
+ source,
217
+ isUnknown: true,
218
+ reason: 'call_result',
219
+ });
220
+ return;
221
+ }
222
+
223
+ // Check nondeterministic EXPRESSION patterns
224
+ if (nodeType === 'EXPRESSION' && detectNondeterministic) {
225
+ if (isNondeterministicExpression(node)) {
226
+ results.push({
227
+ value: undefined,
228
+ source,
229
+ isUnknown: true,
230
+ reason: 'nondeterministic',
231
+ });
232
+ return;
233
+ }
234
+ }
235
+
236
+ // Terminal: OBJECT_LITERAL - a valid structured value
237
+ // OBJECT_LITERAL without edges is valid (e.g., {} or {key: value})
238
+ if (nodeType === 'OBJECT_LITERAL') {
239
+ results.push({
240
+ value: node.value,
241
+ source,
242
+ isUnknown: false,
243
+ });
244
+ return;
245
+ }
246
+
247
+ // REG-334: Special case - CONSTRUCTOR_CALL for Promise
248
+ // Follow RESOLVES_TO edges to find actual data sources from resolve() calls
249
+ if (nodeType === 'CONSTRUCTOR_CALL') {
250
+ const className = (node as { className?: string }).className;
251
+
252
+ if (className === 'Promise') {
253
+ // Look for incoming RESOLVES_TO edges (resolve/reject calls)
254
+ const resolveEdges = await backend.getIncomingEdges(nodeId, ['RESOLVES_TO']);
255
+
256
+ if (resolveEdges.length > 0) {
257
+ // Follow resolve/reject calls to their arguments
258
+ for (const edge of resolveEdges) {
259
+ // edge.src is the resolve(value) CALL node
260
+ // We need to find what value was passed to resolve()
261
+ // The CALL node should have PASSES_ARGUMENT edge to the value
262
+ const argEdges = await backend.getOutgoingEdges(edge.src, ['PASSES_ARGUMENT']);
263
+
264
+ for (const argEdge of argEdges) {
265
+ // Check if this is the first argument (argIndex 0)
266
+ const argIndex = (argEdge.metadata as { argIndex?: number } | undefined)?.argIndex;
267
+ if (argIndex === 0) {
268
+ // Recursively trace the argument value
269
+ await traceRecursive(
270
+ backend,
271
+ argEdge.dst,
272
+ visited,
273
+ depth + 1,
274
+ maxDepth,
275
+ followDerivesFrom,
276
+ detectNondeterministic,
277
+ results
278
+ );
279
+ }
280
+ }
281
+ }
282
+ return; // Traced through resolve, don't mark as unknown
283
+ }
284
+ }
285
+
286
+ // Non-Promise constructor or no resolve edges - mark as unknown
287
+ results.push({
288
+ value: undefined,
289
+ source,
290
+ isUnknown: true,
291
+ reason: 'constructor_call',
292
+ });
293
+ return;
294
+ }
295
+
296
+ // Get outgoing data flow edges
297
+ const edgeTypes = ['ASSIGNED_FROM'];
298
+ if (followDerivesFrom) {
299
+ edgeTypes.push('DERIVES_FROM');
300
+ }
301
+
302
+ const edges = await backend.getOutgoingEdges(nodeId, edgeTypes);
303
+
304
+ // No edges case - unknown
305
+ if (edges.length === 0) {
306
+ results.push({
307
+ value: undefined,
308
+ source,
309
+ isUnknown: true,
310
+ reason: 'no_sources',
311
+ });
312
+ return;
313
+ }
314
+
315
+ // Recurse through sources
316
+ for (const edge of edges) {
317
+ await traceRecursive(
318
+ backend,
319
+ edge.dst,
320
+ visited,
321
+ depth + 1,
322
+ maxDepth,
323
+ followDerivesFrom,
324
+ detectNondeterministic,
325
+ results
326
+ );
327
+ }
328
+ }
329
+
330
+ // =============================================================================
331
+ // HELPERS
332
+ // =============================================================================
333
+
334
+ /**
335
+ * Check if an EXPRESSION node represents a nondeterministic pattern.
336
+ * E.g., process.env.VAR, req.body.userId, etc.
337
+ */
338
+ function isNondeterministicExpression(node: {
339
+ expressionType?: string;
340
+ object?: string;
341
+ property?: string;
342
+ }): boolean {
343
+ if (node.expressionType !== 'MemberExpression') {
344
+ return false;
345
+ }
346
+
347
+ const object = node.object;
348
+ const property = node.property;
349
+
350
+ if (!object || !property) {
351
+ return false;
352
+ }
353
+
354
+ // Check exact patterns (object.property)
355
+ for (const pattern of NONDETERMINISTIC_PATTERNS) {
356
+ if (object === pattern.object && property === pattern.property) {
357
+ return true;
358
+ }
359
+ }
360
+
361
+ // Check if object is a known nondeterministic prefix
362
+ // e.g., process.env.VAR where object is 'process.env'
363
+ for (const prefix of NONDETERMINISTIC_OBJECTS) {
364
+ if (object === prefix || object.startsWith(prefix + '.')) {
365
+ return true;
366
+ }
367
+ }
368
+
369
+ return false;
370
+ }
371
+
372
+ /**
373
+ * Aggregate traced values into a simplified result.
374
+ * Useful for consumers who don't need source locations.
375
+ *
376
+ * Note: null and undefined values are NOT included in the values array.
377
+ * If you need to detect "assigned to null", check the raw TracedValue[] instead.
378
+ *
379
+ * @param traced - Array of traced values
380
+ * @returns Aggregated result with unique values and hasUnknown flag
381
+ */
382
+ export function aggregateValues(traced: TracedValue[]): ValueSetResult {
383
+ const valueSet = new Set<unknown>();
384
+ let hasUnknown = false;
385
+
386
+ for (const t of traced) {
387
+ if (t.isUnknown) {
388
+ hasUnknown = true;
389
+ } else if (t.value !== undefined && t.value !== null) {
390
+ valueSet.add(t.value);
391
+ }
392
+ }
393
+
394
+ return {
395
+ values: Array.from(valueSet),
396
+ hasUnknown,
397
+ };
398
+ }
@@ -0,0 +1,187 @@
1
+ /**
2
+ * Shared Types for Graph Query Utilities
3
+ *
4
+ * These types are used by findCallsInFunction, findContainingFunction,
5
+ * and other query utilities.
6
+ *
7
+ * @module queries/types
8
+ */
9
+
10
+ /**
11
+ * Information about a function/method call found in code
12
+ */
13
+ export interface CallInfo {
14
+ /** Node ID of the call site */
15
+ id: string;
16
+ /** Called function/method name */
17
+ name: string;
18
+ /** Node type: 'CALL' or 'METHOD_CALL' */
19
+ type: 'CALL' | 'METHOD_CALL';
20
+ /** Object name for method calls (e.g., 'response' for response.json()) */
21
+ object?: string;
22
+ /** Whether the call target was resolved (has CALLS edge) */
23
+ resolved: boolean;
24
+ /** Target function info if resolved */
25
+ target?: {
26
+ id: string;
27
+ name: string;
28
+ file?: string;
29
+ line?: number;
30
+ };
31
+ /** File where call occurs */
32
+ file?: string;
33
+ /** Line number of call */
34
+ line?: number;
35
+ /** Depth in transitive call chain (0 = direct call) */
36
+ depth?: number;
37
+ }
38
+
39
+ /**
40
+ * Information about a function that calls another function
41
+ */
42
+ export interface CallerInfo {
43
+ /** Caller function ID */
44
+ id: string;
45
+ /** Caller function name */
46
+ name: string;
47
+ /** Caller function type (FUNCTION, CLASS, MODULE) */
48
+ type: string;
49
+ /** File containing the caller */
50
+ file?: string;
51
+ /** Line of the call site */
52
+ line?: number;
53
+ }
54
+
55
+ /**
56
+ * Options for finding calls in a function
57
+ */
58
+ export interface FindCallsOptions {
59
+ /** Maximum depth for scope traversal (default: 10) */
60
+ maxDepth?: number;
61
+ /** Follow transitive calls (default: false) */
62
+ transitive?: boolean;
63
+ /** Maximum depth for transitive traversal (default: 5) */
64
+ transitiveDepth?: number;
65
+ }
66
+
67
+ // =============================================================================
68
+ // VALUE TRACING TYPES (REG-244)
69
+ // =============================================================================
70
+
71
+ /**
72
+ * Location of a value source in the graph
73
+ */
74
+ export interface ValueSource {
75
+ /** Node ID in the graph */
76
+ id: string;
77
+ /** File path */
78
+ file: string;
79
+ /** Line number (1-based) */
80
+ line: number;
81
+ }
82
+
83
+ /**
84
+ * Reason why a value could not be determined statically.
85
+ * Used for debugging and user-facing messages.
86
+ */
87
+ export type UnknownReason =
88
+ | 'parameter' // Function parameter (runtime input)
89
+ | 'call_result' // Return value from function call
90
+ | 'constructor_call' // Constructor call without traceable data (REG-334)
91
+ | 'nondeterministic' // process.env, req.body, etc.
92
+ | 'max_depth' // Hit depth limit during traversal
93
+ | 'no_sources'; // No ASSIGNED_FROM/DERIVES_FROM edges found
94
+
95
+ /**
96
+ * A single traced value from the graph.
97
+ * Represents either a concrete value (from LITERAL) or an unknown value
98
+ * (from PARAMETER, CALL, nondeterministic source, etc.)
99
+ */
100
+ export interface TracedValue {
101
+ /** The literal value (undefined if unknown) */
102
+ value: unknown;
103
+ /** Source location in the codebase */
104
+ source: ValueSource;
105
+ /** Whether value could not be determined statically */
106
+ isUnknown: boolean;
107
+ /** Why the value is unknown (for debugging/display) */
108
+ reason?: UnknownReason;
109
+ }
110
+
111
+ /**
112
+ * Options for traceValues()
113
+ */
114
+ export interface TraceValuesOptions {
115
+ /** Maximum traversal depth (default: 10) */
116
+ maxDepth?: number;
117
+ /** Follow DERIVES_FROM edges in addition to ASSIGNED_FROM (default: true) */
118
+ followDerivesFrom?: boolean;
119
+ /** Detect nondeterministic patterns like process.env (default: true) */
120
+ detectNondeterministic?: boolean;
121
+ }
122
+
123
+ /**
124
+ * Aggregated result from tracing.
125
+ * Convenience type for consumers who don't need individual sources.
126
+ */
127
+ export interface ValueSetResult {
128
+ /** All unique concrete values found */
129
+ values: unknown[];
130
+ /** Whether any path led to unknown value */
131
+ hasUnknown: boolean;
132
+ }
133
+
134
+ /**
135
+ * Edge record for traceValues
136
+ */
137
+ export interface TraceValuesEdge {
138
+ src: string;
139
+ dst: string;
140
+ type: string;
141
+ metadata?: { argIndex?: number; isReject?: boolean };
142
+ }
143
+
144
+ /**
145
+ * Node record for traceValues
146
+ */
147
+ export interface TraceValuesNode {
148
+ id: string;
149
+ type?: string;
150
+ nodeType?: string;
151
+ value?: unknown;
152
+ file?: string;
153
+ line?: number;
154
+ expressionType?: string;
155
+ object?: string;
156
+ property?: string;
157
+ className?: string;
158
+ }
159
+
160
+ /**
161
+ * Minimal graph backend interface for traceValues().
162
+ * Works with both RFDBServerBackend and internal Graph interface.
163
+ */
164
+ export interface TraceValuesGraphBackend {
165
+ getNode(id: string): Promise<TraceValuesNode | null>;
166
+ getOutgoingEdges(
167
+ nodeId: string,
168
+ edgeTypes: string[] | null
169
+ ): Promise<TraceValuesEdge[]>;
170
+ /**
171
+ * Get incoming edges to a node (REG-334: needed for RESOLVES_TO)
172
+ * Required for Promise tracing - must be implemented by all backends
173
+ */
174
+ getIncomingEdges(
175
+ nodeId: string,
176
+ edgeTypes: string[] | null
177
+ ): Promise<TraceValuesEdge[]>;
178
+ }
179
+
180
+ /**
181
+ * Nondeterministic MemberExpression pattern.
182
+ * object.property combinations that represent external/user input.
183
+ */
184
+ export interface NondeterministicPattern {
185
+ object: string;
186
+ property: string;
187
+ }