@aztec/simulator 0.0.0-test.1 → 0.0.1-commit.5476d83

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 (492) hide show
  1. package/README.md +6 -0
  2. package/dest/client.d.ts +6 -4
  3. package/dest/client.d.ts.map +1 -1
  4. package/dest/client.js +4 -2
  5. package/dest/common/errors.d.ts +5 -14
  6. package/dest/common/errors.d.ts.map +1 -1
  7. package/dest/common/errors.js +51 -32
  8. package/dest/common/index.d.ts +1 -2
  9. package/dest/common/index.d.ts.map +1 -1
  10. package/dest/common/index.js +0 -1
  11. package/dest/common/stats/index.d.ts +1 -1
  12. package/dest/common/stats/stats.d.ts +1 -1
  13. package/dest/private/acvm/acvm.d.ts +12 -6
  14. package/dest/private/acvm/acvm.d.ts.map +1 -1
  15. package/dest/private/acvm/acvm.js +10 -16
  16. package/dest/private/acvm/acvm_types.d.ts +2 -2
  17. package/dest/private/acvm/acvm_types.d.ts.map +1 -1
  18. package/dest/private/acvm/deserialize.d.ts +18 -19
  19. package/dest/private/acvm/deserialize.d.ts.map +1 -1
  20. package/dest/private/acvm/deserialize.js +31 -23
  21. package/dest/private/acvm/index.d.ts +1 -2
  22. package/dest/private/acvm/index.d.ts.map +1 -1
  23. package/dest/private/acvm/index.js +0 -1
  24. package/dest/private/acvm/serialize.d.ts +20 -3
  25. package/dest/private/acvm/serialize.d.ts.map +1 -1
  26. package/dest/private/acvm/serialize.js +53 -0
  27. package/dest/private/acvm_native.d.ts +39 -0
  28. package/dest/private/acvm_native.d.ts.map +1 -0
  29. package/dest/private/{providers/acvm_native.js → acvm_native.js} +26 -20
  30. package/dest/private/acvm_wasm.d.ts +15 -0
  31. package/dest/private/acvm_wasm.d.ts.map +1 -0
  32. package/dest/private/{providers/acvm_wasm.js → acvm_wasm.js} +22 -19
  33. package/dest/private/acvm_wasm_with_blobs.d.ts +20 -0
  34. package/dest/private/acvm_wasm_with_blobs.d.ts.map +1 -0
  35. package/dest/private/acvm_wasm_with_blobs.js +35 -0
  36. package/dest/private/circuit_recording/circuit_recorder.d.ts +108 -0
  37. package/dest/private/circuit_recording/circuit_recorder.d.ts.map +1 -0
  38. package/dest/private/circuit_recording/circuit_recorder.js +209 -0
  39. package/dest/private/circuit_recording/file_circuit_recorder.d.ts +31 -0
  40. package/dest/private/circuit_recording/file_circuit_recorder.d.ts.map +1 -0
  41. package/dest/private/circuit_recording/file_circuit_recorder.js +135 -0
  42. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts +5 -0
  43. package/dest/private/circuit_recording/memory_circuit_recorder.d.ts.map +1 -0
  44. package/dest/private/circuit_recording/memory_circuit_recorder.js +9 -0
  45. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts +21 -0
  46. package/dest/private/circuit_recording/simulator_recorder_wrapper.d.ts.map +1 -0
  47. package/dest/private/circuit_recording/simulator_recorder_wrapper.js +44 -0
  48. package/dest/private/circuit_simulator.d.ts +35 -0
  49. package/dest/private/circuit_simulator.d.ts.map +1 -0
  50. package/dest/private/circuit_simulator.js +43 -0
  51. package/dest/private/factory.d.ts +12 -0
  52. package/dest/private/factory.d.ts.map +1 -0
  53. package/dest/private/{providers/factory.js → factory.js} +2 -2
  54. package/dest/public/avm/avm_context.d.ts +6 -6
  55. package/dest/public/avm/avm_context.d.ts.map +1 -1
  56. package/dest/public/avm/avm_contract_call_result.d.ts +5 -3
  57. package/dest/public/avm/avm_contract_call_result.d.ts.map +1 -1
  58. package/dest/public/avm/avm_contract_call_result.js +11 -7
  59. package/dest/public/avm/avm_execution_environment.d.ts +4 -2
  60. package/dest/public/avm/avm_execution_environment.d.ts.map +1 -1
  61. package/dest/public/avm/avm_execution_environment.js +4 -2
  62. package/dest/public/avm/avm_gas.d.ts +5 -21
  63. package/dest/public/avm/avm_gas.d.ts.map +1 -1
  64. package/dest/public/avm/avm_gas.js +27 -35
  65. package/dest/public/avm/avm_machine_state.d.ts +3 -1
  66. package/dest/public/avm/avm_machine_state.d.ts.map +1 -1
  67. package/dest/public/avm/avm_machine_state.js +2 -0
  68. package/dest/public/avm/avm_memory_types.d.ts +99 -88
  69. package/dest/public/avm/avm_memory_types.d.ts.map +1 -1
  70. package/dest/public/avm/avm_memory_types.js +17 -6
  71. package/dest/public/avm/avm_simulator.d.ts +6 -6
  72. package/dest/public/avm/avm_simulator.d.ts.map +1 -1
  73. package/dest/public/avm/avm_simulator.js +23 -35
  74. package/dest/public/avm/avm_simulator_interface.d.ts +9 -0
  75. package/dest/public/avm/avm_simulator_interface.d.ts.map +1 -0
  76. package/dest/public/avm/avm_simulator_interface.js +3 -0
  77. package/dest/public/avm/errors.d.ts +7 -31
  78. package/dest/public/avm/errors.d.ts.map +1 -1
  79. package/dest/public/avm/errors.js +7 -57
  80. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts +6 -5
  81. package/dest/public/avm/fixtures/avm_simulation_tester.d.ts.map +1 -1
  82. package/dest/public/avm/fixtures/avm_simulation_tester.js +22 -15
  83. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts +7 -5
  84. package/dest/public/avm/fixtures/base_avm_simulation_tester.d.ts.map +1 -1
  85. package/dest/public/avm/fixtures/base_avm_simulation_tester.js +37 -14
  86. package/dest/public/avm/fixtures/initializers.d.ts +42 -0
  87. package/dest/public/avm/fixtures/initializers.d.ts.map +1 -0
  88. package/dest/public/avm/fixtures/initializers.js +44 -0
  89. package/dest/public/avm/fixtures/utils.d.ts +38 -0
  90. package/dest/public/avm/fixtures/utils.d.ts.map +1 -0
  91. package/dest/public/avm/fixtures/utils.js +95 -0
  92. package/dest/public/avm/index.d.ts +1 -3
  93. package/dest/public/avm/index.d.ts.map +1 -1
  94. package/dest/public/avm/index.js +0 -2
  95. package/dest/public/avm/opcodes/accrued_substate.d.ts +3 -3
  96. package/dest/public/avm/opcodes/accrued_substate.d.ts.map +1 -1
  97. package/dest/public/avm/opcodes/accrued_substate.js +28 -25
  98. package/dest/public/avm/opcodes/addressing_mode.d.ts +12 -8
  99. package/dest/public/avm/opcodes/addressing_mode.d.ts.map +1 -1
  100. package/dest/public/avm/opcodes/addressing_mode.js +46 -26
  101. package/dest/public/avm/opcodes/arithmetic.d.ts +17 -7
  102. package/dest/public/avm/opcodes/arithmetic.d.ts.map +1 -1
  103. package/dest/public/avm/opcodes/arithmetic.js +16 -2
  104. package/dest/public/avm/opcodes/bitwise.d.ts +10 -18
  105. package/dest/public/avm/opcodes/bitwise.d.ts.map +1 -1
  106. package/dest/public/avm/opcodes/bitwise.js +19 -26
  107. package/dest/public/avm/opcodes/comparators.d.ts +4 -4
  108. package/dest/public/avm/opcodes/comparators.d.ts.map +1 -1
  109. package/dest/public/avm/opcodes/comparators.js +3 -3
  110. package/dest/public/avm/opcodes/contract.d.ts +2 -3
  111. package/dest/public/avm/opcodes/contract.d.ts.map +1 -1
  112. package/dest/public/avm/opcodes/contract.js +9 -10
  113. package/dest/public/avm/opcodes/control_flow.d.ts +1 -1
  114. package/dest/public/avm/opcodes/control_flow.d.ts.map +1 -1
  115. package/dest/public/avm/opcodes/control_flow.js +10 -8
  116. package/dest/public/avm/opcodes/conversion.d.ts +2 -1
  117. package/dest/public/avm/opcodes/conversion.d.ts.map +1 -1
  118. package/dest/public/avm/opcodes/conversion.js +267 -3
  119. package/dest/public/avm/opcodes/ec_add.d.ts +2 -2
  120. package/dest/public/avm/opcodes/ec_add.d.ts.map +1 -1
  121. package/dest/public/avm/opcodes/ec_add.js +6 -6
  122. package/dest/public/avm/opcodes/environment_getters.d.ts +3 -3
  123. package/dest/public/avm/opcodes/environment_getters.d.ts.map +1 -1
  124. package/dest/public/avm/opcodes/environment_getters.js +17 -19
  125. package/dest/public/avm/opcodes/external_calls.d.ts +9 -8
  126. package/dest/public/avm/opcodes/external_calls.d.ts.map +1 -1
  127. package/dest/public/avm/opcodes/external_calls.js +39 -34
  128. package/dest/public/avm/opcodes/hashing.d.ts +2 -2
  129. package/dest/public/avm/opcodes/hashing.d.ts.map +1 -1
  130. package/dest/public/avm/opcodes/hashing.js +6 -6
  131. package/dest/public/avm/opcodes/index.d.ts +1 -1
  132. package/dest/public/avm/opcodes/instruction.d.ts +15 -11
  133. package/dest/public/avm/opcodes/instruction.d.ts.map +1 -1
  134. package/dest/public/avm/opcodes/instruction.js +23 -19
  135. package/dest/public/avm/opcodes/instruction_impl.d.ts +1 -1
  136. package/dest/public/avm/opcodes/instruction_impl.d.ts.map +1 -1
  137. package/dest/public/avm/opcodes/memory.d.ts +6 -6
  138. package/dest/public/avm/opcodes/memory.d.ts.map +1 -1
  139. package/dest/public/avm/opcodes/memory.js +37 -33
  140. package/dest/public/avm/opcodes/misc.d.ts +3 -2
  141. package/dest/public/avm/opcodes/misc.d.ts.map +1 -1
  142. package/dest/public/avm/opcodes/misc.js +41 -16
  143. package/dest/public/avm/opcodes/storage.d.ts +3 -3
  144. package/dest/public/avm/opcodes/storage.d.ts.map +1 -1
  145. package/dest/public/avm/opcodes/storage.js +7 -5
  146. package/dest/public/avm/revert_reason.d.ts +18 -0
  147. package/dest/public/avm/revert_reason.d.ts.map +1 -0
  148. package/dest/public/avm/revert_reason.js +38 -0
  149. package/dest/public/avm/serialization/buffer_cursor.d.ts +1 -3
  150. package/dest/public/avm/serialization/buffer_cursor.d.ts.map +1 -1
  151. package/dest/public/avm/serialization/bytecode_serialization.d.ts +3 -7
  152. package/dest/public/avm/serialization/bytecode_serialization.d.ts.map +1 -1
  153. package/dest/public/avm/serialization/bytecode_serialization.js +70 -69
  154. package/dest/public/avm/serialization/instruction_serialization.d.ts +14 -5
  155. package/dest/public/avm/serialization/instruction_serialization.d.ts.map +1 -1
  156. package/dest/public/avm/serialization/instruction_serialization.js +70 -35
  157. package/dest/public/avm/test_utils.d.ts +11 -14
  158. package/dest/public/avm/test_utils.d.ts.map +1 -1
  159. package/dest/public/avm/test_utils.js +16 -24
  160. package/dest/public/contracts_db_checkpoint.d.ts +16 -0
  161. package/dest/public/contracts_db_checkpoint.d.ts.map +1 -0
  162. package/dest/public/contracts_db_checkpoint.js +30 -0
  163. package/dest/public/db_interfaces.d.ts +68 -0
  164. package/dest/public/db_interfaces.d.ts.map +1 -0
  165. package/dest/public/db_interfaces.js +3 -0
  166. package/dest/public/debug_fn_name.d.ts +5 -0
  167. package/dest/public/debug_fn_name.d.ts.map +1 -0
  168. package/dest/public/debug_fn_name.js +9 -0
  169. package/dest/public/executor_metrics.d.ts +12 -4
  170. package/dest/public/executor_metrics.d.ts.map +1 -1
  171. package/dest/public/executor_metrics.js +37 -6
  172. package/dest/public/executor_metrics_interface.d.ts +10 -0
  173. package/dest/public/executor_metrics_interface.d.ts.map +1 -0
  174. package/dest/public/executor_metrics_interface.js +1 -0
  175. package/dest/public/fixtures/amm_test.d.ts +10 -0
  176. package/dest/public/fixtures/amm_test.d.ts.map +1 -0
  177. package/dest/public/fixtures/amm_test.js +213 -0
  178. package/dest/public/fixtures/bulk_test.d.ts +6 -0
  179. package/dest/public/fixtures/bulk_test.d.ts.map +1 -0
  180. package/dest/public/fixtures/bulk_test.js +326 -0
  181. package/dest/public/fixtures/custom_bytecode_tester.d.ts +12 -0
  182. package/dest/public/fixtures/custom_bytecode_tester.d.ts.map +1 -0
  183. package/dest/public/fixtures/custom_bytecode_tester.js +29 -0
  184. package/dest/public/fixtures/custom_bytecode_tests.d.ts +9 -0
  185. package/dest/public/fixtures/custom_bytecode_tests.d.ts.map +1 -0
  186. package/dest/public/fixtures/custom_bytecode_tests.js +109 -0
  187. package/dest/public/fixtures/index.d.ts +8 -1
  188. package/dest/public/fixtures/index.d.ts.map +1 -1
  189. package/dest/public/fixtures/index.js +7 -0
  190. package/dest/public/fixtures/minimal_public_tx.d.ts +9 -0
  191. package/dest/public/fixtures/minimal_public_tx.d.ts.map +1 -0
  192. package/dest/public/fixtures/minimal_public_tx.js +29 -0
  193. package/dest/public/fixtures/public_tx_simulation_tester.d.ts +35 -14
  194. package/dest/public/fixtures/public_tx_simulation_tester.d.ts.map +1 -1
  195. package/dest/public/fixtures/public_tx_simulation_tester.js +100 -71
  196. package/dest/public/fixtures/simple_contract_data_source.d.ts +35 -0
  197. package/dest/public/fixtures/simple_contract_data_source.d.ts.map +1 -0
  198. package/dest/public/{avm/fixtures → fixtures}/simple_contract_data_source.js +31 -10
  199. package/dest/public/fixtures/token_test.d.ts +8 -0
  200. package/dest/public/fixtures/token_test.d.ts.map +1 -0
  201. package/dest/public/fixtures/token_test.js +94 -0
  202. package/dest/public/fixtures/utils.d.ts +17 -4
  203. package/dest/public/fixtures/utils.d.ts.map +1 -1
  204. package/dest/public/fixtures/utils.js +100 -58
  205. package/dest/public/hinting_db_sources.d.ts +78 -0
  206. package/dest/public/hinting_db_sources.d.ts.map +1 -0
  207. package/dest/public/hinting_db_sources.js +350 -0
  208. package/dest/public/index.d.ts +6 -9
  209. package/dest/public/index.d.ts.map +1 -1
  210. package/dest/public/index.js +4 -7
  211. package/dest/public/public_db_sources.d.ts +51 -101
  212. package/dest/public/public_db_sources.d.ts.map +1 -1
  213. package/dest/public/public_db_sources.js +219 -192
  214. package/dest/public/public_errors.d.ts +12 -0
  215. package/dest/public/public_errors.d.ts.map +1 -0
  216. package/dest/public/public_errors.js +13 -0
  217. package/dest/public/public_processor/guarded_merkle_tree.d.ts +49 -0
  218. package/dest/public/public_processor/guarded_merkle_tree.d.ts.map +1 -0
  219. package/dest/public/public_processor/guarded_merkle_tree.js +108 -0
  220. package/dest/public/public_processor/public_processor.d.ts +25 -37
  221. package/dest/public/public_processor/public_processor.d.ts.map +1 -1
  222. package/dest/public/public_processor/public_processor.js +154 -111
  223. package/dest/public/public_processor/public_processor_metrics.d.ts +3 -3
  224. package/dest/public/public_processor/public_processor_metrics.d.ts.map +1 -1
  225. package/dest/public/public_processor/public_processor_metrics.js +1 -1
  226. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts +30 -0
  227. package/dest/public/public_tx_simulator/contract_provider_for_cpp.d.ts.map +1 -0
  228. package/dest/public/public_tx_simulator/contract_provider_for_cpp.js +133 -0
  229. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts +66 -0
  230. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.d.ts.map +1 -0
  231. package/dest/public/public_tx_simulator/cpp_public_tx_simulator.js +210 -0
  232. package/dest/public/public_tx_simulator/index.d.ts +5 -0
  233. package/dest/public/public_tx_simulator/index.d.ts.map +1 -0
  234. package/dest/public/public_tx_simulator/index.js +2 -0
  235. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts +31 -0
  236. package/dest/public/public_tx_simulator/measured_public_tx_simulator.d.ts.map +1 -0
  237. package/dest/public/public_tx_simulator/measured_public_tx_simulator.js +51 -0
  238. package/dest/public/public_tx_simulator/public_tx_context.d.ts +23 -30
  239. package/dest/public/public_tx_simulator/public_tx_context.d.ts.map +1 -1
  240. package/dest/public/public_tx_simulator/public_tx_context.js +71 -91
  241. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts +36 -58
  242. package/dest/public/public_tx_simulator/public_tx_simulator.d.ts.map +1 -1
  243. package/dest/public/public_tx_simulator/public_tx_simulator.js +208 -206
  244. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts +9 -0
  245. package/dest/public/public_tx_simulator/public_tx_simulator_interface.d.ts.map +1 -0
  246. package/dest/public/public_tx_simulator/public_tx_simulator_interface.js +1 -0
  247. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts +21 -0
  248. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.d.ts.map +1 -0
  249. package/dest/public/public_tx_simulator/telemetry_public_tx_simulator.js +39 -0
  250. package/dest/public/side_effect_errors.d.ts +42 -2
  251. package/dest/public/side_effect_errors.d.ts.map +1 -1
  252. package/dest/public/side_effect_errors.js +70 -1
  253. package/dest/public/side_effect_trace.d.ts +21 -67
  254. package/dest/public/side_effect_trace.d.ts.map +1 -1
  255. package/dest/public/side_effect_trace.js +71 -121
  256. package/dest/public/side_effect_trace_interface.d.ts +12 -24
  257. package/dest/public/side_effect_trace_interface.d.ts.map +1 -1
  258. package/dest/public/state_manager/index.d.ts +2 -0
  259. package/dest/public/state_manager/index.d.ts.map +1 -0
  260. package/dest/public/state_manager/index.js +1 -0
  261. package/dest/public/{avm/journal → state_manager}/nullifiers.d.ts +3 -6
  262. package/dest/public/state_manager/nullifiers.d.ts.map +1 -0
  263. package/dest/public/{avm/journal → state_manager}/nullifiers.js +3 -8
  264. package/dest/public/{avm/journal → state_manager}/public_storage.d.ts +3 -3
  265. package/dest/public/state_manager/public_storage.d.ts.map +1 -0
  266. package/dest/public/state_manager/state_manager.d.ts +159 -0
  267. package/dest/public/state_manager/state_manager.d.ts.map +1 -0
  268. package/dest/public/state_manager/state_manager.js +392 -0
  269. package/dest/public/test_executor_metrics.d.ts +55 -0
  270. package/dest/public/test_executor_metrics.d.ts.map +1 -0
  271. package/dest/public/test_executor_metrics.js +307 -0
  272. package/dest/public/unique_class_ids.d.ts +1 -1
  273. package/dest/public/unique_class_ids.d.ts.map +1 -1
  274. package/dest/public/utils.d.ts +3 -5
  275. package/dest/public/utils.d.ts.map +1 -1
  276. package/dest/public/utils.js +4 -21
  277. package/dest/server.d.ts +7 -4
  278. package/dest/server.d.ts.map +1 -1
  279. package/dest/server.js +5 -2
  280. package/dest/testing.d.ts +2 -0
  281. package/dest/testing.d.ts.map +1 -0
  282. package/dest/testing.js +1 -0
  283. package/package.json +39 -33
  284. package/src/client.ts +5 -3
  285. package/src/common/errors.ts +79 -44
  286. package/src/common/index.ts +0 -1
  287. package/src/private/acvm/acvm.ts +17 -32
  288. package/src/private/acvm/acvm_types.ts +1 -1
  289. package/src/private/acvm/deserialize.ts +35 -29
  290. package/src/private/acvm/index.ts +0 -1
  291. package/src/private/acvm/serialize.ts +63 -0
  292. package/src/private/{providers/acvm_native.ts → acvm_native.ts} +47 -24
  293. package/src/private/acvm_wasm.ts +72 -0
  294. package/src/private/acvm_wasm_with_blobs.ts +54 -0
  295. package/src/private/circuit_recording/circuit_recorder.ts +260 -0
  296. package/src/private/circuit_recording/file_circuit_recorder.ts +158 -0
  297. package/src/private/circuit_recording/memory_circuit_recorder.ts +11 -0
  298. package/src/private/circuit_recording/simulator_recorder_wrapper.ts +91 -0
  299. package/src/private/circuit_simulator.ts +90 -0
  300. package/src/private/{providers/factory.ts → factory.ts} +6 -6
  301. package/src/public/avm/avm_context.ts +4 -4
  302. package/src/public/avm/avm_contract_call_result.ts +17 -5
  303. package/src/public/avm/avm_execution_environment.ts +8 -1
  304. package/src/public/avm/avm_gas.ts +23 -35
  305. package/src/public/avm/avm_machine_state.ts +5 -0
  306. package/src/public/avm/avm_memory_types.ts +19 -6
  307. package/src/public/avm/avm_simulator.ts +43 -54
  308. package/src/public/avm/avm_simulator_interface.ts +8 -0
  309. package/src/public/avm/errors.ts +8 -77
  310. package/src/public/avm/fixtures/avm_simulation_tester.ts +32 -21
  311. package/src/public/avm/fixtures/base_avm_simulation_tester.ts +45 -12
  312. package/src/public/avm/fixtures/initializers.ts +102 -0
  313. package/src/public/avm/fixtures/utils.ts +150 -0
  314. package/src/public/avm/index.ts +0 -2
  315. package/src/public/avm/opcodes/accrued_substate.ts +64 -29
  316. package/src/public/avm/opcodes/addressing_mode.ts +56 -32
  317. package/src/public/avm/opcodes/arithmetic.ts +24 -2
  318. package/src/public/avm/opcodes/bitwise.ts +33 -29
  319. package/src/public/avm/opcodes/comparators.ts +6 -3
  320. package/src/public/avm/opcodes/contract.ts +10 -7
  321. package/src/public/avm/opcodes/control_flow.ts +19 -10
  322. package/src/public/avm/opcodes/conversion.ts +27 -3
  323. package/src/public/avm/opcodes/ec_add.ts +9 -6
  324. package/src/public/avm/opcodes/environment_getters.ts +27 -22
  325. package/src/public/avm/opcodes/external_calls.ts +61 -29
  326. package/src/public/avm/opcodes/hashing.ts +28 -8
  327. package/src/public/avm/opcodes/instruction.ts +31 -21
  328. package/src/public/avm/opcodes/memory.ts +71 -32
  329. package/src/public/avm/opcodes/misc.ts +60 -18
  330. package/src/public/avm/opcodes/storage.ts +22 -6
  331. package/src/public/avm/revert_reason.ts +55 -0
  332. package/src/public/avm/serialization/buffer_cursor.ts +4 -1
  333. package/src/public/avm/serialization/bytecode_serialization.ts +72 -74
  334. package/src/public/avm/serialization/instruction_serialization.ts +75 -34
  335. package/src/public/avm/test_utils.ts +24 -41
  336. package/src/public/contracts_db_checkpoint.ts +41 -0
  337. package/src/public/db_interfaces.ts +76 -0
  338. package/src/{common → public}/debug_fn_name.ts +7 -7
  339. package/src/public/executor_metrics.ts +56 -6
  340. package/src/public/executor_metrics_interface.ts +15 -0
  341. package/src/public/fixtures/amm_test.ts +331 -0
  342. package/src/public/fixtures/bulk_test.ts +169 -0
  343. package/src/public/fixtures/custom_bytecode_tester.ts +49 -0
  344. package/src/public/fixtures/custom_bytecode_tests.ts +135 -0
  345. package/src/public/fixtures/index.ts +7 -0
  346. package/src/public/fixtures/minimal_public_tx.ts +35 -0
  347. package/src/public/fixtures/public_tx_simulation_tester.ts +166 -113
  348. package/src/public/{avm/fixtures → fixtures}/simple_contract_data_source.ts +36 -18
  349. package/src/public/fixtures/token_test.ts +139 -0
  350. package/src/public/fixtures/utils.ts +141 -68
  351. package/src/public/hinting_db_sources.ts +602 -0
  352. package/src/public/index.ts +5 -8
  353. package/src/public/public_db_sources.ts +278 -258
  354. package/src/public/public_errors.ts +14 -0
  355. package/src/public/public_processor/guarded_merkle_tree.ts +153 -0
  356. package/src/public/public_processor/public_processor.ts +212 -164
  357. package/src/public/public_processor/public_processor_metrics.ts +2 -2
  358. package/src/public/public_tx_simulator/contract_provider_for_cpp.ts +162 -0
  359. package/src/public/public_tx_simulator/cpp_public_tx_simulator.ts +306 -0
  360. package/src/public/public_tx_simulator/index.ts +4 -0
  361. package/src/public/public_tx_simulator/measured_public_tx_simulator.ts +105 -0
  362. package/src/public/public_tx_simulator/public_tx_context.ts +167 -194
  363. package/src/public/public_tx_simulator/public_tx_simulator.ts +292 -265
  364. package/src/public/public_tx_simulator/public_tx_simulator_interface.ts +10 -0
  365. package/src/public/public_tx_simulator/telemetry_public_tx_simulator.ts +63 -0
  366. package/src/public/side_effect_errors.ts +91 -1
  367. package/src/public/side_effect_trace.ts +94 -320
  368. package/src/public/side_effect_trace_interface.ts +10 -58
  369. package/src/public/state_manager/index.ts +1 -0
  370. package/src/public/{avm/journal → state_manager}/nullifiers.ts +5 -11
  371. package/src/public/{avm/journal → state_manager}/public_storage.ts +2 -2
  372. package/src/public/state_manager/state_manager.ts +553 -0
  373. package/src/public/test_executor_metrics.ts +397 -0
  374. package/src/public/utils.ts +5 -21
  375. package/src/server.ts +6 -3
  376. package/src/testing.ts +1 -0
  377. package/dest/common/db_interfaces.d.ts +0 -80
  378. package/dest/common/db_interfaces.d.ts.map +0 -1
  379. package/dest/common/db_interfaces.js +0 -1
  380. package/dest/common/debug_fn_name.d.ts +0 -5
  381. package/dest/common/debug_fn_name.d.ts.map +0 -1
  382. package/dest/common/debug_fn_name.js +0 -6
  383. package/dest/common/message_load_oracle_inputs.d.ts +0 -15
  384. package/dest/common/message_load_oracle_inputs.d.ts.map +0 -1
  385. package/dest/common/message_load_oracle_inputs.js +0 -15
  386. package/dest/private/acvm/oracle/index.d.ts +0 -14
  387. package/dest/private/acvm/oracle/index.d.ts.map +0 -1
  388. package/dest/private/acvm/oracle/index.js +0 -2
  389. package/dest/private/acvm/oracle/oracle.d.ts +0 -49
  390. package/dest/private/acvm/oracle/oracle.d.ts.map +0 -1
  391. package/dest/private/acvm/oracle/oracle.js +0 -263
  392. package/dest/private/acvm/oracle/typed_oracle.d.ts +0 -83
  393. package/dest/private/acvm/oracle/typed_oracle.d.ts.map +0 -1
  394. package/dest/private/acvm/oracle/typed_oracle.js +0 -132
  395. package/dest/private/execution_data_provider.d.ts +0 -261
  396. package/dest/private/execution_data_provider.d.ts.map +0 -1
  397. package/dest/private/execution_data_provider.js +0 -14
  398. package/dest/private/execution_note_cache.d.ts +0 -93
  399. package/dest/private/execution_note_cache.d.ts.map +0 -1
  400. package/dest/private/execution_note_cache.js +0 -180
  401. package/dest/private/hashed_values_cache.d.ts +0 -28
  402. package/dest/private/hashed_values_cache.d.ts.map +0 -1
  403. package/dest/private/hashed_values_cache.js +0 -46
  404. package/dest/private/index.d.ts +0 -13
  405. package/dest/private/index.d.ts.map +0 -1
  406. package/dest/private/index.js +0 -12
  407. package/dest/private/pick_notes.d.ts +0 -85
  408. package/dest/private/pick_notes.d.ts.map +0 -1
  409. package/dest/private/pick_notes.js +0 -51
  410. package/dest/private/private_execution.d.ts +0 -25
  411. package/dest/private/private_execution.d.ts.map +0 -1
  412. package/dest/private/private_execution.js +0 -92
  413. package/dest/private/private_execution_oracle.d.ts +0 -215
  414. package/dest/private/private_execution_oracle.d.ts.map +0 -1
  415. package/dest/private/private_execution_oracle.js +0 -382
  416. package/dest/private/providers/acvm_native.d.ts +0 -40
  417. package/dest/private/providers/acvm_native.d.ts.map +0 -1
  418. package/dest/private/providers/acvm_wasm.d.ts +0 -15
  419. package/dest/private/providers/acvm_wasm.d.ts.map +0 -1
  420. package/dest/private/providers/acvm_wasm_with_blobs.d.ts +0 -19
  421. package/dest/private/providers/acvm_wasm_with_blobs.d.ts.map +0 -1
  422. package/dest/private/providers/acvm_wasm_with_blobs.js +0 -32
  423. package/dest/private/providers/factory.d.ts +0 -12
  424. package/dest/private/providers/factory.d.ts.map +0 -1
  425. package/dest/private/providers/simulation_provider.d.ts +0 -19
  426. package/dest/private/providers/simulation_provider.d.ts.map +0 -1
  427. package/dest/private/providers/simulation_provider.js +0 -24
  428. package/dest/private/simulator.d.ts +0 -34
  429. package/dest/private/simulator.d.ts.map +0 -1
  430. package/dest/private/simulator.js +0 -76
  431. package/dest/private/unconstrained_execution.d.ts +0 -10
  432. package/dest/private/unconstrained_execution.d.ts.map +0 -1
  433. package/dest/private/unconstrained_execution.js +0 -27
  434. package/dest/private/unconstrained_execution_oracle.d.ts +0 -161
  435. package/dest/private/unconstrained_execution_oracle.d.ts.map +0 -1
  436. package/dest/private/unconstrained_execution_oracle.js +0 -258
  437. package/dest/public/avm/bytecode_utils.d.ts +0 -5
  438. package/dest/public/avm/bytecode_utils.d.ts.map +0 -1
  439. package/dest/public/avm/bytecode_utils.js +0 -17
  440. package/dest/public/avm/fixtures/index.d.ts +0 -84
  441. package/dest/public/avm/fixtures/index.d.ts.map +0 -1
  442. package/dest/public/avm/fixtures/index.js +0 -175
  443. package/dest/public/avm/fixtures/simple_contract_data_source.d.ts +0 -35
  444. package/dest/public/avm/fixtures/simple_contract_data_source.d.ts.map +0 -1
  445. package/dest/public/avm/journal/index.d.ts +0 -2
  446. package/dest/public/avm/journal/index.d.ts.map +0 -1
  447. package/dest/public/avm/journal/index.js +0 -1
  448. package/dest/public/avm/journal/journal.d.ts +0 -209
  449. package/dest/public/avm/journal/journal.d.ts.map +0 -1
  450. package/dest/public/avm/journal/journal.js +0 -486
  451. package/dest/public/avm/journal/nullifiers.d.ts.map +0 -1
  452. package/dest/public/avm/journal/public_storage.d.ts.map +0 -1
  453. package/dest/public/bytecode_errors.d.ts +0 -4
  454. package/dest/public/bytecode_errors.d.ts.map +0 -1
  455. package/dest/public/bytecode_errors.js +0 -6
  456. package/dest/public/execution.d.ts +0 -108
  457. package/dest/public/execution.d.ts.map +0 -1
  458. package/dest/public/execution.js +0 -9
  459. package/dest/public/tx_contract_cache.d.ts +0 -41
  460. package/dest/public/tx_contract_cache.d.ts.map +0 -1
  461. package/dest/public/tx_contract_cache.js +0 -49
  462. package/dest/test/utils.d.ts +0 -13
  463. package/dest/test/utils.d.ts.map +0 -1
  464. package/dest/test/utils.js +0 -22
  465. package/src/common/db_interfaces.ts +0 -94
  466. package/src/common/message_load_oracle_inputs.ts +0 -15
  467. package/src/private/acvm/oracle/index.ts +0 -16
  468. package/src/private/acvm/oracle/oracle.ts +0 -455
  469. package/src/private/acvm/oracle/typed_oracle.ts +0 -259
  470. package/src/private/execution_data_provider.ts +0 -323
  471. package/src/private/execution_note_cache.ts +0 -217
  472. package/src/private/hashed_values_cache.ts +0 -55
  473. package/src/private/index.ts +0 -16
  474. package/src/private/pick_notes.ts +0 -141
  475. package/src/private/private_execution.ts +0 -151
  476. package/src/private/private_execution_oracle.ts +0 -614
  477. package/src/private/providers/acvm_wasm.ts +0 -63
  478. package/src/private/providers/acvm_wasm_with_blobs.ts +0 -50
  479. package/src/private/providers/simulation_provider.ts +0 -45
  480. package/src/private/simulator.ts +0 -147
  481. package/src/private/unconstrained_execution.ts +0 -50
  482. package/src/private/unconstrained_execution_oracle.ts +0 -373
  483. package/src/public/avm/bytecode_utils.ts +0 -17
  484. package/src/public/avm/fixtures/index.ts +0 -296
  485. package/src/public/avm/journal/index.ts +0 -1
  486. package/src/public/avm/journal/journal.ts +0 -742
  487. package/src/public/avm/opcodes/.eslintrc.cjs +0 -8
  488. package/src/public/bytecode_errors.ts +0 -6
  489. package/src/public/execution.ts +0 -140
  490. package/src/public/tx_contract_cache.ts +0 -69
  491. package/src/test/utils.ts +0 -36
  492. /package/dest/public/{avm/journal → state_manager}/public_storage.js +0 -0
@@ -1,187 +1,173 @@
1
- function _ts_decorate(decorators, target, key, desc) {
2
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
- else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
- return c > 3 && r && Object.defineProperty(target, key, r), r;
6
- }
1
+ import { AVM_MAX_PROCESSABLE_L2_GAS } from '@aztec/constants';
7
2
  import { createLogger } from '@aztec/foundation/log';
8
- import { Timer } from '@aztec/foundation/timer';
9
- import { ProtocolContractAddress } from '@aztec/protocol-contracts';
3
+ import { ProtocolContractAddress, ProtocolContractsList } from '@aztec/protocol-contracts';
10
4
  import { computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
5
+ import { AvmExecutionHints, AvmTxHint, PublicSimulatorConfig, PublicTxResult } from '@aztec/stdlib/avm';
11
6
  import { SimulationError } from '@aztec/stdlib/errors';
12
7
  import { NestedProcessReturnValues, TxExecutionPhase } from '@aztec/stdlib/tx';
13
- import { Attributes, getTelemetryClient, trackSpan } from '@aztec/telemetry-client';
14
8
  import { strict as assert } from 'assert';
15
- import { getPublicFunctionDebugName } from '../../common/debug_fn_name.js';
16
9
  import { AvmSimulator } from '../avm/index.js';
17
- import { NullifierCollisionError } from '../avm/journal/nullifiers.js';
18
- import { ExecutorMetrics } from '../executor_metrics.js';
10
+ import { getPublicFunctionDebugName } from '../debug_fn_name.js';
11
+ import { HintingMerkleWriteOperations, HintingPublicContractsDB } from '../hinting_db_sources.js';
12
+ import { PublicTreesDB } from '../public_db_sources.js';
13
+ import { L2ToL1MessageLimitReachedError, NoteHashLimitReachedError, NullifierCollisionError, NullifierLimitReachedError } from '../side_effect_errors.js';
19
14
  import { PublicTxContext } from './public_tx_context.js';
15
+ // The errors below are only thrown here in the public tx simulator,
16
+ // and only during revertible phases (revertible insertions, app logic and teardown).
17
+ // These are strictly "checked" errors (not exported and never propagated).
18
+ // They are used internally for control flow to trigger rollbacks to the post-setup state.
19
+ /**
20
+ * Error thrown when public tx simulation reverts in a known/checked way during revertible insertions.
21
+ */ class TxSimRevertibleInsertionsRevert extends Error {
22
+ constructor(){
23
+ super('Public Tx Simulation reverted during Revertible Insertions');
24
+ this.name = 'TxSimRevertibleInsertionsRevert';
25
+ }
26
+ }
27
+ /**
28
+ * Error thrown when public tx simulation reverts during app logic.
29
+ */ class TxSimAppLogicRevert extends Error {
30
+ constructor(){
31
+ super('Public Tx Simulation reverted during App Logic');
32
+ this.name = 'TxSimAppLogicRevert';
33
+ }
34
+ }
35
+ /**
36
+ * Error thrown when public tx simulation reverts during teardown.
37
+ */ class TxSimTeardownRevert extends Error {
38
+ constructor(){
39
+ super('Public Tx Simulation reverted during Teardown');
40
+ this.name = 'TxSimTeardownRevert';
41
+ }
42
+ }
20
43
  export class PublicTxSimulator {
21
- db;
22
- worldStateDB;
44
+ merkleTree;
45
+ contractsDB;
23
46
  globalVariables;
24
- doMerkleOperations;
25
- skipFeeEnforcement;
26
- metrics;
27
47
  log;
28
- constructor(db, worldStateDB, globalVariables, doMerkleOperations = false, skipFeeEnforcement = false, telemetryClient = getTelemetryClient()){
29
- this.db = db;
30
- this.worldStateDB = worldStateDB;
48
+ config;
49
+ constructor(merkleTree, contractsDB, globalVariables, config){
50
+ this.merkleTree = merkleTree;
51
+ this.contractsDB = contractsDB;
31
52
  this.globalVariables = globalVariables;
32
- this.doMerkleOperations = doMerkleOperations;
33
- this.skipFeeEnforcement = skipFeeEnforcement;
53
+ this.config = PublicSimulatorConfig.from(config ?? {});
34
54
  this.log = createLogger(`simulator:public_tx_simulator`);
35
- this.metrics = new ExecutorMetrics(telemetryClient, 'PublicTxSimulator');
36
- }
37
- get tracer() {
38
- return this.metrics.tracer;
39
55
  }
40
56
  /**
41
57
  * Simulate a transaction's public portion including all of its phases.
42
58
  * @param tx - The transaction to simulate.
43
59
  * @returns The result of the transaction's public execution.
44
60
  */ async simulate(tx) {
45
- try {
46
- const startTime = process.hrtime.bigint();
47
- const txHash = await tx.getTxHash();
48
- this.log.debug(`Simulating ${tx.enqueuedPublicFunctionCalls.length} public calls for tx ${txHash}`, {
49
- txHash
50
- });
51
- const context = await PublicTxContext.create(this.db, this.worldStateDB, tx, this.globalVariables, this.doMerkleOperations);
52
- const nonRevertStart = process.hrtime.bigint();
53
- await this.insertNonRevertiblesFromPrivate(context);
54
- // add new contracts to the contracts db so that their functions may be found and called
55
- // TODO(#6464): Should we allow emitting contracts in the private setup phase?
56
- await this.worldStateDB.addNewNonRevertibleContracts(tx);
57
- const nonRevertEnd = process.hrtime.bigint();
58
- this.metrics.recordPrivateEffectsInsertion(Number(nonRevertEnd - nonRevertStart) / 1_000, 'non-revertible');
59
- const processedPhases = [];
60
- if (context.hasPhase(TxExecutionPhase.SETUP)) {
61
- const setupResult = await this.simulateSetupPhase(context);
62
- processedPhases.push(setupResult);
61
+ const txHash = this.computeTxHash(tx);
62
+ this.log.debug(`Simulating ${tx.publicFunctionCalldata.length} public calls for tx ${txHash}`, {
63
+ txHash
64
+ });
65
+ // Create hinting DBs.
66
+ const hints = new AvmExecutionHints(this.globalVariables, AvmTxHint.fromTx(tx, this.globalVariables.gasFees), ProtocolContractsList);
67
+ const hintingMerkleTree = await HintingMerkleWriteOperations.create(this.merkleTree, hints);
68
+ const hintingTreesDB = new PublicTreesDB(hintingMerkleTree);
69
+ const hintingContractsDB = new HintingPublicContractsDB(this.contractsDB, hints);
70
+ const context = await PublicTxContext.create(hintingTreesDB, hintingContractsDB, tx, this.globalVariables, ProtocolContractsList, this.config.proverId);
71
+ // This will throw if there is a nullifier collision.
72
+ // In that case the transaction will be thrown out.
73
+ await this.insertNonRevertiblesFromPrivate(context);
74
+ const processedPhases = [];
75
+ if (context.hasPhase(TxExecutionPhase.SETUP)) {
76
+ // This will throw if the setup phase reverts.
77
+ // In that case the transaction will be thrown out.
78
+ const setupResult = await this.simulatePhase(TxExecutionPhase.SETUP, context);
79
+ if (setupResult.reverted) {
80
+ throw new Error(`Setup phase reverted! The transaction will be thrown out. ${setupResult.revertReason?.message}`);
63
81
  }
64
- const revertStart = process.hrtime.bigint();
65
- const success = await this.insertRevertiblesFromPrivate(context);
66
- if (success) {
67
- // add new contracts to the contracts db so that their functions may be found and called
68
- await this.worldStateDB.addNewRevertibleContracts(tx);
69
- const revertEnd = process.hrtime.bigint();
70
- this.metrics.recordPrivateEffectsInsertion(Number(revertEnd - revertStart) / 1_000, 'revertible');
71
- // Only proceed with app logic if there was no revert during revertible insertion
72
- if (context.hasPhase(TxExecutionPhase.APP_LOGIC)) {
73
- const appLogicResult = await this.simulateAppLogicPhase(context);
74
- processedPhases.push(appLogicResult);
82
+ processedPhases.push(setupResult);
83
+ }
84
+ // The checkpoint we should go back to if anything from now on reverts.
85
+ await context.state.fork();
86
+ hintingContractsDB.createCheckpoint();
87
+ try {
88
+ // This will throw if there is a nullifier collision or other insertion error (limit reached).
89
+ await this.insertRevertiblesFromPrivate(context);
90
+ // Only proceed with app logic if there was no revert during revertible insertion.
91
+ if (context.hasPhase(TxExecutionPhase.APP_LOGIC)) {
92
+ const appLogicResult = await this.simulatePhase(TxExecutionPhase.APP_LOGIC, context);
93
+ processedPhases.push(appLogicResult);
94
+ if (appLogicResult.reverted) {
95
+ throw new TxSimAppLogicRevert();
75
96
  }
97
+ }
98
+ } catch (e) {
99
+ if (e instanceof TxSimRevertibleInsertionsRevert || e instanceof TxSimAppLogicRevert) {
100
+ // We revert to the post-setup state.
101
+ await context.state.discardForkedState();
102
+ hintingContractsDB.revertCheckpoint();
103
+ // But we also create a new fork so that the teardown phase can transparently
104
+ // commit or rollback at the end of teardown.
105
+ await context.state.fork();
106
+ hintingContractsDB.createCheckpoint();
76
107
  } else {
77
- this.log.debug(`Revertible insertions failed. Skipping app logic.`);
108
+ // Unchecked/unknown error - re-throw as-is
109
+ throw e;
78
110
  }
111
+ }
112
+ try {
79
113
  if (context.hasPhase(TxExecutionPhase.TEARDOWN)) {
80
- const teardownResult = await this.simulateTeardownPhase(context);
114
+ const teardownResult = await this.simulatePhase(TxExecutionPhase.TEARDOWN, context);
81
115
  processedPhases.push(teardownResult);
116
+ if (teardownResult.reverted) {
117
+ throw new TxSimTeardownRevert();
118
+ }
82
119
  }
83
- await context.halt();
84
- await this.payFee(context);
85
- const endStateReference = await this.db.getStateReference();
86
- const avmProvingRequest = await context.generateProvingRequest(endStateReference);
87
- const revertCode = context.getFinalRevertCode();
88
- if (!revertCode.isOK()) {
89
- await tx.filterRevertedLogs();
120
+ // We commit the forked state and we are done.
121
+ await context.state.mergeForkedState();
122
+ hintingContractsDB.commitCheckpoint();
123
+ } catch (e) {
124
+ if (e instanceof TxSimTeardownRevert) {
125
+ // We revert to the post-setup state and we are done.
126
+ await context.state.discardForkedState();
127
+ hintingContractsDB.revertCheckpoint();
128
+ } else {
129
+ // Unchecked/unknown error - re-throw as-is
130
+ throw e;
90
131
  }
91
- // Commit contracts from this TX to the block-level cache and clear tx cache
92
- // If the tx reverted, only commit non-revertible contracts
93
- // NOTE: You can't create contracts in public, so this is only relevant for private-created contracts
94
- this.worldStateDB.commitContractsForTx(/*onlyNonRevertibles=*/ !revertCode.isOK());
95
- const endTime = process.hrtime.bigint();
96
- this.log.debug(`Public TX simulator took ${Number(endTime - startTime) / 1_000_000} ms\n`);
97
- return {
98
- avmProvingRequest,
99
- gasUsed: {
100
- totalGas: context.getActualGasUsed(),
101
- teardownGas: context.teardownGasUsed,
102
- publicGas: context.getActualPublicGasUsed(),
103
- billedGas: context.getTotalGasUsed()
104
- },
105
- revertCode,
106
- revertReason: context.revertReason,
107
- processedPhases: processedPhases
108
- };
109
- } finally{
110
- // Make sure there are no new contracts in the tx-level cache.
111
- // They should either be committed to block-level cache or cleared.
112
- this.worldStateDB.clearContractsForTx();
113
132
  }
133
+ context.halt();
134
+ // Such transactions should be filtered by GasTxValidator.
135
+ assert(context.getActualGasUsed().l2Gas <= AVM_MAX_PROCESSABLE_L2_GAS, `Transaction consumes ${context.getActualGasUsed().l2Gas} L2 gas, which exceeds the AVM maximum processable gas of ${AVM_MAX_PROCESSABLE_L2_GAS}`);
136
+ await this.payFee(context);
137
+ const publicInputs = await context.generateAvmCircuitPublicInputs();
138
+ const revertCode = context.getFinalRevertCode();
139
+ // We only return the app logic phase information.
140
+ const appLogicReturnValues = processedPhases.find(({ phase })=>phase === TxExecutionPhase.APP_LOGIC)?.returnValues ?? [];
141
+ return new PublicTxResult(/*gasUsed=*/ {
142
+ totalGas: context.getActualGasUsed(),
143
+ teardownGas: context.teardownGasUsed,
144
+ publicGas: context.getActualPublicGasUsed(),
145
+ billedGas: context.getTotalGasUsed()
146
+ }, /*revertCode=*/ revertCode, /*revertReason=*/ context.revertReason, /*appLogicReturnValues=*/ appLogicReturnValues, /*logs=*/ context.state.getActiveStateManager().getLogs(), /*hints=*/ hints, /*publicInputs=*/ publicInputs);
114
147
  }
115
- /**
116
- * Simulate the setup phase of a transaction's public execution.
117
- * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
118
- * @returns The phase result.
119
- */ async simulateSetupPhase(context) {
120
- return await this.simulatePhase(TxExecutionPhase.SETUP, context);
121
- }
122
- /**
123
- * Simulate the app logic phase of a transaction's public execution.
124
- * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
125
- * @returns The phase result.
126
- */ async simulateAppLogicPhase(context) {
127
- assert(context.state.isForked(), 'App logic phase should operate with forked state.');
128
- const result = await this.simulatePhase(TxExecutionPhase.APP_LOGIC, context);
129
- if (result.reverted) {
130
- // Drop the currently active forked state manager and rollback to end of setup.
131
- await context.state.discardForkedState();
132
- } else {
133
- if (!context.hasPhase(TxExecutionPhase.TEARDOWN)) {
134
- // Nothing to do after this (no teardown), so merge state updates now instead of letting teardown handle it.
135
- await context.state.mergeForkedState();
136
- }
137
- }
138
- return result;
148
+ computeTxHash(tx) {
149
+ return tx.getTxHash();
139
150
  }
140
151
  /**
141
- * Simulate the teardown phase of a transaction's public execution.
142
- * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
143
- * @returns The phase result.
144
- */ async simulateTeardownPhase(context) {
145
- if (!context.state.isForked()) {
146
- // If state isn't forked (app logic reverted), fork now
147
- // so we can rollback to the end of setup if teardown reverts.
148
- await context.state.fork();
149
- }
150
- const result = await this.simulatePhase(TxExecutionPhase.TEARDOWN, context);
151
- if (result.reverted) {
152
- // Drop the currently active forked state manager and rollback to end of setup.
153
- await context.state.discardForkedState();
154
- } else {
155
- // Merge state updates from teardown,
156
- await context.state.mergeForkedState();
157
- }
158
- return result;
159
- }
160
- /**
161
- * Simulate a phase of a transaction's public execution.
162
- * @param phase - The current phase
152
+ * Simulate the setup phase of a transaction's public execution.
163
153
  * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
164
154
  * @returns The phase result.
165
155
  */ async simulatePhase(phase, context) {
166
156
  const callRequests = context.getCallRequestsForPhase(phase);
167
- const executionRequests = context.getExecutionRequestsForPhase(phase);
168
157
  this.log.debug(`Processing phase ${TxExecutionPhase[phase]} for tx ${context.txHash}`, {
169
158
  txHash: context.txHash.toString(),
170
159
  phase: TxExecutionPhase[phase],
171
- callRequests: callRequests.length,
172
- executionRequests: executionRequests.length
160
+ callRequests: callRequests.length
173
161
  });
174
162
  const returnValues = [];
175
163
  let reverted = false;
176
164
  let revertReason;
177
- const phaseTimer = new Timer();
178
- for(let i = callRequests.length - 1; i >= 0; i--){
165
+ for(let i = 0; i < callRequests.length; i++){
179
166
  if (reverted) {
180
167
  break;
181
168
  }
182
169
  const callRequest = callRequests[i];
183
- const executionRequest = executionRequests[i];
184
- const enqueuedCallResult = await this.simulateEnqueuedCall(phase, context, callRequest, executionRequest);
170
+ const enqueuedCallResult = await this.simulateEnqueuedCall(phase, context, callRequest);
185
171
  returnValues.push(new NestedProcessReturnValues(enqueuedCallResult.output));
186
172
  if (enqueuedCallResult.reverted) {
187
173
  reverted = true;
@@ -190,7 +176,6 @@ export class PublicTxSimulator {
190
176
  }
191
177
  return {
192
178
  phase,
193
- durationMs: phaseTimer.ms(),
194
179
  returnValues,
195
180
  reverted,
196
181
  revertReason
@@ -200,22 +185,20 @@ export class PublicTxSimulator {
200
185
  * Simulate an enqueued public call.
201
186
  * @param phase - The current phase of public execution
202
187
  * @param context - WILL BE MUTATED. The context of the currently executing public transaction portion
203
- * @param callRequest - The enqueued call to execute
204
- * @param executionRequest - The execution request (includes args)
188
+ * @param callRequest - The public function call request, including the calldata.
205
189
  * @returns The result of execution.
206
- */ async simulateEnqueuedCall(phase, context, callRequest, executionRequest) {
190
+ */ async simulateEnqueuedCall(phase, context, callRequest) {
207
191
  const stateManager = context.state.getActiveStateManager();
208
- const address = executionRequest.callContext.contractAddress;
209
- const fnName = await getPublicFunctionDebugName(this.worldStateDB, address, executionRequest.args);
192
+ const contractAddress = callRequest.request.contractAddress;
193
+ const fnName = await getPublicFunctionDebugName(this.contractsDB, contractAddress, callRequest.calldata);
210
194
  const allocatedGas = context.getGasLeftAtPhase(phase);
211
- const result = await this.simulateEnqueuedCallInternal(context.state.getActiveStateManager(), executionRequest, allocatedGas, /*transactionFee=*/ context.getTransactionFee(phase), fnName);
195
+ const result = await this.simulateEnqueuedCallInternal(stateManager, callRequest, allocatedGas, /*transactionFee=*/ context.getTransactionFee(phase), fnName);
212
196
  const gasUsed = allocatedGas.sub(result.gasLeft); // by enqueued call
213
197
  context.consumeGas(phase, gasUsed);
214
198
  this.log.debug(`Simulated enqueued public call (${fnName}) consumed ${gasUsed.l2Gas} L2 gas ending with ${result.gasLeft.l2Gas} L2 gas left.`);
215
- stateManager.traceEnqueuedCall(callRequest, executionRequest.args, result.reverted);
216
199
  if (result.reverted) {
217
- const culprit = `${executionRequest.callContext.contractAddress}:${executionRequest.callContext.functionSelector}`;
218
- context.revert(phase, result.revertReason, culprit); // throws if in setup (non-revertible) phase
200
+ const culprit = `${contractAddress}:${callRequest.functionSelector}`;
201
+ context.revert(phase, result.revertReason, culprit);
219
202
  }
220
203
  return result;
221
204
  }
@@ -227,78 +210,110 @@ export class PublicTxSimulator {
227
210
  * while still simulating phases and generating a proving request.
228
211
  *
229
212
  * @param stateManager - The state manager for AvmSimulation
230
- * @param context - The context of the currently executing public transaction portion
231
- * @param executionRequest - The execution request (includes args)
213
+ * @param callRequest - The public function call request, including the calldata.
232
214
  * @param allocatedGas - The gas allocated to the enqueued call
233
215
  * @param fnName - The name of the function
234
216
  * @returns The result of execution.
235
- */ async simulateEnqueuedCallInternal(stateManager, executionRequest, allocatedGas, transactionFee, fnName) {
236
- const address = executionRequest.callContext.contractAddress;
237
- const sender = executionRequest.callContext.msgSender;
217
+ */ async simulateEnqueuedCallInternal(stateManager, { request, calldata }, allocatedGas, transactionFee, fnName) {
218
+ const address = request.contractAddress;
219
+ const sender = request.msgSender;
238
220
  this.log.debug(`Executing enqueued public call to external function ${fnName}@${address} with ${allocatedGas.l2Gas} allocated L2 gas.`);
239
- const timer = new Timer();
240
- const simulator = await AvmSimulator.create(stateManager, address, sender, transactionFee, this.globalVariables, executionRequest.callContext.isStaticCall, executionRequest.args, allocatedGas);
221
+ const simulator = await AvmSimulator.create(stateManager, address, sender, transactionFee, this.globalVariables, request.isStaticCall, calldata, allocatedGas, this.config);
241
222
  const avmCallResult = await simulator.execute();
242
- const result = avmCallResult.finalize();
243
- this.log.verbose(result.reverted ? `Simulation of enqueued public call ${fnName} reverted with reason ${result.revertReason}.` : `Simulation of enqueued public call ${fnName} completed successfully.`, {
244
- eventName: 'avm-simulation',
245
- appCircuitName: fnName,
246
- duration: timer.ms()
247
- });
248
- if (result.reverted) {
249
- this.metrics.recordFunctionSimulationFailure();
250
- } else {
251
- this.metrics.recordFunctionSimulation(timer.ms(), allocatedGas.sub(result.gasLeft).l2Gas, fnName);
252
- }
253
- return result;
223
+ return avmCallResult.finalize();
254
224
  }
255
225
  /**
256
226
  * Insert the non-revertible accumulated data from private into the public state.
257
227
  */ async insertNonRevertiblesFromPrivate(context) {
258
228
  const stateManager = context.state.getActiveStateManager();
259
- try {
260
- await stateManager.writeSiloedNullifiersFromPrivate(context.nonRevertibleAccumulatedDataFromPrivate.nullifiers);
261
- } catch (e) {
262
- if (e instanceof NullifierCollisionError) {
263
- throw new NullifierCollisionError(`Nullifier collision encountered when inserting non-revertible nullifiers from private.\nDetails: ${e.message}\nStack:${e.stack}`);
264
- }
229
+ for (const siloedNullifier of context.nonRevertibleAccumulatedDataFromPrivate.nullifiers.filter((n)=>!n.isEmpty())){
230
+ await stateManager.writeSiloedNullifier(siloedNullifier);
265
231
  }
266
232
  for (const noteHash of context.nonRevertibleAccumulatedDataFromPrivate.noteHashes){
267
233
  if (!noteHash.isEmpty()) {
268
234
  await stateManager.writeUniqueNoteHash(noteHash);
269
235
  }
270
236
  }
237
+ for (const l2ToL1Message of context.nonRevertibleAccumulatedDataFromPrivate.l2ToL1Msgs){
238
+ if (!l2ToL1Message.isEmpty()) {
239
+ stateManager.writeScopedL2ToL1Message(l2ToL1Message);
240
+ }
241
+ }
242
+ // add new contracts to the contracts db so that their code may be found and called
243
+ // FIXME(fcarreiro): this should conceptually use the hinting contracts db.
244
+ // However, things work as expected because later calls to getters on the hintingContractsDB
245
+ // will pick up the new contracts and will generate the necessary hints.
246
+ // So, a consumer of the hints will always see the new contracts.
247
+ await this.contractsDB.addContracts(context.nonRevertibleContractDeploymentData);
271
248
  }
272
249
  /**
273
250
  * Insert the revertible accumulated data from private into the public state.
274
- * Start by forking state so we can rollback to the end of setup if app logic or teardown reverts.
251
+ * Throws TxSimRevertibleInsertionsRevert if there is some checked error during revertible insertions.
252
+ * This function checks for the following errors:
253
+ * - NullifierLimitReachedError
254
+ * - NullifierCollisionError
255
+ * - NoteHashLimitReachedError
256
+ * - L2ToL1MessageLimitReachedError
275
257
  */ async insertRevertiblesFromPrivate(context) {
276
- // Fork the state manager so we can rollback to end of setup if app logic reverts.
277
- await context.state.fork();
278
258
  const stateManager = context.state.getActiveStateManager();
279
259
  try {
280
- await stateManager.writeSiloedNullifiersFromPrivate(context.revertibleAccumulatedDataFromPrivate.nullifiers);
260
+ for (const siloedNullifier of context.revertibleAccumulatedDataFromPrivate.nullifiers.filter((n)=>!n.isEmpty())){
261
+ await stateManager.writeSiloedNullifier(siloedNullifier);
262
+ }
281
263
  } catch (e) {
282
- if (e instanceof NullifierCollisionError) {
283
- // Instead of throwing, revert the app_logic phase
284
- context.revert(TxExecutionPhase.APP_LOGIC, new SimulationError(`Nullifier collision encountered when inserting revertible nullifiers from private\nDetails: ${e.message}\nError stack: ${e.stack}`, []), /*culprit=*/ 'insertRevertiblesFromPrivate');
285
- return /*success=*/ false;
264
+ if (e instanceof NullifierLimitReachedError || e instanceof NullifierCollisionError) {
265
+ context.revert(TxExecutionPhase.APP_LOGIC, new SimulationError(`Error encountered when inserting revertible nullifiers from private.\nDetails: ${e.message}`, []));
266
+ throw new TxSimRevertibleInsertionsRevert();
286
267
  } else {
268
+ // Unchecked/unknown error - re-throw as-is
287
269
  throw e;
288
270
  }
289
271
  }
290
- for (const noteHash of context.revertibleAccumulatedDataFromPrivate.noteHashes){
291
- if (!noteHash.isEmpty()) {
292
- // Revertible note hashes from private are not hashed with nonce, since private can't know their final position, only we can.
293
- await stateManager.writeSiloedNoteHash(noteHash);
272
+ try {
273
+ for (const noteHash of context.revertibleAccumulatedDataFromPrivate.noteHashes){
274
+ if (!noteHash.isEmpty()) {
275
+ // Revertible note hashes from private are not hashed with nonce, since private can't know their final position, only we can.
276
+ await stateManager.writeSiloedNoteHash(noteHash);
277
+ }
278
+ }
279
+ } catch (e) {
280
+ if (e instanceof NoteHashLimitReachedError) {
281
+ context.revert(TxExecutionPhase.APP_LOGIC, new SimulationError(`Error encountered when inserting revertible note hashes from private.\nDetails: ${e.message}`, []));
282
+ throw new TxSimRevertibleInsertionsRevert();
283
+ } else {
284
+ // Unchecked/unknown error - re-throw as-is
285
+ throw e;
286
+ }
287
+ }
288
+ try {
289
+ for (const l2ToL1Message of context.revertibleAccumulatedDataFromPrivate.l2ToL1Msgs){
290
+ if (!l2ToL1Message.isEmpty()) {
291
+ stateManager.writeScopedL2ToL1Message(l2ToL1Message);
292
+ }
293
+ }
294
+ } catch (e) {
295
+ if (e instanceof L2ToL1MessageLimitReachedError) {
296
+ context.revert(TxExecutionPhase.APP_LOGIC, new SimulationError(`Error encountered when inserting revertible L2-to-L1 messages from private.\nDetails: ${e.message}`, []));
297
+ throw new TxSimRevertibleInsertionsRevert();
298
+ } else {
299
+ // Unchecked/unknown error - re-throw as-is
300
+ throw e;
294
301
  }
295
302
  }
296
- return /*success=*/ true;
303
+ // add new contracts to the contracts db so that their functions may be found and called
304
+ // FIXME(fcarreiro): this should conceptually use the hinting contracts db.
305
+ // However, things work as expected because later calls to getters on the hintingContractsDB
306
+ // will pick up the new contracts and will generate the necessary hints.
307
+ // So, a consumer of the hints will always see the new contracts.
308
+ await this.contractsDB.addContracts(context.revertibleContractDeploymentData);
297
309
  }
298
310
  async payFee(context) {
299
311
  const txFee = context.getTransactionFee(TxExecutionPhase.TEARDOWN);
300
312
  if (context.feePayer.isZero()) {
301
- this.log.debug(`No one is paying the fee of ${txFee.toBigInt()}`);
313
+ // Real transactions are enforced by private kernel to have nonzero fee payer.
314
+ // Real transactions cannot skip fee enforcement (skipping fee enforcement makes them unprovable).
315
+ assert(this.config.skipFeeEnforcement, 'Fee payer cannot be 0 unless skipping fee enforcement for simulation');
316
+ this.log.debug(`Fee payer is 0. Skipping fee enforcement. No one is paying the fee of ${txFee.toBigInt()}`);
302
317
  return;
303
318
  }
304
319
  const feeJuiceAddress = ProtocolContractAddress.FeeJuice;
@@ -309,26 +324,13 @@ export class PublicTxSimulator {
309
324
  // We allow to fake the balance of the fee payer to allow fee estimation
310
325
  // When mocking the balance of the fee payer, the circuit should not be able to prove the simulation
311
326
  if (currentBalance.lt(txFee)) {
312
- if (!this.skipFeeEnforcement) {
313
- throw new Error(`Not enough balance for fee payer to pay for transaction (got ${currentBalance.toBigInt()} needs ${txFee.toBigInt()})`);
314
- } else {
315
- currentBalance = txFee;
316
- }
327
+ // Without "skipFeeEnforcement", such transactions should be filtered by GasTxValidator.
328
+ assert(this.config.skipFeeEnforcement, `Not enough balance for fee payer to pay for transaction (got ${currentBalance.toBigInt()} needs ${txFee.toBigInt()})`);
329
+ this.log.debug(`Fee payer balance insufficient, but we're skipping fee enforcement`);
330
+ // We still proceed and perform the storage write to minimize deviation from normal execution.
331
+ currentBalance = txFee;
317
332
  }
318
333
  const updatedBalance = currentBalance.sub(txFee);
319
334
  await stateManager.writeStorage(feeJuiceAddress, balanceSlot, updatedBalance, true);
320
335
  }
321
336
  }
322
- _ts_decorate([
323
- trackSpan('PublicTxSimulator.simulateEnqueuedCall', (phase, context, _callRequest, executionRequest)=>({
324
- [Attributes.TX_HASH]: context.txHash.toString(),
325
- [Attributes.TARGET_ADDRESS]: executionRequest.callContext.contractAddress.toString(),
326
- [Attributes.SENDER_ADDRESS]: executionRequest.callContext.msgSender.toString(),
327
- [Attributes.SIMULATOR_PHASE]: TxExecutionPhase[phase].toString()
328
- }))
329
- ], PublicTxSimulator.prototype, "simulateEnqueuedCall", null);
330
- _ts_decorate([
331
- trackSpan('PublicTxSimulator.simulateEnqueuedCallInternal', (_stateManager, _executionRequest, _allocatedGas, _transactionFee, fnName)=>({
332
- [Attributes.APP_CIRCUIT_NAME]: fnName
333
- }))
334
- ], PublicTxSimulator.prototype, "simulateEnqueuedCallInternal", null);
@@ -0,0 +1,9 @@
1
+ import type { PublicTxResult } from '@aztec/stdlib/avm';
2
+ import type { Tx } from '@aztec/stdlib/tx';
3
+ export interface PublicTxSimulatorInterface {
4
+ simulate(tx: Tx): Promise<PublicTxResult>;
5
+ }
6
+ export interface MeasuredPublicTxSimulatorInterface {
7
+ simulate(tx: Tx, txLabel: string): Promise<PublicTxResult>;
8
+ }
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX3R4X3NpbXVsYXRvcl9pbnRlcmZhY2UuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wdWJsaWMvcHVibGljX3R4X3NpbXVsYXRvci9wdWJsaWNfdHhfc2ltdWxhdG9yX2ludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUN4RCxPQUFPLEtBQUssRUFBRSxFQUFFLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUUzQyxNQUFNLFdBQVcsMEJBQTBCO0lBQ3pDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsRUFBRSxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQztDQUMzQztBQUVELE1BQU0sV0FBVyxrQ0FBa0M7SUFDakQsUUFBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsT0FBTyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUM7Q0FDNUQifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"public_tx_simulator_interface.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/public_tx_simulator_interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAE3C,MAAM,WAAW,0BAA0B;IACzC,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;CAC3C;AAED,MAAM,WAAW,kCAAkC;IACjD,QAAQ,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC;CAC5D"}
@@ -0,0 +1,21 @@
1
+ import type { Fr } from '@aztec/foundation/fields';
2
+ import type { PublicSimulatorConfig } from '@aztec/stdlib/avm';
3
+ import type { Gas } from '@aztec/stdlib/gas';
4
+ import type { MerkleTreeWriteOperations } from '@aztec/stdlib/trees';
5
+ import { type GlobalVariables, PublicCallRequestWithCalldata, TxExecutionPhase } from '@aztec/stdlib/tx';
6
+ import { type TelemetryClient, type Tracer } from '@aztec/telemetry-client';
7
+ import type { AvmFinalizedCallResult } from '../avm/avm_contract_call_result.js';
8
+ import type { PublicContractsDB } from '../public_db_sources.js';
9
+ import type { PublicPersistableStateManager } from '../state_manager/state_manager.js';
10
+ import { MeasuredPublicTxSimulator } from './measured_public_tx_simulator.js';
11
+ import { PublicTxContext } from './public_tx_context.js';
12
+ /**
13
+ * A public tx simulator that tracks runtime/production metrics with telemetry.
14
+ */
15
+ export declare class TelemetryPublicTxSimulator extends MeasuredPublicTxSimulator {
16
+ readonly tracer: Tracer;
17
+ constructor(merkleTree: MerkleTreeWriteOperations, contractsDB: PublicContractsDB, globalVariables: GlobalVariables, telemetryClient?: TelemetryClient, config?: Partial<PublicSimulatorConfig>);
18
+ protected simulateEnqueuedCall(phase: TxExecutionPhase, context: PublicTxContext, callRequest: PublicCallRequestWithCalldata): Promise<AvmFinalizedCallResult>;
19
+ protected simulateEnqueuedCallInternal(stateManager: PublicPersistableStateManager, callRequest: PublicCallRequestWithCalldata, allocatedGas: Gas, transactionFee: Fr, fnName: string): Promise<AvmFinalizedCallResult>;
20
+ }
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVsZW1ldHJ5X3B1YmxpY190eF9zaW11bGF0b3IuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wdWJsaWMvcHVibGljX3R4X3NpbXVsYXRvci90ZWxlbWV0cnlfcHVibGljX3R4X3NpbXVsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxFQUFFLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNuRCxPQUFPLEtBQUssRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQy9ELE9BQU8sS0FBSyxFQUFFLEdBQUcsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQzdDLE9BQU8sS0FBSyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDckUsT0FBTyxFQUFFLEtBQUssZUFBZSxFQUFFLDZCQUE2QixFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDekcsT0FBTyxFQUFjLEtBQUssZUFBZSxFQUFFLEtBQUssTUFBTSxFQUFpQyxNQUFNLHlCQUF5QixDQUFDO0FBRXZILE9BQU8sS0FBSyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFFakYsT0FBTyxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNqRSxPQUFPLEtBQUssRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUV6RDs7R0FFRztBQUNILHFCQUFhLDBCQUEyQixTQUFRLHlCQUF5QjtJQUV2RSxTQUFnQixNQUFNLEVBQUUsTUFBTSxDQUFDO0lBRS9CLFlBQ0UsVUFBVSxFQUFFLHlCQUF5QixFQUNyQyxXQUFXLEVBQUUsaUJBQWlCLEVBQzlCLGVBQWUsRUFBRSxlQUFlLEVBQ2hDLGVBQWUsR0FBRSxlQUFzQyxFQUN2RCxNQUFNLENBQUMsRUFBRSxPQUFPLENBQUMscUJBQXFCLENBQUMsRUFLeEM7SUFFRCxVQU15QixvQkFBb0IsQ0FDM0MsS0FBSyxFQUFFLGdCQUFnQixFQUN2QixPQUFPLEVBQUUsZUFBZSxFQUN4QixXQUFXLEVBQUUsNkJBQTZCLEdBQ3pDLE9BQU8sQ0FBQyxzQkFBc0IsQ0FBQyxDQUVqQztJQUVELFVBTXlCLDRCQUE0QixDQUNuRCxZQUFZLEVBQUUsNkJBQTZCLEVBQzNDLFdBQVcsRUFBRSw2QkFBNkIsRUFDMUMsWUFBWSxFQUFFLEdBQUcsRUFDakIsY0FBYyxFQUFFLEVBQUUsRUFDbEIsTUFBTSxFQUFFLE1BQU0sR0FDYixPQUFPLENBQUMsc0JBQXNCLENBQUMsQ0FFakM7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"telemetry_public_tx_simulator.d.ts","sourceRoot":"","sources":["../../../src/public/public_tx_simulator/telemetry_public_tx_simulator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,0BAA0B,CAAC;AACnD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AAC7C,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,qBAAqB,CAAC;AACrE,OAAO,EAAE,KAAK,eAAe,EAAE,6BAA6B,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AACzG,OAAO,EAAc,KAAK,eAAe,EAAE,KAAK,MAAM,EAAiC,MAAM,yBAAyB,CAAC;AAEvH,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAEjF,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,KAAK,EAAE,6BAA6B,EAAE,MAAM,mCAAmC,CAAC;AACvF,OAAO,EAAE,yBAAyB,EAAE,MAAM,mCAAmC,CAAC;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD;;GAEG;AACH,qBAAa,0BAA2B,SAAQ,yBAAyB;IAEvE,SAAgB,MAAM,EAAE,MAAM,CAAC;IAE/B,YACE,UAAU,EAAE,yBAAyB,EACrC,WAAW,EAAE,iBAAiB,EAC9B,eAAe,EAAE,eAAe,EAChC,eAAe,GAAE,eAAsC,EACvD,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB,CAAC,EAKxC;IAED,UAMyB,oBAAoB,CAC3C,KAAK,EAAE,gBAAgB,EACvB,OAAO,EAAE,eAAe,EACxB,WAAW,EAAE,6BAA6B,GACzC,OAAO,CAAC,sBAAsB,CAAC,CAEjC;IAED,UAMyB,4BAA4B,CACnD,YAAY,EAAE,6BAA6B,EAC3C,WAAW,EAAE,6BAA6B,EAC1C,YAAY,EAAE,GAAG,EACjB,cAAc,EAAE,EAAE,EAClB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,sBAAsB,CAAC,CAEjC;CACF"}
@@ -0,0 +1,39 @@
1
+ function _ts_decorate(decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ }
7
+ import { TxExecutionPhase } from '@aztec/stdlib/tx';
8
+ import { Attributes, getTelemetryClient, trackSpan } from '@aztec/telemetry-client';
9
+ import { ExecutorMetrics } from '../executor_metrics.js';
10
+ import { MeasuredPublicTxSimulator } from './measured_public_tx_simulator.js';
11
+ /**
12
+ * A public tx simulator that tracks runtime/production metrics with telemetry.
13
+ */ export class TelemetryPublicTxSimulator extends MeasuredPublicTxSimulator {
14
+ /* tracer needed by trackSpans */ tracer;
15
+ constructor(merkleTree, contractsDB, globalVariables, telemetryClient = getTelemetryClient(), config){
16
+ const metrics = new ExecutorMetrics(telemetryClient, 'PublicTxSimulator');
17
+ super(merkleTree, contractsDB, globalVariables, metrics, config);
18
+ this.tracer = metrics.tracer;
19
+ }
20
+ async simulateEnqueuedCall(phase, context, callRequest) {
21
+ return await super.simulateEnqueuedCall(phase, context, callRequest);
22
+ }
23
+ async simulateEnqueuedCallInternal(stateManager, callRequest, allocatedGas, transactionFee, fnName) {
24
+ return await super.simulateEnqueuedCallInternal(stateManager, callRequest, allocatedGas, transactionFee, fnName);
25
+ }
26
+ }
27
+ _ts_decorate([
28
+ trackSpan('PublicTxSimulator.simulateEnqueuedCall', (phase, context, callRequest)=>({
29
+ [Attributes.TX_HASH]: context.txHash.toString(),
30
+ [Attributes.TARGET_ADDRESS]: callRequest.request.contractAddress.toString(),
31
+ [Attributes.SENDER_ADDRESS]: callRequest.request.msgSender.toString(),
32
+ [Attributes.SIMULATOR_PHASE]: TxExecutionPhase[phase].toString()
33
+ }))
34
+ ], TelemetryPublicTxSimulator.prototype, "simulateEnqueuedCall", null);
35
+ _ts_decorate([
36
+ trackSpan('PublicTxSimulator.simulateEnqueuedCallInternal', (_stateManager, _callRequest, _allocatedGas, _transactionFee, fnName)=>({
37
+ [Attributes.APP_CIRCUIT_NAME]: fnName
38
+ }))
39
+ ], TelemetryPublicTxSimulator.prototype, "simulateEnqueuedCallInternal", null);