@aztec/pxe 0.0.0-test.1 → 0.0.1-commit.001888fc

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