@aztec/pxe 0.0.1-commit.04852196a → 0.0.1-commit.04d373f

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 (312) hide show
  1. package/dest/bin/check_oracle_version.d.ts +12 -2
  2. package/dest/bin/check_oracle_version.d.ts.map +1 -1
  3. package/dest/bin/check_oracle_version.js +31 -25
  4. package/dest/bin/index.d.ts +2 -0
  5. package/dest/bin/index.d.ts.map +1 -0
  6. package/dest/bin/index.js +1 -0
  7. package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
  8. package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
  9. package/dest/block_synchronizer/block_stream_source.js +62 -0
  10. package/dest/block_synchronizer/block_synchronizer.d.ts +6 -2
  11. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  12. package/dest/block_synchronizer/block_synchronizer.js +30 -10
  13. package/dest/config/index.d.ts +7 -1
  14. package/dest/config/index.d.ts.map +1 -1
  15. package/dest/config/index.js +12 -14
  16. package/dest/contract_function_simulator/contract_function_simulator.d.ts +16 -5
  17. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  18. package/dest/contract_function_simulator/contract_function_simulator.js +51 -16
  19. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  20. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  21. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  22. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -11
  23. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  24. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -15
  25. package/dest/contract_function_simulator/index.d.ts +4 -1
  26. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  27. package/dest/contract_function_simulator/index.js +3 -0
  28. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
  29. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
  30. package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
  31. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +4 -6
  32. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  33. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +8 -9
  34. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +13 -3
  35. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
  36. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +35 -4
  37. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +2 -2
  38. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  39. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
  40. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +4 -7
  41. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  42. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +6 -10
  43. package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
  44. package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
  45. package/dest/contract_function_simulator/noir-structs/option.js +62 -0
  46. package/dest/contract_function_simulator/oracle/interfaces.d.ts +50 -38
  47. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  48. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +2 -2
  49. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  50. package/dest/contract_function_simulator/oracle/note_packing_utils.js +2 -2
  51. package/dest/contract_function_simulator/oracle/oracle.d.ts +73 -44
  52. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  53. package/dest/contract_function_simulator/oracle/oracle.js +403 -262
  54. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +147 -0
  55. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
  56. package/dest/contract_function_simulator/oracle/oracle_registry.js +1199 -0
  57. package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
  58. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +36 -62
  59. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  60. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +77 -80
  61. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +100 -57
  62. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  63. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +375 -122
  64. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  65. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  66. package/dest/contract_function_simulator/pick_notes.js +20 -3
  67. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  68. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  69. package/dest/contract_function_simulator/proxied_contract_data_source.js +35 -64
  70. package/dest/contract_logging.d.ts +9 -4
  71. package/dest/contract_logging.d.ts.map +1 -1
  72. package/dest/contract_logging.js +21 -6
  73. package/dest/contract_sync/contract_sync_service.d.ts +7 -8
  74. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
  75. package/dest/contract_sync/contract_sync_service.js +87 -49
  76. package/dest/contract_sync/helpers.d.ts +2 -4
  77. package/dest/contract_sync/helpers.d.ts.map +1 -1
  78. package/dest/contract_sync/helpers.js +12 -14
  79. package/dest/debug/pxe_debug_utils.d.ts +3 -8
  80. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  81. package/dest/debug/pxe_debug_utils.js +0 -6
  82. package/dest/entrypoints/client/bundle/index.d.ts +1 -2
  83. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  84. package/dest/entrypoints/client/bundle/index.js +0 -1
  85. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  86. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  87. package/dest/entrypoints/client/bundle/utils.js +13 -5
  88. package/dest/entrypoints/client/lazy/index.d.ts +1 -2
  89. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  90. package/dest/entrypoints/client/lazy/index.js +0 -1
  91. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  92. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  93. package/dest/entrypoints/client/lazy/utils.js +13 -5
  94. package/dest/entrypoints/pxe_creation_options.d.ts +9 -1
  95. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  96. package/dest/entrypoints/pxe_creation_options.js +3 -1
  97. package/dest/entrypoints/server/index.d.ts +3 -3
  98. package/dest/entrypoints/server/index.d.ts.map +1 -1
  99. package/dest/entrypoints/server/index.js +2 -2
  100. package/dest/entrypoints/server/utils.d.ts +4 -3
  101. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  102. package/dest/entrypoints/server/utils.js +13 -5
  103. package/dest/events/event_service.d.ts +15 -6
  104. package/dest/events/event_service.d.ts.map +1 -1
  105. package/dest/events/event_service.js +44 -11
  106. package/dest/events/private_event_filter_validator.d.ts +3 -2
  107. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  108. package/dest/events/private_event_filter_validator.js +15 -0
  109. package/dest/hooks/authorize_utility_call.d.ts +41 -0
  110. package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
  111. package/dest/hooks/authorize_utility_call.js +4 -0
  112. package/dest/hooks/execution_hooks.d.ts +42 -0
  113. package/dest/hooks/execution_hooks.d.ts.map +1 -0
  114. package/dest/hooks/execution_hooks.js +9 -0
  115. package/dest/hooks/index.d.ts +4 -0
  116. package/dest/hooks/index.d.ts.map +1 -0
  117. package/dest/hooks/index.js +1 -0
  118. package/dest/logs/log_service.d.ts +9 -9
  119. package/dest/logs/log_service.d.ts.map +1 -1
  120. package/dest/logs/log_service.js +122 -72
  121. package/dest/messages/message_context_service.d.ts +17 -0
  122. package/dest/messages/message_context_service.d.ts.map +1 -0
  123. package/dest/messages/message_context_service.js +38 -0
  124. package/dest/notes/note_service.d.ts +27 -6
  125. package/dest/notes/note_service.d.ts.map +1 -1
  126. package/dest/notes/note_service.js +80 -56
  127. package/dest/notes_filter.d.ts +2 -3
  128. package/dest/notes_filter.d.ts.map +1 -1
  129. package/dest/oracle_version.d.ts +4 -3
  130. package/dest/oracle_version.d.ts.map +1 -1
  131. package/dest/oracle_version.js +20 -10
  132. package/dest/private_kernel/batch_planner.d.ts +47 -0
  133. package/dest/private_kernel/batch_planner.d.ts.map +1 -0
  134. package/dest/private_kernel/batch_planner.js +104 -0
  135. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +1 -1
  136. package/dest/private_kernel/hints/test_utils.d.ts +1 -1
  137. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -1
  138. package/dest/private_kernel/hints/test_utils.js +2 -3
  139. package/dest/private_kernel/private_kernel_execution_prover.d.ts +6 -2
  140. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  141. package/dest/private_kernel/private_kernel_execution_prover.js +152 -59
  142. package/dest/private_kernel/private_kernel_oracle.d.ts +10 -10
  143. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  144. package/dest/private_kernel/private_kernel_oracle.js +24 -22
  145. package/dest/pxe.d.ts +59 -10
  146. package/dest/pxe.d.ts.map +1 -1
  147. package/dest/pxe.js +154 -93
  148. package/dest/storage/anchor_block_store/anchor_block_store.js +1 -1
  149. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
  150. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
  151. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
  152. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
  153. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
  154. package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
  155. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
  156. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
  157. package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
  158. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  159. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  160. package/dest/storage/capsule_store/capsule_service.js +50 -0
  161. package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
  162. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  163. package/dest/storage/capsule_store/capsule_store.js +36 -28
  164. package/dest/storage/capsule_store/index.d.ts +2 -1
  165. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  166. package/dest/storage/capsule_store/index.js +1 -0
  167. package/dest/storage/contract_store/contract_store.d.ts +1 -1
  168. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  169. package/dest/storage/contract_store/contract_store.js +9 -26
  170. package/dest/storage/metadata.d.ts +1 -1
  171. package/dest/storage/metadata.js +1 -1
  172. package/dest/storage/note_store/note_store.d.ts +1 -1
  173. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  174. package/dest/storage/note_store/note_store.js +2 -2
  175. package/dest/storage/open_pxe_stores.d.ts +33 -0
  176. package/dest/storage/open_pxe_stores.d.ts.map +1 -0
  177. package/dest/storage/open_pxe_stores.js +27 -0
  178. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  179. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  180. package/dest/storage/private_event_store/private_event_store.js +3 -0
  181. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  182. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  183. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  184. package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
  185. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  186. package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
  187. package/dest/tagging/get_all_logs_by_tags.d.ts +34 -10
  188. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  189. package/dest/tagging/get_all_logs_by_tags.js +36 -37
  190. package/dest/tagging/index.d.ts +6 -5
  191. package/dest/tagging/index.d.ts.map +1 -1
  192. package/dest/tagging/index.js +4 -3
  193. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
  194. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
  195. package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
  196. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
  197. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
  198. package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
  199. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +3 -3
  200. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -1
  201. package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
  202. package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
  203. package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
  204. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -5
  205. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  206. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +29 -10
  207. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +13 -7
  208. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  209. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +41 -10
  210. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -4
  211. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  212. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +26 -13
  213. package/package.json +20 -17
  214. package/src/bin/check_oracle_version.ts +41 -31
  215. package/src/bin/index.ts +1 -0
  216. package/src/block_synchronizer/block_stream_source.ts +81 -0
  217. package/src/block_synchronizer/block_synchronizer.ts +33 -11
  218. package/src/config/index.ts +14 -8
  219. package/src/contract_function_simulator/contract_function_simulator.ts +80 -20
  220. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  221. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
  222. package/src/contract_function_simulator/index.ts +3 -0
  223. package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
  224. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +10 -9
  225. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
  226. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  227. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +5 -10
  228. package/src/contract_function_simulator/noir-structs/option.ts +69 -0
  229. package/src/contract_function_simulator/oracle/interfaces.ts +65 -55
  230. package/src/contract_function_simulator/oracle/note_packing_utils.ts +3 -3
  231. package/src/contract_function_simulator/oracle/oracle.ts +497 -451
  232. package/src/contract_function_simulator/oracle/oracle_registry.ts +904 -0
  233. package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
  234. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +102 -115
  235. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +531 -202
  236. package/src/contract_function_simulator/pick_notes.ts +22 -3
  237. package/src/contract_function_simulator/proxied_contract_data_source.ts +41 -64
  238. package/src/contract_logging.ts +18 -5
  239. package/src/contract_sync/contract_sync_service.ts +120 -83
  240. package/src/contract_sync/helpers.ts +13 -25
  241. package/src/debug/pxe_debug_utils.ts +3 -11
  242. package/src/entrypoints/client/bundle/index.ts +0 -1
  243. package/src/entrypoints/client/bundle/utils.ts +10 -5
  244. package/src/entrypoints/client/lazy/index.ts +0 -1
  245. package/src/entrypoints/client/lazy/utils.ts +10 -5
  246. package/src/entrypoints/pxe_creation_options.ts +14 -0
  247. package/src/entrypoints/server/index.ts +2 -2
  248. package/src/entrypoints/server/utils.ts +15 -6
  249. package/src/events/event_service.ts +69 -21
  250. package/src/events/private_event_filter_validator.ts +21 -1
  251. package/src/hooks/authorize_utility_call.ts +44 -0
  252. package/src/hooks/execution_hooks.ts +48 -0
  253. package/src/hooks/index.ts +7 -0
  254. package/src/logs/log_service.ts +153 -134
  255. package/src/messages/message_context_service.ts +45 -0
  256. package/src/notes/note_service.ts +119 -85
  257. package/src/notes_filter.ts +1 -3
  258. package/src/oracle_version.ts +20 -10
  259. package/src/private_kernel/batch_planner.ts +169 -0
  260. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +1 -1
  261. package/src/private_kernel/hints/test_utils.ts +2 -9
  262. package/src/private_kernel/private_kernel_execution_prover.ts +240 -82
  263. package/src/private_kernel/private_kernel_oracle.ts +35 -25
  264. package/src/pxe.ts +262 -98
  265. package/src/storage/anchor_block_store/anchor_block_store.ts +1 -1
  266. package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
  267. package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
  268. package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
  269. package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
  270. package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
  271. package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
  272. package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
  273. package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
  274. package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
  275. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
  276. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
  277. package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
  278. package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
  279. package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
  280. package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
  281. package/src/storage/capsule_store/capsule_service.ts +90 -0
  282. package/src/storage/capsule_store/capsule_store.ts +44 -26
  283. package/src/storage/capsule_store/index.ts +1 -0
  284. package/src/storage/contract_store/contract_store.ts +14 -35
  285. package/src/storage/metadata.ts +1 -1
  286. package/src/storage/note_store/note_store.ts +2 -5
  287. package/src/storage/open_pxe_stores.ts +49 -0
  288. package/src/storage/private_event_store/private_event_store.ts +4 -0
  289. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  290. package/src/storage/tagging_store/recipient_tagging_store.ts +5 -9
  291. package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
  292. package/src/tagging/get_all_logs_by_tags.ts +78 -50
  293. package/src/tagging/index.ts +5 -4
  294. package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
  295. package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
  296. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  297. package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
  298. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +52 -12
  299. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +44 -14
  300. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +23 -14
  301. package/dest/access_scopes.d.ts +0 -9
  302. package/dest/access_scopes.d.ts.map +0 -1
  303. package/dest/access_scopes.js +0 -6
  304. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -14
  305. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +0 -1
  306. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +0 -99
  307. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -14
  308. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
  309. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -33
  310. package/src/access_scopes.ts +0 -9
  311. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -140
  312. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -44
@@ -1,12 +1,5 @@
1
- import { BlockNumber } from '@aztec/foundation/branded-types';
2
- import { Fr } from '@aztec/foundation/curves/bn254';
3
- import { Point } from '@aztec/foundation/curves/grumpkin';
4
- import { arrayOfArraysToBoundedVecOfArrays, bufferToBoundedVec, fromUintArray, fromUintBoundedVec, toACVMField } from '@aztec/simulator/client';
5
- import { FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
6
- import { AztecAddress } from '@aztec/stdlib/aztec-address';
7
- import { BlockHash } from '@aztec/stdlib/block';
8
- import { ContractClassLog, ContractClassLogFields } from '@aztec/stdlib/logs';
9
- import { packAsHintedNote } from './note_packing_utils.js';
1
+ import { ORACLE_VERSION_MAJOR, ORACLE_VERSION_MINOR } from '../../oracle_version.js';
2
+ import { callHandler } from './oracle_registry.js';
10
3
  export class UnavailableOracleError extends Error {
11
4
  constructor(oracleName){
12
5
  super(`${oracleName} oracles not available with the current handler`);
@@ -14,6 +7,25 @@ export class UnavailableOracleError extends Error {
14
7
  }
15
8
  /**
16
9
  * A data source that has all the apis required by Aztec.nr.
10
+ *
11
+ * ## Oracle naming conventions
12
+ *
13
+ * We try to keep oracle naming consistent, please see below the conventions we adhere to.
14
+ *
15
+ * Each oracle method name has the form `aztec_{scope}_{verb}{Object}`, where:
16
+ *
17
+ * - **Scope prefix** indicates the execution context required:
18
+ * - `aztec_prv_` — available only during private function execution.
19
+ * - `aztec_utl_` — available during both utility and private execution.
20
+ *
21
+ * - **Verb** signals the operation's semantics (verb-first, then object):
22
+ * - `get` — read / lookup / get data from oracle into contract.
23
+ * - `does`/`is`/`has` — predicate (returns boolean).
24
+ * - `emit`/`notify` — propagate data from contract to oracle.
25
+ * - `set` — contract driven oracle state mutation (capsules, execution cache, tagging, etc).
26
+ * - `call` — trigger nested execution (control flow).
27
+ * - `assert` — validate a condition, throw on failure.
28
+ * - Standalone verbs (`delete`, `copy`, `decrypt`, `log`, etc) are used when no generic verb fits.
17
29
  */ export class Oracle {
18
30
  handler;
19
31
  constructor(handler){
@@ -60,352 +72,481 @@ export class UnavailableOracleError extends Error {
60
72
  }
61
73
  });
62
74
  // Build callback object and return it
63
- return oracleNames.reduce((acc, name)=>{
75
+ const callback = oracleNames.reduce((acc, name)=>{
64
76
  const method = this[name];
65
77
  acc[name] = method.bind(this);
66
78
  return acc;
67
79
  }, {});
80
+ // Wrap in a Proxy to intercept access to missing oracle names and provide enhanced error messages when the
81
+ // contract's minor version is higher than the PXE's (i.e. the contract expects oracles that were added in a newer
82
+ // minor version).
83
+ const handler = this.handler;
84
+ return new Proxy(callback, {
85
+ get (target, prop) {
86
+ if (prop in target) {
87
+ return target[prop];
88
+ }
89
+ // Return a function that throws with an enhanced error message if applicable
90
+ return ()=>{
91
+ let contractVersion = undefined;
92
+ if ('nonOracleFunctionGetContractOracleVersion' in handler) {
93
+ contractVersion = handler.nonOracleFunctionGetContractOracleVersion();
94
+ }
95
+ if (!contractVersion) {
96
+ throw new Error(`Oracle '${prop}' not found and the contract's oracle version is unknown (the version check oracle ` + `was not called before '${prop}'). This usually means the contract was not compiled with the ` + `#[aztec] macro, which injects the version check as the first oracle call in every private/utility ` + `external function. If you're using a custom entry point, ensure assert_compatible_oracle_version() ` + `is called before any other oracle calls. See https://docs.aztec.network/errors/8`);
97
+ } else if (contractVersion.minor > ORACLE_VERSION_MINOR) {
98
+ throw new Error(`Oracle '${prop}' not found.` + ` This usually means the contract requires a newer private execution environment than you have.` + ` Upgrade your private execution environment to a compatible version. The contract was compiled with` + ` Aztec.nr oracle version ${contractVersion.major}.${contractVersion.minor}, but this private` + ` execution environment only supports up to ${ORACLE_VERSION_MAJOR}.${ORACLE_VERSION_MINOR}.` + ` See https://docs.aztec.network/errors/8`);
99
+ } else {
100
+ throw new Error(`Oracle '${prop}' not found.` + ` The contract's oracle version (${contractVersion.major}.${contractVersion.minor}) is compatible` + ` with this private execution environment (${ORACLE_VERSION_MAJOR}.${ORACLE_VERSION_MINOR}), so all` + ` standard oracles should be available. This could mean the contract was compiled against a modified` + ` version of Aztec.nr, or that it references an oracle that does not exist.` + ` See https://docs.aztec.network/errors/8`);
101
+ }
102
+ };
103
+ }
104
+ });
68
105
  }
69
106
  // eslint-disable-next-line camelcase
70
- aztec_utl_assertCompatibleOracleVersion([version]) {
71
- this.handlerAsMisc().assertCompatibleOracleVersion(Fr.fromString(version).toNumber());
72
- return Promise.resolve([]);
107
+ aztec_utl_assertCompatibleOracleVersion(...inputs) {
108
+ return callHandler({
109
+ oracle: 'aztec_utl_assertCompatibleOracleVersion',
110
+ inputs,
111
+ handler: ([major, minor])=>{
112
+ this.handlerAsMisc().assertCompatibleOracleVersion(major, minor);
113
+ }
114
+ });
73
115
  }
74
116
  // eslint-disable-next-line camelcase
75
117
  aztec_utl_getRandomField() {
76
- const val = this.handlerAsMisc().getRandomField();
77
- return Promise.resolve([
78
- toACVMField(val)
79
- ]);
118
+ return callHandler({
119
+ oracle: 'aztec_utl_getRandomField',
120
+ inputs: [],
121
+ handler: ()=>this.handlerAsMisc().getRandomField()
122
+ });
80
123
  }
81
124
  // eslint-disable-next-line camelcase
82
- aztec_prv_storeInExecutionCache(values, [hash]) {
83
- this.handlerAsPrivate().storeInExecutionCache(values.map(Fr.fromString), Fr.fromString(hash));
84
- return Promise.resolve([]);
125
+ aztec_prv_setHashPreimage(...inputs) {
126
+ return callHandler({
127
+ oracle: 'aztec_prv_setHashPreimage',
128
+ inputs,
129
+ handler: ([values, hash])=>{
130
+ this.handlerAsPrivate().setHashPreimage(values, hash);
131
+ }
132
+ });
85
133
  }
86
134
  // eslint-disable-next-line camelcase
87
- async aztec_prv_loadFromExecutionCache([returnsHash]) {
88
- const values = await this.handlerAsPrivate().loadFromExecutionCache(Fr.fromString(returnsHash));
89
- return [
90
- values.map(toACVMField)
91
- ];
135
+ aztec_prv_getHashPreimage(...inputs) {
136
+ return callHandler({
137
+ oracle: 'aztec_prv_getHashPreimage',
138
+ inputs,
139
+ handler: ([returnsHash])=>this.handlerAsPrivate().getHashPreimage(returnsHash)
140
+ });
92
141
  }
93
142
  // eslint-disable-next-line camelcase
94
143
  aztec_utl_getUtilityContext() {
95
- const context = this.handlerAsUtility().getUtilityContext();
96
- return Promise.resolve(context.toNoirRepresentation());
144
+ return callHandler({
145
+ oracle: 'aztec_utl_getUtilityContext',
146
+ inputs: [],
147
+ handler: ()=>this.handlerAsUtility().getUtilityContext()
148
+ });
97
149
  }
98
150
  // eslint-disable-next-line camelcase
99
- async aztec_utl_getKeyValidationRequest([pkMHash]) {
100
- const keyValidationRequest = await this.handlerAsUtility().getKeyValidationRequest(Fr.fromString(pkMHash));
101
- return keyValidationRequest.toFields().map(toACVMField);
151
+ aztec_utl_getKeyValidationRequest(...inputs) {
152
+ return callHandler({
153
+ oracle: 'aztec_utl_getKeyValidationRequest',
154
+ inputs,
155
+ handler: ([pkMHash])=>this.handlerAsUtility().getKeyValidationRequest(pkMHash)
156
+ });
102
157
  }
103
158
  // eslint-disable-next-line camelcase
104
- async aztec_utl_getContractInstance([address]) {
105
- const instance = await this.handlerAsUtility().getContractInstance(AztecAddress.fromField(Fr.fromString(address)));
106
- return [
107
- instance.salt,
108
- instance.deployer,
109
- instance.currentContractClassId,
110
- instance.initializationHash,
111
- ...instance.publicKeys.toFields()
112
- ].map(toACVMField);
159
+ aztec_utl_getContractInstance(...inputs) {
160
+ return callHandler({
161
+ oracle: 'aztec_utl_getContractInstance',
162
+ inputs,
163
+ handler: ([address])=>this.handlerAsUtility().getContractInstance(address)
164
+ });
113
165
  }
114
166
  // eslint-disable-next-line camelcase
115
- async aztec_utl_getNoteHashMembershipWitness([anchorBlockHash], [noteHash]) {
116
- const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
117
- const parsedNoteHash = Fr.fromString(noteHash);
118
- const witness = await this.handlerAsUtility().getNoteHashMembershipWitness(parsedAnchorBlockHash, parsedNoteHash);
119
- if (!witness) {
120
- throw new Error(`Note hash ${noteHash} not found in the note hash tree at anchor block hash ${parsedAnchorBlockHash.toString()}.`);
121
- }
122
- return witness.toNoirRepresentation();
167
+ aztec_utl_getNoteHashMembershipWitness(...inputs) {
168
+ return callHandler({
169
+ oracle: 'aztec_utl_getNoteHashMembershipWitness',
170
+ inputs,
171
+ handler: ([anchorBlockHash, noteHash])=>this.handlerAsUtility().getNoteHashMembershipWitness(anchorBlockHash, noteHash)
172
+ });
123
173
  }
124
174
  // eslint-disable-next-line camelcase
125
- async aztec_utl_getBlockHashMembershipWitness([anchorBlockHash], [blockHash]) {
126
- const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
127
- const parsedBlockHash = BlockHash.fromString(blockHash);
128
- const witness = await this.handlerAsUtility().getBlockHashMembershipWitness(parsedAnchorBlockHash, parsedBlockHash);
129
- if (!witness) {
130
- throw new Error(`Block hash ${parsedBlockHash.toString()} not found in the archive tree at anchor block ${parsedAnchorBlockHash.toString()}.`);
131
- }
132
- return witness.toNoirRepresentation();
175
+ aztec_utl_getBlockHashMembershipWitness(...inputs) {
176
+ return callHandler({
177
+ oracle: 'aztec_utl_getBlockHashMembershipWitness',
178
+ inputs,
179
+ handler: ([anchorBlockHash, blockHash])=>this.handlerAsUtility().getBlockHashMembershipWitness(anchorBlockHash, blockHash)
180
+ });
133
181
  }
134
182
  // eslint-disable-next-line camelcase
135
- async aztec_utl_getNullifierMembershipWitness([blockHash], [nullifier]) {
136
- const parsedBlockHash = BlockHash.fromString(blockHash);
137
- const parsedNullifier = Fr.fromString(nullifier);
138
- const witness = await this.handlerAsUtility().getNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
139
- if (!witness) {
140
- throw new Error(`Nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`);
141
- }
142
- return witness.toNoirRepresentation();
183
+ aztec_utl_getNullifierMembershipWitness(...inputs) {
184
+ return callHandler({
185
+ oracle: 'aztec_utl_getNullifierMembershipWitness',
186
+ inputs,
187
+ handler: ([blockHash, nullifier])=>this.handlerAsUtility().getNullifierMembershipWitness(blockHash, nullifier)
188
+ });
143
189
  }
144
190
  // eslint-disable-next-line camelcase
145
- async aztec_utl_getLowNullifierMembershipWitness([blockHash], [nullifier]) {
146
- const parsedBlockHash = BlockHash.fromString(blockHash);
147
- const parsedNullifier = Fr.fromString(nullifier);
148
- const witness = await this.handlerAsUtility().getLowNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
149
- if (!witness) {
150
- throw new Error(`Low nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`);
151
- }
152
- return witness.toNoirRepresentation();
191
+ aztec_utl_getLowNullifierMembershipWitness(...inputs) {
192
+ return callHandler({
193
+ oracle: 'aztec_utl_getLowNullifierMembershipWitness',
194
+ inputs,
195
+ handler: ([blockHash, nullifier])=>this.handlerAsUtility().getLowNullifierMembershipWitness(blockHash, nullifier)
196
+ });
153
197
  }
154
198
  // eslint-disable-next-line camelcase
155
- async aztec_utl_getPublicDataWitness([blockHash], [leafSlot]) {
156
- const parsedBlockHash = BlockHash.fromString(blockHash);
157
- const parsedLeafSlot = Fr.fromString(leafSlot);
158
- const witness = await this.handlerAsUtility().getPublicDataWitness(parsedBlockHash, parsedLeafSlot);
159
- if (!witness) {
160
- throw new Error(`Public data witness not found for slot ${parsedLeafSlot} at block hash ${parsedBlockHash.toString()}.`);
161
- }
162
- return witness.toNoirRepresentation();
199
+ aztec_utl_getPublicDataWitness(...inputs) {
200
+ return callHandler({
201
+ oracle: 'aztec_utl_getPublicDataWitness',
202
+ inputs,
203
+ handler: ([blockHash, leafSlot])=>this.handlerAsUtility().getPublicDataWitness(blockHash, leafSlot)
204
+ });
163
205
  }
164
206
  // eslint-disable-next-line camelcase
165
- async aztec_utl_getBlockHeader([blockNumber]) {
166
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
167
- const header = await this.handlerAsUtility().getBlockHeader(BlockNumber(parsedBlockNumber));
168
- if (!header) {
169
- throw new Error(`Block header not found for block ${parsedBlockNumber}.`);
170
- }
171
- return header.toFields().map(toACVMField);
207
+ aztec_utl_getBlockHeader(...inputs) {
208
+ return callHandler({
209
+ oracle: 'aztec_utl_getBlockHeader',
210
+ inputs,
211
+ handler: ([blockNumber])=>this.handlerAsUtility().getBlockHeader(blockNumber)
212
+ });
172
213
  }
173
214
  // eslint-disable-next-line camelcase
174
- async aztec_utl_getAuthWitness([messageHash]) {
175
- const messageHashField = Fr.fromString(messageHash);
176
- const witness = await this.handlerAsUtility().getAuthWitness(messageHashField);
177
- if (!witness) {
178
- throw new Error(`Unknown auth witness for message hash ${messageHashField}`);
179
- }
180
- return [
181
- witness.map(toACVMField)
182
- ];
215
+ aztec_utl_getAuthWitness(...inputs) {
216
+ return callHandler({
217
+ oracle: 'aztec_utl_getAuthWitness',
218
+ inputs,
219
+ handler: ([messageHash])=>this.handlerAsUtility().getAuthWitness(messageHash)
220
+ });
183
221
  }
184
222
  // eslint-disable-next-line camelcase
185
- async aztec_utl_tryGetPublicKeysAndPartialAddress([address]) {
186
- const parsedAddress = AztecAddress.fromField(Fr.fromString(address));
187
- const result = await this.handlerAsUtility().tryGetPublicKeysAndPartialAddress(parsedAddress);
188
- // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
189
- // with two fields: `some` (a boolean) and `value` (a field array in this case).
190
- if (result === undefined) {
191
- // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
192
- return [
193
- toACVMField(0),
194
- Array(13).fill(toACVMField(0))
195
- ];
196
- } else {
197
- // Data was found so we set `some` to 1 and return it along with `value`.
198
- return [
199
- toACVMField(1),
200
- [
201
- ...result.publicKeys.toFields(),
202
- result.partialAddress
203
- ].map(toACVMField)
204
- ];
205
- }
223
+ aztec_utl_getPublicKeysAndPartialAddress(...inputs) {
224
+ return callHandler({
225
+ oracle: 'aztec_utl_getPublicKeysAndPartialAddress',
226
+ inputs,
227
+ handler: ([address])=>this.handlerAsUtility().getPublicKeysAndPartialAddress(address)
228
+ });
206
229
  }
207
230
  // eslint-disable-next-line camelcase
208
- async aztec_utl_getNotes([ownerSome], [ownerValue], [storageSlot], [numSelects], selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, [limit], [offset], [status], [maxNotes], [packedHintedNoteLength]) {
209
- // Parse Option<AztecAddress>: ownerSome is 0 for None, 1 for Some
210
- const owner = Fr.fromString(ownerSome).toNumber() === 1 ? AztecAddress.fromString(ownerValue) : undefined;
211
- const noteDatas = await this.handlerAsUtility().getNotes(owner, Fr.fromString(storageSlot), +numSelects, selectByIndexes.map((s)=>+s), selectByOffsets.map((s)=>+s), selectByLengths.map((s)=>+s), selectValues.map(Fr.fromString), selectComparators.map((s)=>+s), sortByIndexes.map((s)=>+s), sortByOffsets.map((s)=>+s), sortByLengths.map((s)=>+s), sortOrder.map((s)=>+s), +limit, +offset, +status);
212
- const returnDataAsArrayOfPackedHintedNotes = noteDatas.map((noteData)=>packAsHintedNote({
213
- contractAddress: noteData.contractAddress,
214
- owner: noteData.owner,
215
- randomness: noteData.randomness,
216
- storageSlot: noteData.storageSlot,
217
- noteNonce: noteData.noteNonce,
218
- isPending: noteData.isPending,
219
- note: noteData.note
220
- }));
221
- // Now we convert each sub-array to an array of ACVMField
222
- const returnDataAsArrayOfACVMFieldArrays = returnDataAsArrayOfPackedHintedNotes.map((subArray)=>subArray.map(toACVMField));
223
- // At last we convert the array of arrays to a bounded vec of arrays
224
- return arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfACVMFieldArrays, +maxNotes, +packedHintedNoteLength);
231
+ aztec_utl_getNotes(...inputs) {
232
+ return callHandler({
233
+ oracle: 'aztec_utl_getNotes',
234
+ inputs,
235
+ handler: ([owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status, maxNotes, packedHintedNoteLength])=>this.handlerAsUtility().getNotes(owner, storageSlot, numSelects, selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, limit, offset, status, maxNotes, packedHintedNoteLength)
236
+ });
225
237
  }
226
238
  // eslint-disable-next-line camelcase
227
- aztec_prv_notifyCreatedNote([owner], [storageSlot], [randomness], [noteTypeId], note, [noteHash], [counter]) {
228
- this.handlerAsPrivate().notifyCreatedNote(AztecAddress.fromString(owner), Fr.fromString(storageSlot), Fr.fromString(randomness), NoteSelector.fromField(Fr.fromString(noteTypeId)), note.map(Fr.fromString), Fr.fromString(noteHash), +counter);
229
- return Promise.resolve([]);
239
+ aztec_prv_notifyCreatedNote(...inputs) {
240
+ return callHandler({
241
+ oracle: 'aztec_prv_notifyCreatedNote',
242
+ inputs,
243
+ handler: ([owner, storageSlot, randomness, noteTypeId, note, noteHash, counter])=>{
244
+ this.handlerAsPrivate().notifyCreatedNote(owner, storageSlot, randomness, noteTypeId, note, noteHash, counter);
245
+ }
246
+ });
230
247
  }
231
248
  // eslint-disable-next-line camelcase
232
- async aztec_prv_notifyNullifiedNote([innerNullifier], [noteHash], [counter]) {
233
- await this.handlerAsPrivate().notifyNullifiedNote(Fr.fromString(innerNullifier), Fr.fromString(noteHash), +counter);
234
- return [];
249
+ aztec_prv_notifyNullifiedNote(...inputs) {
250
+ return callHandler({
251
+ oracle: 'aztec_prv_notifyNullifiedNote',
252
+ inputs,
253
+ handler: ([innerNullifier, noteHash, counter])=>this.handlerAsPrivate().notifyNullifiedNote(innerNullifier, noteHash, counter)
254
+ });
235
255
  }
236
256
  // eslint-disable-next-line camelcase
237
- async aztec_prv_notifyCreatedNullifier([innerNullifier]) {
238
- await this.handlerAsPrivate().notifyCreatedNullifier(Fr.fromString(innerNullifier));
239
- return [];
257
+ aztec_prv_notifyCreatedNullifier(...inputs) {
258
+ return callHandler({
259
+ oracle: 'aztec_prv_notifyCreatedNullifier',
260
+ inputs,
261
+ handler: ([innerNullifier])=>this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier)
262
+ });
240
263
  }
241
264
  // eslint-disable-next-line camelcase
242
- async aztec_prv_isNullifierPending([innerNullifier], [contractAddress]) {
243
- const isPending = await this.handlerAsPrivate().isNullifierPending(Fr.fromString(innerNullifier), AztecAddress.fromString(contractAddress));
244
- return [
245
- toACVMField(isPending)
246
- ];
265
+ aztec_prv_isNullifierPending(...inputs) {
266
+ return callHandler({
267
+ oracle: 'aztec_prv_isNullifierPending',
268
+ inputs,
269
+ handler: ([innerNullifier, contractAddress])=>this.handlerAsPrivate().isNullifierPending(innerNullifier, contractAddress)
270
+ });
247
271
  }
248
272
  // eslint-disable-next-line camelcase
249
- async aztec_utl_checkNullifierExists([innerNullifier]) {
250
- const exists = await this.handlerAsUtility().checkNullifierExists(Fr.fromString(innerNullifier));
251
- return [
252
- toACVMField(exists)
253
- ];
273
+ aztec_utl_doesNullifierExist(...inputs) {
274
+ return callHandler({
275
+ oracle: 'aztec_utl_doesNullifierExist',
276
+ inputs,
277
+ handler: ([innerNullifier])=>this.handlerAsUtility().doesNullifierExist(innerNullifier)
278
+ });
254
279
  }
255
280
  // eslint-disable-next-line camelcase
256
- async aztec_utl_getL1ToL2MembershipWitness([contractAddress], [messageHash], [secret]) {
257
- const message = await this.handlerAsUtility().getL1ToL2MembershipWitness(AztecAddress.fromString(contractAddress), Fr.fromString(messageHash), Fr.fromString(secret));
258
- return message.toNoirRepresentation();
281
+ aztec_utl_getL1ToL2MembershipWitness(...inputs) {
282
+ return callHandler({
283
+ oracle: 'aztec_utl_getL1ToL2MembershipWitness',
284
+ inputs,
285
+ handler: ([contractAddress, messageHash, secret])=>this.handlerAsUtility().getL1ToL2MembershipWitness(contractAddress, messageHash, secret)
286
+ });
259
287
  }
260
288
  // eslint-disable-next-line camelcase
261
- async aztec_utl_storageRead([blockHash], [contractAddress], [startStorageSlot], [numberOfElements]) {
262
- const values = await this.handlerAsUtility().storageRead(BlockHash.fromString(blockHash), new AztecAddress(Fr.fromString(contractAddress)), Fr.fromString(startStorageSlot), +numberOfElements);
263
- return [
264
- values.map(toACVMField)
265
- ];
289
+ aztec_utl_getFromPublicStorage(...inputs) {
290
+ return callHandler({
291
+ oracle: 'aztec_utl_getFromPublicStorage',
292
+ inputs,
293
+ handler: ([blockHash, contractAddress, startStorageSlot, numberOfElements])=>this.handlerAsUtility().getFromPublicStorage(blockHash, contractAddress, startStorageSlot, numberOfElements)
294
+ });
295
+ }
296
+ // eslint-disable-next-line camelcase
297
+ aztec_utl_callUtilityFunction(...inputs) {
298
+ return callHandler({
299
+ oracle: 'aztec_utl_callUtilityFunction',
300
+ inputs,
301
+ handler: ([contractAddress, functionSelector, args])=>this.handlerAsUtility().callUtilityFunction(contractAddress, functionSelector, args)
302
+ });
266
303
  }
267
304
  // eslint-disable-next-line camelcase
268
- aztec_prv_notifyCreatedContractClassLog([contractAddress], message, [length], [counter]) {
269
- const logFields = new ContractClassLogFields(message.map(Fr.fromString));
270
- const log = new ContractClassLog(new AztecAddress(Fr.fromString(contractAddress)), logFields, +length);
271
- this.handlerAsPrivate().notifyCreatedContractClassLog(log, +counter);
272
- return Promise.resolve([]);
305
+ aztec_prv_notifyCreatedContractClassLog(...inputs) {
306
+ return callHandler({
307
+ oracle: 'aztec_prv_notifyCreatedContractClassLog',
308
+ inputs,
309
+ handler: ([log, counter])=>{
310
+ this.handlerAsPrivate().notifyCreatedContractClassLog(log, counter);
311
+ }
312
+ });
273
313
  }
274
314
  // eslint-disable-next-line camelcase
275
- async aztec_utl_log(level, message, _ignoredFieldsSize, fields) {
276
- const levelFr = Fr.fromString(level[0]);
277
- const messageStr = message.map((acvmField)=>String.fromCharCode(Fr.fromString(acvmField).toNumber())).join('');
278
- const fieldsFr = fields.map(Fr.fromString);
279
- await this.handlerAsMisc().log(levelFr.toNumber(), messageStr, fieldsFr);
280
- return [];
315
+ aztec_utl_log(...inputs) {
316
+ return callHandler({
317
+ oracle: 'aztec_utl_log',
318
+ inputs,
319
+ handler: ([level, message, _, fields])=>this.handlerAsMisc().log(level, message, fields)
320
+ });
281
321
  }
282
322
  // This function's name is directly hardcoded in `circuit_recorder.ts`. Don't forget to update it there if you
283
323
  // change the name here.
284
324
  // eslint-disable-next-line camelcase
285
- async aztec_prv_callPrivateFunction([contractAddress], [functionSelector], [argsHash], [sideEffectCounter], [isStaticCall]) {
286
- const { endSideEffectCounter, returnsHash } = await this.handlerAsPrivate().callPrivateFunction(AztecAddress.fromField(Fr.fromString(contractAddress)), FunctionSelector.fromField(Fr.fromString(functionSelector)), Fr.fromString(argsHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
287
- return [
288
- [
289
- endSideEffectCounter,
290
- returnsHash
291
- ].map(toACVMField)
292
- ];
325
+ aztec_prv_callPrivateFunction(...inputs) {
326
+ return callHandler({
327
+ oracle: 'aztec_prv_callPrivateFunction',
328
+ inputs,
329
+ handler: ([contractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall])=>this.handlerAsPrivate().callPrivateFunction(contractAddress, functionSelector, argsHash, sideEffectCounter, isStaticCall)
330
+ });
331
+ }
332
+ // eslint-disable-next-line camelcase
333
+ aztec_prv_assertValidPublicCalldata(...inputs) {
334
+ return callHandler({
335
+ oracle: 'aztec_prv_assertValidPublicCalldata',
336
+ inputs,
337
+ handler: ([calldataHash])=>this.handlerAsPrivate().assertValidPublicCalldata(calldataHash)
338
+ });
293
339
  }
294
340
  // eslint-disable-next-line camelcase
295
- async aztec_prv_notifyEnqueuedPublicFunctionCall([contractAddress], [calldataHash], [sideEffectCounter], [isStaticCall]) {
296
- await this.handlerAsPrivate().notifyEnqueuedPublicFunctionCall(AztecAddress.fromString(contractAddress), Fr.fromString(calldataHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
297
- return [];
341
+ aztec_prv_notifyRevertiblePhaseStart(...inputs) {
342
+ return callHandler({
343
+ oracle: 'aztec_prv_notifyRevertiblePhaseStart',
344
+ inputs,
345
+ handler: ([minRevertibleSideEffectCounter])=>this.handlerAsPrivate().notifyRevertiblePhaseStart(minRevertibleSideEffectCounter)
346
+ });
298
347
  }
299
348
  // eslint-disable-next-line camelcase
300
- async aztec_prv_notifySetPublicTeardownFunctionCall([contractAddress], [calldataHash], [sideEffectCounter], [isStaticCall]) {
301
- await this.handlerAsPrivate().notifySetPublicTeardownFunctionCall(AztecAddress.fromString(contractAddress), Fr.fromString(calldataHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
302
- return [];
349
+ aztec_prv_isExecutionInRevertiblePhase(...inputs) {
350
+ return callHandler({
351
+ oracle: 'aztec_prv_isExecutionInRevertiblePhase',
352
+ inputs,
353
+ handler: ([sideEffectCounter])=>this.handlerAsPrivate().isExecutionInRevertiblePhase(sideEffectCounter)
354
+ });
303
355
  }
304
356
  // eslint-disable-next-line camelcase
305
- async aztec_prv_notifySetMinRevertibleSideEffectCounter([minRevertibleSideEffectCounter]) {
306
- await this.handlerAsPrivate().notifySetMinRevertibleSideEffectCounter(Fr.fromString(minRevertibleSideEffectCounter).toNumber());
307
- return Promise.resolve([]);
357
+ aztec_prv_getNextAppTagAsSender(...inputs) {
358
+ return callHandler({
359
+ oracle: 'aztec_prv_getNextAppTagAsSender',
360
+ inputs,
361
+ handler: ([sender, recipient])=>this.handlerAsPrivate().getNextAppTagAsSender(sender, recipient)
362
+ });
308
363
  }
309
364
  // eslint-disable-next-line camelcase
310
- async aztec_prv_isSideEffectCounterRevertible([sideEffectCounter]) {
311
- const isRevertible = await this.handlerAsPrivate().isSideEffectCounterRevertible(Fr.fromString(sideEffectCounter).toNumber());
312
- return Promise.resolve([
313
- toACVMField(isRevertible)
314
- ]);
365
+ aztec_prv_getNextConstrainedTaggingIndex(...inputs) {
366
+ return callHandler({
367
+ oracle: 'aztec_prv_getNextConstrainedTaggingIndex',
368
+ inputs,
369
+ handler: ([appSiloedSecret])=>this.handlerAsPrivate().getNextConstrainedTaggingIndex(appSiloedSecret)
370
+ });
315
371
  }
316
372
  // eslint-disable-next-line camelcase
317
- async aztec_prv_getNextAppTagAsSender([sender], [recipient]) {
318
- const tag = await this.handlerAsPrivate().getNextAppTagAsSender(AztecAddress.fromString(sender), AztecAddress.fromString(recipient));
319
- return [
320
- toACVMField(tag.value)
321
- ];
373
+ aztec_utl_getPendingTaggedLogs(...inputs) {
374
+ return callHandler({
375
+ oracle: 'aztec_utl_getPendingTaggedLogs',
376
+ inputs,
377
+ handler: ([scope])=>this.handlerAsUtility().getPendingTaggedLogs(scope)
378
+ });
322
379
  }
323
380
  // eslint-disable-next-line camelcase
324
- async aztec_utl_fetchTaggedLogs([pendingTaggedLogArrayBaseSlot]) {
325
- await this.handlerAsUtility().fetchTaggedLogs(Fr.fromString(pendingTaggedLogArrayBaseSlot));
326
- return [];
381
+ aztec_utl_validateAndStoreEnqueuedNotesAndEvents(...inputs) {
382
+ return callHandler({
383
+ oracle: 'aztec_utl_validateAndStoreEnqueuedNotesAndEvents',
384
+ inputs,
385
+ handler: ([noteValidationRequestsArrayBaseSlot, eventValidationRequestsArrayBaseSlot, scope])=>this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(noteValidationRequestsArrayBaseSlot, eventValidationRequestsArrayBaseSlot, scope)
386
+ });
327
387
  }
328
388
  // eslint-disable-next-line camelcase
329
- async aztec_utl_validateAndStoreEnqueuedNotesAndEvents([contractAddress], [noteValidationRequestsArrayBaseSlot], [eventValidationRequestsArrayBaseSlot]) {
330
- await this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(AztecAddress.fromString(contractAddress), Fr.fromString(noteValidationRequestsArrayBaseSlot), Fr.fromString(eventValidationRequestsArrayBaseSlot));
331
- return [];
389
+ aztec_utl_getLogsByTag(...inputs) {
390
+ return callHandler({
391
+ oracle: 'aztec_utl_getLogsByTag',
392
+ inputs,
393
+ handler: ([requestArrayBaseSlot])=>this.handlerAsUtility().getLogsByTag(requestArrayBaseSlot)
394
+ });
332
395
  }
333
396
  // eslint-disable-next-line camelcase
334
- async aztec_utl_bulkRetrieveLogs([contractAddress], [logRetrievalRequestsArrayBaseSlot], [logRetrievalResponsesArrayBaseSlot]) {
335
- await this.handlerAsUtility().bulkRetrieveLogs(AztecAddress.fromString(contractAddress), Fr.fromString(logRetrievalRequestsArrayBaseSlot), Fr.fromString(logRetrievalResponsesArrayBaseSlot));
336
- return [];
397
+ aztec_utl_getMessageContextsByTxHash(...inputs) {
398
+ return callHandler({
399
+ oracle: 'aztec_utl_getMessageContextsByTxHash',
400
+ inputs,
401
+ handler: ([requestArrayBaseSlot])=>this.handlerAsUtility().getMessageContextsByTxHash(requestArrayBaseSlot)
402
+ });
337
403
  }
338
404
  // eslint-disable-next-line camelcase
339
- async aztec_utl_storeCapsule([contractAddress], [slot], capsule) {
340
- await this.handlerAsUtility().storeCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot), capsule.map(Fr.fromString));
341
- return [];
405
+ aztec_utl_getTxEffect(...inputs) {
406
+ return callHandler({
407
+ oracle: 'aztec_utl_getTxEffect',
408
+ inputs,
409
+ handler: ([txHash])=>this.handlerAsUtility().getTxEffect(txHash)
410
+ });
342
411
  }
343
412
  // eslint-disable-next-line camelcase
344
- async aztec_utl_loadCapsule([contractAddress], [slot], [tSize]) {
345
- const values = await this.handlerAsUtility().loadCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
346
- // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
347
- // with two fields: `some` (a boolean) and `value` (a field array in this case).
348
- if (values === null) {
349
- // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
350
- return [
351
- toACVMField(0),
352
- Array(Fr.fromString(tSize).toNumber()).fill(toACVMField(0))
353
- ];
354
- } else {
355
- // Data was found so we set `some` to 1 and return it along with `value`.
356
- return [
357
- toACVMField(1),
358
- values.map(toACVMField)
359
- ];
360
- }
413
+ aztec_utl_setCapsule(...inputs) {
414
+ return callHandler({
415
+ oracle: 'aztec_utl_setCapsule',
416
+ inputs,
417
+ handler: ([contractAddress, slot, capsule, scope])=>{
418
+ this.handlerAsUtility().setCapsule(contractAddress, slot, capsule, scope);
419
+ }
420
+ });
361
421
  }
362
422
  // eslint-disable-next-line camelcase
363
- async aztec_utl_deleteCapsule([contractAddress], [slot]) {
364
- await this.handlerAsUtility().deleteCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
365
- return [];
423
+ aztec_utl_getCapsule(...inputs) {
424
+ return callHandler({
425
+ oracle: 'aztec_utl_getCapsule',
426
+ inputs,
427
+ handler: ([contractAddress, slot, tSize, scope])=>this.handlerAsUtility().getCapsule(contractAddress, slot, tSize, scope)
428
+ });
366
429
  }
367
430
  // eslint-disable-next-line camelcase
368
- async aztec_utl_copyCapsule([contractAddress], [srcSlot], [dstSlot], [numEntries]) {
369
- await this.handlerAsUtility().copyCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(srcSlot), Fr.fromString(dstSlot), Fr.fromString(numEntries).toNumber());
370
- return [];
431
+ aztec_utl_deleteCapsule(...inputs) {
432
+ return callHandler({
433
+ oracle: 'aztec_utl_deleteCapsule',
434
+ inputs,
435
+ handler: ([contractAddress, slot, scope])=>{
436
+ this.handlerAsUtility().deleteCapsule(contractAddress, slot, scope);
437
+ }
438
+ });
371
439
  }
372
440
  // eslint-disable-next-line camelcase
373
- async aztec_utl_aes128Decrypt(ciphertextBVecStorage, [ciphertextLength], iv, symKey) {
374
- const ciphertext = fromUintBoundedVec(ciphertextBVecStorage, ciphertextLength, 8);
375
- const ivBuffer = fromUintArray(iv, 8);
376
- const symKeyBuffer = fromUintArray(symKey, 8);
377
- const plaintext = await this.handlerAsUtility().aes128Decrypt(ciphertext, ivBuffer, symKeyBuffer);
378
- return bufferToBoundedVec(plaintext, ciphertextBVecStorage.length);
441
+ aztec_utl_copyCapsule(...inputs) {
442
+ return callHandler({
443
+ oracle: 'aztec_utl_copyCapsule',
444
+ inputs,
445
+ handler: ([contractAddress, srcSlot, dstSlot, numEntries, scope])=>this.handlerAsUtility().copyCapsule(contractAddress, srcSlot, dstSlot, numEntries, scope)
446
+ });
379
447
  }
380
448
  // eslint-disable-next-line camelcase
381
- async aztec_utl_getSharedSecret([address], [ephPKField0], [ephPKField1], [ephPKField2]) {
382
- const secret = await this.handlerAsUtility().getSharedSecret(AztecAddress.fromField(Fr.fromString(address)), Point.fromFields([
383
- ephPKField0,
384
- ephPKField1,
385
- ephPKField2
386
- ].map(Fr.fromString)));
387
- return secret.toFields().map(toACVMField);
449
+ aztec_utl_pushEphemeral(...inputs) {
450
+ return callHandler({
451
+ oracle: 'aztec_utl_pushEphemeral',
452
+ inputs,
453
+ handler: ([slot, elements])=>this.handlerAsUtility().pushEphemeral(slot, elements)
454
+ });
388
455
  }
389
456
  // eslint-disable-next-line camelcase
390
- async aztec_utl_emitOffchainEffect(data) {
391
- await this.handlerAsPrivate().emitOffchainEffect(data.map(Fr.fromString));
392
- return [];
457
+ aztec_utl_popEphemeral(...inputs) {
458
+ return callHandler({
459
+ oracle: 'aztec_utl_popEphemeral',
460
+ inputs,
461
+ handler: ([slot])=>this.handlerAsUtility().popEphemeral(slot)
462
+ });
393
463
  }
394
464
  // eslint-disable-next-line camelcase
395
- async aztec_prv_getSenderForTags() {
396
- const sender = await this.handlerAsPrivate().getSenderForTags();
397
- // Return [1, address] for Some(address), [0, 0] for None
398
- return sender ? [
399
- toACVMField(1n),
400
- toACVMField(sender)
401
- ] : [
402
- toACVMField(0n),
403
- toACVMField(0n)
404
- ];
465
+ aztec_utl_getEphemeral(...inputs) {
466
+ return callHandler({
467
+ oracle: 'aztec_utl_getEphemeral',
468
+ inputs,
469
+ handler: ([slot, index])=>this.handlerAsUtility().getEphemeral(slot, index)
470
+ });
471
+ }
472
+ // eslint-disable-next-line camelcase
473
+ aztec_utl_setEphemeral(...inputs) {
474
+ return callHandler({
475
+ oracle: 'aztec_utl_setEphemeral',
476
+ inputs,
477
+ handler: ([slot, index, elements])=>{
478
+ this.handlerAsUtility().setEphemeral(slot, index, elements);
479
+ }
480
+ });
405
481
  }
406
482
  // eslint-disable-next-line camelcase
407
- async aztec_prv_setSenderForTags([senderForTags]) {
408
- await this.handlerAsPrivate().setSenderForTags(AztecAddress.fromField(Fr.fromString(senderForTags)));
409
- return [];
483
+ aztec_utl_getEphemeralLen(...inputs) {
484
+ return callHandler({
485
+ oracle: 'aztec_utl_getEphemeralLen',
486
+ inputs,
487
+ handler: ([slot])=>this.handlerAsUtility().getEphemeralLen(slot)
488
+ });
489
+ }
490
+ // eslint-disable-next-line camelcase
491
+ aztec_utl_removeEphemeral(...inputs) {
492
+ return callHandler({
493
+ oracle: 'aztec_utl_removeEphemeral',
494
+ inputs,
495
+ handler: ([slot, index])=>{
496
+ this.handlerAsUtility().removeEphemeral(slot, index);
497
+ }
498
+ });
499
+ }
500
+ // eslint-disable-next-line camelcase
501
+ aztec_utl_clearEphemeral(...inputs) {
502
+ return callHandler({
503
+ oracle: 'aztec_utl_clearEphemeral',
504
+ inputs,
505
+ handler: ([slot])=>{
506
+ this.handlerAsUtility().clearEphemeral(slot);
507
+ }
508
+ });
509
+ }
510
+ // eslint-disable-next-line camelcase
511
+ aztec_utl_decryptAes128(...inputs) {
512
+ return callHandler({
513
+ oracle: 'aztec_utl_decryptAes128',
514
+ inputs,
515
+ handler: ([ciphertext, iv, symKey])=>this.handlerAsUtility().decryptAes128(ciphertext, iv, symKey)
516
+ });
517
+ }
518
+ // eslint-disable-next-line camelcase
519
+ aztec_utl_getSharedSecrets(...inputs) {
520
+ return callHandler({
521
+ oracle: 'aztec_utl_getSharedSecrets',
522
+ inputs,
523
+ handler: ([address, ephPksSlot, contractAddress])=>this.handlerAsUtility().getSharedSecrets(address, ephPksSlot, contractAddress)
524
+ });
525
+ }
526
+ // eslint-disable-next-line camelcase
527
+ aztec_utl_setContractSyncCacheInvalid(...inputs) {
528
+ return callHandler({
529
+ oracle: 'aztec_utl_setContractSyncCacheInvalid',
530
+ inputs,
531
+ handler: ([contractAddress, scopes])=>{
532
+ this.handlerAsUtility().setContractSyncCacheInvalid(contractAddress, scopes);
533
+ }
534
+ });
535
+ }
536
+ // eslint-disable-next-line camelcase
537
+ aztec_utl_emitOffchainEffect(...inputs) {
538
+ return callHandler({
539
+ oracle: 'aztec_utl_emitOffchainEffect',
540
+ inputs,
541
+ handler: ([data])=>this.handlerAsUtility().emitOffchainEffect(data)
542
+ });
543
+ }
544
+ // eslint-disable-next-line camelcase
545
+ aztec_prv_getSenderForTags() {
546
+ return callHandler({
547
+ oracle: 'aztec_prv_getSenderForTags',
548
+ inputs: [],
549
+ handler: ()=>this.handlerAsPrivate().getSenderForTags()
550
+ });
410
551
  }
411
552
  }