@aztec/pxe 0.0.1-commit.24de95ac → 0.0.1-commit.2606882

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 (521) hide show
  1. package/dest/bin/check_oracle_version.d.ts +1 -1
  2. package/dest/bin/check_oracle_version.js +54 -20
  3. package/dest/bin/index.d.ts +2 -0
  4. package/dest/bin/index.d.ts.map +1 -0
  5. package/dest/bin/index.js +1 -0
  6. package/dest/bin/oracle_version_helpers.d.ts +26 -0
  7. package/dest/bin/oracle_version_helpers.d.ts.map +1 -0
  8. package/dest/bin/oracle_version_helpers.js +93 -0
  9. package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
  10. package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
  11. package/dest/block_synchronizer/block_stream_source.js +62 -0
  12. package/dest/block_synchronizer/block_synchronizer.d.ts +49 -0
  13. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -0
  14. package/dest/block_synchronizer/block_synchronizer.js +173 -0
  15. package/dest/block_synchronizer/index.d.ts +2 -0
  16. package/dest/block_synchronizer/index.d.ts.map +1 -0
  17. package/dest/block_synchronizer/index.js +1 -0
  18. package/dest/config/index.d.ts +13 -13
  19. package/dest/config/index.d.ts.map +1 -1
  20. package/dest/config/index.js +24 -15
  21. package/dest/config/package_info.d.ts +1 -1
  22. package/dest/config/package_info.js +1 -1
  23. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  24. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  25. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  26. package/dest/contract_function_simulator/contract_function_simulator.d.ts +89 -26
  27. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/contract_function_simulator.js +267 -88
  29. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  30. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  31. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  32. package/dest/contract_function_simulator/execution_note_cache.d.ts +26 -15
  33. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  34. package/dest/contract_function_simulator/execution_note_cache.js +59 -34
  35. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -11
  36. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  37. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -15
  38. package/dest/contract_function_simulator/hashed_values_cache.d.ts +2 -2
  39. package/dest/contract_function_simulator/hashed_values_cache.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/index.d.ts +15 -3
  41. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  42. package/dest/contract_function_simulator/index.js +12 -1
  43. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
  44. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
  45. package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
  46. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts +37 -0
  47. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts.map +1 -0
  48. package/dest/contract_function_simulator/noir-structs/ephemeral_array.js +59 -0
  49. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +6 -6
  50. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  51. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +12 -10
  52. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +16 -5
  53. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
  54. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +39 -7
  55. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +4 -4
  56. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  57. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +3 -5
  58. package/dest/contract_function_simulator/noir-structs/note_data.d.ts +27 -0
  59. package/dest/contract_function_simulator/noir-structs/note_data.d.ts.map +1 -0
  60. package/dest/contract_function_simulator/noir-structs/note_data.js +3 -0
  61. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +7 -7
  62. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  63. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +15 -10
  64. package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
  65. package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
  66. package/dest/contract_function_simulator/noir-structs/option.js +62 -0
  67. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts +11 -0
  68. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts.map +1 -0
  69. package/dest/contract_function_simulator/noir-structs/provided_secret.js +24 -0
  70. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  71. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  72. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  73. package/dest/contract_function_simulator/oracle/index.d.ts +1 -1
  74. package/dest/contract_function_simulator/oracle/interfaces.d.ts +16 -88
  75. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  76. package/dest/contract_function_simulator/oracle/interfaces.js +2 -2
  77. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +2 -2
  78. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  79. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.js +1 -1
  80. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +14 -8
  81. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  82. package/dest/contract_function_simulator/oracle/note_packing_utils.js +17 -12
  83. package/dest/contract_function_simulator/oracle/oracle.d.ts +75 -43
  84. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  85. package/dest/contract_function_simulator/oracle/oracle.js +475 -251
  86. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +127 -0
  87. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
  88. package/dest/contract_function_simulator/oracle/oracle_registry.js +786 -0
  89. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts +139 -0
  90. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts.map +1 -0
  91. package/dest/contract_function_simulator/oracle/oracle_type_mappings.js +560 -0
  92. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -27
  93. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  94. package/dest/contract_function_simulator/oracle/private_execution.js +6 -40
  95. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +78 -102
  96. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  97. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +177 -137
  98. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +189 -60
  99. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  100. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +507 -118
  101. package/dest/contract_function_simulator/pick_notes.d.ts +2 -2
  102. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  103. package/dest/contract_function_simulator/pick_notes.js +21 -4
  104. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +4 -4
  105. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  106. package/dest/contract_function_simulator/proxied_contract_data_source.js +39 -50
  107. package/dest/contract_logging.d.ts +27 -0
  108. package/dest/contract_logging.d.ts.map +1 -0
  109. package/dest/contract_logging.js +38 -0
  110. package/dest/contract_sync/contract_sync_service.d.ts +42 -0
  111. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  112. package/dest/contract_sync/contract_sync_service.js +135 -0
  113. package/dest/contract_sync/helpers.d.ts +27 -0
  114. package/dest/contract_sync/helpers.d.ts.map +1 -0
  115. package/dest/contract_sync/helpers.js +53 -0
  116. package/dest/debug/pxe_debug_utils.d.ts +40 -0
  117. package/dest/debug/pxe_debug_utils.d.ts.map +1 -0
  118. package/dest/debug/pxe_debug_utils.js +42 -0
  119. package/dest/entrypoints/client/bundle/index.d.ts +3 -2
  120. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  121. package/dest/entrypoints/client/bundle/index.js +2 -1
  122. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  123. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  124. package/dest/entrypoints/client/bundle/utils.js +43 -12
  125. package/dest/entrypoints/client/lazy/index.d.ts +3 -2
  126. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  127. package/dest/entrypoints/client/lazy/index.js +2 -1
  128. package/dest/entrypoints/client/lazy/utils.d.ts +3 -3
  129. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  130. package/dest/entrypoints/client/lazy/utils.js +44 -13
  131. package/dest/entrypoints/pxe_creation_options.d.ts +15 -3
  132. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  133. package/dest/entrypoints/pxe_creation_options.js +3 -1
  134. package/dest/entrypoints/server/index.d.ts +7 -3
  135. package/dest/entrypoints/server/index.d.ts.map +1 -1
  136. package/dest/entrypoints/server/index.js +6 -2
  137. package/dest/entrypoints/server/utils.d.ts +4 -3
  138. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  139. package/dest/entrypoints/server/utils.js +50 -30
  140. package/dest/error_enriching.d.ts +4 -4
  141. package/dest/error_enriching.d.ts.map +1 -1
  142. package/dest/error_enriching.js +6 -6
  143. package/dest/events/event_service.d.ts +24 -0
  144. package/dest/events/event_service.d.ts.map +1 -0
  145. package/dest/events/event_service.js +77 -0
  146. package/dest/events/index.d.ts +2 -0
  147. package/dest/events/index.d.ts.map +1 -0
  148. package/dest/events/index.js +1 -0
  149. package/dest/events/private_event_filter_validator.d.ts +10 -0
  150. package/dest/events/private_event_filter_validator.d.ts.map +1 -0
  151. package/dest/events/private_event_filter_validator.js +53 -0
  152. package/dest/hooks/authorize_utility_call.d.ts +41 -0
  153. package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
  154. package/dest/hooks/authorize_utility_call.js +4 -0
  155. package/dest/hooks/execution_hooks.d.ts +42 -0
  156. package/dest/hooks/execution_hooks.d.ts.map +1 -0
  157. package/dest/hooks/execution_hooks.js +9 -0
  158. package/dest/hooks/index.d.ts +4 -0
  159. package/dest/hooks/index.d.ts.map +1 -0
  160. package/dest/hooks/index.js +1 -0
  161. package/dest/job_coordinator/job_coordinator.d.ts +75 -0
  162. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
  163. package/dest/job_coordinator/job_coordinator.js +94 -0
  164. package/dest/logs/log_service.d.ts +29 -0
  165. package/dest/logs/log_service.d.ts.map +1 -0
  166. package/dest/logs/log_service.js +172 -0
  167. package/dest/messages/message_context_service.d.ts +17 -0
  168. package/dest/messages/message_context_service.d.ts.map +1 -0
  169. package/dest/messages/message_context_service.js +55 -0
  170. package/dest/notes/index.d.ts +2 -0
  171. package/dest/notes/index.d.ts.map +1 -0
  172. package/dest/notes/index.js +1 -0
  173. package/dest/notes/note_service.d.ts +70 -0
  174. package/dest/notes/note_service.d.ts.map +1 -0
  175. package/dest/notes/note_service.js +172 -0
  176. package/dest/notes_filter.d.ts +24 -0
  177. package/dest/notes_filter.d.ts.map +1 -0
  178. package/dest/notes_filter.js +4 -0
  179. package/dest/oracle_version.d.ts +4 -3
  180. package/dest/oracle_version.d.ts.map +1 -1
  181. package/dest/oracle_version.js +20 -9
  182. package/dest/private_kernel/batch_planner.d.ts +47 -0
  183. package/dest/private_kernel/batch_planner.d.ts.map +1 -0
  184. package/dest/private_kernel/batch_planner.js +104 -0
  185. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  186. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  187. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  188. package/dest/private_kernel/hints/index.d.ts +3 -3
  189. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  190. package/dest/private_kernel/hints/index.js +2 -2
  191. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  192. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  193. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +145 -78
  194. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  195. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  196. package/dest/private_kernel/hints/test_utils.js +202 -0
  197. package/dest/private_kernel/index.d.ts +1 -1
  198. package/dest/private_kernel/private_kernel_execution_prover.d.ts +7 -2
  199. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  200. package/dest/private_kernel/private_kernel_execution_prover.js +177 -76
  201. package/dest/private_kernel/private_kernel_oracle.d.ts +30 -29
  202. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  203. package/dest/private_kernel/private_kernel_oracle.js +96 -2
  204. package/dest/pxe.d.ts +170 -103
  205. package/dest/pxe.d.ts.map +1 -1
  206. package/dest/pxe.js +356 -306
  207. package/dest/storage/address_store/address_store.d.ts +11 -0
  208. package/dest/storage/address_store/address_store.d.ts.map +1 -0
  209. package/dest/storage/{address_data_provider/address_data_provider.js → address_store/address_store.js} +13 -12
  210. package/dest/storage/address_store/index.d.ts +2 -0
  211. package/dest/storage/address_store/index.d.ts.map +1 -0
  212. package/dest/storage/address_store/index.js +1 -0
  213. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +17 -0
  214. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -0
  215. package/dest/storage/anchor_block_store/anchor_block_store.js +26 -0
  216. package/dest/storage/anchor_block_store/index.d.ts +2 -0
  217. package/dest/storage/anchor_block_store/index.d.ts.map +1 -0
  218. package/dest/storage/anchor_block_store/index.js +1 -0
  219. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
  220. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
  221. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
  222. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
  223. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
  224. package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
  225. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
  226. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
  227. package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
  228. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  229. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  230. package/dest/storage/capsule_store/capsule_service.js +50 -0
  231. package/dest/storage/capsule_store/capsule_store.d.ts +72 -0
  232. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -0
  233. package/dest/storage/capsule_store/capsule_store.js +261 -0
  234. package/dest/storage/capsule_store/index.d.ts +3 -0
  235. package/dest/storage/capsule_store/index.d.ts.map +1 -0
  236. package/dest/storage/capsule_store/index.js +2 -0
  237. package/dest/storage/contract_store/contract_store.d.ts +93 -0
  238. package/dest/storage/contract_store/contract_store.d.ts.map +1 -0
  239. package/dest/storage/contract_store/contract_store.js +292 -0
  240. package/dest/storage/contract_store/index.d.ts +2 -0
  241. package/dest/storage/contract_store/index.d.ts.map +1 -0
  242. package/dest/storage/contract_store/index.js +1 -0
  243. package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.d.ts +1 -1
  244. package/dest/storage/contract_store/private_functions_tree.d.ts.map +1 -0
  245. package/dest/storage/{contract_data_provider → contract_store}/private_functions_tree.js +1 -1
  246. package/dest/storage/index.d.ts +8 -8
  247. package/dest/storage/index.d.ts.map +1 -1
  248. package/dest/storage/index.js +7 -7
  249. package/dest/storage/metadata.d.ts +2 -2
  250. package/dest/storage/metadata.js +1 -1
  251. package/dest/storage/note_store/index.d.ts +3 -0
  252. package/dest/storage/note_store/index.d.ts.map +1 -0
  253. package/dest/storage/note_store/index.js +2 -0
  254. package/dest/storage/note_store/note_store.d.ts +83 -0
  255. package/dest/storage/note_store/note_store.d.ts.map +1 -0
  256. package/dest/storage/note_store/note_store.js +343 -0
  257. package/dest/storage/note_store/stored_note.d.ts +16 -0
  258. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  259. package/dest/storage/note_store/stored_note.js +43 -0
  260. package/dest/storage/open_pxe_stores.d.ts +33 -0
  261. package/dest/storage/open_pxe_stores.d.ts.map +1 -0
  262. package/dest/storage/open_pxe_stores.js +27 -0
  263. package/dest/storage/private_event_store/private_event_store.d.ts +91 -0
  264. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -0
  265. package/dest/storage/private_event_store/private_event_store.js +276 -0
  266. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  267. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  268. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  269. package/dest/storage/tagging_store/index.d.ts +4 -0
  270. package/dest/storage/tagging_store/index.d.ts.map +1 -0
  271. package/dest/storage/tagging_store/index.js +3 -0
  272. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +28 -0
  273. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -0
  274. package/dest/storage/tagging_store/recipient_tagging_store.js +111 -0
  275. package/dest/storage/tagging_store/sender_address_book_store.d.ts +14 -0
  276. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -0
  277. package/dest/storage/tagging_store/sender_address_book_store.js +36 -0
  278. package/dest/storage/tagging_store/sender_tagging_store.d.ts +78 -0
  279. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -0
  280. package/dest/storage/tagging_store/sender_tagging_store.js +374 -0
  281. package/dest/tagging/constants.d.ts +2 -2
  282. package/dest/tagging/constants.d.ts.map +1 -1
  283. package/dest/tagging/constants.js +10 -2
  284. package/dest/tagging/get_all_logs_by_tags.d.ts +48 -0
  285. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  286. package/dest/tagging/get_all_logs_by_tags.js +59 -0
  287. package/dest/tagging/index.d.ts +18 -7
  288. package/dest/tagging/index.d.ts.map +1 -1
  289. package/dest/tagging/index.js +16 -5
  290. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
  291. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
  292. package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
  293. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
  294. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
  295. package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
  296. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +12 -0
  297. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -0
  298. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +20 -0
  299. package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
  300. package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
  301. package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
  302. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +16 -0
  303. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -0
  304. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +92 -0
  305. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +17 -0
  306. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -0
  307. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +60 -0
  308. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +19 -0
  309. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -0
  310. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +72 -0
  311. package/package.json +33 -20
  312. package/src/bin/check_oracle_version.ts +63 -25
  313. package/src/bin/index.ts +1 -0
  314. package/src/bin/oracle_version_helpers.ts +121 -0
  315. package/src/block_synchronizer/block_stream_source.ts +81 -0
  316. package/src/block_synchronizer/block_synchronizer.ts +200 -0
  317. package/src/block_synchronizer/index.ts +1 -0
  318. package/src/config/index.ts +31 -26
  319. package/src/config/package_info.ts +1 -1
  320. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  321. package/src/contract_function_simulator/contract_function_simulator.ts +462 -122
  322. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  323. package/src/contract_function_simulator/execution_note_cache.ts +59 -29
  324. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
  325. package/src/contract_function_simulator/hashed_values_cache.ts +1 -1
  326. package/src/contract_function_simulator/index.ts +52 -2
  327. package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
  328. package/src/contract_function_simulator/noir-structs/ephemeral_array.ts +66 -0
  329. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +15 -10
  330. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +40 -6
  331. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +4 -7
  332. package/src/contract_function_simulator/noir-structs/note_data.ts +27 -0
  333. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +17 -10
  334. package/src/contract_function_simulator/noir-structs/option.ts +69 -0
  335. package/src/contract_function_simulator/noir-structs/provided_secret.ts +27 -0
  336. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  337. package/src/contract_function_simulator/oracle/interfaces.ts +12 -151
  338. package/src/contract_function_simulator/oracle/message_load_oracle_inputs.ts +1 -1
  339. package/src/contract_function_simulator/oracle/note_packing_utils.ts +31 -15
  340. package/src/contract_function_simulator/oracle/oracle.ts +570 -434
  341. package/src/contract_function_simulator/oracle/oracle_registry.ts +585 -0
  342. package/src/contract_function_simulator/oracle/oracle_type_mappings.ts +553 -0
  343. package/src/contract_function_simulator/oracle/private_execution.ts +6 -72
  344. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +230 -188
  345. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +751 -142
  346. package/src/contract_function_simulator/pick_notes.ts +23 -4
  347. package/src/contract_function_simulator/proxied_contract_data_source.ts +47 -53
  348. package/src/contract_logging.ts +52 -0
  349. package/src/contract_sync/contract_sync_service.ts +189 -0
  350. package/src/contract_sync/helpers.ts +86 -0
  351. package/src/debug/pxe_debug_utils.ts +85 -0
  352. package/src/entrypoints/client/bundle/index.ts +2 -1
  353. package/src/entrypoints/client/bundle/utils.ts +33 -21
  354. package/src/entrypoints/client/lazy/index.ts +2 -1
  355. package/src/entrypoints/client/lazy/utils.ts +35 -23
  356. package/src/entrypoints/pxe_creation_options.ts +20 -2
  357. package/src/entrypoints/server/index.ts +6 -2
  358. package/src/entrypoints/server/utils.ts +47 -60
  359. package/src/error_enriching.ts +7 -15
  360. package/src/events/event_service.ts +119 -0
  361. package/src/events/index.ts +1 -0
  362. package/src/events/private_event_filter_validator.ts +66 -0
  363. package/src/hooks/authorize_utility_call.ts +44 -0
  364. package/src/hooks/execution_hooks.ts +48 -0
  365. package/src/hooks/index.ts +7 -0
  366. package/src/job_coordinator/job_coordinator.ts +150 -0
  367. package/src/logs/log_service.ts +237 -0
  368. package/src/messages/message_context_service.ts +62 -0
  369. package/src/notes/index.ts +1 -0
  370. package/src/notes/note_service.ts +230 -0
  371. package/src/notes_filter.ts +24 -0
  372. package/src/oracle_version.ts +20 -9
  373. package/src/private_kernel/batch_planner.ts +169 -0
  374. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  375. package/src/private_kernel/hints/index.ts +2 -2
  376. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +200 -146
  377. package/src/private_kernel/hints/test_utils.ts +318 -0
  378. package/src/private_kernel/private_kernel_execution_prover.ts +272 -110
  379. package/src/private_kernel/private_kernel_oracle.ts +130 -39
  380. package/src/pxe.ts +606 -414
  381. package/src/storage/{address_data_provider/address_data_provider.ts → address_store/address_store.ts} +16 -16
  382. package/src/storage/address_store/index.ts +1 -0
  383. package/src/storage/{sync_data_provider/sync_data_provider.ts → anchor_block_store/anchor_block_store.ts} +11 -12
  384. package/src/storage/anchor_block_store/index.ts +1 -0
  385. package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
  386. package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
  387. package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
  388. package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
  389. package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
  390. package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
  391. package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
  392. package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
  393. package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
  394. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
  395. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
  396. package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
  397. package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
  398. package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
  399. package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
  400. package/src/storage/capsule_store/capsule_service.ts +90 -0
  401. package/src/storage/capsule_store/capsule_store.ts +333 -0
  402. package/src/storage/capsule_store/index.ts +2 -0
  403. package/src/storage/contract_store/contract_store.ts +408 -0
  404. package/src/storage/contract_store/index.ts +1 -0
  405. package/src/storage/{contract_data_provider → contract_store}/private_functions_tree.ts +1 -1
  406. package/src/storage/index.ts +7 -7
  407. package/src/storage/metadata.ts +1 -1
  408. package/src/storage/note_store/index.ts +2 -0
  409. package/src/storage/note_store/note_store.ts +415 -0
  410. package/src/storage/note_store/stored_note.ts +48 -0
  411. package/src/storage/open_pxe_stores.ts +49 -0
  412. package/src/storage/private_event_store/private_event_store.ts +388 -0
  413. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  414. package/src/storage/tagging_store/index.ts +3 -0
  415. package/src/storage/tagging_store/recipient_tagging_store.ts +139 -0
  416. package/src/storage/tagging_store/sender_address_book_store.ts +48 -0
  417. package/src/storage/tagging_store/sender_tagging_store.ts +476 -0
  418. package/src/tagging/constants.ts +10 -2
  419. package/src/tagging/get_all_logs_by_tags.ts +120 -0
  420. package/src/tagging/index.ts +20 -6
  421. package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
  422. package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
  423. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +34 -0
  424. package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
  425. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +134 -0
  426. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +66 -0
  427. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +84 -0
  428. package/dest/contract_function_simulator/execution_data_provider.d.ts +0 -274
  429. package/dest/contract_function_simulator/execution_data_provider.d.ts.map +0 -1
  430. package/dest/contract_function_simulator/execution_data_provider.js +0 -14
  431. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  432. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  433. package/dest/contract_function_simulator/proxied_node.js +0 -27
  434. package/dest/contract_function_simulator/pxe_oracle_interface.d.ts +0 -122
  435. package/dest/contract_function_simulator/pxe_oracle_interface.d.ts.map +0 -1
  436. package/dest/contract_function_simulator/pxe_oracle_interface.js +0 -701
  437. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  438. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  439. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  440. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  441. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -45
  442. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  443. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -86
  444. package/dest/storage/address_data_provider/address_data_provider.d.ts +0 -11
  445. package/dest/storage/address_data_provider/address_data_provider.d.ts.map +0 -1
  446. package/dest/storage/address_data_provider/index.d.ts +0 -2
  447. package/dest/storage/address_data_provider/index.d.ts.map +0 -1
  448. package/dest/storage/address_data_provider/index.js +0 -1
  449. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts +0 -25
  450. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts.map +0 -1
  451. package/dest/storage/capsule_data_provider/capsule_data_provider.js +0 -118
  452. package/dest/storage/capsule_data_provider/index.d.ts +0 -2
  453. package/dest/storage/capsule_data_provider/index.d.ts.map +0 -1
  454. package/dest/storage/capsule_data_provider/index.js +0 -1
  455. package/dest/storage/contract_data_provider/contract_data_provider.d.ts +0 -74
  456. package/dest/storage/contract_data_provider/contract_data_provider.d.ts.map +0 -1
  457. package/dest/storage/contract_data_provider/contract_data_provider.js +0 -205
  458. package/dest/storage/contract_data_provider/index.d.ts +0 -2
  459. package/dest/storage/contract_data_provider/index.d.ts.map +0 -1
  460. package/dest/storage/contract_data_provider/index.js +0 -1
  461. package/dest/storage/contract_data_provider/private_functions_tree.d.ts.map +0 -1
  462. package/dest/storage/note_data_provider/index.d.ts +0 -3
  463. package/dest/storage/note_data_provider/index.d.ts.map +0 -1
  464. package/dest/storage/note_data_provider/index.js +0 -2
  465. package/dest/storage/note_data_provider/note_dao.d.ts +0 -100
  466. package/dest/storage/note_data_provider/note_dao.d.ts.map +0 -1
  467. package/dest/storage/note_data_provider/note_dao.js +0 -102
  468. package/dest/storage/note_data_provider/note_data_provider.d.ts +0 -83
  469. package/dest/storage/note_data_provider/note_data_provider.d.ts.map +0 -1
  470. package/dest/storage/note_data_provider/note_data_provider.js +0 -308
  471. package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts +0 -43
  472. package/dest/storage/private_event_data_provider/private_event_data_provider.d.ts.map +0 -1
  473. package/dest/storage/private_event_data_provider/private_event_data_provider.js +0 -104
  474. package/dest/storage/sync_data_provider/index.d.ts +0 -2
  475. package/dest/storage/sync_data_provider/index.d.ts.map +0 -1
  476. package/dest/storage/sync_data_provider/index.js +0 -1
  477. package/dest/storage/sync_data_provider/sync_data_provider.d.ts +0 -10
  478. package/dest/storage/sync_data_provider/sync_data_provider.d.ts.map +0 -1
  479. package/dest/storage/sync_data_provider/sync_data_provider.js +0 -26
  480. package/dest/storage/tagging_data_provider/index.d.ts +0 -2
  481. package/dest/storage/tagging_data_provider/index.d.ts.map +0 -1
  482. package/dest/storage/tagging_data_provider/index.js +0 -1
  483. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts +0 -40
  484. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts.map +0 -1
  485. package/dest/storage/tagging_data_provider/tagging_data_provider.js +0 -89
  486. package/dest/synchronizer/index.d.ts +0 -2
  487. package/dest/synchronizer/index.d.ts.map +0 -1
  488. package/dest/synchronizer/index.js +0 -1
  489. package/dest/synchronizer/synchronizer.d.ts +0 -35
  490. package/dest/synchronizer/synchronizer.d.ts.map +0 -1
  491. package/dest/synchronizer/synchronizer.js +0 -101
  492. package/dest/tagging/siloed_tag.d.ts +0 -14
  493. package/dest/tagging/siloed_tag.d.ts.map +0 -1
  494. package/dest/tagging/siloed_tag.js +0 -20
  495. package/dest/tagging/tag.d.ts +0 -12
  496. package/dest/tagging/tag.d.ts.map +0 -1
  497. package/dest/tagging/tag.js +0 -17
  498. package/dest/tagging/utils.d.ts +0 -18
  499. package/dest/tagging/utils.d.ts.map +0 -1
  500. package/dest/tagging/utils.js +0 -24
  501. package/src/contract_function_simulator/execution_data_provider.ts +0 -343
  502. package/src/contract_function_simulator/proxied_node.ts +0 -33
  503. package/src/contract_function_simulator/pxe_oracle_interface.ts +0 -1019
  504. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -132
  505. package/src/storage/address_data_provider/index.ts +0 -1
  506. package/src/storage/capsule_data_provider/capsule_data_provider.ts +0 -147
  507. package/src/storage/capsule_data_provider/index.ts +0 -1
  508. package/src/storage/contract_data_provider/contract_data_provider.ts +0 -294
  509. package/src/storage/contract_data_provider/index.ts +0 -1
  510. package/src/storage/note_data_provider/index.ts +0 -2
  511. package/src/storage/note_data_provider/note_dao.ts +0 -154
  512. package/src/storage/note_data_provider/note_data_provider.ts +0 -393
  513. package/src/storage/private_event_data_provider/private_event_data_provider.ts +0 -148
  514. package/src/storage/sync_data_provider/index.ts +0 -1
  515. package/src/storage/tagging_data_provider/index.ts +0 -1
  516. package/src/storage/tagging_data_provider/tagging_data_provider.ts +0 -120
  517. package/src/synchronizer/index.ts +0 -1
  518. package/src/synchronizer/synchronizer.ts +0 -120
  519. package/src/tagging/siloed_tag.ts +0 -22
  520. package/src/tagging/tag.ts +0 -16
  521. package/src/tagging/utils.ts +0 -31
@@ -2,25 +2,31 @@ import {
2
2
  AVM_EMITNOTEHASH_BASE_L2_GAS,
3
3
  AVM_EMITNULLIFIER_BASE_L2_GAS,
4
4
  AVM_SENDL2TOL1MSG_BASE_L2_GAS,
5
- DA_BYTES_PER_FIELD,
6
- DA_GAS_PER_BYTE,
5
+ DA_GAS_PER_FIELD,
7
6
  FIXED_AVM_STARTUP_L2_GAS,
8
- FIXED_DA_GAS,
9
- FIXED_L2_GAS,
10
7
  L2_GAS_PER_CONTRACT_CLASS_LOG,
8
+ L2_GAS_PER_L2_TO_L1_MSG,
9
+ L2_GAS_PER_NOTE_HASH,
10
+ L2_GAS_PER_NULLIFIER,
11
11
  L2_GAS_PER_PRIVATE_LOG,
12
12
  MAX_CONTRACT_CLASS_LOGS_PER_TX,
13
13
  MAX_ENQUEUED_CALLS_PER_TX,
14
14
  MAX_L2_TO_L1_MSGS_PER_TX,
15
15
  MAX_NOTE_HASHES_PER_TX,
16
+ MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
16
17
  MAX_NULLIFIERS_PER_TX,
18
+ MAX_NULLIFIER_READ_REQUESTS_PER_TX,
17
19
  MAX_PRIVATE_LOGS_PER_TX,
20
+ MAX_TX_LIFETIME,
21
+ PRIVATE_TX_L2_GAS_OVERHEAD,
22
+ PUBLIC_TX_L2_GAS_OVERHEAD,
23
+ TX_DA_GAS_OVERHEAD,
18
24
  } from '@aztec/constants';
19
25
  import { arrayNonEmptyLength, padArrayEnd } from '@aztec/foundation/collection';
20
- import { poseidon2Hash } from '@aztec/foundation/crypto';
21
- import { Fr } from '@aztec/foundation/fields';
26
+ import { Fr } from '@aztec/foundation/curves/bn254';
22
27
  import { type Logger, createLogger } from '@aztec/foundation/log';
23
28
  import { Timer } from '@aztec/foundation/timer';
29
+ import type { KeyStore } from '@aztec/key-store';
24
30
  import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
25
31
  import { protocolContractsHash } from '@aztec/protocol-contracts';
26
32
  import {
@@ -32,98 +38,188 @@ import {
32
38
  toACVMWitness,
33
39
  witnessMapToFields,
34
40
  } from '@aztec/simulator/client';
35
- import type { AbiDecoded, FunctionCall } from '@aztec/stdlib/abi';
36
- import { FunctionSelector, FunctionType, decodeFromAbi } from '@aztec/stdlib/abi';
41
+ import type { FunctionCall } from '@aztec/stdlib/abi';
42
+ import { FunctionSelector, FunctionType } from '@aztec/stdlib/abi';
37
43
  import type { AuthWitness } from '@aztec/stdlib/auth-witness';
38
44
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
45
+ import type { BlockParameter, L2TipsProvider } from '@aztec/stdlib/block';
39
46
  import { Gas } from '@aztec/stdlib/gas';
40
- import { computeNoteHashNonce, computeUniqueNoteHash, siloNoteHash, siloNullifier } from '@aztec/stdlib/hash';
41
47
  import {
48
+ computeNoteHashNonce,
49
+ computeProtocolNullifier,
50
+ computeSiloedPrivateLogFirstField,
51
+ computeUniqueNoteHash,
52
+ siloNoteHash,
53
+ siloNullifier,
54
+ } from '@aztec/stdlib/hash';
55
+ import type { AztecNode } from '@aztec/stdlib/interfaces/server';
56
+ import {
57
+ ClaimedLengthArray,
42
58
  PartialPrivateTailPublicInputsForPublic,
43
59
  PartialPrivateTailPublicInputsForRollup,
44
60
  type PrivateExecutionStep,
45
61
  type PrivateKernelExecutionProofOutput,
46
62
  PrivateKernelTailCircuitPublicInputs,
63
+ PrivateLogData,
47
64
  PrivateToPublicAccumulatedData,
48
65
  PrivateToRollupAccumulatedData,
49
66
  PublicCallRequest,
67
+ ReadRequestActionEnum,
50
68
  ScopedLogHash,
69
+ ScopedNoteHash,
70
+ ScopedNullifier,
71
+ ScopedReadRequest,
72
+ buildTransientDataHints,
73
+ getNoteHashReadRequestResetActions,
74
+ getNullifierReadRequestResetActions,
51
75
  } from '@aztec/stdlib/kernel';
52
76
  import { PrivateLog } from '@aztec/stdlib/logs';
53
77
  import { ScopedL2ToL1Message } from '@aztec/stdlib/messaging';
54
78
  import { ChonkProof } from '@aztec/stdlib/proofs';
79
+ import { MerkleTreeId } from '@aztec/stdlib/trees';
55
80
  import {
81
+ BlockHeader,
56
82
  CallContext,
57
83
  HashedValues,
84
+ type OffchainEffect,
58
85
  PrivateExecutionResult,
59
86
  TxConstantData,
60
87
  TxExecutionRequest,
61
88
  collectNested,
89
+ collectNoteHashNullifierCounterMap,
62
90
  getFinalMinRevertibleSideEffectCounter,
63
91
  } from '@aztec/stdlib/tx';
64
92
 
65
- import type { ContractDataProvider } from '../storage/index.js';
66
- import type { ExecutionDataProvider } from './execution_data_provider.js';
93
+ import type { ContractSyncService } from '../contract_sync/contract_sync_service.js';
94
+ import type { ExecutionHooks } from '../hooks/index.js';
95
+ import type { MessageContextService } from '../messages/message_context_service.js';
96
+ import type { AddressStore } from '../storage/address_store/address_store.js';
97
+ import { CapsuleService } from '../storage/capsule_store/capsule_service.js';
98
+ import type { CapsuleStore } from '../storage/capsule_store/capsule_store.js';
99
+ import type { ContractStore } from '../storage/contract_store/contract_store.js';
100
+ import type { NoteStore } from '../storage/note_store/note_store.js';
101
+ import type { PrivateEventStore } from '../storage/private_event_store/private_event_store.js';
102
+ import type { RecipientTaggingStore } from '../storage/tagging_store/recipient_tagging_store.js';
103
+ import type { SenderAddressBookStore } from '../storage/tagging_store/sender_address_book_store.js';
104
+ import type { SenderTaggingStore } from '../storage/tagging_store/sender_tagging_store.js';
105
+ import type { BenchmarkedNode } from './benchmarked_node.js';
67
106
  import { ExecutionNoteCache } from './execution_note_cache.js';
68
107
  import { ExecutionTaggingIndexCache } from './execution_tagging_index_cache.js';
69
108
  import { HashedValuesCache } from './hashed_values_cache.js';
70
109
  import { Oracle } from './oracle/oracle.js';
71
- import { executePrivateFunction, verifyCurrentClassId } from './oracle/private_execution.js';
110
+ import { executePrivateFunction } from './oracle/private_execution.js';
72
111
  import { PrivateExecutionOracle } from './oracle/private_execution_oracle.js';
73
112
  import { UtilityExecutionOracle } from './oracle/utility_execution_oracle.js';
74
113
 
114
+ /** Options for ContractFunctionSimulator.run. */
115
+ export type ContractSimulatorRunOpts = {
116
+ /** The address of the contract (should match request.origin). */
117
+ contractAddress: AztecAddress;
118
+ /** The function selector of the entry point. */
119
+ selector: FunctionSelector;
120
+ /** The address calling the function. Can be replaced to simulate a call from another contract or account. */
121
+ msgSender?: AztecAddress;
122
+ /** The block header to use as base state for this run. */
123
+ anchorBlockHeader: BlockHeader;
124
+ /** The address used as a tagging sender when emitting private logs. */
125
+ senderForTags?: AztecAddress;
126
+ /** The accounts whose notes we can access in this call. */
127
+ scopes: AztecAddress[];
128
+ /** The job ID for staged writes. */
129
+ jobId: string;
130
+ };
131
+
132
+ /** Args for ContractFunctionSimulator constructor. */
133
+ export type ContractFunctionSimulatorArgs = {
134
+ contractStore: ContractStore;
135
+ noteStore: NoteStore;
136
+ keyStore: KeyStore;
137
+ addressStore: AddressStore;
138
+ aztecNode: AztecNode;
139
+ l2TipsStore: L2TipsProvider;
140
+ senderTaggingStore: SenderTaggingStore;
141
+ recipientTaggingStore: RecipientTaggingStore;
142
+ senderAddressBookStore: SenderAddressBookStore;
143
+ capsuleStore: CapsuleStore;
144
+ privateEventStore: PrivateEventStore;
145
+ simulator: CircuitSimulator;
146
+ contractSyncService: ContractSyncService;
147
+ messageContextService: MessageContextService;
148
+ hooks?: ExecutionHooks;
149
+ };
150
+
75
151
  /**
76
152
  * The contract function simulator.
77
153
  */
78
154
  export class ContractFunctionSimulator {
79
- private log: Logger;
80
-
81
- constructor(
82
- private executionDataProvider: ExecutionDataProvider,
83
- private simulator: CircuitSimulator,
84
- ) {
155
+ private readonly log: Logger;
156
+ private readonly contractStore: ContractStore;
157
+ private readonly noteStore: NoteStore;
158
+ private readonly keyStore: KeyStore;
159
+ private readonly addressStore: AddressStore;
160
+ private readonly aztecNode: AztecNode;
161
+ private readonly l2TipsStore: L2TipsProvider;
162
+ private readonly senderTaggingStore: SenderTaggingStore;
163
+ private readonly recipientTaggingStore: RecipientTaggingStore;
164
+ private readonly senderAddressBookStore: SenderAddressBookStore;
165
+ private readonly capsuleStore: CapsuleStore;
166
+ private readonly privateEventStore: PrivateEventStore;
167
+ private readonly simulator: CircuitSimulator;
168
+ private readonly contractSyncService: ContractSyncService;
169
+ private readonly messageContextService: MessageContextService;
170
+ private readonly hooks: ExecutionHooks | undefined;
171
+
172
+ constructor(args: ContractFunctionSimulatorArgs) {
173
+ this.contractStore = args.contractStore;
174
+ this.noteStore = args.noteStore;
175
+ this.keyStore = args.keyStore;
176
+ this.addressStore = args.addressStore;
177
+ this.aztecNode = args.aztecNode;
178
+ this.l2TipsStore = args.l2TipsStore;
179
+ this.senderTaggingStore = args.senderTaggingStore;
180
+ this.recipientTaggingStore = args.recipientTaggingStore;
181
+ this.senderAddressBookStore = args.senderAddressBookStore;
182
+ this.capsuleStore = args.capsuleStore;
183
+ this.privateEventStore = args.privateEventStore;
184
+ this.simulator = args.simulator;
185
+ this.contractSyncService = args.contractSyncService;
186
+ this.messageContextService = args.messageContextService;
187
+ this.hooks = args.hooks;
85
188
  this.log = createLogger('simulator');
86
189
  }
87
190
 
88
191
  /**
89
192
  * Runs a private function.
90
193
  * @param request - The transaction request.
91
- * @param entryPointArtifact - The artifact of the entry point function.
92
- * @param contractAddress - The address of the contract (should match request.origin)
93
- * @param msgSender - The address calling the function. This can be replaced to simulate a call from another contract
94
- * or a specific account.
95
- * @param senderForTags - The address that is used as a tagging sender when emitting private logs. Returned from
96
- * the `privateGetSenderForTags` oracle.
97
- * @param scopes - The accounts whose notes we can access in this call. Currently optional and will default to all.
98
- * @returns The result of the execution.
99
194
  */
100
195
  public async run(
101
196
  request: TxExecutionRequest,
102
- contractAddress: AztecAddress,
103
- selector: FunctionSelector,
104
- msgSender = AztecAddress.fromField(Fr.MAX_FIELD_VALUE),
105
- senderForTags?: AztecAddress,
106
- scopes?: AztecAddress[],
197
+ {
198
+ contractAddress,
199
+ selector,
200
+ msgSender = AztecAddress.fromField(Fr.MAX_FIELD_VALUE),
201
+ anchorBlockHeader,
202
+ senderForTags,
203
+ scopes,
204
+ jobId,
205
+ }: ContractSimulatorRunOpts,
107
206
  ): Promise<PrivateExecutionResult> {
108
207
  const simulatorSetupTimer = new Timer();
109
- const anchorBlockHeader = await this.executionDataProvider.getAnchorBlockHeader();
110
-
111
- await verifyCurrentClassId(contractAddress, this.executionDataProvider);
112
208
 
113
- const entryPointArtifact = await this.executionDataProvider.getFunctionArtifact(contractAddress, selector);
209
+ const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(contractAddress, selector);
114
210
 
115
211
  if (entryPointArtifact.functionType !== FunctionType.PRIVATE) {
116
212
  throw new Error(`Cannot run ${entryPointArtifact.functionType} function as private`);
117
213
  }
118
214
 
119
215
  if (request.origin !== contractAddress) {
120
- this.log.warn(
216
+ throw new Error(
121
217
  `Request origin does not match contract address in simulation. Request origin: ${request.origin}, contract address: ${contractAddress}`,
122
218
  );
123
219
  }
124
220
 
125
221
  // reserve the first side effect for the tx hash (inserted by the private kernel)
126
- const startSideEffectCounter = 1;
222
+ const startSideEffectCounter = 2;
127
223
 
128
224
  const callContext = new CallContext(
129
225
  msgSender,
@@ -132,28 +228,44 @@ export class ContractFunctionSimulator {
132
228
  entryPointArtifact.isStatic,
133
229
  );
134
230
 
135
- const txRequestHash = await request.toTxRequest().hash();
136
- const noteCache = new ExecutionNoteCache(txRequestHash);
231
+ const protocolNullifier = await computeProtocolNullifier(await request.toTxRequest().hash());
232
+ const noteCache = new ExecutionNoteCache(protocolNullifier);
137
233
  const taggingIndexCache = new ExecutionTaggingIndexCache();
138
234
 
139
- const privateExecutionOracle = new PrivateExecutionOracle(
140
- request.firstCallArgsHash,
141
- request.txContext,
235
+ const privateExecutionOracle = new PrivateExecutionOracle({
236
+ argsHash: request.firstCallArgsHash,
237
+ txContext: request.txContext,
142
238
  callContext,
143
239
  anchorBlockHeader,
144
- request.authWitnesses,
145
- request.capsules,
146
- HashedValuesCache.create(request.argsOfCalls),
240
+ utilityExecutor: async (call, execScopes) => {
241
+ await this.runUtility(call, [], anchorBlockHeader, execScopes, jobId);
242
+ },
243
+ authWitnesses: request.authWitnesses,
244
+ capsules: request.capsules,
245
+ executionCache: HashedValuesCache.create(request.argsOfCalls),
147
246
  noteCache,
148
247
  taggingIndexCache,
149
- this.executionDataProvider,
150
- 0, // totalPublicArgsCount
151
- startSideEffectCounter,
152
- undefined, // log
248
+ contractStore: this.contractStore,
249
+ noteStore: this.noteStore,
250
+ keyStore: this.keyStore,
251
+ addressStore: this.addressStore,
252
+ aztecNode: this.aztecNode,
253
+ senderTaggingStore: this.senderTaggingStore,
254
+ recipientTaggingStore: this.recipientTaggingStore,
255
+ senderAddressBookStore: this.senderAddressBookStore,
256
+ capsuleService: new CapsuleService(this.capsuleStore, scopes),
257
+ privateEventStore: this.privateEventStore,
258
+ messageContextService: this.messageContextService,
259
+ contractSyncService: this.contractSyncService,
260
+ jobId,
261
+ totalPublicCalldataCount: 0,
262
+ sideEffectCounter: startSideEffectCounter,
153
263
  scopes,
154
264
  senderForTags,
155
- this.simulator,
156
- );
265
+ simulator: this.simulator,
266
+ l2TipsStore: this.l2TipsStore,
267
+ hooks: this.hooks,
268
+ });
157
269
 
158
270
  const setupTime = simulatorSetupTimer.ms();
159
271
 
@@ -170,8 +282,9 @@ export class ContractFunctionSimulator {
170
282
  request.functionSelector,
171
283
  );
172
284
  const simulatorTeardownTimer = new Timer();
173
- const { usedTxRequestHashForNonces } = noteCache.finish();
174
- const firstNullifierHint = usedTxRequestHashForNonces ? Fr.ZERO : noteCache.getAllNullifiers()[0];
285
+
286
+ noteCache.finish();
287
+ const firstNullifierHint = noteCache.getNonceGenerator();
175
288
 
176
289
  const publicCallRequests = collectNested([executionResult], r =>
177
290
  r.publicInputs.publicCallRequests
@@ -181,7 +294,7 @@ export class ContractFunctionSimulator {
181
294
  );
182
295
  const publicFunctionsCalldata = await Promise.all(
183
296
  publicCallRequests.map(async r => {
184
- const calldata = await privateExecutionOracle.privateLoadFromExecutionCache(r.calldataHash);
297
+ const calldata = await privateExecutionOracle.getHashPreimage(r.calldataHash);
185
298
  return new HashedValues(calldata, r.calldataHash);
186
299
  }),
187
300
  );
@@ -202,25 +315,55 @@ export class ContractFunctionSimulator {
202
315
  }
203
316
  }
204
317
 
205
- // docs:start:execute_utility_function
206
318
  /**
207
319
  * Runs a utility function.
208
320
  * @param call - The function call to execute.
209
321
  * @param authwits - Authentication witnesses required for the function call.
322
+ * @param anchorBlockHeader - The block header to use as base state for this run.
210
323
  * @param scopes - Optional array of account addresses whose notes can be accessed in this call. Defaults to all
211
324
  * accounts if not specified.
212
- * @returns A decoded ABI value containing the function's return data.
325
+ * @returns A return value of the utility function in a form as returned by the simulator (Noir fields)
213
326
  */
214
- public async runUtility(call: FunctionCall, authwits: AuthWitness[], scopes?: AztecAddress[]): Promise<AbiDecoded> {
215
- await verifyCurrentClassId(call.to, this.executionDataProvider);
216
-
217
- const entryPointArtifact = await this.executionDataProvider.getFunctionArtifact(call.to, call.selector);
327
+ public async runUtility(
328
+ call: FunctionCall,
329
+ authwits: AuthWitness[],
330
+ anchorBlockHeader: BlockHeader,
331
+ scopes: AztecAddress[],
332
+ jobId: string,
333
+ ): Promise<{ result: Fr[]; offchainEffects: OffchainEffect[] }> {
334
+ const entryPointArtifact = await this.contractStore.getFunctionArtifactWithDebugMetadata(call.to, call.selector);
218
335
 
219
336
  if (entryPointArtifact.functionType !== FunctionType.UTILITY) {
220
337
  throw new Error(`Cannot run ${entryPointArtifact.functionType} function as utility`);
221
338
  }
222
339
 
223
- const oracle = new UtilityExecutionOracle(call.to, authwits, [], this.executionDataProvider, undefined, scopes);
340
+ const utilityExecutor = async (syncCall: FunctionCall, execScopes: AztecAddress[]) => {
341
+ await this.runUtility(syncCall, [], anchorBlockHeader, execScopes, jobId);
342
+ };
343
+
344
+ const oracle = new UtilityExecutionOracle({
345
+ contractAddress: call.to,
346
+ authWitnesses: authwits,
347
+ capsules: [],
348
+ anchorBlockHeader,
349
+ contractStore: this.contractStore,
350
+ noteStore: this.noteStore,
351
+ keyStore: this.keyStore,
352
+ addressStore: this.addressStore,
353
+ aztecNode: this.aztecNode,
354
+ recipientTaggingStore: this.recipientTaggingStore,
355
+ senderAddressBookStore: this.senderAddressBookStore,
356
+ capsuleService: new CapsuleService(this.capsuleStore, scopes),
357
+ privateEventStore: this.privateEventStore,
358
+ messageContextService: this.messageContextService,
359
+ contractSyncService: this.contractSyncService,
360
+ l2TipsStore: this.l2TipsStore,
361
+ jobId,
362
+ scopes,
363
+ simulator: this.simulator,
364
+ hooks: this.hooks,
365
+ utilityExecutor,
366
+ });
224
367
 
225
368
  try {
226
369
  this.log.verbose(`Executing utility function ${entryPointArtifact.name}`, {
@@ -244,17 +387,30 @@ export class ContractFunctionSimulator {
244
387
  );
245
388
  });
246
389
 
247
- const returnWitness = witnessMapToFields(acirExecutionResult.returnWitness);
248
- this.log.verbose(`Utility simulation for ${call.to}.${call.selector} completed`);
249
- return decodeFromAbi(entryPointArtifact.returnTypes, returnWitness);
390
+ this.log.verbose(`Utility execution for ${call.to}.${call.selector} completed`);
391
+ return {
392
+ result: witnessMapToFields(acirExecutionResult.returnWitness),
393
+ offchainEffects: oracle.getOffchainEffects(),
394
+ };
250
395
  } catch (err) {
251
396
  throw createSimulationError(err instanceof Error ? err : new Error('Unknown error during private execution'));
252
397
  }
253
398
  }
254
- // docs:end:execute_utility_function
255
399
 
400
+ /**
401
+ * Returns the execution statistics collected during the simulator run.
402
+ * @returns The execution statistics.
403
+ */
256
404
  getStats() {
257
- return this.executionDataProvider.getStats();
405
+ const nodeRPCCalls =
406
+ typeof (this.aztecNode as BenchmarkedNode).getStats === 'function'
407
+ ? (this.aztecNode as BenchmarkedNode).getStats()
408
+ : {
409
+ perMethod: {},
410
+ roundTrips: { roundTrips: 0, totalBlockingTime: 0, roundTripDurations: [], roundTripMethods: [] },
411
+ };
412
+
413
+ return { nodeRPCCalls };
258
414
  }
259
415
  }
260
416
 
@@ -275,63 +431,82 @@ class OrderedSideEffect<T> {
275
431
  * (allowing state overrides) and is much faster, while still generating a valid
276
432
  * output that can be sent to the node for public simulation
277
433
  * @param privateExecutionResult - The result of the private execution.
278
- * @param nonceGenerator - A nonce generator for note hashes. According to the protocol rules,
279
- * it can either be the first nullifier in the tx or the hash of the initial tx request if there are none.
280
- * @param contractDataProvider - A provider for contract data in order to get function names and debug info.
434
+ * @param debugFunctionNameGetter - A provider for contract data in order to get function names and debug info.
435
+ * @param node - AztecNode for verifying settled read requests against the note hash and nullifier trees.
436
+ * @param minRevertibleSideEffectCounterOverride - Optional override for the min revertible side effect counter.
437
+ * Used by TXE to simulate account contract behavior (setting the counter before app execution).
281
438
  * @returns The simulated proving result.
282
439
  */
283
440
  export async function generateSimulatedProvingResult(
284
441
  privateExecutionResult: PrivateExecutionResult,
285
- nonceGenerator: Fr,
286
- contractDataProvider: ContractDataProvider,
442
+ debugFunctionNameGetter: (contractAddress: AztecAddress, functionSelector: FunctionSelector) => Promise<string>,
443
+ node: AztecNode,
444
+ minRevertibleSideEffectCounterOverride?: number,
287
445
  ): Promise<PrivateKernelExecutionProofOutput<PrivateKernelTailCircuitPublicInputs>> {
288
- const siloedNoteHashes: OrderedSideEffect<Fr>[] = [];
289
- const nullifiers: OrderedSideEffect<Fr>[] = [];
290
- const taggedPrivateLogs: OrderedSideEffect<PrivateLog>[] = [];
446
+ const taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[] = [];
291
447
  const l2ToL1Messages: OrderedSideEffect<ScopedL2ToL1Message>[] = [];
292
448
  const contractClassLogsHashes: OrderedSideEffect<ScopedLogHash>[] = [];
293
449
  const publicCallRequests: OrderedSideEffect<PublicCallRequest>[] = [];
294
450
  const executionSteps: PrivateExecutionStep[] = [];
295
451
 
452
+ // Unsiloed scoped arrays — used for squashing, read request verification,
453
+ // and siloed at the end only for the surviving items
454
+ const scopedNoteHashes: ScopedNoteHash[] = [];
455
+ const scopedNullifiers: ScopedNullifier[] = [];
456
+
457
+ // Read requests for verification
458
+ const noteHashReadRequests: ScopedReadRequest[] = [];
459
+ const nullifierReadRequests: ScopedReadRequest[] = [];
460
+
296
461
  let publicTeardownCallRequest;
297
462
 
463
+ // We set expiration timestamp to anchor_block_timestamp + MAX_TX_LIFETIME (24h) just like kernels do
464
+ let expirationTimestamp =
465
+ privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader.globalVariables.timestamp +
466
+ BigInt(MAX_TX_LIFETIME);
467
+
468
+ let feePayer = AztecAddress.zero();
469
+
298
470
  const executions = [privateExecutionResult.entrypoint];
299
471
 
300
472
  while (executions.length !== 0) {
301
473
  const execution = executions.shift()!;
302
474
  executions.unshift(...execution!.nestedExecutionResults);
303
475
 
476
+ // Just like kernels we overwrite the default value if the call sets it.
477
+ const callExpirationTimestamp = execution.publicInputs.expirationTimestamp;
478
+ if (callExpirationTimestamp !== 0n && callExpirationTimestamp < expirationTimestamp) {
479
+ expirationTimestamp = callExpirationTimestamp;
480
+ }
481
+
304
482
  const { contractAddress } = execution.publicInputs.callContext;
305
483
 
306
- const noteHashesFromExecution = await Promise.all(
307
- execution.publicInputs.noteHashes
308
- .getActiveItems()
309
- .filter(noteHash => !noteHash.isEmpty())
310
- .map(
311
- async noteHash =>
312
- new OrderedSideEffect(await siloNoteHash(contractAddress, noteHash.value), noteHash.counter),
313
- ),
314
- );
484
+ if (execution.publicInputs.isFeePayer) {
485
+ if (!feePayer.isZero()) {
486
+ throw new Error('Multiple fee payers found in private execution result');
487
+ }
488
+ feePayer = contractAddress;
489
+ }
315
490
 
316
- const nullifiersFromExecution = await Promise.all(
317
- execution.publicInputs.nullifiers
491
+ scopedNoteHashes.push(
492
+ ...execution.publicInputs.noteHashes
318
493
  .getActiveItems()
319
- .map(
320
- async nullifier =>
321
- new OrderedSideEffect(await siloNullifier(contractAddress, nullifier.value), nullifier.counter),
322
- ),
494
+ .filter(nh => !nh.isEmpty())
495
+ .map(nh => nh.scope(contractAddress)),
323
496
  );
497
+ scopedNullifiers.push(...execution.publicInputs.nullifiers.getActiveItems().map(n => n.scope(contractAddress)));
324
498
 
325
- const privateLogsFromExecution = await Promise.all(
326
- execution.publicInputs.privateLogs.getActiveItems().map(async metadata => {
327
- metadata.log.fields[0] = await poseidon2Hash([contractAddress, metadata.log.fields[0]]);
328
- return new OrderedSideEffect(metadata.log, metadata.counter);
329
- }),
499
+ taggedPrivateLogs.push(
500
+ ...(await Promise.all(
501
+ execution.publicInputs.privateLogs.getActiveItems().map(async metadata => {
502
+ metadata.log.fields[0] = await computeSiloedPrivateLogFirstField(contractAddress, metadata.log.fields[0]);
503
+ return new OrderedSideEffect(metadata, metadata.counter);
504
+ }),
505
+ )),
330
506
  );
331
507
 
332
- siloedNoteHashes.push(...noteHashesFromExecution);
333
- taggedPrivateLogs.push(...privateLogsFromExecution);
334
- nullifiers.push(...nullifiersFromExecution);
508
+ noteHashReadRequests.push(...execution.publicInputs.noteHashReadRequests.getActiveItems());
509
+ nullifierReadRequests.push(...execution.publicInputs.nullifierReadRequests.getActiveItems());
335
510
  l2ToL1Messages.push(
336
511
  ...execution.publicInputs.l2ToL1Msgs
337
512
  .getActiveItems()
@@ -360,7 +535,7 @@ export async function generateSimulatedProvingResult(
360
535
  : execution.publicInputs.publicTeardownCallRequest;
361
536
 
362
537
  executionSteps.push({
363
- functionName: await contractDataProvider.getDebugFunctionName(
538
+ functionName: await debugFunctionNameGetter(
364
539
  execution.publicInputs.callContext.contractAddress,
365
540
  execution.publicInputs.callContext.functionSelector,
366
541
  ),
@@ -371,6 +546,47 @@ export async function generateSimulatedProvingResult(
371
546
  });
372
547
  }
373
548
 
549
+ const noteHashNullifierCounterMap = collectNoteHashNullifierCounterMap(privateExecutionResult);
550
+ const minRevertibleSideEffectCounter =
551
+ minRevertibleSideEffectCounterOverride ?? getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
552
+
553
+ const scopedNoteHashesCLA = new ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>(
554
+ padArrayEnd(scopedNoteHashes, ScopedNoteHash.empty(), MAX_NOTE_HASHES_PER_TX),
555
+ scopedNoteHashes.length,
556
+ );
557
+ const scopedNullifiersCLA = new ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>(
558
+ padArrayEnd(scopedNullifiers, ScopedNullifier.empty(), MAX_NULLIFIERS_PER_TX),
559
+ scopedNullifiers.length,
560
+ );
561
+
562
+ const { filteredNoteHashes, filteredNullifiers, filteredPrivateLogs } = squashTransientSideEffects(
563
+ taggedPrivateLogs,
564
+ scopedNoteHashesCLA,
565
+ scopedNullifiersCLA,
566
+ noteHashNullifierCounterMap,
567
+ minRevertibleSideEffectCounter,
568
+ );
569
+
570
+ await verifyReadRequests(
571
+ node,
572
+ await privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader.hash(),
573
+ noteHashReadRequests,
574
+ nullifierReadRequests,
575
+ scopedNoteHashesCLA,
576
+ scopedNullifiersCLA,
577
+ );
578
+
579
+ const siloedNoteHashes = await Promise.all(
580
+ filteredNoteHashes
581
+ .sort((a, b) => a.counter - b.counter)
582
+ .map(async nh => new OrderedSideEffect(await siloNoteHash(nh.contractAddress, nh.value), nh.counter)),
583
+ );
584
+ const siloedNullifiers = await Promise.all(
585
+ filteredNullifiers
586
+ .sort((a, b) => a.counter - b.counter)
587
+ .map(async n => new OrderedSideEffect(await siloNullifier(n.contractAddress, n.value), n.counter)),
588
+ );
589
+
374
590
  const constantData = new TxConstantData(
375
591
  privateExecutionResult.entrypoint.publicInputs.anchorBlockHeader,
376
592
  privateExecutionResult.entrypoint.publicInputs.txContext,
@@ -387,23 +603,23 @@ export async function generateSimulatedProvingResult(
387
603
  const getEffect = <T>(orderedSideEffect: OrderedSideEffect<T>) => orderedSideEffect.sideEffect;
388
604
 
389
605
  const isPrivateOnlyTx = privateExecutionResult.publicFunctionCalldata.length === 0;
390
- const minRevertibleSideEffectCounter = getFinalMinRevertibleSideEffectCounter(privateExecutionResult);
391
606
 
392
607
  const [nonRevertibleNullifiers, revertibleNullifiers] = splitOrderedSideEffects(
393
- nullifiers.sort(sortByCounter),
608
+ siloedNullifiers,
394
609
  minRevertibleSideEffectCounter,
395
610
  );
396
- if (nonRevertibleNullifiers.length > 0 && !nonRevertibleNullifiers[0].equals(nonceGenerator)) {
611
+ const nonceGenerator = privateExecutionResult.firstNullifier;
612
+ if (nonRevertibleNullifiers.length === 0) {
613
+ nonRevertibleNullifiers.push(nonceGenerator);
614
+ } else if (!nonRevertibleNullifiers[0].equals(nonceGenerator)) {
397
615
  throw new Error('The first non revertible nullifier should be equal to the nonce generator. This is a bug!');
398
- } else {
399
- nonRevertibleNullifiers.unshift(nonceGenerator);
400
616
  }
401
617
 
402
618
  if (isPrivateOnlyTx) {
403
619
  // We must make the note hashes unique by using the
404
620
  // nonce generator and their index in the tx.
405
621
  const uniqueNoteHashes = await Promise.all(
406
- siloedNoteHashes.sort(sortByCounter).map(async (orderedSideEffect, i) => {
622
+ siloedNoteHashes.map(async (orderedSideEffect, i) => {
407
623
  const siloedNoteHash = orderedSideEffect.sideEffect;
408
624
  const nonce = await computeNoteHashNonce(nonceGenerator, i);
409
625
  const uniqueNoteHash = await computeUniqueNoteHash(nonce, siloedNoteHash);
@@ -418,26 +634,32 @@ export async function generateSimulatedProvingResult(
418
634
  ScopedL2ToL1Message.empty(),
419
635
  MAX_L2_TO_L1_MSGS_PER_TX,
420
636
  ),
421
- padArrayEnd(taggedPrivateLogs.sort(sortByCounter).map(getEffect), PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
637
+ padArrayEnd(filteredPrivateLogs.sort(sortByCounter).map(getEffect), PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
422
638
  padArrayEnd(
423
639
  contractClassLogsHashes.sort(sortByCounter).map(getEffect),
424
640
  ScopedLogHash.empty(),
425
641
  MAX_CONTRACT_CLASS_LOGS_PER_TX,
426
642
  ),
427
643
  );
428
- gasUsed = meterGasUsed(accumulatedDataForRollup);
644
+ gasUsed = meterGasUsed(accumulatedDataForRollup, isPrivateOnlyTx);
429
645
  inputsForRollup = new PartialPrivateTailPublicInputsForRollup(accumulatedDataForRollup);
430
646
  } else {
431
647
  const [nonRevertibleNoteHashes, revertibleNoteHashes] = splitOrderedSideEffects(
432
- siloedNoteHashes.sort(sortByCounter),
648
+ siloedNoteHashes,
433
649
  minRevertibleSideEffectCounter,
434
650
  );
651
+ const nonRevertibleUniqueNoteHashes = await Promise.all(
652
+ nonRevertibleNoteHashes.map(async (noteHash, i) => {
653
+ const nonce = await computeNoteHashNonce(nonceGenerator, i);
654
+ return await computeUniqueNoteHash(nonce, noteHash);
655
+ }),
656
+ );
435
657
  const [nonRevertibleL2ToL1Messages, revertibleL2ToL1Messages] = splitOrderedSideEffects(
436
658
  l2ToL1Messages.sort(sortByCounter),
437
659
  minRevertibleSideEffectCounter,
438
660
  );
439
661
  const [nonRevertibleTaggedPrivateLogs, revertibleTaggedPrivateLogs] = splitOrderedSideEffects(
440
- taggedPrivateLogs,
662
+ filteredPrivateLogs,
441
663
  minRevertibleSideEffectCounter,
442
664
  );
443
665
  const [nonRevertibleContractClassLogHashes, revertibleContractClassLogHashes] = splitOrderedSideEffects(
@@ -450,7 +672,7 @@ export async function generateSimulatedProvingResult(
450
672
  );
451
673
 
452
674
  const nonRevertibleData = new PrivateToPublicAccumulatedData(
453
- padArrayEnd(nonRevertibleNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
675
+ padArrayEnd(nonRevertibleUniqueNoteHashes, Fr.ZERO, MAX_NOTE_HASHES_PER_TX),
454
676
  padArrayEnd(nonRevertibleNullifiers, Fr.ZERO, MAX_NULLIFIERS_PER_TX),
455
677
  padArrayEnd(nonRevertibleL2ToL1Messages, ScopedL2ToL1Message.empty(), MAX_L2_TO_L1_MSGS_PER_TX),
456
678
  padArrayEnd(nonRevertibleTaggedPrivateLogs, PrivateLog.empty(), MAX_PRIVATE_LOGS_PER_TX),
@@ -466,9 +688,9 @@ export async function generateSimulatedProvingResult(
466
688
  padArrayEnd(revertibleContractClassLogHashes, ScopedLogHash.empty(), MAX_CONTRACT_CLASS_LOGS_PER_TX),
467
689
  padArrayEnd(revertiblePublicCallRequests, PublicCallRequest.empty(), MAX_ENQUEUED_CALLS_PER_TX),
468
690
  );
469
- gasUsed = meterGasUsed(revertibleData).add(meterGasUsed(nonRevertibleData));
691
+ gasUsed = meterGasUsed(revertibleData, isPrivateOnlyTx).add(meterGasUsed(nonRevertibleData, isPrivateOnlyTx));
470
692
  if (publicTeardownCallRequest) {
471
- gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
693
+ gasUsed = gasUsed.add(privateExecutionResult.entrypoint.publicInputs.txContext.gasSettings.teardownGasLimits);
472
694
  }
473
695
 
474
696
  inputsForPublic = new PartialPrivateTailPublicInputsForPublic(
@@ -480,9 +702,14 @@ export async function generateSimulatedProvingResult(
480
702
 
481
703
  const publicInputs = new PrivateKernelTailCircuitPublicInputs(
482
704
  constantData,
483
- /*gasUsed=*/ gasUsed.add(Gas.from({ l2Gas: FIXED_L2_GAS, daGas: FIXED_DA_GAS })),
484
- /*feePayer=*/ AztecAddress.zero(),
485
- /*includeByTimestamp=*/ 0n,
705
+ /*gasUsed=*/ gasUsed.add(
706
+ Gas.from({
707
+ l2Gas: isPrivateOnlyTx ? PRIVATE_TX_L2_GAS_OVERHEAD : PUBLIC_TX_L2_GAS_OVERHEAD,
708
+ daGas: TX_DA_GAS_OVERHEAD,
709
+ }),
710
+ ),
711
+ /*feePayer=*/ feePayer,
712
+ /*expirationTimestamp=*/ expirationTimestamp,
486
713
  hasPublicCalls ? inputsForPublic : undefined,
487
714
  !hasPublicCalls ? inputsForRollup : undefined,
488
715
  );
@@ -494,11 +721,121 @@ export async function generateSimulatedProvingResult(
494
721
  };
495
722
  }
496
723
 
724
+ /**
725
+ * Squashes transient note hashes and nullifiers, mimicking the behavior
726
+ * of the reset kernels. Returns the filtered (surviving) scoped items and private logs.
727
+ */
728
+ function squashTransientSideEffects(
729
+ taggedPrivateLogs: OrderedSideEffect<PrivateLogData>[],
730
+ scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
731
+ scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
732
+ noteHashNullifierCounterMap: Map<number, number>,
733
+ minRevertibleSideEffectCounter: number,
734
+ ) {
735
+ const { numTransientData, hints: transientDataHints } = buildTransientDataHints(
736
+ scopedNoteHashesCLA,
737
+ scopedNullifiersCLA,
738
+ /*futureNoteHashReads=*/ [],
739
+ /*futureNullifierReads=*/ [],
740
+ /*futureLogs=*/ [],
741
+ noteHashNullifierCounterMap,
742
+ minRevertibleSideEffectCounter,
743
+ );
744
+
745
+ const squashedNoteHashCounters = new Set<number>();
746
+ const squashedNullifierCounters = new Set<number>();
747
+ for (let i = 0; i < numTransientData; i++) {
748
+ const hint = transientDataHints[i];
749
+ squashedNoteHashCounters.add(scopedNoteHashesCLA.array[hint.noteHashIndex].counter);
750
+ squashedNullifierCounters.add(scopedNullifiersCLA.array[hint.nullifierIndex].counter);
751
+ }
752
+
753
+ return {
754
+ filteredNoteHashes: scopedNoteHashesCLA.getActiveItems().filter(nh => !squashedNoteHashCounters.has(nh.counter)),
755
+ filteredNullifiers: scopedNullifiersCLA.getActiveItems().filter(n => !squashedNullifierCounters.has(n.counter)),
756
+ filteredPrivateLogs: taggedPrivateLogs
757
+ .filter(item => !squashedNoteHashCounters.has(item.sideEffect.noteHashCounter))
758
+ .map(item => new OrderedSideEffect(item.sideEffect.log, item.counter)),
759
+ };
760
+ }
761
+
762
+ /**
763
+ * Verifies settled read requests by checking membership in the note hash and nullifier trees
764
+ * at the tx's anchor block, mimicking the behavior of the kernels
765
+ */
766
+ async function verifyReadRequests(
767
+ node: Pick<AztecNode, 'findLeavesIndexes'>,
768
+ anchorBlockHash: BlockParameter,
769
+ noteHashReadRequests: ScopedReadRequest[],
770
+ nullifierReadRequests: ScopedReadRequest[],
771
+ scopedNoteHashesCLA: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
772
+ scopedNullifiersCLA: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
773
+ ) {
774
+ const noteHashReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>(
775
+ padArrayEnd(noteHashReadRequests, ScopedReadRequest.empty(), MAX_NOTE_HASH_READ_REQUESTS_PER_TX),
776
+ noteHashReadRequests.length,
777
+ );
778
+ const nullifierReadRequestsCLA = new ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>(
779
+ padArrayEnd(nullifierReadRequests, ScopedReadRequest.empty(), MAX_NULLIFIER_READ_REQUESTS_PER_TX),
780
+ nullifierReadRequests.length,
781
+ );
782
+
783
+ const noteHashResetActions = getNoteHashReadRequestResetActions(noteHashReadRequestsCLA, scopedNoteHashesCLA);
784
+ const nullifierResetActions = getNullifierReadRequestResetActions(nullifierReadRequestsCLA, scopedNullifiersCLA);
785
+
786
+ const settledNoteHashReads: { index: number; value: Fr }[] = [];
787
+ for (let i = 0; i < noteHashResetActions.actions.length; i++) {
788
+ if (noteHashResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
789
+ settledNoteHashReads.push({ index: i, value: noteHashReadRequests[i].value });
790
+ }
791
+ }
792
+
793
+ const settledNullifierReads: { index: number; value: Fr }[] = [];
794
+ for (let i = 0; i < nullifierResetActions.actions.length; i++) {
795
+ if (nullifierResetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
796
+ settledNullifierReads.push({ index: i, value: nullifierReadRequests[i].value });
797
+ }
798
+ }
799
+
800
+ const [noteHashResults, nullifierResults] = await Promise.all([
801
+ settledNoteHashReads.length > 0
802
+ ? node.findLeavesIndexes(
803
+ anchorBlockHash,
804
+ MerkleTreeId.NOTE_HASH_TREE,
805
+ settledNoteHashReads.map(({ value }) => value),
806
+ )
807
+ : [],
808
+ settledNullifierReads.length > 0
809
+ ? node.findLeavesIndexes(
810
+ anchorBlockHash,
811
+ MerkleTreeId.NULLIFIER_TREE,
812
+ settledNullifierReads.map(({ value }) => value),
813
+ )
814
+ : [],
815
+ ]);
816
+
817
+ for (let i = 0; i < settledNoteHashReads.length; i++) {
818
+ if (!noteHashResults[i]) {
819
+ throw new Error(
820
+ `Note hash read request at index ${settledNoteHashReads[i].index} is reading an unknown note hash: ${settledNoteHashReads[i].value}`,
821
+ );
822
+ }
823
+ }
824
+
825
+ for (let i = 0; i < settledNullifierReads.length; i++) {
826
+ if (!nullifierResults[i]) {
827
+ throw new Error(
828
+ `Nullifier read request at index ${settledNullifierReads[i].index} is reading an unknown nullifier: ${settledNullifierReads[i].value}`,
829
+ );
830
+ }
831
+ }
832
+ }
833
+
497
834
  function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertibleSideEffectCounter: number) {
498
835
  const revertibleSideEffects: T[] = [];
499
836
  const nonRevertibleSideEffects: T[] = [];
500
837
  effects.forEach(effect => {
501
- if (effect.counter < minRevertibleSideEffectCounter) {
838
+ if (minRevertibleSideEffectCounter === 0 || effect.counter < minRevertibleSideEffectCounter) {
502
839
  nonRevertibleSideEffects.push(effect.sideEffect);
503
840
  } else {
504
841
  revertibleSideEffects.push(effect.sideEffect);
@@ -507,21 +844,24 @@ function splitOrderedSideEffects<T>(effects: OrderedSideEffect<T>[], minRevertib
507
844
  return [nonRevertibleSideEffects, revertibleSideEffects];
508
845
  }
509
846
 
510
- function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData) {
847
+ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccumulatedData, isPrivateOnlyTx: boolean) {
511
848
  let meteredDAFields = 0;
512
849
  let meteredL2Gas = 0;
513
850
 
514
851
  const numNoteHashes = arrayNonEmptyLength(data.noteHashes, hash => hash.isEmpty());
515
852
  meteredDAFields += numNoteHashes;
516
- meteredL2Gas += numNoteHashes * AVM_EMITNOTEHASH_BASE_L2_GAS;
853
+ const noteHashBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NOTE_HASH : AVM_EMITNOTEHASH_BASE_L2_GAS;
854
+ meteredL2Gas += numNoteHashes * noteHashBaseGas;
517
855
 
518
856
  const numNullifiers = arrayNonEmptyLength(data.nullifiers, nullifier => nullifier.isEmpty());
519
857
  meteredDAFields += numNullifiers;
520
- meteredL2Gas += numNullifiers * AVM_EMITNULLIFIER_BASE_L2_GAS;
858
+ const nullifierBaseGas = isPrivateOnlyTx ? L2_GAS_PER_NULLIFIER : AVM_EMITNULLIFIER_BASE_L2_GAS;
859
+ meteredL2Gas += numNullifiers * nullifierBaseGas;
521
860
 
522
861
  const numL2toL1Messages = arrayNonEmptyLength(data.l2ToL1Msgs, msg => msg.isEmpty());
523
862
  meteredDAFields += numL2toL1Messages;
524
- meteredL2Gas += numL2toL1Messages * AVM_SENDL2TOL1MSG_BASE_L2_GAS;
863
+ const l2ToL1MessageBaseGas = isPrivateOnlyTx ? L2_GAS_PER_L2_TO_L1_MSG : AVM_SENDL2TOL1MSG_BASE_L2_GAS;
864
+ meteredL2Gas += numL2toL1Messages * l2ToL1MessageBaseGas;
525
865
 
526
866
  const numPrivatelogs = arrayNonEmptyLength(data.privateLogs, log => log.isEmpty());
527
867
  // Every private log emits its length as an additional field
@@ -529,14 +869,14 @@ function meterGasUsed(data: PrivateToRollupAccumulatedData | PrivateToPublicAccu
529
869
  meteredL2Gas += numPrivatelogs * L2_GAS_PER_PRIVATE_LOG;
530
870
 
531
871
  const numContractClassLogs = arrayNonEmptyLength(data.contractClassLogsHashes, log => log.isEmpty());
532
- // Every contract class log emits its length and contract address as additional fields
872
+ // Every contract class log emits its contract address as an additional field
533
873
  meteredDAFields += data.contractClassLogsHashes.reduce(
534
- (acc, log) => (!log.isEmpty() ? acc + log.logHash.length + 2 : acc),
874
+ (acc, log) => (!log.isEmpty() ? acc + log.logHash.length + 1 : acc),
535
875
  0,
536
876
  );
537
877
  meteredL2Gas += numContractClassLogs * L2_GAS_PER_CONTRACT_CLASS_LOG;
538
878
 
539
- const meteredDAGas = meteredDAFields * DA_BYTES_PER_FIELD * DA_GAS_PER_BYTE;
879
+ const meteredDAGas = meteredDAFields * DA_GAS_PER_FIELD;
540
880
 
541
881
  if ((data as PrivateToPublicAccumulatedData).publicCallRequests) {
542
882
  const dataForPublic = data as PrivateToPublicAccumulatedData;