@aztec/pxe 0.0.1-commit.001888fc → 0.0.1-commit.017a351

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 (343) hide show
  1. package/dest/bin/check_oracle_version.js +43 -99
  2. package/dest/bin/index.d.ts +2 -0
  3. package/dest/bin/index.d.ts.map +1 -0
  4. package/dest/bin/index.js +1 -0
  5. package/dest/bin/oracle_version_helpers.d.ts +26 -0
  6. package/dest/bin/oracle_version_helpers.d.ts.map +1 -0
  7. package/dest/bin/oracle_version_helpers.js +93 -0
  8. package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
  9. package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
  10. package/dest/block_synchronizer/block_stream_source.js +62 -0
  11. package/dest/block_synchronizer/block_synchronizer.d.ts +6 -2
  12. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  13. package/dest/block_synchronizer/block_synchronizer.js +30 -10
  14. package/dest/config/index.d.ts +7 -1
  15. package/dest/config/index.d.ts.map +1 -1
  16. package/dest/config/index.js +12 -14
  17. package/dest/config/package_info.js +1 -1
  18. package/dest/contract_function_simulator/contract_function_simulator.d.ts +9 -4
  19. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/contract_function_simulator.js +35 -14
  21. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  22. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  23. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  24. package/dest/contract_function_simulator/execution_note_cache.d.ts +2 -2
  25. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  26. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +5 -9
  27. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/execution_tagging_index_cache.js +3 -7
  29. package/dest/contract_function_simulator/index.d.ts +13 -2
  30. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/index.js +10 -0
  32. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
  33. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
  34. package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
  35. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts +37 -0
  36. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts.map +1 -0
  37. package/dest/contract_function_simulator/noir-structs/ephemeral_array.js +59 -0
  38. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +5 -5
  39. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +6 -8
  41. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +13 -3
  42. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -1
  43. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +35 -4
  44. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +1 -1
  45. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +1 -1
  46. package/dest/contract_function_simulator/noir-structs/note_data.d.ts +27 -0
  47. package/dest/contract_function_simulator/noir-structs/note_data.d.ts.map +1 -0
  48. package/dest/contract_function_simulator/noir-structs/note_data.js +3 -0
  49. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +5 -5
  50. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  51. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +6 -8
  52. package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
  53. package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
  54. package/dest/contract_function_simulator/noir-structs/option.js +62 -0
  55. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts +11 -0
  56. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts.map +1 -0
  57. package/dest/contract_function_simulator/noir-structs/provided_secret.js +24 -0
  58. package/dest/contract_function_simulator/oracle/interfaces.d.ts +16 -102
  59. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  60. package/dest/contract_function_simulator/oracle/interfaces.js +2 -2
  61. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +2 -2
  62. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  63. package/dest/contract_function_simulator/oracle/note_packing_utils.js +2 -2
  64. package/dest/contract_function_simulator/oracle/oracle.d.ts +74 -45
  65. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  66. package/dest/contract_function_simulator/oracle/oracle.js +405 -270
  67. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +127 -0
  68. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
  69. package/dest/contract_function_simulator/oracle/oracle_registry.js +786 -0
  70. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts +139 -0
  71. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts.map +1 -0
  72. package/dest/contract_function_simulator/oracle/oracle_type_mappings.js +560 -0
  73. package/dest/contract_function_simulator/oracle/private_execution.js +1 -1
  74. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +33 -39
  75. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  76. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +70 -54
  77. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +104 -60
  78. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  79. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +374 -160
  80. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  81. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  82. package/dest/contract_function_simulator/pick_notes.js +20 -3
  83. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  84. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  85. package/dest/contract_function_simulator/proxied_contract_data_source.js +35 -64
  86. package/dest/contract_logging.d.ts +9 -4
  87. package/dest/contract_logging.d.ts.map +1 -1
  88. package/dest/contract_logging.js +21 -6
  89. package/dest/contract_sync/contract_sync_service.d.ts +7 -8
  90. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
  91. package/dest/contract_sync/contract_sync_service.js +87 -49
  92. package/dest/contract_sync/helpers.d.ts +2 -4
  93. package/dest/contract_sync/helpers.d.ts.map +1 -1
  94. package/dest/contract_sync/helpers.js +12 -14
  95. package/dest/debug/pxe_debug_utils.d.ts +3 -8
  96. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  97. package/dest/debug/pxe_debug_utils.js +0 -6
  98. package/dest/entrypoints/client/bundle/index.d.ts +1 -2
  99. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  100. package/dest/entrypoints/client/bundle/index.js +0 -1
  101. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  102. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  103. package/dest/entrypoints/client/bundle/utils.js +13 -5
  104. package/dest/entrypoints/client/lazy/index.d.ts +1 -2
  105. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  106. package/dest/entrypoints/client/lazy/index.js +0 -1
  107. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  108. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  109. package/dest/entrypoints/client/lazy/utils.js +13 -5
  110. package/dest/entrypoints/pxe_creation_options.d.ts +9 -1
  111. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  112. package/dest/entrypoints/pxe_creation_options.js +3 -1
  113. package/dest/entrypoints/server/index.d.ts +3 -3
  114. package/dest/entrypoints/server/index.d.ts.map +1 -1
  115. package/dest/entrypoints/server/index.js +2 -2
  116. package/dest/entrypoints/server/utils.d.ts +4 -3
  117. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  118. package/dest/entrypoints/server/utils.js +13 -5
  119. package/dest/events/event_service.d.ts +15 -6
  120. package/dest/events/event_service.d.ts.map +1 -1
  121. package/dest/events/event_service.js +44 -11
  122. package/dest/events/private_event_filter_validator.d.ts +3 -2
  123. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  124. package/dest/events/private_event_filter_validator.js +15 -0
  125. package/dest/hooks/authorize_utility_call.d.ts +41 -0
  126. package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
  127. package/dest/hooks/authorize_utility_call.js +4 -0
  128. package/dest/hooks/execution_hooks.d.ts +42 -0
  129. package/dest/hooks/execution_hooks.d.ts.map +1 -0
  130. package/dest/hooks/execution_hooks.js +9 -0
  131. package/dest/hooks/index.d.ts +4 -0
  132. package/dest/hooks/index.d.ts.map +1 -0
  133. package/dest/hooks/index.js +1 -0
  134. package/dest/logs/log_service.d.ts +9 -9
  135. package/dest/logs/log_service.d.ts.map +1 -1
  136. package/dest/logs/log_service.js +126 -72
  137. package/dest/messages/message_context_service.d.ts +3 -3
  138. package/dest/messages/message_context_service.d.ts.map +1 -1
  139. package/dest/messages/message_context_service.js +30 -11
  140. package/dest/notes/note_service.d.ts +27 -6
  141. package/dest/notes/note_service.d.ts.map +1 -1
  142. package/dest/notes/note_service.js +80 -56
  143. package/dest/notes_filter.d.ts +2 -3
  144. package/dest/notes_filter.d.ts.map +1 -1
  145. package/dest/oracle_version.d.ts +4 -3
  146. package/dest/oracle_version.d.ts.map +1 -1
  147. package/dest/oracle_version.js +20 -10
  148. package/dest/private_kernel/batch_planner.d.ts +47 -0
  149. package/dest/private_kernel/batch_planner.d.ts.map +1 -0
  150. package/dest/private_kernel/batch_planner.js +104 -0
  151. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +1 -1
  152. package/dest/private_kernel/hints/test_utils.d.ts +1 -1
  153. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -1
  154. package/dest/private_kernel/hints/test_utils.js +2 -3
  155. package/dest/private_kernel/private_kernel_execution_prover.d.ts +6 -2
  156. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  157. package/dest/private_kernel/private_kernel_execution_prover.js +152 -59
  158. package/dest/private_kernel/private_kernel_oracle.d.ts +10 -10
  159. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  160. package/dest/private_kernel/private_kernel_oracle.js +24 -22
  161. package/dest/pxe.d.ts +56 -10
  162. package/dest/pxe.d.ts.map +1 -1
  163. package/dest/pxe.js +139 -88
  164. package/dest/storage/anchor_block_store/anchor_block_store.js +1 -1
  165. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
  166. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
  167. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
  168. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
  169. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
  170. package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
  171. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
  172. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
  173. package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
  174. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  175. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  176. package/dest/storage/capsule_store/capsule_service.js +50 -0
  177. package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
  178. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  179. package/dest/storage/capsule_store/capsule_store.js +36 -28
  180. package/dest/storage/capsule_store/index.d.ts +2 -1
  181. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  182. package/dest/storage/capsule_store/index.js +1 -0
  183. package/dest/storage/contract_store/contract_store.d.ts +1 -1
  184. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  185. package/dest/storage/contract_store/contract_store.js +9 -26
  186. package/dest/storage/metadata.d.ts +1 -1
  187. package/dest/storage/metadata.js +1 -1
  188. package/dest/storage/note_store/note_store.d.ts +1 -1
  189. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  190. package/dest/storage/note_store/note_store.js +2 -2
  191. package/dest/storage/open_pxe_stores.d.ts +33 -0
  192. package/dest/storage/open_pxe_stores.d.ts.map +1 -0
  193. package/dest/storage/open_pxe_stores.js +27 -0
  194. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  195. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  196. package/dest/storage/private_event_store/private_event_store.js +3 -0
  197. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  198. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  199. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  200. package/dest/storage/tagging_store/sender_tagging_store.d.ts +5 -5
  201. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  202. package/dest/storage/tagging_store/sender_tagging_store.js +3 -3
  203. package/dest/tagging/get_all_logs_by_tags.d.ts +34 -10
  204. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  205. package/dest/tagging/get_all_logs_by_tags.js +36 -37
  206. package/dest/tagging/index.d.ts +5 -4
  207. package/dest/tagging/index.d.ts.map +1 -1
  208. package/dest/tagging/index.js +4 -3
  209. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
  210. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
  211. package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
  212. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
  213. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
  214. package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
  215. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +3 -3
  216. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -1
  217. package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
  218. package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
  219. package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
  220. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -5
  221. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  222. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +26 -14
  223. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +11 -6
  224. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  225. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +21 -0
  226. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +4 -4
  227. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  228. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +2 -2
  229. package/package.json +20 -17
  230. package/src/bin/check_oracle_version.ts +49 -122
  231. package/src/bin/index.ts +1 -0
  232. package/src/bin/oracle_version_helpers.ts +121 -0
  233. package/src/block_synchronizer/block_stream_source.ts +81 -0
  234. package/src/block_synchronizer/block_synchronizer.ts +33 -11
  235. package/src/config/index.ts +14 -8
  236. package/src/config/package_info.ts +1 -1
  237. package/src/contract_function_simulator/contract_function_simulator.ts +55 -17
  238. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  239. package/src/contract_function_simulator/execution_note_cache.ts +1 -1
  240. package/src/contract_function_simulator/execution_tagging_index_cache.ts +5 -9
  241. package/src/contract_function_simulator/index.ts +50 -1
  242. package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
  243. package/src/contract_function_simulator/noir-structs/ephemeral_array.ts +66 -0
  244. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +4 -6
  245. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
  246. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +1 -1
  247. package/src/contract_function_simulator/noir-structs/note_data.ts +27 -0
  248. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -6
  249. package/src/contract_function_simulator/noir-structs/option.ts +69 -0
  250. package/src/contract_function_simulator/noir-structs/provided_secret.ts +27 -0
  251. package/src/contract_function_simulator/oracle/interfaces.ts +12 -175
  252. package/src/contract_function_simulator/oracle/note_packing_utils.ts +3 -3
  253. package/src/contract_function_simulator/oracle/oracle.ts +498 -442
  254. package/src/contract_function_simulator/oracle/oracle_registry.ts +585 -0
  255. package/src/contract_function_simulator/oracle/oracle_type_mappings.ts +553 -0
  256. package/src/contract_function_simulator/oracle/private_execution.ts +1 -1
  257. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +93 -75
  258. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +547 -265
  259. package/src/contract_function_simulator/pick_notes.ts +22 -3
  260. package/src/contract_function_simulator/proxied_contract_data_source.ts +41 -64
  261. package/src/contract_logging.ts +18 -5
  262. package/src/contract_sync/contract_sync_service.ts +120 -83
  263. package/src/contract_sync/helpers.ts +13 -25
  264. package/src/debug/pxe_debug_utils.ts +3 -11
  265. package/src/entrypoints/client/bundle/index.ts +0 -1
  266. package/src/entrypoints/client/bundle/utils.ts +10 -5
  267. package/src/entrypoints/client/lazy/index.ts +0 -1
  268. package/src/entrypoints/client/lazy/utils.ts +10 -5
  269. package/src/entrypoints/pxe_creation_options.ts +14 -0
  270. package/src/entrypoints/server/index.ts +2 -2
  271. package/src/entrypoints/server/utils.ts +15 -6
  272. package/src/events/event_service.ts +69 -21
  273. package/src/events/private_event_filter_validator.ts +21 -1
  274. package/src/hooks/authorize_utility_call.ts +44 -0
  275. package/src/hooks/execution_hooks.ts +48 -0
  276. package/src/hooks/index.ts +7 -0
  277. package/src/logs/log_service.ts +158 -134
  278. package/src/messages/message_context_service.ts +43 -26
  279. package/src/notes/note_service.ts +119 -85
  280. package/src/notes_filter.ts +1 -3
  281. package/src/oracle_version.ts +20 -10
  282. package/src/private_kernel/batch_planner.ts +169 -0
  283. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +1 -1
  284. package/src/private_kernel/hints/test_utils.ts +2 -9
  285. package/src/private_kernel/private_kernel_execution_prover.ts +240 -82
  286. package/src/private_kernel/private_kernel_oracle.ts +35 -25
  287. package/src/pxe.ts +227 -92
  288. package/src/storage/anchor_block_store/anchor_block_store.ts +1 -1
  289. package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
  290. package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
  291. package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
  292. package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
  293. package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
  294. package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
  295. package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
  296. package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
  297. package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
  298. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
  299. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
  300. package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
  301. package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
  302. package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
  303. package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
  304. package/src/storage/capsule_store/capsule_service.ts +90 -0
  305. package/src/storage/capsule_store/capsule_store.ts +44 -26
  306. package/src/storage/capsule_store/index.ts +1 -0
  307. package/src/storage/contract_store/contract_store.ts +14 -35
  308. package/src/storage/metadata.ts +1 -1
  309. package/src/storage/note_store/note_store.ts +2 -5
  310. package/src/storage/open_pxe_stores.ts +49 -0
  311. package/src/storage/private_event_store/private_event_store.ts +4 -0
  312. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  313. package/src/storage/tagging_store/recipient_tagging_store.ts +5 -9
  314. package/src/storage/tagging_store/sender_tagging_store.ts +6 -6
  315. package/src/tagging/get_all_logs_by_tags.ts +78 -50
  316. package/src/tagging/index.ts +4 -3
  317. package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
  318. package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
  319. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  320. package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
  321. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +41 -19
  322. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +23 -8
  323. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +4 -5
  324. package/dest/access_scopes.d.ts +0 -9
  325. package/dest/access_scopes.d.ts.map +0 -1
  326. package/dest/access_scopes.js +0 -6
  327. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts +0 -16
  328. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts.map +0 -1
  329. package/dest/contract_function_simulator/noir-structs/message_tx_context.js +0 -57
  330. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +0 -9
  331. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +0 -1
  332. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +0 -43
  333. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -14
  334. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +0 -1
  335. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +0 -99
  336. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -14
  337. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
  338. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -33
  339. package/src/access_scopes.ts +0 -9
  340. package/src/contract_function_simulator/noir-structs/message_tx_context.ts +0 -55
  341. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +0 -142
  342. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -140
  343. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -44
@@ -1,13 +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 { buildLegacyOracleCallbacks } from './legacy_oracle_mappings.js';
10
- 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';
11
3
  export class UnavailableOracleError extends Error {
12
4
  constructor(oracleName){
13
5
  super(`${oracleName} oracles not available with the current handler`);
@@ -15,6 +7,25 @@ export class UnavailableOracleError extends Error {
15
7
  }
16
8
  /**
17
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.
18
29
  */ export class Oracle {
19
30
  handler;
20
31
  constructor(handler){
@@ -52,8 +63,8 @@ export class UnavailableOracleError extends Error {
52
63
  // Validate oracle names - these must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate their scope
53
64
  // and must correspond to a function on the Oracle class.
54
65
  oracleNames.forEach((name)=>{
55
- if (!name.startsWith('aztec_prv_') && !name.startsWith('aztec_utl_')) {
56
- throw new Error(`Oracle function "${name}" must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate its scope`);
66
+ if (!name.startsWith('aztec_prv_') && !name.startsWith('aztec_utl_') && !name.startsWith('aztec_misc_')) {
67
+ throw new Error(`Oracle function "${name}" must be prefixed with "aztec_prv_", "aztec_utl_", or "aztec_misc_" to indicate its scope`);
57
68
  }
58
69
  const method = this[name];
59
70
  if (typeof method !== 'function') {
@@ -66,352 +77,476 @@ export class UnavailableOracleError extends Error {
66
77
  acc[name] = method.bind(this);
67
78
  return acc;
68
79
  }, {});
69
- return {
70
- ...callback,
71
- ...buildLegacyOracleCallbacks(this)
72
- };
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
+ });
73
105
  }
74
106
  // eslint-disable-next-line camelcase
75
- aztec_utl_assertCompatibleOracleVersion([version]) {
76
- this.handlerAsMisc().assertCompatibleOracleVersion(Fr.fromString(version).toNumber());
77
- return Promise.resolve([]);
107
+ aztec_misc_assertCompatibleOracleVersion(...inputs) {
108
+ return callHandler({
109
+ oracle: 'aztec_misc_assertCompatibleOracleVersion',
110
+ inputs,
111
+ handler: ([major, minor])=>{
112
+ this.handlerAsMisc().assertCompatibleOracleVersion(major, minor);
113
+ }
114
+ });
78
115
  }
79
116
  // eslint-disable-next-line camelcase
80
- aztec_utl_getRandomField() {
81
- const val = this.handlerAsMisc().getRandomField();
82
- return Promise.resolve([
83
- toACVMField(val)
84
- ]);
117
+ aztec_misc_getRandomField() {
118
+ return callHandler({
119
+ oracle: 'aztec_misc_getRandomField',
120
+ inputs: [],
121
+ handler: ()=>this.handlerAsMisc().getRandomField()
122
+ });
85
123
  }
86
124
  // eslint-disable-next-line camelcase
87
- aztec_prv_storeInExecutionCache(values, [hash]) {
88
- this.handlerAsPrivate().storeInExecutionCache(values.map(Fr.fromString), Fr.fromString(hash));
89
- 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
+ });
90
133
  }
91
134
  // eslint-disable-next-line camelcase
92
- async aztec_prv_loadFromExecutionCache([returnsHash]) {
93
- const values = await this.handlerAsPrivate().loadFromExecutionCache(Fr.fromString(returnsHash));
94
- return [
95
- values.map(toACVMField)
96
- ];
135
+ aztec_prv_getHashPreimage(...inputs) {
136
+ return callHandler({
137
+ oracle: 'aztec_prv_getHashPreimage',
138
+ inputs,
139
+ handler: ([returnsHash])=>this.handlerAsPrivate().getHashPreimage(returnsHash)
140
+ });
97
141
  }
98
142
  // eslint-disable-next-line camelcase
99
143
  aztec_utl_getUtilityContext() {
100
- const context = this.handlerAsUtility().getUtilityContext();
101
- return Promise.resolve(context.toNoirRepresentation());
144
+ return callHandler({
145
+ oracle: 'aztec_utl_getUtilityContext',
146
+ inputs: [],
147
+ handler: ()=>this.handlerAsUtility().getUtilityContext()
148
+ });
102
149
  }
103
150
  // eslint-disable-next-line camelcase
104
- async aztec_utl_getKeyValidationRequest([pkMHash]) {
105
- const keyValidationRequest = await this.handlerAsUtility().getKeyValidationRequest(Fr.fromString(pkMHash));
106
- 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
+ });
107
157
  }
108
158
  // eslint-disable-next-line camelcase
109
- async aztec_utl_getContractInstance([address]) {
110
- const instance = await this.handlerAsUtility().getContractInstance(AztecAddress.fromField(Fr.fromString(address)));
111
- return [
112
- instance.salt,
113
- instance.deployer,
114
- instance.currentContractClassId,
115
- instance.initializationHash,
116
- ...instance.publicKeys.toFields()
117
- ].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
+ });
118
165
  }
119
166
  // eslint-disable-next-line camelcase
120
- async aztec_utl_getNoteHashMembershipWitness([anchorBlockHash], [noteHash]) {
121
- const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
122
- const parsedNoteHash = Fr.fromString(noteHash);
123
- const witness = await this.handlerAsUtility().getNoteHashMembershipWitness(parsedAnchorBlockHash, parsedNoteHash);
124
- if (!witness) {
125
- throw new Error(`Note hash ${noteHash} not found in the note hash tree at anchor block hash ${parsedAnchorBlockHash.toString()}.`);
126
- }
127
- 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
+ });
128
173
  }
129
174
  // eslint-disable-next-line camelcase
130
- async aztec_utl_getBlockHashMembershipWitness([anchorBlockHash], [blockHash]) {
131
- const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
132
- const parsedBlockHash = BlockHash.fromString(blockHash);
133
- const witness = await this.handlerAsUtility().getBlockHashMembershipWitness(parsedAnchorBlockHash, parsedBlockHash);
134
- if (!witness) {
135
- throw new Error(`Block hash ${parsedBlockHash.toString()} not found in the archive tree at anchor block ${parsedAnchorBlockHash.toString()}.`);
136
- }
137
- 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
+ });
138
181
  }
139
182
  // eslint-disable-next-line camelcase
140
- async aztec_utl_getNullifierMembershipWitness([blockHash], [nullifier]) {
141
- const parsedBlockHash = BlockHash.fromString(blockHash);
142
- const parsedNullifier = Fr.fromString(nullifier);
143
- const witness = await this.handlerAsUtility().getNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
144
- if (!witness) {
145
- throw new Error(`Nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`);
146
- }
147
- 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
+ });
148
189
  }
149
190
  // eslint-disable-next-line camelcase
150
- async aztec_utl_getLowNullifierMembershipWitness([blockHash], [nullifier]) {
151
- const parsedBlockHash = BlockHash.fromString(blockHash);
152
- const parsedNullifier = Fr.fromString(nullifier);
153
- const witness = await this.handlerAsUtility().getLowNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
154
- if (!witness) {
155
- throw new Error(`Low nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`);
156
- }
157
- 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
+ });
158
197
  }
159
198
  // eslint-disable-next-line camelcase
160
- async aztec_utl_getPublicDataWitness([blockHash], [leafSlot]) {
161
- const parsedBlockHash = BlockHash.fromString(blockHash);
162
- const parsedLeafSlot = Fr.fromString(leafSlot);
163
- const witness = await this.handlerAsUtility().getPublicDataWitness(parsedBlockHash, parsedLeafSlot);
164
- if (!witness) {
165
- throw new Error(`Public data witness not found for slot ${parsedLeafSlot} at block hash ${parsedBlockHash.toString()}.`);
166
- }
167
- 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
+ });
168
205
  }
169
206
  // eslint-disable-next-line camelcase
170
- async aztec_utl_getBlockHeader([blockNumber]) {
171
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
172
- const header = await this.handlerAsUtility().getBlockHeader(BlockNumber(parsedBlockNumber));
173
- if (!header) {
174
- throw new Error(`Block header not found for block ${parsedBlockNumber}.`);
175
- }
176
- 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
+ });
177
213
  }
178
214
  // eslint-disable-next-line camelcase
179
- async aztec_utl_getAuthWitness([messageHash]) {
180
- const messageHashField = Fr.fromString(messageHash);
181
- const witness = await this.handlerAsUtility().getAuthWitness(messageHashField);
182
- if (!witness) {
183
- throw new Error(`Unknown auth witness for message hash ${messageHashField}`);
184
- }
185
- return [
186
- witness.map(toACVMField)
187
- ];
215
+ aztec_utl_getAuthWitness(...inputs) {
216
+ return callHandler({
217
+ oracle: 'aztec_utl_getAuthWitness',
218
+ inputs,
219
+ handler: ([messageHash])=>this.handlerAsUtility().getAuthWitness(messageHash)
220
+ });
188
221
  }
189
222
  // eslint-disable-next-line camelcase
190
- async aztec_utl_tryGetPublicKeysAndPartialAddress([address]) {
191
- const parsedAddress = AztecAddress.fromField(Fr.fromString(address));
192
- const result = await this.handlerAsUtility().tryGetPublicKeysAndPartialAddress(parsedAddress);
193
- // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
194
- // with two fields: `some` (a boolean) and `value` (a field array in this case).
195
- if (result === undefined) {
196
- // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
197
- return [
198
- toACVMField(0),
199
- Array(13).fill(toACVMField(0))
200
- ];
201
- } else {
202
- // Data was found so we set `some` to 1 and return it along with `value`.
203
- return [
204
- toACVMField(1),
205
- [
206
- ...result.publicKeys.toFields(),
207
- result.partialAddress
208
- ].map(toACVMField)
209
- ];
210
- }
223
+ aztec_utl_getPublicKeysAndPartialAddress(...inputs) {
224
+ return callHandler({
225
+ oracle: 'aztec_utl_getPublicKeysAndPartialAddress',
226
+ inputs,
227
+ handler: ([address])=>this.handlerAsUtility().getPublicKeysAndPartialAddress(address)
228
+ });
211
229
  }
212
230
  // eslint-disable-next-line camelcase
213
- async aztec_utl_getNotes([ownerSome], [ownerValue], [storageSlot], [numSelects], selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, [limit], [offset], [status], [maxNotes], [packedHintedNoteLength]) {
214
- // Parse Option<AztecAddress>: ownerSome is 0 for None, 1 for Some
215
- const owner = Fr.fromString(ownerSome).toNumber() === 1 ? AztecAddress.fromString(ownerValue) : undefined;
216
- 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);
217
- const returnDataAsArrayOfPackedHintedNotes = noteDatas.map((noteData)=>packAsHintedNote({
218
- contractAddress: noteData.contractAddress,
219
- owner: noteData.owner,
220
- randomness: noteData.randomness,
221
- storageSlot: noteData.storageSlot,
222
- noteNonce: noteData.noteNonce,
223
- isPending: noteData.isPending,
224
- note: noteData.note
225
- }));
226
- // Now we convert each sub-array to an array of ACVMField
227
- const returnDataAsArrayOfACVMFieldArrays = returnDataAsArrayOfPackedHintedNotes.map((subArray)=>subArray.map(toACVMField));
228
- // At last we convert the array of arrays to a bounded vec of arrays
229
- 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
+ });
230
237
  }
231
238
  // eslint-disable-next-line camelcase
232
- aztec_prv_notifyCreatedNote([owner], [storageSlot], [randomness], [noteTypeId], note, [noteHash], [counter]) {
233
- 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);
234
- 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
+ });
235
247
  }
236
248
  // eslint-disable-next-line camelcase
237
- async aztec_prv_notifyNullifiedNote([innerNullifier], [noteHash], [counter]) {
238
- await this.handlerAsPrivate().notifyNullifiedNote(Fr.fromString(innerNullifier), Fr.fromString(noteHash), +counter);
239
- 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
+ });
240
255
  }
241
256
  // eslint-disable-next-line camelcase
242
- async aztec_prv_notifyCreatedNullifier([innerNullifier]) {
243
- await this.handlerAsPrivate().notifyCreatedNullifier(Fr.fromString(innerNullifier));
244
- return [];
257
+ aztec_prv_notifyCreatedNullifier(...inputs) {
258
+ return callHandler({
259
+ oracle: 'aztec_prv_notifyCreatedNullifier',
260
+ inputs,
261
+ handler: ([innerNullifier])=>this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier)
262
+ });
245
263
  }
246
264
  // eslint-disable-next-line camelcase
247
- async aztec_prv_isNullifierPending([innerNullifier], [contractAddress]) {
248
- const isPending = await this.handlerAsPrivate().isNullifierPending(Fr.fromString(innerNullifier), AztecAddress.fromString(contractAddress));
249
- return [
250
- toACVMField(isPending)
251
- ];
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
+ });
252
271
  }
253
272
  // eslint-disable-next-line camelcase
254
- async aztec_utl_checkNullifierExists([innerNullifier]) {
255
- const exists = await this.handlerAsUtility().checkNullifierExists(Fr.fromString(innerNullifier));
256
- return [
257
- toACVMField(exists)
258
- ];
273
+ aztec_utl_doesNullifierExist(...inputs) {
274
+ return callHandler({
275
+ oracle: 'aztec_utl_doesNullifierExist',
276
+ inputs,
277
+ handler: ([innerNullifier])=>this.handlerAsUtility().doesNullifierExist(innerNullifier)
278
+ });
259
279
  }
260
280
  // eslint-disable-next-line camelcase
261
- async aztec_utl_getL1ToL2MembershipWitness([contractAddress], [messageHash], [secret]) {
262
- const message = await this.handlerAsUtility().getL1ToL2MembershipWitness(AztecAddress.fromString(contractAddress), Fr.fromString(messageHash), Fr.fromString(secret));
263
- 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
+ });
264
287
  }
265
288
  // eslint-disable-next-line camelcase
266
- async aztec_utl_storageRead([blockHash], [contractAddress], [startStorageSlot], [numberOfElements]) {
267
- const values = await this.handlerAsUtility().storageRead(BlockHash.fromString(blockHash), new AztecAddress(Fr.fromString(contractAddress)), Fr.fromString(startStorageSlot), +numberOfElements);
268
- return [
269
- values.map(toACVMField)
270
- ];
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
+ });
271
303
  }
272
304
  // eslint-disable-next-line camelcase
273
- aztec_prv_notifyCreatedContractClassLog([contractAddress], message, [length], [counter]) {
274
- const logFields = new ContractClassLogFields(message.map(Fr.fromString));
275
- const log = new ContractClassLog(new AztecAddress(Fr.fromString(contractAddress)), logFields, +length);
276
- this.handlerAsPrivate().notifyCreatedContractClassLog(log, +counter);
277
- 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
+ });
278
313
  }
279
314
  // eslint-disable-next-line camelcase
280
- async aztec_utl_log(level, message, _ignoredFieldsSize, fields) {
281
- const levelFr = Fr.fromString(level[0]);
282
- const messageStr = message.map((acvmField)=>String.fromCharCode(Fr.fromString(acvmField).toNumber())).join('');
283
- const fieldsFr = fields.map(Fr.fromString);
284
- await this.handlerAsMisc().log(levelFr.toNumber(), messageStr, fieldsFr);
285
- return [];
315
+ aztec_misc_log(...inputs) {
316
+ return callHandler({
317
+ oracle: 'aztec_misc_log',
318
+ inputs,
319
+ handler: ([level, message, fieldsSize, fields])=>this.handlerAsMisc().log(level, message, fieldsSize, fields)
320
+ });
286
321
  }
287
322
  // This function's name is directly hardcoded in `circuit_recorder.ts`. Don't forget to update it there if you
288
323
  // change the name here.
289
324
  // eslint-disable-next-line camelcase
290
- async aztec_prv_callPrivateFunction([contractAddress], [functionSelector], [argsHash], [sideEffectCounter], [isStaticCall]) {
291
- 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());
292
- return [
293
- [
294
- endSideEffectCounter,
295
- returnsHash
296
- ].map(toACVMField)
297
- ];
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
+ });
298
339
  }
299
340
  // eslint-disable-next-line camelcase
300
- async aztec_prv_validatePublicCalldata([calldataHash]) {
301
- await this.handlerAsPrivate().validatePublicCalldata(Fr.fromString(calldataHash));
302
- return [];
341
+ aztec_prv_notifyRevertiblePhaseStart(...inputs) {
342
+ return callHandler({
343
+ oracle: 'aztec_prv_notifyRevertiblePhaseStart',
344
+ inputs,
345
+ handler: ([minRevertibleSideEffectCounter])=>this.handlerAsPrivate().notifyRevertiblePhaseStart(minRevertibleSideEffectCounter)
346
+ });
303
347
  }
304
348
  // eslint-disable-next-line camelcase
305
- async aztec_prv_notifyRevertiblePhaseStart([minRevertibleSideEffectCounter]) {
306
- await this.handlerAsPrivate().notifyRevertiblePhaseStart(Fr.fromString(minRevertibleSideEffectCounter).toNumber());
307
- return Promise.resolve([]);
349
+ aztec_prv_isExecutionInRevertiblePhase(...inputs) {
350
+ return callHandler({
351
+ oracle: 'aztec_prv_isExecutionInRevertiblePhase',
352
+ inputs,
353
+ handler: ([sideEffectCounter])=>this.handlerAsPrivate().isExecutionInRevertiblePhase(sideEffectCounter)
354
+ });
308
355
  }
309
356
  // eslint-disable-next-line camelcase
310
- async aztec_prv_inRevertiblePhase([sideEffectCounter]) {
311
- const isRevertible = await this.handlerAsPrivate().inRevertiblePhase(Fr.fromString(sideEffectCounter).toNumber());
312
- return Promise.resolve([
313
- toACVMField(isRevertible)
314
- ]);
357
+ aztec_prv_getAppTaggingSecret(...inputs) {
358
+ return callHandler({
359
+ oracle: 'aztec_prv_getAppTaggingSecret',
360
+ inputs,
361
+ handler: ([sender, recipient])=>this.handlerAsPrivate().getAppTaggingSecret(sender, recipient)
362
+ });
315
363
  }
316
364
  // 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
- ];
365
+ aztec_prv_getNextTaggingIndex(...inputs) {
366
+ return callHandler({
367
+ oracle: 'aztec_prv_getNextTaggingIndex',
368
+ inputs,
369
+ handler: ([secret, mode])=>this.handlerAsPrivate().getNextTaggingIndex(secret, mode)
370
+ });
322
371
  }
323
372
  // eslint-disable-next-line camelcase
324
- async aztec_utl_fetchTaggedLogs([pendingTaggedLogArrayBaseSlot]) {
325
- await this.handlerAsUtility().fetchTaggedLogs(Fr.fromString(pendingTaggedLogArrayBaseSlot));
326
- return [];
373
+ aztec_utl_getPendingTaggedLogs(...inputs) {
374
+ return callHandler({
375
+ oracle: 'aztec_utl_getPendingTaggedLogs',
376
+ inputs,
377
+ handler: ([scope, providedSecrets])=>this.handlerAsUtility().getPendingTaggedLogs(scope, providedSecrets)
378
+ });
327
379
  }
328
380
  // eslint-disable-next-line camelcase
329
- async aztec_utl_validateAndStoreEnqueuedNotesAndEvents([contractAddress], [noteValidationRequestsArrayBaseSlot], [eventValidationRequestsArrayBaseSlot], [maxNotePackedLen], [maxEventSerializedLen]) {
330
- await this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(AztecAddress.fromString(contractAddress), Fr.fromString(noteValidationRequestsArrayBaseSlot), Fr.fromString(eventValidationRequestsArrayBaseSlot), Fr.fromString(maxNotePackedLen).toNumber(), Fr.fromString(maxEventSerializedLen).toNumber());
331
- return [];
381
+ aztec_utl_validateAndStoreEnqueuedNotesAndEvents(...inputs) {
382
+ return callHandler({
383
+ oracle: 'aztec_utl_validateAndStoreEnqueuedNotesAndEvents',
384
+ inputs,
385
+ handler: ([noteValidationRequests, eventValidationRequests, scope])=>this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(noteValidationRequests, eventValidationRequests, scope)
386
+ });
332
387
  }
333
388
  // 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 [];
389
+ aztec_utl_getLogsByTag(...inputs) {
390
+ return callHandler({
391
+ oracle: 'aztec_utl_getLogsByTag',
392
+ inputs,
393
+ handler: ([requests])=>this.handlerAsUtility().getLogsByTag(requests)
394
+ });
337
395
  }
338
396
  // eslint-disable-next-line camelcase
339
- async aztec_utl_utilityResolveMessageContexts([contractAddress], [messageContextRequestsArrayBaseSlot], [messageContextResponsesArrayBaseSlot]) {
340
- await this.handlerAsUtility().utilityResolveMessageContexts(AztecAddress.fromString(contractAddress), Fr.fromString(messageContextRequestsArrayBaseSlot), Fr.fromString(messageContextResponsesArrayBaseSlot));
341
- return [];
397
+ aztec_utl_getMessageContextsByTxHash(...inputs) {
398
+ return callHandler({
399
+ oracle: 'aztec_utl_getMessageContextsByTxHash',
400
+ inputs,
401
+ handler: ([requests])=>this.handlerAsUtility().getMessageContextsByTxHash(requests)
402
+ });
342
403
  }
343
404
  // eslint-disable-next-line camelcase
344
- async aztec_utl_storeCapsule([contractAddress], [slot], capsule) {
345
- await this.handlerAsUtility().storeCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot), capsule.map(Fr.fromString));
346
- return [];
405
+ aztec_utl_getTxEffect(...inputs) {
406
+ return callHandler({
407
+ oracle: 'aztec_utl_getTxEffect',
408
+ inputs,
409
+ handler: ([txHash])=>this.handlerAsUtility().getTxEffect(txHash)
410
+ });
347
411
  }
348
412
  // eslint-disable-next-line camelcase
349
- async aztec_utl_loadCapsule([contractAddress], [slot], [tSize]) {
350
- const values = await this.handlerAsUtility().loadCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
351
- // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
352
- // with two fields: `some` (a boolean) and `value` (a field array in this case).
353
- if (values === null) {
354
- // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
355
- return [
356
- toACVMField(0),
357
- Array(Fr.fromString(tSize).toNumber()).fill(toACVMField(0))
358
- ];
359
- } else {
360
- // Data was found so we set `some` to 1 and return it along with `value`.
361
- return [
362
- toACVMField(1),
363
- values.map(toACVMField)
364
- ];
365
- }
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
+ });
366
421
  }
367
422
  // eslint-disable-next-line camelcase
368
- async aztec_utl_deleteCapsule([contractAddress], [slot]) {
369
- await this.handlerAsUtility().deleteCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
370
- 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
+ });
371
429
  }
372
430
  // eslint-disable-next-line camelcase
373
- async aztec_utl_copyCapsule([contractAddress], [srcSlot], [dstSlot], [numEntries]) {
374
- await this.handlerAsUtility().copyCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(srcSlot), Fr.fromString(dstSlot), Fr.fromString(numEntries).toNumber());
375
- 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
+ });
376
439
  }
377
- // TODO(F-452): Return Option and wrap in try/catch so BB exceptions don't crash PXE.
378
440
  // eslint-disable-next-line camelcase
379
- async aztec_utl_aes128Decrypt(ciphertextBVecStorage, [ciphertextLength], iv, symKey) {
380
- const ciphertext = fromUintBoundedVec(ciphertextBVecStorage, ciphertextLength, 8);
381
- const ivBuffer = fromUintArray(iv, 8);
382
- const symKeyBuffer = fromUintArray(symKey, 8);
383
- const plaintext = await this.handlerAsUtility().aes128Decrypt(ciphertext, ivBuffer, symKeyBuffer);
384
- 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
+ });
385
447
  }
386
448
  // eslint-disable-next-line camelcase
387
- async aztec_utl_getSharedSecret([address], [ephPKField0], [ephPKField1], [ephPKField2]) {
388
- const secret = await this.handlerAsUtility().getSharedSecret(AztecAddress.fromField(Fr.fromString(address)), Point.fromFields([
389
- ephPKField0,
390
- ephPKField1,
391
- ephPKField2
392
- ].map(Fr.fromString)));
393
- 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
+ });
394
455
  }
395
456
  // eslint-disable-next-line camelcase
396
- async aztec_utl_emitOffchainEffect(data) {
397
- await this.handlerAsUtility().emitOffchainEffect(data.map(Fr.fromString));
398
- return [];
457
+ aztec_utl_popEphemeral(...inputs) {
458
+ return callHandler({
459
+ oracle: 'aztec_utl_popEphemeral',
460
+ inputs,
461
+ handler: ([slot])=>this.handlerAsUtility().popEphemeral(slot)
462
+ });
399
463
  }
400
464
  // eslint-disable-next-line camelcase
401
- async aztec_prv_getSenderForTags() {
402
- const sender = await this.handlerAsPrivate().getSenderForTags();
403
- // Return [1, address] for Some(address), [0, 0] for None
404
- return sender ? [
405
- toACVMField(1n),
406
- toACVMField(sender)
407
- ] : [
408
- toACVMField(0n),
409
- toACVMField(0n)
410
- ];
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
+ });
411
481
  }
412
482
  // eslint-disable-next-line camelcase
413
- async aztec_prv_setSenderForTags([senderForTags]) {
414
- await this.handlerAsPrivate().setSenderForTags(AztecAddress.fromField(Fr.fromString(senderForTags)));
415
- 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, ephPks, contractAddress])=>this.handlerAsUtility().getSharedSecrets(address, ephPks, 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
+ });
416
551
  }
417
552
  }