@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
@@ -1,20 +1,8 @@
1
- import { Fr, Point } from '@aztec/foundation/fields';
2
- import {
3
- type ACIRCallback,
4
- type ACVMField,
5
- arrayOfArraysToBoundedVecOfArrays,
6
- bufferToBoundedVec,
7
- fromUintArray,
8
- fromUintBoundedVec,
9
- toACVMField,
10
- } from '@aztec/simulator/client';
11
- import { FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
12
- import { AztecAddress } from '@aztec/stdlib/aztec-address';
13
- import { ContractClassLog, ContractClassLogFields } from '@aztec/stdlib/logs';
14
- import { MerkleTreeId } from '@aztec/stdlib/trees';
1
+ import type { ACIRCallback, ACVMField } from '@aztec/simulator/client';
15
2
 
3
+ import { ORACLE_VERSION_MAJOR, ORACLE_VERSION_MINOR } from '../../oracle_version.js';
16
4
  import type { IMiscOracle, IPrivateExecutionOracle, IUtilityExecutionOracle } from './interfaces.js';
17
- import { packAsRetrievedNote } from './note_packing_utils.js';
5
+ import { callHandler } from './oracle_registry.js';
18
6
 
19
7
  export class UnavailableOracleError extends Error {
20
8
  constructor(oracleName: string) {
@@ -24,9 +12,28 @@ export class UnavailableOracleError extends Error {
24
12
 
25
13
  /**
26
14
  * A data source that has all the apis required by Aztec.nr.
15
+ *
16
+ * ## Oracle naming conventions
17
+ *
18
+ * We try to keep oracle naming consistent, please see below the conventions we adhere to.
19
+ *
20
+ * Each oracle method name has the form `aztec_{scope}_{verb}{Object}`, where:
21
+ *
22
+ * - **Scope prefix** indicates the execution context required:
23
+ * - `aztec_prv_` — available only during private function execution.
24
+ * - `aztec_utl_` — available during both utility and private execution.
25
+ *
26
+ * - **Verb** signals the operation's semantics (verb-first, then object):
27
+ * - `get` — read / lookup / get data from oracle into contract.
28
+ * - `does`/`is`/`has` — predicate (returns boolean).
29
+ * - `emit`/`notify` — propagate data from contract to oracle.
30
+ * - `set` — contract driven oracle state mutation (capsules, execution cache, tagging, etc).
31
+ * - `call` — trigger nested execution (control flow).
32
+ * - `assert` — validate a condition, throw on failure.
33
+ * - Standalone verbs (`delete`, `copy`, `decrypt`, `log`, etc) are used when no generic verb fits.
27
34
  */
28
35
  export class Oracle {
29
- constructor(private handler: IMiscOracle | IUtilityExecutionOracle | IPrivateExecutionOracle) {}
36
+ constructor(private handler: IMiscOracle & (IUtilityExecutionOracle | IPrivateExecutionOracle)) {}
30
37
 
31
38
  private handlerAsMisc(): IMiscOracle {
32
39
  if (!('isMisc' in this.handler)) {
@@ -67,12 +74,12 @@ export class Oracle {
67
74
  name => !excludedProps.includes(name as (typeof excludedProps)[number]),
68
75
  );
69
76
 
70
- // Validate oracle names - these must be prefixed with either "private" or "utility" to indicate their scope
77
+ // Validate oracle names - these must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate their scope
71
78
  // and must correspond to a function on the Oracle class.
72
79
  oracleNames.forEach(name => {
73
- if (!name.startsWith('private') && !name.startsWith('utility')) {
80
+ if (!name.startsWith('aztec_prv_') && !name.startsWith('aztec_utl_') && !name.startsWith('aztec_misc_')) {
74
81
  throw new Error(
75
- `Oracle function "${name}" must be prefixed with either "private" or "utility" to indicate its scope`,
82
+ `Oracle function "${name}" must be prefixed with "aztec_prv_", "aztec_utl_", or "aztec_misc_" to indicate its scope`,
76
83
  );
77
84
  }
78
85
 
@@ -83,493 +90,622 @@ export class Oracle {
83
90
  });
84
91
 
85
92
  // Build callback object and return it
86
- return oracleNames.reduce((acc, name) => {
93
+ const callback = oracleNames.reduce((acc, name) => {
87
94
  const method = this[name as keyof Omit<Oracle, (typeof excludedProps)[number]>];
88
95
  acc[name] = method.bind(this);
89
96
  return acc;
90
97
  }, {} as ACIRCallback);
91
- }
92
98
 
93
- utilityAssertCompatibleOracleVersion([version]: ACVMField[]) {
94
- this.handlerAsMisc().utilityAssertCompatibleOracleVersion(Fr.fromString(version).toNumber());
95
- return Promise.resolve([]);
99
+ // Wrap in a Proxy to intercept access to missing oracle names and provide enhanced error messages when the
100
+ // contract's minor version is higher than the PXE's (i.e. the contract expects oracles that were added in a newer
101
+ // minor version).
102
+ const handler = this.handler;
103
+ return new Proxy(callback, {
104
+ get(target, prop: string) {
105
+ if (prop in target) {
106
+ return target[prop];
107
+ }
108
+ // Return a function that throws with an enhanced error message if applicable
109
+ return () => {
110
+ type NonOracleFunctionGetContractOracleVersion = {
111
+ nonOracleFunctionGetContractOracleVersion(): { major: number; minor: number } | undefined;
112
+ };
113
+
114
+ let contractVersion = undefined;
115
+ if ('nonOracleFunctionGetContractOracleVersion' in handler) {
116
+ contractVersion = (
117
+ handler as unknown as NonOracleFunctionGetContractOracleVersion
118
+ ).nonOracleFunctionGetContractOracleVersion();
119
+ }
120
+ if (!contractVersion) {
121
+ throw new Error(
122
+ `Oracle '${prop}' not found and the contract's oracle version is unknown (the version check oracle ` +
123
+ `was not called before '${prop}'). This usually means the contract was not compiled with the ` +
124
+ `#[aztec] macro, which injects the version check as the first oracle call in every private/utility ` +
125
+ `external function. If you're using a custom entry point, ensure assert_compatible_oracle_version() ` +
126
+ `is called before any other oracle calls. See https://docs.aztec.network/errors/8`,
127
+ );
128
+ } else if (contractVersion.minor > ORACLE_VERSION_MINOR) {
129
+ throw new Error(
130
+ `Oracle '${prop}' not found.` +
131
+ ` This usually means the contract requires a newer private execution environment than you have.` +
132
+ ` Upgrade your private execution environment to a compatible version. The contract was compiled with` +
133
+ ` Aztec.nr oracle version ${contractVersion.major}.${contractVersion.minor}, but this private` +
134
+ ` execution environment only supports up to ${ORACLE_VERSION_MAJOR}.${ORACLE_VERSION_MINOR}.` +
135
+ ` See https://docs.aztec.network/errors/8`,
136
+ );
137
+ } else {
138
+ throw new Error(
139
+ `Oracle '${prop}' not found.` +
140
+ ` The contract's oracle version (${contractVersion.major}.${contractVersion.minor}) is compatible` +
141
+ ` with this private execution environment (${ORACLE_VERSION_MAJOR}.${ORACLE_VERSION_MINOR}), so all` +
142
+ ` standard oracles should be available. This could mean the contract was compiled against a modified` +
143
+ ` version of Aztec.nr, or that it references an oracle that does not exist.` +
144
+ ` See https://docs.aztec.network/errors/8`,
145
+ );
146
+ }
147
+ };
148
+ },
149
+ });
96
150
  }
97
151
 
98
- utilityGetRandomField(): Promise<ACVMField[]> {
99
- const val = this.handlerAsMisc().utilityGetRandomField();
100
- return Promise.resolve([toACVMField(val)]);
152
+ // eslint-disable-next-line camelcase
153
+ aztec_misc_assertCompatibleOracleVersion(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
154
+ return callHandler({
155
+ oracle: 'aztec_misc_assertCompatibleOracleVersion',
156
+ inputs,
157
+ handler: ([major, minor]) => {
158
+ this.handlerAsMisc().assertCompatibleOracleVersion(major, minor);
159
+ },
160
+ });
101
161
  }
102
162
 
103
- // Since the argument is a slice, noir automatically adds a length field to oracle call.
104
- privateStoreInExecutionCache(_length: ACVMField[], values: ACVMField[], [hash]: ACVMField[]): Promise<ACVMField[]> {
105
- this.handlerAsPrivate().privateStoreInExecutionCache(values.map(Fr.fromString), Fr.fromString(hash));
106
- return Promise.resolve([]);
163
+ // eslint-disable-next-line camelcase
164
+ aztec_misc_getRandomField(): Promise<(ACVMField | ACVMField[])[]> {
165
+ return callHandler({
166
+ oracle: 'aztec_misc_getRandomField',
167
+ inputs: [],
168
+ handler: () => this.handlerAsMisc().getRandomField(),
169
+ });
107
170
  }
108
171
 
109
- async privateLoadFromExecutionCache([returnsHash]: ACVMField[]): Promise<ACVMField[][]> {
110
- const values = await this.handlerAsPrivate().privateLoadFromExecutionCache(Fr.fromString(returnsHash));
111
- return [values.map(toACVMField)];
172
+ // eslint-disable-next-line camelcase
173
+ aztec_prv_setHashPreimage(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
174
+ return callHandler({
175
+ oracle: 'aztec_prv_setHashPreimage',
176
+ inputs,
177
+ handler: ([values, hash]) => {
178
+ this.handlerAsPrivate().setHashPreimage(values, hash);
179
+ },
180
+ });
112
181
  }
113
182
 
114
- async utilityGetUtilityContext(): Promise<(ACVMField | ACVMField[])[]> {
115
- const context = await this.handlerAsUtility().utilityGetUtilityContext();
116
- return context.toNoirRepresentation();
183
+ // eslint-disable-next-line camelcase
184
+ aztec_prv_getHashPreimage(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
185
+ return callHandler({
186
+ oracle: 'aztec_prv_getHashPreimage',
187
+ inputs,
188
+ handler: ([returnsHash]) => this.handlerAsPrivate().getHashPreimage(returnsHash),
189
+ });
117
190
  }
118
191
 
119
- async utilityGetKeyValidationRequest([pkMHash]: ACVMField[]): Promise<ACVMField[]> {
120
- const keyValidationRequest = await this.handlerAsUtility().utilityGetKeyValidationRequest(Fr.fromString(pkMHash));
192
+ // eslint-disable-next-line camelcase
193
+ aztec_utl_getUtilityContext(): Promise<(ACVMField | ACVMField[])[]> {
194
+ return callHandler({
195
+ oracle: 'aztec_utl_getUtilityContext',
196
+ inputs: [],
197
+ handler: () => this.handlerAsUtility().getUtilityContext(),
198
+ });
199
+ }
121
200
 
122
- return keyValidationRequest.toFields().map(toACVMField);
201
+ // eslint-disable-next-line camelcase
202
+ aztec_utl_getKeyValidationRequest(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
203
+ return callHandler({
204
+ oracle: 'aztec_utl_getKeyValidationRequest',
205
+ inputs,
206
+ handler: ([pkMHash]) => this.handlerAsUtility().getKeyValidationRequest(pkMHash),
207
+ });
123
208
  }
124
209
 
125
- async utilityGetContractInstance([address]: ACVMField[]): Promise<ACVMField[]> {
126
- const instance = await this.handlerAsUtility().utilityGetContractInstance(
127
- AztecAddress.fromField(Fr.fromString(address)),
128
- );
210
+ // eslint-disable-next-line camelcase
211
+ aztec_utl_getContractInstance(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
212
+ return callHandler({
213
+ oracle: 'aztec_utl_getContractInstance',
214
+ inputs,
215
+ handler: ([address]) => this.handlerAsUtility().getContractInstance(address),
216
+ });
217
+ }
129
218
 
130
- return [
131
- instance.salt,
132
- instance.deployer,
133
- instance.currentContractClassId,
134
- instance.initializationHash,
135
- ...instance.publicKeys.toFields(),
136
- ].map(toACVMField);
137
- }
138
-
139
- async utilityGetMembershipWitness(
140
- [blockNumber]: ACVMField[],
141
- [treeId]: ACVMField[],
142
- [leafValue]: ACVMField[],
143
- ): Promise<(ACVMField | ACVMField[])[]> {
144
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
145
- const parsedTreeId = Fr.fromString(treeId).toNumber();
146
- const parsedLeafValue = Fr.fromString(leafValue);
147
-
148
- const witness = await this.handlerAsUtility().utilityGetMembershipWitness(
149
- parsedBlockNumber,
150
- parsedTreeId,
151
- parsedLeafValue,
152
- );
153
- if (!witness) {
154
- throw new Error(
155
- `Leaf ${leafValue} not found in the tree ${MerkleTreeId[parsedTreeId]} at block ${parsedBlockNumber}.`,
156
- );
157
- }
158
- return [toACVMField(witness[0]), witness.slice(1).map(toACVMField)];
219
+ // eslint-disable-next-line camelcase
220
+ aztec_utl_getNoteHashMembershipWitness(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
221
+ return callHandler({
222
+ oracle: 'aztec_utl_getNoteHashMembershipWitness',
223
+ inputs,
224
+ handler: ([anchorBlockHash, noteHash]) =>
225
+ this.handlerAsUtility().getNoteHashMembershipWitness(anchorBlockHash, noteHash),
226
+ });
159
227
  }
160
228
 
161
- async utilityGetNullifierMembershipWitness(
162
- [blockNumber]: ACVMField[],
163
- [nullifier]: ACVMField[], // nullifier, we try to find the witness for (to prove inclusion)
164
- ): Promise<(ACVMField | ACVMField[])[]> {
165
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
166
- const parsedNullifier = Fr.fromString(nullifier);
229
+ // eslint-disable-next-line camelcase
230
+ aztec_utl_getBlockHashMembershipWitness(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
231
+ return callHandler({
232
+ oracle: 'aztec_utl_getBlockHashMembershipWitness',
233
+ inputs,
234
+ handler: ([anchorBlockHash, blockHash]) =>
235
+ this.handlerAsUtility().getBlockHashMembershipWitness(anchorBlockHash, blockHash),
236
+ });
237
+ }
167
238
 
168
- const witness = await this.handlerAsUtility().utilityGetNullifierMembershipWitness(
169
- parsedBlockNumber,
170
- parsedNullifier,
171
- );
172
- if (!witness) {
173
- throw new Error(`Nullifier witness not found for nullifier ${parsedNullifier} at block ${parsedBlockNumber}.`);
174
- }
175
- return witness.toNoirRepresentation();
239
+ // eslint-disable-next-line camelcase
240
+ aztec_utl_getNullifierMembershipWitness(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
241
+ return callHandler({
242
+ oracle: 'aztec_utl_getNullifierMembershipWitness',
243
+ inputs,
244
+ handler: ([blockHash, nullifier]) => this.handlerAsUtility().getNullifierMembershipWitness(blockHash, nullifier),
245
+ });
176
246
  }
177
247
 
178
- async utilityGetLowNullifierMembershipWitness(
179
- [blockNumber]: ACVMField[],
180
- [nullifier]: ACVMField[], // nullifier, we try to find the low nullifier witness for (to prove non-inclusion)
181
- ): Promise<(ACVMField | ACVMField[])[]> {
182
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
183
- const parsedNullifier = Fr.fromString(nullifier);
248
+ // eslint-disable-next-line camelcase
249
+ aztec_utl_getLowNullifierMembershipWitness(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
250
+ return callHandler({
251
+ oracle: 'aztec_utl_getLowNullifierMembershipWitness',
252
+ inputs,
253
+ handler: ([blockHash, nullifier]) =>
254
+ this.handlerAsUtility().getLowNullifierMembershipWitness(blockHash, nullifier),
255
+ });
256
+ }
184
257
 
185
- const witness = await this.handlerAsUtility().utilityGetLowNullifierMembershipWitness(
186
- parsedBlockNumber,
187
- parsedNullifier,
188
- );
189
- if (!witness) {
190
- throw new Error(
191
- `Low nullifier witness not found for nullifier ${parsedNullifier} at block ${parsedBlockNumber}.`,
192
- );
193
- }
194
- return witness.toNoirRepresentation();
258
+ // eslint-disable-next-line camelcase
259
+ aztec_utl_getPublicDataWitness(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
260
+ return callHandler({
261
+ oracle: 'aztec_utl_getPublicDataWitness',
262
+ inputs,
263
+ handler: ([blockHash, leafSlot]) => this.handlerAsUtility().getPublicDataWitness(blockHash, leafSlot),
264
+ });
195
265
  }
196
266
 
197
- async utilityGetPublicDataWitness(
198
- [blockNumber]: ACVMField[],
199
- [leafSlot]: ACVMField[],
200
- ): Promise<(ACVMField | ACVMField[])[]> {
201
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
202
- const parsedLeafSlot = Fr.fromString(leafSlot);
267
+ // eslint-disable-next-line camelcase
268
+ aztec_utl_getBlockHeader(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
269
+ return callHandler({
270
+ oracle: 'aztec_utl_getBlockHeader',
271
+ inputs,
272
+ handler: ([blockNumber]) => this.handlerAsUtility().getBlockHeader(blockNumber),
273
+ });
274
+ }
203
275
 
204
- const witness = await this.handlerAsUtility().utilityGetPublicDataWitness(parsedBlockNumber, parsedLeafSlot);
205
- if (!witness) {
206
- throw new Error(`Public data witness not found for slot ${parsedLeafSlot} at block ${parsedBlockNumber}.`);
207
- }
208
- return witness.toNoirRepresentation();
276
+ // eslint-disable-next-line camelcase
277
+ aztec_utl_getAuthWitness(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
278
+ return callHandler({
279
+ oracle: 'aztec_utl_getAuthWitness',
280
+ inputs,
281
+ handler: ([messageHash]) => this.handlerAsUtility().getAuthWitness(messageHash),
282
+ });
209
283
  }
210
284
 
211
- async utilityGetBlockHeader([blockNumber]: ACVMField[]): Promise<ACVMField[]> {
212
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
285
+ // eslint-disable-next-line camelcase
286
+ aztec_utl_getPublicKeysAndPartialAddress(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
287
+ return callHandler({
288
+ oracle: 'aztec_utl_getPublicKeysAndPartialAddress',
289
+ inputs,
290
+ handler: ([address]) => this.handlerAsUtility().getPublicKeysAndPartialAddress(address),
291
+ });
292
+ }
213
293
 
214
- const header = await this.handlerAsUtility().utilityGetBlockHeader(parsedBlockNumber);
215
- if (!header) {
216
- throw new Error(`Block header not found for block ${parsedBlockNumber}.`);
217
- }
218
- return header.toFields().map(toACVMField);
294
+ // eslint-disable-next-line camelcase
295
+ aztec_utl_getNotes(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
296
+ return callHandler({
297
+ oracle: 'aztec_utl_getNotes',
298
+ inputs,
299
+ handler: ([
300
+ owner,
301
+ storageSlot,
302
+ numSelects,
303
+ selectByIndexes,
304
+ selectByOffsets,
305
+ selectByLengths,
306
+ selectValues,
307
+ selectComparators,
308
+ sortByIndexes,
309
+ sortByOffsets,
310
+ sortByLengths,
311
+ sortOrder,
312
+ limit,
313
+ offset,
314
+ status,
315
+ maxNotes,
316
+ packedHintedNoteLength,
317
+ ]) =>
318
+ this.handlerAsUtility().getNotes(
319
+ owner,
320
+ storageSlot,
321
+ numSelects,
322
+ selectByIndexes,
323
+ selectByOffsets,
324
+ selectByLengths,
325
+ selectValues,
326
+ selectComparators,
327
+ sortByIndexes,
328
+ sortByOffsets,
329
+ sortByLengths,
330
+ sortOrder,
331
+ limit,
332
+ offset,
333
+ status,
334
+ maxNotes,
335
+ packedHintedNoteLength,
336
+ ),
337
+ });
219
338
  }
220
339
 
221
- async utilityGetAuthWitness([messageHash]: ACVMField[]): Promise<ACVMField[][]> {
222
- const messageHashField = Fr.fromString(messageHash);
223
- const witness = await this.handlerAsUtility().utilityGetAuthWitness(messageHashField);
224
- if (!witness) {
225
- throw new Error(`Unknown auth witness for message hash ${messageHashField}`);
226
- }
227
- return [witness.map(toACVMField)];
228
- }
229
-
230
- async utilityGetPublicKeysAndPartialAddress([address]: ACVMField[]): Promise<ACVMField[][]> {
231
- const parsedAddress = AztecAddress.fromField(Fr.fromString(address));
232
- const { publicKeys, partialAddress } =
233
- await this.handlerAsUtility().utilityGetPublicKeysAndPartialAddress(parsedAddress);
234
-
235
- return [[...publicKeys.toFields(), partialAddress].map(toACVMField)];
236
- }
237
-
238
- async utilityGetNotes(
239
- [storageSlot]: ACVMField[],
240
- [numSelects]: ACVMField[],
241
- selectByIndexes: ACVMField[],
242
- selectByOffsets: ACVMField[],
243
- selectByLengths: ACVMField[],
244
- selectValues: ACVMField[],
245
- selectComparators: ACVMField[],
246
- sortByIndexes: ACVMField[],
247
- sortByOffsets: ACVMField[],
248
- sortByLengths: ACVMField[],
249
- sortOrder: ACVMField[],
250
- [limit]: ACVMField[],
251
- [offset]: ACVMField[],
252
- [status]: ACVMField[],
253
- [maxNotes]: ACVMField[],
254
- [packedRetrievedNoteLength]: ACVMField[],
255
- ): Promise<(ACVMField | ACVMField[])[]> {
256
- const noteDatas = await this.handlerAsUtility().utilityGetNotes(
257
- Fr.fromString(storageSlot),
258
- +numSelects,
259
- selectByIndexes.map(s => +s),
260
- selectByOffsets.map(s => +s),
261
- selectByLengths.map(s => +s),
262
- selectValues.map(Fr.fromString),
263
- selectComparators.map(s => +s),
264
- sortByIndexes.map(s => +s),
265
- sortByOffsets.map(s => +s),
266
- sortByLengths.map(s => +s),
267
- sortOrder.map(s => +s),
268
- +limit,
269
- +offset,
270
- +status,
271
- );
340
+ // eslint-disable-next-line camelcase
341
+ aztec_prv_notifyCreatedNote(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
342
+ return callHandler({
343
+ oracle: 'aztec_prv_notifyCreatedNote',
344
+ inputs,
345
+ handler: ([owner, storageSlot, randomness, noteTypeId, note, noteHash, counter]) => {
346
+ this.handlerAsPrivate().notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, note, noteHash, counter);
347
+ },
348
+ });
349
+ }
272
350
 
273
- const returnDataAsArrayOfPackedRetrievedNotes = noteDatas.map(packAsRetrievedNote);
351
+ // eslint-disable-next-line camelcase
352
+ aztec_prv_notifyNullifiedNote(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
353
+ return callHandler({
354
+ oracle: 'aztec_prv_notifyNullifiedNote',
355
+ inputs,
356
+ handler: ([innerNullifier, noteHash, counter]) =>
357
+ this.handlerAsPrivate().notifyNullifiedNote(innerNullifier, noteHash, counter),
358
+ });
359
+ }
274
360
 
275
- // Now we convert each sub-array to an array of ACVMField
276
- const returnDataAsArrayOfACVMFieldArrays = returnDataAsArrayOfPackedRetrievedNotes.map(subArray =>
277
- subArray.map(toACVMField),
278
- );
361
+ // eslint-disable-next-line camelcase
362
+ aztec_prv_notifyCreatedNullifier(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
363
+ return callHandler({
364
+ oracle: 'aztec_prv_notifyCreatedNullifier',
365
+ inputs,
366
+ handler: ([innerNullifier]) => this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier),
367
+ });
368
+ }
279
369
 
280
- // At last we convert the array of arrays to a bounded vec of arrays
281
- return arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfACVMFieldArrays, +maxNotes, +packedRetrievedNoteLength);
282
- }
283
-
284
- privateNotifyCreatedNote(
285
- [storageSlot]: ACVMField[],
286
- [noteTypeId]: ACVMField[],
287
- note: ACVMField[],
288
- [noteHash]: ACVMField[],
289
- [counter]: ACVMField[],
290
- ): Promise<ACVMField[]> {
291
- this.handlerAsPrivate().privateNotifyCreatedNote(
292
- Fr.fromString(storageSlot),
293
- NoteSelector.fromField(Fr.fromString(noteTypeId)),
294
- note.map(Fr.fromString),
295
- Fr.fromString(noteHash),
296
- +counter,
297
- );
298
- return Promise.resolve([]);
299
- }
300
-
301
- async privateNotifyNullifiedNote(
302
- [innerNullifier]: ACVMField[],
303
- [noteHash]: ACVMField[],
304
- [counter]: ACVMField[],
305
- ): Promise<ACVMField[]> {
306
- await this.handlerAsPrivate().privateNotifyNullifiedNote(
307
- Fr.fromString(innerNullifier),
308
- Fr.fromString(noteHash),
309
- +counter,
310
- );
311
- return [];
370
+ // eslint-disable-next-line camelcase
371
+ aztec_prv_isNullifierPending(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
372
+ return callHandler({
373
+ oracle: 'aztec_prv_isNullifierPending',
374
+ inputs,
375
+ handler: ([innerNullifier, contractAddress]) =>
376
+ this.handlerAsPrivate().isNullifierPending(innerNullifier, contractAddress),
377
+ });
312
378
  }
313
379
 
314
- async privateNotifyCreatedNullifier([innerNullifier]: ACVMField[]): Promise<ACVMField[]> {
315
- await this.handlerAsPrivate().privateNotifyCreatedNullifier(Fr.fromString(innerNullifier));
316
- return [];
380
+ // eslint-disable-next-line camelcase
381
+ aztec_utl_doesNullifierExist(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
382
+ return callHandler({
383
+ oracle: 'aztec_utl_doesNullifierExist',
384
+ inputs,
385
+ handler: ([innerNullifier]) => this.handlerAsUtility().doesNullifierExist(innerNullifier),
386
+ });
317
387
  }
318
388
 
319
- async utilityCheckNullifierExists([innerNullifier]: ACVMField[]): Promise<ACVMField[]> {
320
- const exists = await this.handlerAsUtility().utilityCheckNullifierExists(Fr.fromString(innerNullifier));
321
- return [toACVMField(exists)];
389
+ // eslint-disable-next-line camelcase
390
+ aztec_utl_getL1ToL2MembershipWitness(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
391
+ return callHandler({
392
+ oracle: 'aztec_utl_getL1ToL2MembershipWitness',
393
+ inputs,
394
+ handler: ([contractAddress, messageHash, secret]) =>
395
+ this.handlerAsUtility().getL1ToL2MembershipWitness(contractAddress, messageHash, secret),
396
+ });
322
397
  }
323
398
 
324
- async utilityGetL1ToL2MembershipWitness(
325
- [contractAddress]: ACVMField[],
326
- [messageHash]: ACVMField[],
327
- [secret]: ACVMField[],
328
- ): Promise<(ACVMField | ACVMField[])[]> {
329
- const message = await this.handlerAsUtility().utilityGetL1ToL2MembershipWitness(
330
- AztecAddress.fromString(contractAddress),
331
- Fr.fromString(messageHash),
332
- Fr.fromString(secret),
333
- );
334
- return message.toNoirRepresentation();
335
- }
336
-
337
- async utilityStorageRead(
338
- [contractAddress]: ACVMField[],
339
- [startStorageSlot]: ACVMField[],
340
- [blockNumber]: ACVMField[],
341
- [numberOfElements]: ACVMField[],
342
- ): Promise<ACVMField[][]> {
343
- const values = await this.handlerAsUtility().utilityStorageRead(
344
- new AztecAddress(Fr.fromString(contractAddress)),
345
- Fr.fromString(startStorageSlot),
346
- +blockNumber,
347
- +numberOfElements,
348
- );
349
- return [values.map(toACVMField)];
399
+ // eslint-disable-next-line camelcase
400
+ aztec_utl_getFromPublicStorage(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
401
+ return callHandler({
402
+ oracle: 'aztec_utl_getFromPublicStorage',
403
+ inputs,
404
+ handler: ([blockHash, contractAddress, startStorageSlot, numberOfElements]) =>
405
+ this.handlerAsUtility().getFromPublicStorage(blockHash, contractAddress, startStorageSlot, numberOfElements),
406
+ });
350
407
  }
351
408
 
352
- privateNotifyCreatedContractClassLog(
353
- [contractAddress]: ACVMField[],
354
- message: ACVMField[],
355
- [length]: ACVMField[],
356
- [counter]: ACVMField[],
357
- ): Promise<ACVMField[]> {
358
- const logFields = new ContractClassLogFields(message.map(Fr.fromString));
359
- const log = new ContractClassLog(new AztecAddress(Fr.fromString(contractAddress)), logFields, +length);
409
+ // eslint-disable-next-line camelcase
410
+ aztec_utl_callUtilityFunction(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
411
+ return callHandler({
412
+ oracle: 'aztec_utl_callUtilityFunction',
413
+ inputs,
414
+ handler: ([contractAddress, functionSelector, args]) =>
415
+ this.handlerAsUtility().callUtilityFunction(contractAddress, functionSelector, args),
416
+ });
417
+ }
360
418
 
361
- this.handlerAsPrivate().privateNotifyCreatedContractClassLog(log, +counter);
362
- return Promise.resolve([]);
419
+ // eslint-disable-next-line camelcase
420
+ aztec_prv_notifyCreatedContractClassLog(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
421
+ return callHandler({
422
+ oracle: 'aztec_prv_notifyCreatedContractClassLog',
423
+ inputs,
424
+ handler: ([log, counter]) => {
425
+ this.handlerAsPrivate().notifyCreatedContractClassLog(log, counter);
426
+ },
427
+ });
363
428
  }
364
429
 
365
- utilityDebugLog(
366
- level: ACVMField[],
367
- message: ACVMField[],
368
- _ignoredFieldsSize: ACVMField[],
369
- fields: ACVMField[],
370
- ): Promise<ACVMField[]> {
371
- const levelFr = Fr.fromString(level[0]);
372
- const messageStr = message.map(acvmField => String.fromCharCode(Fr.fromString(acvmField).toNumber())).join('');
373
- const fieldsFr = fields.map(Fr.fromString);
374
- this.handlerAsMisc().utilityDebugLog(levelFr.toNumber(), messageStr, fieldsFr);
375
- return Promise.resolve([]);
430
+ // eslint-disable-next-line camelcase
431
+ aztec_misc_log(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
432
+ return callHandler({
433
+ oracle: 'aztec_misc_log',
434
+ inputs,
435
+ handler: ([level, message, fieldsSize, fields]) => this.handlerAsMisc().log(level, message, fieldsSize, fields),
436
+ });
376
437
  }
377
438
 
378
439
  // This function's name is directly hardcoded in `circuit_recorder.ts`. Don't forget to update it there if you
379
440
  // change the name here.
380
- async privateCallPrivateFunction(
381
- [contractAddress]: ACVMField[],
382
- [functionSelector]: ACVMField[],
383
- [argsHash]: ACVMField[],
384
- [sideEffectCounter]: ACVMField[],
385
- [isStaticCall]: ACVMField[],
386
- ): Promise<ACVMField[][]> {
387
- const { endSideEffectCounter, returnsHash } = await this.handlerAsPrivate().privateCallPrivateFunction(
388
- AztecAddress.fromField(Fr.fromString(contractAddress)),
389
- FunctionSelector.fromField(Fr.fromString(functionSelector)),
390
- Fr.fromString(argsHash),
391
- Fr.fromString(sideEffectCounter).toNumber(),
392
- Fr.fromString(isStaticCall).toBool(),
393
- );
394
- return [[endSideEffectCounter, returnsHash].map(toACVMField)];
395
- }
396
-
397
- async privateNotifyEnqueuedPublicFunctionCall(
398
- [contractAddress]: ACVMField[],
399
- [calldataHash]: ACVMField[],
400
- [sideEffectCounter]: ACVMField[],
401
- [isStaticCall]: ACVMField[],
402
- ): Promise<ACVMField[]> {
403
- await this.handlerAsPrivate().privateNotifyEnqueuedPublicFunctionCall(
404
- AztecAddress.fromString(contractAddress),
405
- Fr.fromString(calldataHash),
406
- Fr.fromString(sideEffectCounter).toNumber(),
407
- Fr.fromString(isStaticCall).toBool(),
408
- );
409
- return [];
410
- }
411
-
412
- async privateNotifySetPublicTeardownFunctionCall(
413
- [contractAddress]: ACVMField[],
414
- [calldataHash]: ACVMField[],
415
- [sideEffectCounter]: ACVMField[],
416
- [isStaticCall]: ACVMField[],
417
- ): Promise<ACVMField[]> {
418
- await this.handlerAsPrivate().privateNotifySetPublicTeardownFunctionCall(
419
- AztecAddress.fromString(contractAddress),
420
- Fr.fromString(calldataHash),
421
- Fr.fromString(sideEffectCounter).toNumber(),
422
- Fr.fromString(isStaticCall).toBool(),
423
- );
424
- return [];
441
+ // eslint-disable-next-line camelcase
442
+ aztec_prv_callPrivateFunction(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
443
+ return callHandler({
444
+ oracle: 'aztec_prv_callPrivateFunction',
445
+ inputs,
446
+ handler: ([contractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall]) =>
447
+ this.handlerAsPrivate().callPrivateFunction(
448
+ contractAddress,
449
+ functionSelector,
450
+ argsHash,
451
+ sideEffectCounter,
452
+ isStaticCall,
453
+ ),
454
+ });
425
455
  }
426
456
 
427
- async privateNotifySetMinRevertibleSideEffectCounter([minRevertibleSideEffectCounter]: ACVMField[]): Promise<
428
- ACVMField[]
429
- > {
430
- await this.handlerAsPrivate().privateNotifySetMinRevertibleSideEffectCounter(
431
- Fr.fromString(minRevertibleSideEffectCounter).toNumber(),
432
- );
433
- return Promise.resolve([]);
457
+ // eslint-disable-next-line camelcase
458
+ aztec_prv_assertValidPublicCalldata(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
459
+ return callHandler({
460
+ oracle: 'aztec_prv_assertValidPublicCalldata',
461
+ inputs,
462
+ handler: ([calldataHash]) => this.handlerAsPrivate().assertValidPublicCalldata(calldataHash),
463
+ });
434
464
  }
435
465
 
436
- async privateGetNextAppTagAsSender([sender]: ACVMField[], [recipient]: ACVMField[]): Promise<ACVMField[]> {
437
- const tag = await this.handlerAsPrivate().privateGetNextAppTagAsSender(
438
- AztecAddress.fromString(sender),
439
- AztecAddress.fromString(recipient),
440
- );
441
- return [toACVMField(tag.value)];
466
+ // eslint-disable-next-line camelcase
467
+ aztec_prv_notifyRevertiblePhaseStart(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
468
+ return callHandler({
469
+ oracle: 'aztec_prv_notifyRevertiblePhaseStart',
470
+ inputs,
471
+ handler: ([minRevertibleSideEffectCounter]) =>
472
+ this.handlerAsPrivate().notifyRevertiblePhaseStart(minRevertibleSideEffectCounter),
473
+ });
442
474
  }
443
475
 
444
- async utilityFetchTaggedLogs([pendingTaggedLogArrayBaseSlot]: ACVMField[]): Promise<ACVMField[]> {
445
- await this.handlerAsUtility().utilityFetchTaggedLogs(Fr.fromString(pendingTaggedLogArrayBaseSlot));
446
- return [];
476
+ // eslint-disable-next-line camelcase
477
+ aztec_prv_isExecutionInRevertiblePhase(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
478
+ return callHandler({
479
+ oracle: 'aztec_prv_isExecutionInRevertiblePhase',
480
+ inputs,
481
+ handler: ([sideEffectCounter]) => this.handlerAsPrivate().isExecutionInRevertiblePhase(sideEffectCounter),
482
+ });
447
483
  }
448
484
 
449
- async utilityValidateEnqueuedNotesAndEvents(
450
- [contractAddress]: ACVMField[],
451
- [noteValidationRequestsArrayBaseSlot]: ACVMField[],
452
- [eventValidationRequestsArrayBaseSlot]: ACVMField[],
453
- ): Promise<ACVMField[]> {
454
- await this.handlerAsUtility().utilityValidateEnqueuedNotesAndEvents(
455
- AztecAddress.fromString(contractAddress),
456
- Fr.fromString(noteValidationRequestsArrayBaseSlot),
457
- Fr.fromString(eventValidationRequestsArrayBaseSlot),
458
- );
485
+ // eslint-disable-next-line camelcase
486
+ aztec_prv_getAppTaggingSecret(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
487
+ return callHandler({
488
+ oracle: 'aztec_prv_getAppTaggingSecret',
489
+ inputs,
490
+ handler: ([sender, recipient]) => this.handlerAsPrivate().getAppTaggingSecret(sender, recipient),
491
+ });
492
+ }
459
493
 
460
- return [];
494
+ // eslint-disable-next-line camelcase
495
+ aztec_prv_getNextTaggingIndex(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
496
+ return callHandler({
497
+ oracle: 'aztec_prv_getNextTaggingIndex',
498
+ inputs,
499
+ handler: ([secret, mode]) => this.handlerAsPrivate().getNextTaggingIndex(secret, mode),
500
+ });
461
501
  }
462
502
 
463
- async utilityBulkRetrieveLogs(
464
- [contractAddress]: ACVMField[],
465
- [logRetrievalRequestsArrayBaseSlot]: ACVMField[],
466
- [logRetrievalResponsesArrayBaseSlot]: ACVMField[],
467
- ): Promise<ACVMField[]> {
468
- await this.handlerAsUtility().utilityBulkRetrieveLogs(
469
- AztecAddress.fromString(contractAddress),
470
- Fr.fromString(logRetrievalRequestsArrayBaseSlot),
471
- Fr.fromString(logRetrievalResponsesArrayBaseSlot),
472
- );
473
- return [];
474
- }
475
-
476
- async utilityStoreCapsule(
477
- [contractAddress]: ACVMField[],
478
- [slot]: ACVMField[],
479
- capsule: ACVMField[],
480
- ): Promise<ACVMField[]> {
481
- await this.handlerAsUtility().utilityStoreCapsule(
482
- AztecAddress.fromField(Fr.fromString(contractAddress)),
483
- Fr.fromString(slot),
484
- capsule.map(Fr.fromString),
485
- );
486
- return [];
503
+ // eslint-disable-next-line camelcase
504
+ aztec_utl_getPendingTaggedLogs(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
505
+ return callHandler({
506
+ oracle: 'aztec_utl_getPendingTaggedLogs',
507
+ inputs,
508
+ handler: ([scope, providedSecrets]) => this.handlerAsUtility().getPendingTaggedLogs(scope, providedSecrets),
509
+ });
487
510
  }
488
511
 
489
- async utilityLoadCapsule(
490
- [contractAddress]: ACVMField[],
491
- [slot]: ACVMField[],
492
- [tSize]: ACVMField[],
493
- ): Promise<(ACVMField | ACVMField[])[]> {
494
- const values = await this.handlerAsUtility().utilityLoadCapsule(
495
- AztecAddress.fromField(Fr.fromString(contractAddress)),
496
- Fr.fromString(slot),
497
- );
512
+ // eslint-disable-next-line camelcase
513
+ aztec_utl_validateAndStoreEnqueuedNotesAndEvents(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
514
+ return callHandler({
515
+ oracle: 'aztec_utl_validateAndStoreEnqueuedNotesAndEvents',
516
+ inputs,
517
+ handler: ([noteValidationRequests, eventValidationRequests, scope]) =>
518
+ this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(
519
+ noteValidationRequests,
520
+ eventValidationRequests,
521
+ scope,
522
+ ),
523
+ });
524
+ }
498
525
 
499
- // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
500
- // with two fields: `some` (a boolean) and `value` (a field array in this case).
501
- if (values === null) {
502
- // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
503
- return [toACVMField(0), Array(Fr.fromString(tSize).toNumber()).fill(toACVMField(0))];
504
- } else {
505
- // Data was found so we set `some` to 1 and return it along with `value`.
506
- return [toACVMField(1), values.map(toACVMField)];
507
- }
526
+ // eslint-disable-next-line camelcase
527
+ aztec_utl_getLogsByTag(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
528
+ return callHandler({
529
+ oracle: 'aztec_utl_getLogsByTag',
530
+ inputs,
531
+ handler: ([requests]) => this.handlerAsUtility().getLogsByTag(requests),
532
+ });
508
533
  }
509
534
 
510
- async utilityDeleteCapsule([contractAddress]: ACVMField[], [slot]: ACVMField[]): Promise<ACVMField[]> {
511
- await this.handlerAsUtility().utilityDeleteCapsule(
512
- AztecAddress.fromField(Fr.fromString(contractAddress)),
513
- Fr.fromString(slot),
514
- );
515
- return [];
516
- }
517
-
518
- async utilityCopyCapsule(
519
- [contractAddress]: ACVMField[],
520
- [srcSlot]: ACVMField[],
521
- [dstSlot]: ACVMField[],
522
- [numEntries]: ACVMField[],
523
- ): Promise<ACVMField[]> {
524
- await this.handlerAsUtility().utilityCopyCapsule(
525
- AztecAddress.fromField(Fr.fromString(contractAddress)),
526
- Fr.fromString(srcSlot),
527
- Fr.fromString(dstSlot),
528
- Fr.fromString(numEntries).toNumber(),
529
- );
530
- return [];
531
- }
532
-
533
- async utilityAes128Decrypt(
534
- ciphertextBVecStorage: ACVMField[],
535
- [ciphertextLength]: ACVMField[],
536
- iv: ACVMField[],
537
- symKey: ACVMField[],
538
- ): Promise<(ACVMField | ACVMField[])[]> {
539
- const ciphertext = fromUintBoundedVec(ciphertextBVecStorage, ciphertextLength, 8);
540
- const ivBuffer = fromUintArray(iv, 8);
541
- const symKeyBuffer = fromUintArray(symKey, 8);
542
-
543
- const plaintext = await this.handlerAsUtility().utilityAes128Decrypt(ciphertext, ivBuffer, symKeyBuffer);
544
- return bufferToBoundedVec(plaintext, ciphertextBVecStorage.length);
545
- }
546
-
547
- async utilityGetSharedSecret(
548
- [address]: ACVMField[],
549
- [ephPKField0]: ACVMField[],
550
- [ephPKField1]: ACVMField[],
551
- [ephPKField2]: ACVMField[],
552
- ): Promise<ACVMField[]> {
553
- const secret = await this.handlerAsUtility().utilityGetSharedSecret(
554
- AztecAddress.fromField(Fr.fromString(address)),
555
- Point.fromFields([ephPKField0, ephPKField1, ephPKField2].map(Fr.fromString)),
556
- );
557
- return secret.toFields().map(toACVMField);
535
+ // eslint-disable-next-line camelcase
536
+ aztec_utl_getMessageContextsByTxHash(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
537
+ return callHandler({
538
+ oracle: 'aztec_utl_getMessageContextsByTxHash',
539
+ inputs,
540
+ handler: ([requests]) => this.handlerAsUtility().getMessageContextsByTxHash(requests),
541
+ });
542
+ }
543
+
544
+ // eslint-disable-next-line camelcase
545
+ aztec_utl_getTxEffect(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
546
+ return callHandler({
547
+ oracle: 'aztec_utl_getTxEffect',
548
+ inputs,
549
+ handler: ([txHash]) => this.handlerAsUtility().getTxEffect(txHash),
550
+ });
551
+ }
552
+
553
+ // eslint-disable-next-line camelcase
554
+ aztec_utl_setCapsule(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
555
+ return callHandler({
556
+ oracle: 'aztec_utl_setCapsule',
557
+ inputs,
558
+ handler: ([contractAddress, slot, capsule, scope]) => {
559
+ this.handlerAsUtility().setCapsule(contractAddress, slot, capsule, scope);
560
+ },
561
+ });
562
+ }
563
+
564
+ // eslint-disable-next-line camelcase
565
+ aztec_utl_getCapsule(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
566
+ return callHandler({
567
+ oracle: 'aztec_utl_getCapsule',
568
+ inputs,
569
+ handler: ([contractAddress, slot, tSize, scope]) =>
570
+ this.handlerAsUtility().getCapsule(contractAddress, slot, tSize, scope),
571
+ });
572
+ }
573
+
574
+ // eslint-disable-next-line camelcase
575
+ aztec_utl_deleteCapsule(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
576
+ return callHandler({
577
+ oracle: 'aztec_utl_deleteCapsule',
578
+ inputs,
579
+ handler: ([contractAddress, slot, scope]) => {
580
+ this.handlerAsUtility().deleteCapsule(contractAddress, slot, scope);
581
+ },
582
+ });
583
+ }
584
+
585
+ // eslint-disable-next-line camelcase
586
+ aztec_utl_copyCapsule(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
587
+ return callHandler({
588
+ oracle: 'aztec_utl_copyCapsule',
589
+ inputs,
590
+ handler: ([contractAddress, srcSlot, dstSlot, numEntries, scope]) =>
591
+ this.handlerAsUtility().copyCapsule(contractAddress, srcSlot, dstSlot, numEntries, scope),
592
+ });
593
+ }
594
+
595
+ // eslint-disable-next-line camelcase
596
+ aztec_utl_pushEphemeral(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
597
+ return callHandler({
598
+ oracle: 'aztec_utl_pushEphemeral',
599
+ inputs,
600
+ handler: ([slot, elements]) => this.handlerAsUtility().pushEphemeral(slot, elements),
601
+ });
602
+ }
603
+
604
+ // eslint-disable-next-line camelcase
605
+ aztec_utl_popEphemeral(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
606
+ return callHandler({
607
+ oracle: 'aztec_utl_popEphemeral',
608
+ inputs,
609
+ handler: ([slot]) => this.handlerAsUtility().popEphemeral(slot),
610
+ });
611
+ }
612
+
613
+ // eslint-disable-next-line camelcase
614
+ aztec_utl_getEphemeral(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
615
+ return callHandler({
616
+ oracle: 'aztec_utl_getEphemeral',
617
+ inputs,
618
+ handler: ([slot, index]) => this.handlerAsUtility().getEphemeral(slot, index),
619
+ });
620
+ }
621
+
622
+ // eslint-disable-next-line camelcase
623
+ aztec_utl_setEphemeral(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
624
+ return callHandler({
625
+ oracle: 'aztec_utl_setEphemeral',
626
+ inputs,
627
+ handler: ([slot, index, elements]) => {
628
+ this.handlerAsUtility().setEphemeral(slot, index, elements);
629
+ },
630
+ });
558
631
  }
559
632
 
560
- async utilityEmitOffchainEffect(data: ACVMField[]) {
561
- await this.handlerAsPrivate().utilityEmitOffchainEffect(data.map(Fr.fromString));
562
- return [];
633
+ // eslint-disable-next-line camelcase
634
+ aztec_utl_getEphemeralLen(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
635
+ return callHandler({
636
+ oracle: 'aztec_utl_getEphemeralLen',
637
+ inputs,
638
+ handler: ([slot]) => this.handlerAsUtility().getEphemeralLen(slot),
639
+ });
563
640
  }
564
641
 
565
- async privateGetSenderForTags(): Promise<ACVMField[]> {
566
- const sender = await this.handlerAsPrivate().privateGetSenderForTags();
567
- // Return [1, address] for Some(address), [0, 0] for None
568
- return sender ? [toACVMField(1n), toACVMField(sender)] : [toACVMField(0n), toACVMField(0n)];
642
+ // eslint-disable-next-line camelcase
643
+ aztec_utl_removeEphemeral(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
644
+ return callHandler({
645
+ oracle: 'aztec_utl_removeEphemeral',
646
+ inputs,
647
+ handler: ([slot, index]) => {
648
+ this.handlerAsUtility().removeEphemeral(slot, index);
649
+ },
650
+ });
569
651
  }
570
652
 
571
- async privateSetSenderForTags([senderForTags]: ACVMField[]): Promise<ACVMField[]> {
572
- await this.handlerAsPrivate().privateSetSenderForTags(AztecAddress.fromField(Fr.fromString(senderForTags)));
573
- return [];
653
+ // eslint-disable-next-line camelcase
654
+ aztec_utl_clearEphemeral(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
655
+ return callHandler({
656
+ oracle: 'aztec_utl_clearEphemeral',
657
+ inputs,
658
+ handler: ([slot]) => {
659
+ this.handlerAsUtility().clearEphemeral(slot);
660
+ },
661
+ });
662
+ }
663
+
664
+ // eslint-disable-next-line camelcase
665
+ aztec_utl_decryptAes128(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
666
+ return callHandler({
667
+ oracle: 'aztec_utl_decryptAes128',
668
+ inputs,
669
+ handler: ([ciphertext, iv, symKey]) => this.handlerAsUtility().decryptAes128(ciphertext, iv, symKey),
670
+ });
671
+ }
672
+
673
+ // eslint-disable-next-line camelcase
674
+ aztec_utl_getSharedSecrets(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
675
+ return callHandler({
676
+ oracle: 'aztec_utl_getSharedSecrets',
677
+ inputs,
678
+ handler: ([address, ephPks, contractAddress]) =>
679
+ this.handlerAsUtility().getSharedSecrets(address, ephPks, contractAddress),
680
+ });
681
+ }
682
+
683
+ // eslint-disable-next-line camelcase
684
+ aztec_utl_setContractSyncCacheInvalid(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
685
+ return callHandler({
686
+ oracle: 'aztec_utl_setContractSyncCacheInvalid',
687
+ inputs,
688
+ handler: ([contractAddress, scopes]) => {
689
+ this.handlerAsUtility().setContractSyncCacheInvalid(contractAddress, scopes);
690
+ },
691
+ });
692
+ }
693
+
694
+ // eslint-disable-next-line camelcase
695
+ aztec_utl_emitOffchainEffect(...inputs: ACVMField[][]): Promise<(ACVMField | ACVMField[])[]> {
696
+ return callHandler({
697
+ oracle: 'aztec_utl_emitOffchainEffect',
698
+ inputs,
699
+ handler: ([data]) => this.handlerAsUtility().emitOffchainEffect(data),
700
+ });
701
+ }
702
+
703
+ // eslint-disable-next-line camelcase
704
+ aztec_prv_getSenderForTags(): Promise<(ACVMField | ACVMField[])[]> {
705
+ return callHandler({
706
+ oracle: 'aztec_prv_getSenderForTags',
707
+ inputs: [],
708
+ handler: () => this.handlerAsPrivate().getSenderForTags(),
709
+ });
574
710
  }
575
711
  }