@aztec/pxe 0.0.1-commit.96bb3f7 → 0.0.1-commit.993d240

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 (379) 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 +32 -26
  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 +16 -6
  11. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  12. package/dest/block_synchronizer/block_synchronizer.js +94 -23
  13. package/dest/config/index.d.ts +10 -2
  14. package/dest/config/index.d.ts.map +1 -1
  15. package/dest/config/index.js +17 -2
  16. package/dest/config/package_info.js +1 -1
  17. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  18. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  19. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  20. package/dest/contract_function_simulator/contract_function_simulator.d.ts +69 -36
  21. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  22. package/dest/contract_function_simulator/contract_function_simulator.js +240 -91
  23. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  24. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  25. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  26. package/dest/contract_function_simulator/execution_note_cache.d.ts +18 -9
  27. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/execution_note_cache.js +45 -28
  29. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -11
  30. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -15
  32. package/dest/contract_function_simulator/index.d.ts +5 -2
  33. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  34. package/dest/contract_function_simulator/index.js +4 -1
  35. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
  36. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
  37. package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
  38. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +5 -7
  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 +9 -10
  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 +2 -2
  45. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -1
  46. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +2 -4
  47. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +5 -8
  48. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  49. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +7 -11
  50. package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
  51. package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
  52. package/dest/contract_function_simulator/noir-structs/option.js +62 -0
  53. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  54. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  55. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  56. package/dest/contract_function_simulator/oracle/interfaces.d.ts +70 -50
  57. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  58. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
  59. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  60. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +7 -7
  61. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  62. package/dest/contract_function_simulator/oracle/note_packing_utils.js +10 -10
  63. package/dest/contract_function_simulator/oracle/oracle.d.ts +74 -43
  64. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  65. package/dest/contract_function_simulator/oracle/oracle.js +471 -264
  66. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +147 -0
  67. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
  68. package/dest/contract_function_simulator/oracle/oracle_registry.js +1199 -0
  69. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
  70. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  71. package/dest/contract_function_simulator/oracle/private_execution.js +5 -38
  72. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +74 -91
  73. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  74. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +164 -110
  75. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +156 -78
  76. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  77. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +459 -186
  78. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  79. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  80. package/dest/contract_function_simulator/pick_notes.js +20 -3
  81. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  82. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  83. package/dest/contract_function_simulator/proxied_contract_data_source.js +35 -64
  84. package/dest/contract_logging.d.ts +27 -0
  85. package/dest/contract_logging.d.ts.map +1 -0
  86. package/dest/contract_logging.js +38 -0
  87. package/dest/contract_sync/contract_sync_service.d.ts +42 -0
  88. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  89. package/dest/contract_sync/contract_sync_service.js +135 -0
  90. package/dest/contract_sync/helpers.d.ts +27 -0
  91. package/dest/contract_sync/helpers.d.ts.map +1 -0
  92. package/dest/contract_sync/helpers.js +53 -0
  93. package/dest/debug/pxe_debug_utils.d.ts +19 -10
  94. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  95. package/dest/debug/pxe_debug_utils.js +22 -17
  96. package/dest/entrypoints/client/bundle/index.d.ts +3 -1
  97. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  98. package/dest/entrypoints/client/bundle/index.js +2 -0
  99. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  100. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  101. package/dest/entrypoints/client/bundle/utils.js +33 -11
  102. package/dest/entrypoints/client/lazy/index.d.ts +3 -1
  103. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  104. package/dest/entrypoints/client/lazy/index.js +2 -0
  105. package/dest/entrypoints/client/lazy/utils.d.ts +3 -3
  106. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  107. package/dest/entrypoints/client/lazy/utils.js +34 -12
  108. package/dest/entrypoints/pxe_creation_options.d.ts +11 -2
  109. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  110. package/dest/entrypoints/pxe_creation_options.js +3 -1
  111. package/dest/entrypoints/server/index.d.ts +6 -2
  112. package/dest/entrypoints/server/index.d.ts.map +1 -1
  113. package/dest/entrypoints/server/index.js +5 -1
  114. package/dest/entrypoints/server/utils.d.ts +4 -3
  115. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  116. package/dest/entrypoints/server/utils.js +40 -13
  117. package/dest/events/event_service.d.ts +17 -8
  118. package/dest/events/event_service.d.ts.map +1 -1
  119. package/dest/events/event_service.js +58 -28
  120. package/dest/events/private_event_filter_validator.d.ts +6 -5
  121. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  122. package/dest/events/private_event_filter_validator.js +20 -6
  123. package/dest/hooks/authorize_utility_call.d.ts +41 -0
  124. package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
  125. package/dest/hooks/authorize_utility_call.js +4 -0
  126. package/dest/hooks/execution_hooks.d.ts +42 -0
  127. package/dest/hooks/execution_hooks.d.ts.map +1 -0
  128. package/dest/hooks/execution_hooks.js +9 -0
  129. package/dest/hooks/index.d.ts +4 -0
  130. package/dest/hooks/index.d.ts.map +1 -0
  131. package/dest/hooks/index.js +1 -0
  132. package/dest/job_coordinator/job_coordinator.d.ts +3 -2
  133. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -1
  134. package/dest/job_coordinator/job_coordinator.js +3 -2
  135. package/dest/logs/log_service.d.ts +13 -10
  136. package/dest/logs/log_service.d.ts.map +1 -1
  137. package/dest/logs/log_service.js +132 -84
  138. package/dest/messages/message_context_service.d.ts +17 -0
  139. package/dest/messages/message_context_service.d.ts.map +1 -0
  140. package/dest/messages/message_context_service.js +38 -0
  141. package/dest/notes/note_service.d.ts +31 -9
  142. package/dest/notes/note_service.d.ts.map +1 -1
  143. package/dest/notes/note_service.js +97 -77
  144. package/dest/notes_filter.d.ts +24 -0
  145. package/dest/notes_filter.d.ts.map +1 -0
  146. package/dest/notes_filter.js +4 -0
  147. package/dest/oracle_version.d.ts +4 -3
  148. package/dest/oracle_version.d.ts.map +1 -1
  149. package/dest/oracle_version.js +20 -9
  150. package/dest/private_kernel/batch_planner.d.ts +47 -0
  151. package/dest/private_kernel/batch_planner.d.ts.map +1 -0
  152. package/dest/private_kernel/batch_planner.js +104 -0
  153. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  154. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  155. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  156. package/dest/private_kernel/hints/index.d.ts +3 -3
  157. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  158. package/dest/private_kernel/hints/index.js +2 -2
  159. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  160. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  161. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +141 -74
  162. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  163. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  164. package/dest/private_kernel/hints/test_utils.js +202 -0
  165. package/dest/private_kernel/private_kernel_execution_prover.d.ts +7 -2
  166. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  167. package/dest/private_kernel/private_kernel_execution_prover.js +168 -67
  168. package/dest/private_kernel/private_kernel_oracle.d.ts +28 -29
  169. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  170. package/dest/private_kernel/private_kernel_oracle.js +96 -2
  171. package/dest/pxe.d.ts +126 -59
  172. package/dest/pxe.d.ts.map +1 -1
  173. package/dest/pxe.js +257 -200
  174. package/dest/storage/address_store/address_store.d.ts +1 -1
  175. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  176. package/dest/storage/address_store/address_store.js +12 -11
  177. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  178. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  179. package/dest/storage/anchor_block_store/anchor_block_store.js +9 -2
  180. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
  181. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
  182. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
  183. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
  184. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
  185. package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
  186. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
  187. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
  188. package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
  189. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  190. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  191. package/dest/storage/capsule_store/capsule_service.js +50 -0
  192. package/dest/storage/capsule_store/capsule_store.d.ts +25 -10
  193. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  194. package/dest/storage/capsule_store/capsule_store.js +143 -28
  195. package/dest/storage/capsule_store/index.d.ts +2 -1
  196. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  197. package/dest/storage/capsule_store/index.js +1 -0
  198. package/dest/storage/contract_store/contract_store.d.ts +42 -16
  199. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  200. package/dest/storage/contract_store/contract_store.js +158 -102
  201. package/dest/storage/metadata.d.ts +1 -1
  202. package/dest/storage/metadata.js +1 -1
  203. package/dest/storage/note_store/note_store.d.ts +50 -51
  204. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  205. package/dest/storage/note_store/note_store.js +284 -263
  206. package/dest/storage/note_store/stored_note.d.ts +16 -0
  207. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  208. package/dest/storage/note_store/stored_note.js +43 -0
  209. package/dest/storage/open_pxe_stores.d.ts +33 -0
  210. package/dest/storage/open_pxe_stores.d.ts.map +1 -0
  211. package/dest/storage/open_pxe_stores.js +27 -0
  212. package/dest/storage/private_event_store/private_event_store.d.ts +43 -8
  213. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  214. package/dest/storage/private_event_store/private_event_store.js +229 -111
  215. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  216. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  217. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  218. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +16 -9
  219. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  220. package/dest/storage/tagging_store/recipient_tagging_store.js +88 -19
  221. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  222. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  223. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  224. package/dest/storage/tagging_store/sender_tagging_store.d.ts +43 -32
  225. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  226. package/dest/storage/tagging_store/sender_tagging_store.js +300 -122
  227. package/dest/tagging/get_all_logs_by_tags.d.ts +48 -0
  228. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  229. package/dest/tagging/get_all_logs_by_tags.js +59 -0
  230. package/dest/tagging/index.d.ts +7 -5
  231. package/dest/tagging/index.d.ts.map +1 -1
  232. package/dest/tagging/index.js +5 -3
  233. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
  234. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
  235. package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
  236. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
  237. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
  238. package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
  239. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +3 -3
  240. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -1
  241. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  242. package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
  243. package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
  244. package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
  245. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +5 -9
  246. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  247. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +34 -18
  248. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +13 -7
  249. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  250. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +44 -16
  251. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +8 -7
  252. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  253. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +44 -27
  254. package/package.json +31 -19
  255. package/src/bin/check_oracle_version.ts +42 -31
  256. package/src/bin/index.ts +1 -0
  257. package/src/block_synchronizer/block_stream_source.ts +81 -0
  258. package/src/block_synchronizer/block_synchronizer.ts +116 -36
  259. package/src/config/index.ts +21 -1
  260. package/src/config/package_info.ts +1 -1
  261. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  262. package/src/contract_function_simulator/contract_function_simulator.ts +417 -156
  263. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  264. package/src/contract_function_simulator/execution_note_cache.ts +44 -25
  265. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
  266. package/src/contract_function_simulator/index.ts +4 -1
  267. package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
  268. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +11 -10
  269. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
  270. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  271. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +6 -11
  272. package/src/contract_function_simulator/noir-structs/option.ts +69 -0
  273. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  274. package/src/contract_function_simulator/oracle/interfaces.ts +93 -70
  275. package/src/contract_function_simulator/oracle/note_packing_utils.ts +13 -13
  276. package/src/contract_function_simulator/oracle/oracle.ts +567 -461
  277. package/src/contract_function_simulator/oracle/oracle_registry.ts +904 -0
  278. package/src/contract_function_simulator/oracle/private_execution.ts +5 -71
  279. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +213 -209
  280. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +657 -254
  281. package/src/contract_function_simulator/pick_notes.ts +22 -3
  282. package/src/contract_function_simulator/proxied_contract_data_source.ts +41 -64
  283. package/src/contract_logging.ts +52 -0
  284. package/src/contract_sync/contract_sync_service.ts +189 -0
  285. package/src/contract_sync/helpers.ts +86 -0
  286. package/src/debug/pxe_debug_utils.ts +55 -18
  287. package/src/entrypoints/client/bundle/index.ts +2 -0
  288. package/src/entrypoints/client/bundle/utils.ts +26 -20
  289. package/src/entrypoints/client/lazy/index.ts +2 -0
  290. package/src/entrypoints/client/lazy/utils.ts +28 -21
  291. package/src/entrypoints/pxe_creation_options.ts +16 -1
  292. package/src/entrypoints/server/index.ts +5 -1
  293. package/src/entrypoints/server/utils.ts +37 -32
  294. package/src/events/event_service.ts +79 -39
  295. package/src/events/private_event_filter_validator.ts +23 -5
  296. package/src/hooks/authorize_utility_call.ts +44 -0
  297. package/src/hooks/execution_hooks.ts +48 -0
  298. package/src/hooks/index.ts +7 -0
  299. package/src/job_coordinator/job_coordinator.ts +4 -3
  300. package/src/logs/log_service.ts +171 -141
  301. package/src/messages/message_context_service.ts +45 -0
  302. package/src/notes/note_service.ts +137 -107
  303. package/src/notes_filter.ts +24 -0
  304. package/src/oracle_version.ts +20 -9
  305. package/src/private_kernel/batch_planner.ts +169 -0
  306. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  307. package/src/private_kernel/hints/index.ts +2 -2
  308. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +196 -137
  309. package/src/private_kernel/hints/test_utils.ts +318 -0
  310. package/src/private_kernel/private_kernel_execution_prover.ts +261 -93
  311. package/src/private_kernel/private_kernel_oracle.ts +129 -40
  312. package/src/pxe.ts +467 -273
  313. package/src/storage/address_store/address_store.ts +15 -15
  314. package/src/storage/anchor_block_store/anchor_block_store.ts +9 -1
  315. package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
  316. package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
  317. package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
  318. package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
  319. package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
  320. package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
  321. package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
  322. package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
  323. package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
  324. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
  325. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
  326. package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
  327. package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
  328. package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
  329. package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
  330. package/src/storage/capsule_store/capsule_service.ts +90 -0
  331. package/src/storage/capsule_store/capsule_store.ts +183 -29
  332. package/src/storage/capsule_store/index.ts +1 -0
  333. package/src/storage/contract_store/contract_store.ts +194 -125
  334. package/src/storage/metadata.ts +1 -1
  335. package/src/storage/note_store/note_store.ts +323 -320
  336. package/src/storage/note_store/stored_note.ts +48 -0
  337. package/src/storage/open_pxe_stores.ts +49 -0
  338. package/src/storage/private_event_store/private_event_store.ts +296 -124
  339. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  340. package/src/storage/tagging_store/recipient_tagging_store.ts +107 -21
  341. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  342. package/src/storage/tagging_store/sender_tagging_store.ts +366 -134
  343. package/src/tagging/get_all_logs_by_tags.ts +120 -0
  344. package/src/tagging/index.ts +6 -4
  345. package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
  346. package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
  347. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +4 -4
  348. package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
  349. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +59 -21
  350. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +47 -29
  351. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +41 -29
  352. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  353. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  354. package/dest/contract_function_simulator/proxied_node.js +0 -27
  355. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  356. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  357. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  358. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  359. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
  360. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  361. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -85
  362. package/dest/public_storage/public_storage_service.d.ts +0 -24
  363. package/dest/public_storage/public_storage_service.d.ts.map +0 -1
  364. package/dest/public_storage/public_storage_service.js +0 -26
  365. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -14
  366. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +0 -1
  367. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +0 -99
  368. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -14
  369. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
  370. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -29
  371. package/dest/tree_membership/tree_membership_service.d.ts +0 -52
  372. package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
  373. package/dest/tree_membership/tree_membership_service.js +0 -84
  374. package/src/contract_function_simulator/proxied_node.ts +0 -33
  375. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -127
  376. package/src/public_storage/public_storage_service.ts +0 -33
  377. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -132
  378. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -43
  379. package/src/tree_membership/tree_membership_service.ts +0 -112
@@ -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 { ContractClassLog, ContractClassLogFields } from '@aztec/stdlib/logs';
8
- import { MerkleTreeId } from '@aztec/stdlib/trees';
9
- import { packAsRetrievedNote } 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){
@@ -48,11 +60,11 @@ export class UnavailableOracleError extends Error {
48
60
  ];
49
61
  // Get all the oracle function names
50
62
  const oracleNames = Object.getOwnPropertyNames(Oracle.prototype).filter((name)=>!excludedProps.includes(name));
51
- // Validate oracle names - these must be prefixed with either "private" or "utility" to indicate their scope
63
+ // Validate oracle names - these must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate their scope
52
64
  // and must correspond to a function on the Oracle class.
53
65
  oracleNames.forEach((name)=>{
54
- if (!name.startsWith('private') && !name.startsWith('utility')) {
55
- throw new Error(`Oracle function "${name}" must be prefixed with either "private" or "utility" to indicate its scope`);
66
+ if (!name.startsWith('aztec_prv_') && !name.startsWith('aztec_utl_')) {
67
+ throw new Error(`Oracle function "${name}" must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate its scope`);
56
68
  }
57
69
  const method = this[name];
58
70
  if (typeof method !== 'function') {
@@ -60,286 +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
- utilityAssertCompatibleOracleVersion([version]) {
70
- this.handlerAsMisc().utilityAssertCompatibleOracleVersion(Fr.fromString(version).toNumber());
71
- return Promise.resolve([]);
106
+ // eslint-disable-next-line camelcase
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
+ });
72
115
  }
73
- utilityGetRandomField() {
74
- const val = this.handlerAsMisc().utilityGetRandomField();
75
- return Promise.resolve([
76
- toACVMField(val)
77
- ]);
116
+ // eslint-disable-next-line camelcase
117
+ aztec_utl_getRandomField() {
118
+ return callHandler({
119
+ oracle: 'aztec_utl_getRandomField',
120
+ inputs: [],
121
+ handler: ()=>this.handlerAsMisc().getRandomField()
122
+ });
78
123
  }
79
- privateStoreInExecutionCache(values, [hash]) {
80
- this.handlerAsPrivate().privateStoreInExecutionCache(values.map(Fr.fromString), Fr.fromString(hash));
81
- return Promise.resolve([]);
124
+ // eslint-disable-next-line camelcase
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
+ });
82
133
  }
83
- async privateLoadFromExecutionCache([returnsHash]) {
84
- const values = await this.handlerAsPrivate().privateLoadFromExecutionCache(Fr.fromString(returnsHash));
85
- return [
86
- values.map(toACVMField)
87
- ];
134
+ // eslint-disable-next-line camelcase
135
+ aztec_prv_getHashPreimage(...inputs) {
136
+ return callHandler({
137
+ oracle: 'aztec_prv_getHashPreimage',
138
+ inputs,
139
+ handler: ([returnsHash])=>this.handlerAsPrivate().getHashPreimage(returnsHash)
140
+ });
88
141
  }
89
- utilityGetUtilityContext() {
90
- const context = this.handlerAsUtility().utilityGetUtilityContext();
91
- return Promise.resolve(context.toNoirRepresentation());
92
- }
93
- async utilityGetKeyValidationRequest([pkMHash]) {
94
- const keyValidationRequest = await this.handlerAsUtility().utilityGetKeyValidationRequest(Fr.fromString(pkMHash));
95
- return keyValidationRequest.toFields().map(toACVMField);
96
- }
97
- async utilityGetContractInstance([address]) {
98
- const instance = await this.handlerAsUtility().utilityGetContractInstance(AztecAddress.fromField(Fr.fromString(address)));
99
- return [
100
- instance.salt,
101
- instance.deployer,
102
- instance.currentContractClassId,
103
- instance.initializationHash,
104
- ...instance.publicKeys.toFields()
105
- ].map(toACVMField);
106
- }
107
- async utilityGetMembershipWitness([blockNumber], [treeId], [leafValue]) {
108
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
109
- const parsedTreeId = Fr.fromString(treeId).toNumber();
110
- const parsedLeafValue = Fr.fromString(leafValue);
111
- const witness = await this.handlerAsUtility().utilityGetMembershipWitness(BlockNumber(parsedBlockNumber), parsedTreeId, parsedLeafValue);
112
- if (!witness) {
113
- throw new Error(`Leaf ${leafValue} not found in the tree ${MerkleTreeId[parsedTreeId]} at block ${parsedBlockNumber}.`);
114
- }
115
- return [
116
- toACVMField(witness[0]),
117
- witness.slice(1).map(toACVMField)
118
- ];
142
+ // eslint-disable-next-line camelcase
143
+ aztec_utl_getUtilityContext() {
144
+ return callHandler({
145
+ oracle: 'aztec_utl_getUtilityContext',
146
+ inputs: [],
147
+ handler: ()=>this.handlerAsUtility().getUtilityContext()
148
+ });
119
149
  }
120
- async utilityGetNullifierMembershipWitness([blockNumber], [nullifier]) {
121
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
122
- const parsedNullifier = Fr.fromString(nullifier);
123
- const witness = await this.handlerAsUtility().utilityGetNullifierMembershipWitness(BlockNumber(parsedBlockNumber), parsedNullifier);
124
- if (!witness) {
125
- throw new Error(`Nullifier witness not found for nullifier ${parsedNullifier} at block ${parsedBlockNumber}.`);
126
- }
127
- return witness.toNoirRepresentation();
128
- }
129
- async utilityGetLowNullifierMembershipWitness([blockNumber], [nullifier]) {
130
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
131
- const parsedNullifier = Fr.fromString(nullifier);
132
- const witness = await this.handlerAsUtility().utilityGetLowNullifierMembershipWitness(BlockNumber(parsedBlockNumber), parsedNullifier);
133
- if (!witness) {
134
- throw new Error(`Low nullifier witness not found for nullifier ${parsedNullifier} at block ${parsedBlockNumber}.`);
135
- }
136
- return witness.toNoirRepresentation();
137
- }
138
- async utilityGetPublicDataWitness([blockNumber], [leafSlot]) {
139
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
140
- const parsedLeafSlot = Fr.fromString(leafSlot);
141
- const witness = await this.handlerAsUtility().utilityGetPublicDataWitness(BlockNumber(parsedBlockNumber), parsedLeafSlot);
142
- if (!witness) {
143
- throw new Error(`Public data witness not found for slot ${parsedLeafSlot} at block ${parsedBlockNumber}.`);
144
- }
145
- return witness.toNoirRepresentation();
150
+ // eslint-disable-next-line camelcase
151
+ aztec_utl_getKeyValidationRequest(...inputs) {
152
+ return callHandler({
153
+ oracle: 'aztec_utl_getKeyValidationRequest',
154
+ inputs,
155
+ handler: ([pkMHash])=>this.handlerAsUtility().getKeyValidationRequest(pkMHash)
156
+ });
146
157
  }
147
- async utilityGetBlockHeader([blockNumber]) {
148
- const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
149
- const header = await this.handlerAsUtility().utilityGetBlockHeader(BlockNumber(parsedBlockNumber));
150
- if (!header) {
151
- throw new Error(`Block header not found for block ${parsedBlockNumber}.`);
152
- }
153
- return header.toFields().map(toACVMField);
158
+ // eslint-disable-next-line camelcase
159
+ aztec_utl_getContractInstance(...inputs) {
160
+ return callHandler({
161
+ oracle: 'aztec_utl_getContractInstance',
162
+ inputs,
163
+ handler: ([address])=>this.handlerAsUtility().getContractInstance(address)
164
+ });
154
165
  }
155
- async utilityGetAuthWitness([messageHash]) {
156
- const messageHashField = Fr.fromString(messageHash);
157
- const witness = await this.handlerAsUtility().utilityGetAuthWitness(messageHashField);
158
- if (!witness) {
159
- throw new Error(`Unknown auth witness for message hash ${messageHashField}`);
160
- }
161
- return [
162
- witness.map(toACVMField)
163
- ];
166
+ // eslint-disable-next-line camelcase
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
+ });
164
173
  }
165
- async utilityGetPublicKeysAndPartialAddress([address]) {
166
- const parsedAddress = AztecAddress.fromField(Fr.fromString(address));
167
- const { publicKeys, partialAddress } = await this.handlerAsUtility().utilityGetPublicKeysAndPartialAddress(parsedAddress);
168
- return [
169
- [
170
- ...publicKeys.toFields(),
171
- partialAddress
172
- ].map(toACVMField)
173
- ];
174
+ // eslint-disable-next-line camelcase
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
+ });
174
181
  }
175
- async utilityGetNotes([ownerSome], [ownerValue], [storageSlot], [numSelects], selectByIndexes, selectByOffsets, selectByLengths, selectValues, selectComparators, sortByIndexes, sortByOffsets, sortByLengths, sortOrder, [limit], [offset], [status], [maxNotes], [packedRetrievedNoteLength]) {
176
- // Parse Option<AztecAddress>: ownerSome is 0 for None, 1 for Some
177
- const owner = Fr.fromString(ownerSome).toNumber() === 1 ? AztecAddress.fromString(ownerValue) : undefined;
178
- const noteDatas = await this.handlerAsUtility().utilityGetNotes(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);
179
- const returnDataAsArrayOfPackedRetrievedNotes = noteDatas.map((noteData)=>packAsRetrievedNote({
180
- contractAddress: noteData.contractAddress,
181
- owner: noteData.owner,
182
- randomness: noteData.randomness,
183
- storageSlot: noteData.storageSlot,
184
- noteNonce: noteData.noteNonce,
185
- index: noteData.index,
186
- note: noteData.note
187
- }));
188
- // Now we convert each sub-array to an array of ACVMField
189
- const returnDataAsArrayOfACVMFieldArrays = returnDataAsArrayOfPackedRetrievedNotes.map((subArray)=>subArray.map(toACVMField));
190
- // At last we convert the array of arrays to a bounded vec of arrays
191
- return arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfACVMFieldArrays, +maxNotes, +packedRetrievedNoteLength);
192
- }
193
- privateNotifyCreatedNote([owner], [storageSlot], [randomness], [noteTypeId], note, [noteHash], [counter]) {
194
- this.handlerAsPrivate().privateNotifyCreatedNote(AztecAddress.fromString(owner), Fr.fromString(storageSlot), Fr.fromString(randomness), NoteSelector.fromField(Fr.fromString(noteTypeId)), note.map(Fr.fromString), Fr.fromString(noteHash), +counter);
195
- return Promise.resolve([]);
196
- }
197
- async privateNotifyNullifiedNote([innerNullifier], [noteHash], [counter]) {
198
- await this.handlerAsPrivate().privateNotifyNullifiedNote(Fr.fromString(innerNullifier), Fr.fromString(noteHash), +counter);
199
- return [];
200
- }
201
- async privateNotifyCreatedNullifier([innerNullifier]) {
202
- await this.handlerAsPrivate().privateNotifyCreatedNullifier(Fr.fromString(innerNullifier));
203
- return [];
204
- }
205
- async utilityCheckNullifierExists([innerNullifier]) {
206
- const exists = await this.handlerAsUtility().utilityCheckNullifierExists(Fr.fromString(innerNullifier));
207
- return [
208
- toACVMField(exists)
209
- ];
182
+ // eslint-disable-next-line camelcase
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
+ });
210
189
  }
211
- async utilityGetL1ToL2MembershipWitness([contractAddress], [messageHash], [secret]) {
212
- const message = await this.handlerAsUtility().utilityGetL1ToL2MembershipWitness(AztecAddress.fromString(contractAddress), Fr.fromString(messageHash), Fr.fromString(secret));
213
- return message.toNoirRepresentation();
190
+ // eslint-disable-next-line camelcase
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
+ });
214
197
  }
215
- async utilityStorageRead([contractAddress], [startStorageSlot], [blockNumber], [numberOfElements]) {
216
- const values = await this.handlerAsUtility().utilityStorageRead(new AztecAddress(Fr.fromString(contractAddress)), Fr.fromString(startStorageSlot), BlockNumber(+blockNumber), +numberOfElements);
217
- return [
218
- values.map(toACVMField)
219
- ];
198
+ // eslint-disable-next-line camelcase
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
+ });
220
205
  }
221
- privateNotifyCreatedContractClassLog([contractAddress], message, [length], [counter]) {
222
- const logFields = new ContractClassLogFields(message.map(Fr.fromString));
223
- const log = new ContractClassLog(new AztecAddress(Fr.fromString(contractAddress)), logFields, +length);
224
- this.handlerAsPrivate().privateNotifyCreatedContractClassLog(log, +counter);
225
- return Promise.resolve([]);
206
+ // eslint-disable-next-line camelcase
207
+ aztec_utl_getBlockHeader(...inputs) {
208
+ return callHandler({
209
+ oracle: 'aztec_utl_getBlockHeader',
210
+ inputs,
211
+ handler: ([blockNumber])=>this.handlerAsUtility().getBlockHeader(blockNumber)
212
+ });
213
+ }
214
+ // eslint-disable-next-line camelcase
215
+ aztec_utl_getAuthWitness(...inputs) {
216
+ return callHandler({
217
+ oracle: 'aztec_utl_getAuthWitness',
218
+ inputs,
219
+ handler: ([messageHash])=>this.handlerAsUtility().getAuthWitness(messageHash)
220
+ });
221
+ }
222
+ // eslint-disable-next-line camelcase
223
+ aztec_utl_getPublicKeysAndPartialAddress(...inputs) {
224
+ return callHandler({
225
+ oracle: 'aztec_utl_getPublicKeysAndPartialAddress',
226
+ inputs,
227
+ handler: ([address])=>this.handlerAsUtility().getPublicKeysAndPartialAddress(address)
228
+ });
229
+ }
230
+ // eslint-disable-next-line camelcase
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
+ });
237
+ }
238
+ // eslint-disable-next-line camelcase
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
+ });
247
+ }
248
+ // eslint-disable-next-line camelcase
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
+ });
255
+ }
256
+ // eslint-disable-next-line camelcase
257
+ aztec_prv_notifyCreatedNullifier(...inputs) {
258
+ return callHandler({
259
+ oracle: 'aztec_prv_notifyCreatedNullifier',
260
+ inputs,
261
+ handler: ([innerNullifier])=>this.handlerAsPrivate().notifyCreatedNullifier(innerNullifier)
262
+ });
226
263
  }
227
- utilityDebugLog(level, message, _ignoredFieldsSize, fields) {
228
- const levelFr = Fr.fromString(level[0]);
229
- const messageStr = message.map((acvmField)=>String.fromCharCode(Fr.fromString(acvmField).toNumber())).join('');
230
- const fieldsFr = fields.map(Fr.fromString);
231
- this.handlerAsMisc().utilityDebugLog(levelFr.toNumber(), messageStr, fieldsFr);
232
- return Promise.resolve([]);
264
+ // eslint-disable-next-line camelcase
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
+ });
271
+ }
272
+ // eslint-disable-next-line camelcase
273
+ aztec_utl_doesNullifierExist(...inputs) {
274
+ return callHandler({
275
+ oracle: 'aztec_utl_doesNullifierExist',
276
+ inputs,
277
+ handler: ([innerNullifier])=>this.handlerAsUtility().doesNullifierExist(innerNullifier)
278
+ });
279
+ }
280
+ // eslint-disable-next-line camelcase
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
+ });
287
+ }
288
+ // eslint-disable-next-line camelcase
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
+ });
303
+ }
304
+ // eslint-disable-next-line camelcase
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
+ });
313
+ }
314
+ // eslint-disable-next-line camelcase
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
+ });
233
321
  }
234
322
  // This function's name is directly hardcoded in `circuit_recorder.ts`. Don't forget to update it there if you
235
323
  // change the name here.
236
- async privateCallPrivateFunction([contractAddress], [functionSelector], [argsHash], [sideEffectCounter], [isStaticCall]) {
237
- const { endSideEffectCounter, returnsHash } = await this.handlerAsPrivate().privateCallPrivateFunction(AztecAddress.fromField(Fr.fromString(contractAddress)), FunctionSelector.fromField(Fr.fromString(functionSelector)), Fr.fromString(argsHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
238
- return [
239
- [
240
- endSideEffectCounter,
241
- returnsHash
242
- ].map(toACVMField)
243
- ];
324
+ // eslint-disable-next-line camelcase
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
+ });
244
331
  }
245
- async privateNotifyEnqueuedPublicFunctionCall([contractAddress], [calldataHash], [sideEffectCounter], [isStaticCall]) {
246
- await this.handlerAsPrivate().privateNotifyEnqueuedPublicFunctionCall(AztecAddress.fromString(contractAddress), Fr.fromString(calldataHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
247
- return [];
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
+ });
248
339
  }
249
- async privateNotifySetPublicTeardownFunctionCall([contractAddress], [calldataHash], [sideEffectCounter], [isStaticCall]) {
250
- await this.handlerAsPrivate().privateNotifySetPublicTeardownFunctionCall(AztecAddress.fromString(contractAddress), Fr.fromString(calldataHash), Fr.fromString(sideEffectCounter).toNumber(), Fr.fromString(isStaticCall).toBool());
251
- return [];
340
+ // eslint-disable-next-line camelcase
341
+ aztec_prv_notifyRevertiblePhaseStart(...inputs) {
342
+ return callHandler({
343
+ oracle: 'aztec_prv_notifyRevertiblePhaseStart',
344
+ inputs,
345
+ handler: ([minRevertibleSideEffectCounter])=>this.handlerAsPrivate().notifyRevertiblePhaseStart(minRevertibleSideEffectCounter)
346
+ });
252
347
  }
253
- async privateNotifySetMinRevertibleSideEffectCounter([minRevertibleSideEffectCounter]) {
254
- await this.handlerAsPrivate().privateNotifySetMinRevertibleSideEffectCounter(Fr.fromString(minRevertibleSideEffectCounter).toNumber());
255
- return Promise.resolve([]);
348
+ // eslint-disable-next-line camelcase
349
+ aztec_prv_isExecutionInRevertiblePhase(...inputs) {
350
+ return callHandler({
351
+ oracle: 'aztec_prv_isExecutionInRevertiblePhase',
352
+ inputs,
353
+ handler: ([sideEffectCounter])=>this.handlerAsPrivate().isExecutionInRevertiblePhase(sideEffectCounter)
354
+ });
256
355
  }
257
- async privateIsSideEffectCounterRevertible([sideEffectCounter]) {
258
- const isRevertible = await this.handlerAsPrivate().privateIsSideEffectCounterRevertible(Fr.fromString(sideEffectCounter).toNumber());
259
- return Promise.resolve([
260
- toACVMField(isRevertible)
261
- ]);
356
+ // eslint-disable-next-line camelcase
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
+ });
262
363
  }
263
- async privateGetNextAppTagAsSender([sender], [recipient]) {
264
- const tag = await this.handlerAsPrivate().privateGetNextAppTagAsSender(AztecAddress.fromString(sender), AztecAddress.fromString(recipient));
265
- return [
266
- toACVMField(tag.value)
267
- ];
364
+ // eslint-disable-next-line camelcase
365
+ aztec_prv_getNextConstrainedTaggingIndex(...inputs) {
366
+ return callHandler({
367
+ oracle: 'aztec_prv_getNextConstrainedTaggingIndex',
368
+ inputs,
369
+ handler: ([appSiloedSecret])=>this.handlerAsPrivate().getNextConstrainedTaggingIndex(appSiloedSecret)
370
+ });
268
371
  }
269
- async utilityFetchTaggedLogs([pendingTaggedLogArrayBaseSlot]) {
270
- await this.handlerAsUtility().utilityFetchTaggedLogs(Fr.fromString(pendingTaggedLogArrayBaseSlot));
271
- return [];
272
- }
273
- async utilityValidateEnqueuedNotesAndEvents([contractAddress], [noteValidationRequestsArrayBaseSlot], [eventValidationRequestsArrayBaseSlot]) {
274
- await this.handlerAsUtility().utilityValidateEnqueuedNotesAndEvents(AztecAddress.fromString(contractAddress), Fr.fromString(noteValidationRequestsArrayBaseSlot), Fr.fromString(eventValidationRequestsArrayBaseSlot));
275
- return [];
276
- }
277
- async utilityBulkRetrieveLogs([contractAddress], [logRetrievalRequestsArrayBaseSlot], [logRetrievalResponsesArrayBaseSlot]) {
278
- await this.handlerAsUtility().utilityBulkRetrieveLogs(AztecAddress.fromString(contractAddress), Fr.fromString(logRetrievalRequestsArrayBaseSlot), Fr.fromString(logRetrievalResponsesArrayBaseSlot));
279
- return [];
280
- }
281
- async utilityStoreCapsule([contractAddress], [slot], capsule) {
282
- await this.handlerAsUtility().utilityStoreCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot), capsule.map(Fr.fromString));
283
- return [];
284
- }
285
- async utilityLoadCapsule([contractAddress], [slot], [tSize]) {
286
- const values = await this.handlerAsUtility().utilityLoadCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
287
- // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
288
- // with two fields: `some` (a boolean) and `value` (a field array in this case).
289
- if (values === null) {
290
- // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
291
- return [
292
- toACVMField(0),
293
- Array(Fr.fromString(tSize).toNumber()).fill(toACVMField(0))
294
- ];
295
- } else {
296
- // Data was found so we set `some` to 1 and return it along with `value`.
297
- return [
298
- toACVMField(1),
299
- values.map(toACVMField)
300
- ];
301
- }
372
+ // eslint-disable-next-line camelcase
373
+ aztec_utl_getPendingTaggedLogs(...inputs) {
374
+ return callHandler({
375
+ oracle: 'aztec_utl_getPendingTaggedLogs',
376
+ inputs,
377
+ handler: ([scope])=>this.handlerAsUtility().getPendingTaggedLogs(scope)
378
+ });
302
379
  }
303
- async utilityDeleteCapsule([contractAddress], [slot]) {
304
- await this.handlerAsUtility().utilityDeleteCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(slot));
305
- return [];
306
- }
307
- async utilityCopyCapsule([contractAddress], [srcSlot], [dstSlot], [numEntries]) {
308
- await this.handlerAsUtility().utilityCopyCapsule(AztecAddress.fromField(Fr.fromString(contractAddress)), Fr.fromString(srcSlot), Fr.fromString(dstSlot), Fr.fromString(numEntries).toNumber());
309
- return [];
310
- }
311
- async utilityAes128Decrypt(ciphertextBVecStorage, [ciphertextLength], iv, symKey) {
312
- const ciphertext = fromUintBoundedVec(ciphertextBVecStorage, ciphertextLength, 8);
313
- const ivBuffer = fromUintArray(iv, 8);
314
- const symKeyBuffer = fromUintArray(symKey, 8);
315
- const plaintext = await this.handlerAsUtility().utilityAes128Decrypt(ciphertext, ivBuffer, symKeyBuffer);
316
- return bufferToBoundedVec(plaintext, ciphertextBVecStorage.length);
317
- }
318
- async utilityGetSharedSecret([address], [ephPKField0], [ephPKField1], [ephPKField2]) {
319
- const secret = await this.handlerAsUtility().utilityGetSharedSecret(AztecAddress.fromField(Fr.fromString(address)), Point.fromFields([
320
- ephPKField0,
321
- ephPKField1,
322
- ephPKField2
323
- ].map(Fr.fromString)));
324
- return secret.toFields().map(toACVMField);
325
- }
326
- async utilityEmitOffchainEffect(data) {
327
- await this.handlerAsPrivate().utilityEmitOffchainEffect(data.map(Fr.fromString));
328
- return [];
329
- }
330
- async privateGetSenderForTags() {
331
- const sender = await this.handlerAsPrivate().privateGetSenderForTags();
332
- // Return [1, address] for Some(address), [0, 0] for None
333
- return sender ? [
334
- toACVMField(1n),
335
- toACVMField(sender)
336
- ] : [
337
- toACVMField(0n),
338
- toACVMField(0n)
339
- ];
380
+ // eslint-disable-next-line camelcase
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
+ });
387
+ }
388
+ // eslint-disable-next-line camelcase
389
+ aztec_utl_getLogsByTag(...inputs) {
390
+ return callHandler({
391
+ oracle: 'aztec_utl_getLogsByTag',
392
+ inputs,
393
+ handler: ([requestArrayBaseSlot])=>this.handlerAsUtility().getLogsByTag(requestArrayBaseSlot)
394
+ });
395
+ }
396
+ // eslint-disable-next-line camelcase
397
+ aztec_utl_getMessageContextsByTxHash(...inputs) {
398
+ return callHandler({
399
+ oracle: 'aztec_utl_getMessageContextsByTxHash',
400
+ inputs,
401
+ handler: ([requestArrayBaseSlot])=>this.handlerAsUtility().getMessageContextsByTxHash(requestArrayBaseSlot)
402
+ });
403
+ }
404
+ // eslint-disable-next-line camelcase
405
+ aztec_utl_getTxEffect(...inputs) {
406
+ return callHandler({
407
+ oracle: 'aztec_utl_getTxEffect',
408
+ inputs,
409
+ handler: ([txHash])=>this.handlerAsUtility().getTxEffect(txHash)
410
+ });
411
+ }
412
+ // eslint-disable-next-line camelcase
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
+ });
421
+ }
422
+ // eslint-disable-next-line camelcase
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
+ });
429
+ }
430
+ // eslint-disable-next-line camelcase
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
+ });
439
+ }
440
+ // eslint-disable-next-line camelcase
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
+ });
340
447
  }
341
- async privateSetSenderForTags([senderForTags]) {
342
- await this.handlerAsPrivate().privateSetSenderForTags(AztecAddress.fromField(Fr.fromString(senderForTags)));
343
- return [];
448
+ // eslint-disable-next-line camelcase
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
+ });
455
+ }
456
+ // eslint-disable-next-line camelcase
457
+ aztec_utl_popEphemeral(...inputs) {
458
+ return callHandler({
459
+ oracle: 'aztec_utl_popEphemeral',
460
+ inputs,
461
+ handler: ([slot])=>this.handlerAsUtility().popEphemeral(slot)
462
+ });
463
+ }
464
+ // eslint-disable-next-line camelcase
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
+ });
481
+ }
482
+ // eslint-disable-next-line camelcase
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
+ });
344
551
  }
345
552
  }