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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (491) hide show
  1. package/README.md +5 -5
  2. package/dest/access_scopes.d.ts +9 -0
  3. package/dest/access_scopes.d.ts.map +1 -0
  4. package/dest/access_scopes.js +6 -0
  5. package/dest/bin/check_oracle_version.d.ts +2 -0
  6. package/dest/bin/check_oracle_version.d.ts.map +1 -0
  7. package/dest/bin/check_oracle_version.js +129 -0
  8. package/dest/block_synchronizer/block_synchronizer.d.ts +45 -0
  9. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -0
  10. package/dest/block_synchronizer/block_synchronizer.js +153 -0
  11. package/dest/block_synchronizer/index.d.ts +2 -0
  12. package/dest/block_synchronizer/index.d.ts.map +1 -0
  13. package/dest/block_synchronizer/index.js +1 -0
  14. package/dest/config/index.d.ts +14 -25
  15. package/dest/config/index.d.ts.map +1 -1
  16. package/dest/config/index.js +36 -34
  17. package/dest/config/package_info.d.ts +1 -1
  18. package/dest/config/package_info.js +1 -1
  19. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  20. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  21. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  22. package/dest/contract_function_simulator/contract_function_simulator.d.ts +114 -0
  23. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -0
  24. package/dest/contract_function_simulator/contract_function_simulator.js +459 -0
  25. package/dest/contract_function_simulator/execution_note_cache.d.ts +104 -0
  26. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -0
  27. package/dest/contract_function_simulator/execution_note_cache.js +208 -0
  28. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +16 -0
  29. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -0
  30. package/dest/contract_function_simulator/execution_tagging_index_cache.js +34 -0
  31. package/dest/contract_function_simulator/hashed_values_cache.d.ts +28 -0
  32. package/dest/contract_function_simulator/hashed_values_cache.d.ts.map +1 -0
  33. package/dest/contract_function_simulator/hashed_values_cache.js +36 -0
  34. package/dest/contract_function_simulator/index.d.ts +15 -0
  35. package/dest/contract_function_simulator/index.d.ts.map +1 -0
  36. package/dest/contract_function_simulator/index.js +13 -0
  37. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +20 -0
  38. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -0
  39. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +41 -0
  40. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts +16 -0
  41. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.d.ts.map +1 -0
  42. package/dest/contract_function_simulator/noir-structs/log_retrieval_request.js +26 -0
  43. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts +17 -0
  44. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.d.ts.map +1 -0
  45. package/dest/contract_function_simulator/noir-structs/log_retrieval_response.js +63 -0
  46. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts +16 -0
  47. package/dest/contract_function_simulator/noir-structs/message_tx_context.d.ts.map +1 -0
  48. package/dest/contract_function_simulator/noir-structs/message_tx_context.js +57 -0
  49. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +22 -0
  50. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -0
  51. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +49 -0
  52. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +16 -0
  53. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -0
  54. package/dest/contract_function_simulator/noir-structs/utility_context.js +22 -0
  55. package/dest/contract_function_simulator/oracle/index.d.ts +14 -0
  56. package/dest/contract_function_simulator/oracle/index.d.ts.map +1 -0
  57. package/dest/contract_function_simulator/oracle/index.js +2 -0
  58. package/dest/contract_function_simulator/oracle/interfaces.d.ts +111 -0
  59. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -0
  60. package/dest/contract_function_simulator/oracle/interfaces.js +4 -0
  61. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts +9 -0
  62. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.d.ts.map +1 -0
  63. package/dest/contract_function_simulator/oracle/legacy_oracle_mappings.js +43 -0
  64. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +19 -0
  65. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -0
  66. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.js +24 -0
  67. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +28 -0
  68. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -0
  69. package/dest/contract_function_simulator/oracle/note_packing_utils.js +54 -0
  70. package/dest/contract_function_simulator/oracle/oracle.d.ts +60 -0
  71. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -0
  72. package/dest/contract_function_simulator/oracle/oracle.js +417 -0
  73. package/dest/contract_function_simulator/oracle/private_execution.d.ts +23 -0
  74. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -0
  75. package/dest/contract_function_simulator/oracle/private_execution.js +89 -0
  76. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +218 -0
  77. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -0
  78. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +441 -0
  79. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +239 -0
  80. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -0
  81. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +440 -0
  82. package/dest/contract_function_simulator/pick_notes.d.ts +85 -0
  83. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -0
  84. package/dest/contract_function_simulator/pick_notes.js +51 -0
  85. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +6 -0
  86. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -0
  87. package/dest/contract_function_simulator/proxied_contract_data_source.js +80 -0
  88. package/dest/contract_logging.d.ts +22 -0
  89. package/dest/contract_logging.d.ts.map +1 -0
  90. package/dest/contract_logging.js +23 -0
  91. package/dest/contract_sync/contract_sync_service.d.ts +43 -0
  92. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  93. package/dest/contract_sync/contract_sync_service.js +97 -0
  94. package/dest/contract_sync/helpers.d.ts +29 -0
  95. package/dest/contract_sync/helpers.d.ts.map +1 -0
  96. package/dest/contract_sync/helpers.js +55 -0
  97. package/dest/debug/pxe_debug_utils.d.ts +45 -0
  98. package/dest/debug/pxe_debug_utils.d.ts.map +1 -0
  99. package/dest/debug/pxe_debug_utils.js +48 -0
  100. package/dest/entrypoints/client/bundle/index.d.ts +7 -3
  101. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  102. package/dest/entrypoints/client/bundle/index.js +5 -2
  103. package/dest/entrypoints/client/bundle/utils.d.ts +10 -10
  104. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  105. package/dest/entrypoints/client/bundle/utils.js +41 -12
  106. package/dest/entrypoints/client/lazy/index.d.ts +7 -3
  107. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  108. package/dest/entrypoints/client/lazy/index.js +5 -2
  109. package/dest/entrypoints/client/lazy/utils.d.ts +10 -10
  110. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  111. package/dest/entrypoints/client/lazy/utils.js +41 -12
  112. package/dest/entrypoints/pxe_creation_options.d.ts +18 -0
  113. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -0
  114. package/dest/entrypoints/server/index.d.ts +10 -4
  115. package/dest/entrypoints/server/index.d.ts.map +1 -1
  116. package/dest/entrypoints/server/index.js +8 -3
  117. package/dest/entrypoints/server/utils.d.ts +8 -16
  118. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  119. package/dest/entrypoints/server/utils.js +54 -36
  120. package/dest/error_enriching.d.ts +11 -0
  121. package/dest/error_enriching.d.ts.map +1 -0
  122. package/dest/{pxe_service/error_enriching.js → error_enriching.js} +30 -22
  123. package/dest/events/event_service.d.ts +15 -0
  124. package/dest/events/event_service.d.ts.map +1 -0
  125. package/dest/events/event_service.js +44 -0
  126. package/dest/events/index.d.ts +2 -0
  127. package/dest/events/index.d.ts.map +1 -0
  128. package/dest/events/index.js +1 -0
  129. package/dest/events/private_event_filter_validator.d.ts +9 -0
  130. package/dest/events/private_event_filter_validator.d.ts.map +1 -0
  131. package/dest/events/private_event_filter_validator.js +38 -0
  132. package/dest/job_coordinator/job_coordinator.d.ts +75 -0
  133. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
  134. package/dest/job_coordinator/job_coordinator.js +94 -0
  135. package/dest/logs/log_service.d.ts +29 -0
  136. package/dest/logs/log_service.d.ts.map +1 -0
  137. package/dest/logs/log_service.js +118 -0
  138. package/dest/messages/message_context_service.d.ts +17 -0
  139. package/dest/messages/message_context_service.d.ts.map +1 -0
  140. package/dest/messages/message_context_service.js +36 -0
  141. package/dest/notes/index.d.ts +2 -0
  142. package/dest/notes/index.d.ts.map +1 -0
  143. package/dest/notes/index.js +1 -0
  144. package/dest/notes/note_service.d.ts +49 -0
  145. package/dest/notes/note_service.d.ts.map +1 -0
  146. package/dest/notes/note_service.js +148 -0
  147. package/dest/notes_filter.d.ts +25 -0
  148. package/dest/notes_filter.d.ts.map +1 -0
  149. package/dest/notes_filter.js +4 -0
  150. package/dest/oracle_version.d.ts +3 -0
  151. package/dest/oracle_version.d.ts.map +1 -0
  152. package/dest/oracle_version.js +11 -0
  153. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  154. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  155. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.js +41 -0
  156. package/dest/private_kernel/hints/index.d.ts +3 -0
  157. package/dest/private_kernel/hints/index.d.ts.map +1 -0
  158. package/dest/private_kernel/hints/index.js +2 -0
  159. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  160. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  161. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +338 -0
  162. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  163. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  164. package/dest/private_kernel/hints/test_utils.js +203 -0
  165. package/dest/private_kernel/index.d.ts +3 -0
  166. package/dest/private_kernel/index.d.ts.map +1 -0
  167. package/dest/private_kernel/index.js +2 -0
  168. package/dest/private_kernel/private_kernel_execution_prover.d.ts +45 -0
  169. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -0
  170. package/dest/private_kernel/private_kernel_execution_prover.js +293 -0
  171. package/dest/private_kernel/private_kernel_oracle.d.ts +63 -0
  172. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -0
  173. package/dest/private_kernel/private_kernel_oracle.js +96 -0
  174. package/dest/pxe.d.ts +254 -0
  175. package/dest/pxe.d.ts.map +1 -0
  176. package/dest/pxe.js +788 -0
  177. package/dest/storage/address_store/address_store.d.ts +11 -0
  178. package/dest/storage/address_store/address_store.d.ts.map +1 -0
  179. package/dest/storage/{address_data_provider/address_data_provider.js → address_store/address_store.js} +13 -15
  180. package/dest/storage/address_store/index.d.ts +2 -0
  181. package/dest/storage/address_store/index.d.ts.map +1 -0
  182. package/dest/storage/address_store/index.js +1 -0
  183. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +17 -0
  184. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -0
  185. package/dest/storage/anchor_block_store/anchor_block_store.js +26 -0
  186. package/dest/storage/anchor_block_store/index.d.ts +2 -0
  187. package/dest/storage/anchor_block_store/index.d.ts.map +1 -0
  188. package/dest/storage/anchor_block_store/index.js +1 -0
  189. package/dest/storage/capsule_store/capsule_store.d.ts +72 -0
  190. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -0
  191. package/dest/storage/capsule_store/capsule_store.js +253 -0
  192. package/dest/storage/capsule_store/index.d.ts +2 -0
  193. package/dest/storage/capsule_store/index.d.ts.map +1 -0
  194. package/dest/storage/capsule_store/index.js +1 -0
  195. package/dest/storage/contract_store/contract_store.d.ts +93 -0
  196. package/dest/storage/contract_store/contract_store.d.ts.map +1 -0
  197. package/dest/storage/contract_store/contract_store.js +309 -0
  198. package/dest/storage/contract_store/index.d.ts +2 -0
  199. package/dest/storage/contract_store/index.d.ts.map +1 -0
  200. package/dest/storage/contract_store/index.js +1 -0
  201. package/dest/storage/contract_store/private_functions_tree.d.ts +27 -0
  202. package/dest/storage/contract_store/private_functions_tree.d.ts.map +1 -0
  203. package/dest/storage/contract_store/private_functions_tree.js +47 -0
  204. package/dest/storage/index.d.ts +9 -10
  205. package/dest/storage/index.d.ts.map +1 -1
  206. package/dest/storage/index.js +8 -9
  207. package/dest/storage/metadata.d.ts +2 -0
  208. package/dest/storage/metadata.d.ts.map +1 -0
  209. package/dest/storage/metadata.js +1 -0
  210. package/dest/storage/note_store/index.d.ts +3 -0
  211. package/dest/storage/note_store/index.d.ts.map +1 -0
  212. package/dest/storage/note_store/index.js +2 -0
  213. package/dest/storage/note_store/note_store.d.ts +83 -0
  214. package/dest/storage/note_store/note_store.d.ts.map +1 -0
  215. package/dest/storage/note_store/note_store.js +343 -0
  216. package/dest/storage/note_store/stored_note.d.ts +16 -0
  217. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  218. package/dest/storage/note_store/stored_note.js +43 -0
  219. package/dest/storage/private_event_store/private_event_store.d.ts +91 -0
  220. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -0
  221. package/dest/storage/private_event_store/private_event_store.js +273 -0
  222. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  223. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  224. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  225. package/dest/storage/tagging_store/index.d.ts +4 -0
  226. package/dest/storage/tagging_store/index.d.ts.map +1 -0
  227. package/dest/storage/tagging_store/index.js +3 -0
  228. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +28 -0
  229. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -0
  230. package/dest/storage/tagging_store/recipient_tagging_store.js +111 -0
  231. package/dest/storage/tagging_store/sender_address_book_store.d.ts +14 -0
  232. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -0
  233. package/dest/storage/tagging_store/sender_address_book_store.js +36 -0
  234. package/dest/storage/tagging_store/sender_tagging_store.d.ts +78 -0
  235. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -0
  236. package/dest/storage/tagging_store/sender_tagging_store.js +374 -0
  237. package/dest/tagging/constants.d.ts +2 -0
  238. package/dest/tagging/constants.d.ts.map +1 -0
  239. package/dest/tagging/constants.js +10 -0
  240. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  241. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  242. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  243. package/dest/tagging/index.d.ts +17 -0
  244. package/dest/tagging/index.d.ts.map +1 -0
  245. package/dest/tagging/index.js +15 -0
  246. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +14 -0
  247. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -0
  248. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +99 -0
  249. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +12 -0
  250. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -0
  251. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +20 -0
  252. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +14 -0
  253. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -0
  254. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +33 -0
  255. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +17 -0
  256. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -0
  257. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +80 -0
  258. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +12 -0
  259. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -0
  260. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +39 -0
  261. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +19 -0
  262. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -0
  263. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +72 -0
  264. package/package.json +46 -34
  265. package/src/access_scopes.ts +9 -0
  266. package/src/bin/check_oracle_version.ts +161 -0
  267. package/src/block_synchronizer/block_synchronizer.ts +178 -0
  268. package/src/block_synchronizer/index.ts +1 -0
  269. package/src/config/index.ts +42 -56
  270. package/src/config/package_info.ts +1 -1
  271. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  272. package/src/contract_function_simulator/contract_function_simulator.ts +850 -0
  273. package/src/contract_function_simulator/execution_note_cache.ts +252 -0
  274. package/src/contract_function_simulator/execution_tagging_index_cache.ts +37 -0
  275. package/src/contract_function_simulator/hashed_values_cache.ts +47 -0
  276. package/src/contract_function_simulator/index.ts +14 -0
  277. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +54 -0
  278. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +28 -0
  279. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +66 -0
  280. package/src/contract_function_simulator/noir-structs/message_tx_context.ts +55 -0
  281. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +61 -0
  282. package/src/contract_function_simulator/noir-structs/utility_context.ts +23 -0
  283. package/src/contract_function_simulator/oracle/index.ts +16 -0
  284. package/src/contract_function_simulator/oracle/interfaces.ts +184 -0
  285. package/src/contract_function_simulator/oracle/legacy_oracle_mappings.ts +142 -0
  286. package/src/contract_function_simulator/oracle/message_load_oracle_inputs.ts +23 -0
  287. package/src/contract_function_simulator/oracle/note_packing_utils.ts +68 -0
  288. package/src/contract_function_simulator/oracle/oracle.ts +655 -0
  289. package/src/contract_function_simulator/oracle/private_execution.ts +141 -0
  290. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +649 -0
  291. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +685 -0
  292. package/src/contract_function_simulator/pick_notes.ts +141 -0
  293. package/src/contract_function_simulator/proxied_contract_data_source.ts +83 -0
  294. package/src/contract_logging.ts +39 -0
  295. package/src/contract_sync/contract_sync_service.ts +152 -0
  296. package/src/contract_sync/helpers.ts +98 -0
  297. package/src/debug/pxe_debug_utils.ts +93 -0
  298. package/src/entrypoints/client/bundle/index.ts +6 -2
  299. package/src/entrypoints/client/bundle/utils.ts +40 -33
  300. package/src/entrypoints/client/lazy/index.ts +6 -2
  301. package/src/entrypoints/client/lazy/utils.ts +41 -29
  302. package/src/entrypoints/pxe_creation_options.ts +14 -0
  303. package/src/entrypoints/server/index.ts +9 -3
  304. package/src/entrypoints/server/utils.ts +55 -55
  305. package/src/{pxe_service/error_enriching.ts → error_enriching.ts} +40 -39
  306. package/src/events/event_service.ts +71 -0
  307. package/src/events/index.ts +1 -0
  308. package/src/events/private_event_filter_validator.ts +46 -0
  309. package/src/job_coordinator/job_coordinator.ts +150 -0
  310. package/src/logs/log_service.ts +213 -0
  311. package/src/messages/message_context_service.ts +45 -0
  312. package/src/notes/index.ts +1 -0
  313. package/src/notes/note_service.ts +196 -0
  314. package/src/notes_filter.ts +26 -0
  315. package/src/oracle_version.ts +12 -0
  316. package/src/private_kernel/hints/compute_tx_expiration_timestamp.ts +58 -0
  317. package/src/private_kernel/hints/index.ts +2 -0
  318. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +542 -0
  319. package/src/private_kernel/hints/test_utils.ts +325 -0
  320. package/src/private_kernel/index.ts +2 -0
  321. package/src/private_kernel/private_kernel_execution_prover.ts +440 -0
  322. package/src/private_kernel/private_kernel_oracle.ts +152 -0
  323. package/src/pxe.ts +1170 -0
  324. package/src/storage/{address_data_provider/address_data_provider.ts → address_store/address_store.ts} +15 -21
  325. package/src/storage/address_store/index.ts +1 -0
  326. package/src/storage/{sync_data_provider/sync_data_provider.ts → anchor_block_store/anchor_block_store.ts} +10 -17
  327. package/src/storage/anchor_block_store/index.ts +1 -0
  328. package/src/storage/capsule_store/capsule_store.ts +315 -0
  329. package/src/storage/capsule_store/index.ts +1 -0
  330. package/src/storage/contract_store/contract_store.ts +429 -0
  331. package/src/storage/contract_store/index.ts +1 -0
  332. package/src/storage/contract_store/private_functions_tree.ts +67 -0
  333. package/src/storage/index.ts +8 -10
  334. package/src/storage/metadata.ts +1 -0
  335. package/src/storage/note_store/index.ts +2 -0
  336. package/src/storage/note_store/note_store.ts +418 -0
  337. package/src/storage/note_store/stored_note.ts +48 -0
  338. package/src/storage/private_event_store/private_event_store.ts +384 -0
  339. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  340. package/src/storage/tagging_store/index.ts +3 -0
  341. package/src/storage/tagging_store/recipient_tagging_store.ts +143 -0
  342. package/src/storage/tagging_store/sender_address_book_store.ts +48 -0
  343. package/src/storage/tagging_store/sender_tagging_store.ts +476 -0
  344. package/src/tagging/constants.ts +10 -0
  345. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  346. package/src/tagging/index.ts +19 -0
  347. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +140 -0
  348. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +34 -0
  349. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +44 -0
  350. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +112 -0
  351. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +51 -0
  352. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +85 -0
  353. package/dest/bin/index.d.ts +0 -3
  354. package/dest/bin/index.d.ts.map +0 -1
  355. package/dest/bin/index.js +0 -28
  356. package/dest/entrypoints/client/pxe_creation_options.d.ts +0 -11
  357. package/dest/entrypoints/client/pxe_creation_options.d.ts.map +0 -1
  358. package/dest/kernel_oracle/index.d.ts +0 -45
  359. package/dest/kernel_oracle/index.d.ts.map +0 -1
  360. package/dest/kernel_oracle/index.js +0 -76
  361. package/dest/kernel_prover/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  362. package/dest/kernel_prover/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  363. package/dest/kernel_prover/hints/build_private_kernel_reset_private_inputs.js +0 -270
  364. package/dest/kernel_prover/hints/index.d.ts +0 -2
  365. package/dest/kernel_prover/hints/index.d.ts.map +0 -1
  366. package/dest/kernel_prover/hints/index.js +0 -1
  367. package/dest/kernel_prover/index.d.ts +0 -3
  368. package/dest/kernel_prover/index.d.ts.map +0 -1
  369. package/dest/kernel_prover/index.js +0 -2
  370. package/dest/kernel_prover/kernel_prover.d.ts +0 -38
  371. package/dest/kernel_prover/kernel_prover.d.ts.map +0 -1
  372. package/dest/kernel_prover/kernel_prover.js +0 -217
  373. package/dest/kernel_prover/proving_data_oracle.d.ts +0 -73
  374. package/dest/kernel_prover/proving_data_oracle.d.ts.map +0 -1
  375. package/dest/kernel_prover/proving_data_oracle.js +0 -4
  376. package/dest/note_decryption_utils/add_public_values_to_payload.d.ts +0 -11
  377. package/dest/note_decryption_utils/add_public_values_to_payload.d.ts.map +0 -1
  378. package/dest/note_decryption_utils/add_public_values_to_payload.js +0 -47
  379. package/dest/pxe_http/index.d.ts +0 -2
  380. package/dest/pxe_http/index.d.ts.map +0 -1
  381. package/dest/pxe_http/index.js +0 -1
  382. package/dest/pxe_http/pxe_http_server.d.ts +0 -16
  383. package/dest/pxe_http/pxe_http_server.d.ts.map +0 -1
  384. package/dest/pxe_http/pxe_http_server.js +0 -27
  385. package/dest/pxe_oracle_interface/index.d.ts +0 -159
  386. package/dest/pxe_oracle_interface/index.d.ts.map +0 -1
  387. package/dest/pxe_oracle_interface/index.js +0 -692
  388. package/dest/pxe_oracle_interface/tagging_utils.d.ts +0 -17
  389. package/dest/pxe_oracle_interface/tagging_utils.d.ts.map +0 -1
  390. package/dest/pxe_oracle_interface/tagging_utils.js +0 -23
  391. package/dest/pxe_service/error_enriching.d.ts +0 -11
  392. package/dest/pxe_service/error_enriching.d.ts.map +0 -1
  393. package/dest/pxe_service/index.d.ts +0 -3
  394. package/dest/pxe_service/index.d.ts.map +0 -1
  395. package/dest/pxe_service/index.js +0 -2
  396. package/dest/pxe_service/pxe_service.d.ts +0 -111
  397. package/dest/pxe_service/pxe_service.d.ts.map +0 -1
  398. package/dest/pxe_service/pxe_service.js +0 -664
  399. package/dest/storage/address_data_provider/address_data_provider.d.ts +0 -13
  400. package/dest/storage/address_data_provider/address_data_provider.d.ts.map +0 -1
  401. package/dest/storage/address_data_provider/index.d.ts +0 -2
  402. package/dest/storage/address_data_provider/index.d.ts.map +0 -1
  403. package/dest/storage/address_data_provider/index.js +0 -1
  404. package/dest/storage/auth_witness_data_provider/auth_witness_data_provider.d.ts +0 -11
  405. package/dest/storage/auth_witness_data_provider/auth_witness_data_provider.d.ts.map +0 -1
  406. package/dest/storage/auth_witness_data_provider/auth_witness_data_provider.js +0 -20
  407. package/dest/storage/auth_witness_data_provider/index.d.ts +0 -2
  408. package/dest/storage/auth_witness_data_provider/index.d.ts.map +0 -1
  409. package/dest/storage/auth_witness_data_provider/index.js +0 -1
  410. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts +0 -16
  411. package/dest/storage/capsule_data_provider/capsule_data_provider.d.ts.map +0 -1
  412. package/dest/storage/capsule_data_provider/capsule_data_provider.js +0 -57
  413. package/dest/storage/capsule_data_provider/index.d.ts +0 -2
  414. package/dest/storage/capsule_data_provider/index.d.ts.map +0 -1
  415. package/dest/storage/capsule_data_provider/index.js +0 -1
  416. package/dest/storage/contract_data_provider/contract_data_provider.d.ts +0 -109
  417. package/dest/storage/contract_data_provider/contract_data_provider.d.ts.map +0 -1
  418. package/dest/storage/contract_data_provider/contract_data_provider.js +0 -183
  419. package/dest/storage/contract_data_provider/index.d.ts +0 -3
  420. package/dest/storage/contract_data_provider/index.d.ts.map +0 -1
  421. package/dest/storage/contract_data_provider/index.js +0 -2
  422. package/dest/storage/contract_data_provider/private_functions_tree.d.ts +0 -66
  423. package/dest/storage/contract_data_provider/private_functions_tree.d.ts.map +0 -1
  424. package/dest/storage/contract_data_provider/private_functions_tree.js +0 -99
  425. package/dest/storage/data_provider.d.ts +0 -4
  426. package/dest/storage/data_provider.d.ts.map +0 -1
  427. package/dest/storage/data_provider.js +0 -1
  428. package/dest/storage/note_data_provider/index.d.ts +0 -3
  429. package/dest/storage/note_data_provider/index.d.ts.map +0 -1
  430. package/dest/storage/note_data_provider/index.js +0 -2
  431. package/dest/storage/note_data_provider/note_dao.d.ts +0 -106
  432. package/dest/storage/note_data_provider/note_dao.d.ts.map +0 -1
  433. package/dest/storage/note_data_provider/note_dao.js +0 -106
  434. package/dest/storage/note_data_provider/note_data_provider.d.ts +0 -20
  435. package/dest/storage/note_data_provider/note_data_provider.d.ts.map +0 -1
  436. package/dest/storage/note_data_provider/note_data_provider.js +0 -249
  437. package/dest/storage/sync_data_provider/index.d.ts +0 -2
  438. package/dest/storage/sync_data_provider/index.d.ts.map +0 -1
  439. package/dest/storage/sync_data_provider/index.js +0 -1
  440. package/dest/storage/sync_data_provider/sync_data_provider.d.ts +0 -12
  441. package/dest/storage/sync_data_provider/sync_data_provider.d.ts.map +0 -1
  442. package/dest/storage/sync_data_provider/sync_data_provider.js +0 -29
  443. package/dest/storage/tagging_data_provider/index.d.ts +0 -2
  444. package/dest/storage/tagging_data_provider/index.d.ts.map +0 -1
  445. package/dest/storage/tagging_data_provider/index.js +0 -1
  446. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts +0 -18
  447. package/dest/storage/tagging_data_provider/tagging_data_provider.d.ts.map +0 -1
  448. package/dest/storage/tagging_data_provider/tagging_data_provider.js +0 -65
  449. package/dest/synchronizer/index.d.ts +0 -2
  450. package/dest/synchronizer/index.d.ts.map +0 -1
  451. package/dest/synchronizer/index.js +0 -1
  452. package/dest/synchronizer/synchronizer.d.ts +0 -37
  453. package/dest/synchronizer/synchronizer.d.ts.map +0 -1
  454. package/dest/synchronizer/synchronizer.js +0 -103
  455. package/dest/test/pxe_test_suite.d.ts +0 -3
  456. package/dest/test/pxe_test_suite.d.ts.map +0 -1
  457. package/dest/test/pxe_test_suite.js +0 -97
  458. package/src/bin/index.ts +0 -38
  459. package/src/entrypoints/client/pxe_creation_options.ts +0 -7
  460. package/src/kernel_oracle/index.ts +0 -117
  461. package/src/kernel_prover/hints/build_private_kernel_reset_private_inputs.ts +0 -472
  462. package/src/kernel_prover/hints/index.ts +0 -1
  463. package/src/kernel_prover/index.ts +0 -2
  464. package/src/kernel_prover/kernel_prover.ts +0 -351
  465. package/src/kernel_prover/proving_data_oracle.ts +0 -83
  466. package/src/note_decryption_utils/add_public_values_to_payload.ts +0 -64
  467. package/src/pxe_http/index.ts +0 -1
  468. package/src/pxe_http/pxe_http_server.ts +0 -29
  469. package/src/pxe_oracle_interface/index.ts +0 -925
  470. package/src/pxe_oracle_interface/tagging_utils.ts +0 -32
  471. package/src/pxe_service/index.ts +0 -2
  472. package/src/pxe_service/pxe_service.ts +0 -949
  473. package/src/storage/address_data_provider/index.ts +0 -1
  474. package/src/storage/auth_witness_data_provider/auth_witness_data_provider.ts +0 -34
  475. package/src/storage/auth_witness_data_provider/index.ts +0 -1
  476. package/src/storage/capsule_data_provider/capsule_data_provider.ts +0 -80
  477. package/src/storage/capsule_data_provider/index.ts +0 -1
  478. package/src/storage/contract_data_provider/contract_data_provider.ts +0 -261
  479. package/src/storage/contract_data_provider/index.ts +0 -2
  480. package/src/storage/contract_data_provider/private_functions_tree.ts +0 -131
  481. package/src/storage/data_provider.ts +0 -3
  482. package/src/storage/note_data_provider/index.ts +0 -2
  483. package/src/storage/note_data_provider/note_dao.ts +0 -162
  484. package/src/storage/note_data_provider/note_data_provider.ts +0 -345
  485. package/src/storage/sync_data_provider/index.ts +0 -1
  486. package/src/storage/tagging_data_provider/index.ts +0 -1
  487. package/src/storage/tagging_data_provider/tagging_data_provider.ts +0 -92
  488. package/src/synchronizer/index.ts +0 -1
  489. package/src/synchronizer/synchronizer.ts +0 -121
  490. package/src/test/pxe_test_suite.ts +0 -111
  491. /package/dest/entrypoints/{client/pxe_creation_options.js → pxe_creation_options.js} +0 -0
@@ -0,0 +1,655 @@
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 {
5
+ type ACIRCallback,
6
+ type ACVMField,
7
+ arrayOfArraysToBoundedVecOfArrays,
8
+ bufferToBoundedVec,
9
+ fromUintArray,
10
+ fromUintBoundedVec,
11
+ toACVMField,
12
+ } from '@aztec/simulator/client';
13
+ import { FunctionSelector, NoteSelector } from '@aztec/stdlib/abi';
14
+ import { AztecAddress } from '@aztec/stdlib/aztec-address';
15
+ import { BlockHash } from '@aztec/stdlib/block';
16
+ import { ContractClassLog, ContractClassLogFields } from '@aztec/stdlib/logs';
17
+
18
+ import type { IMiscOracle, IPrivateExecutionOracle, IUtilityExecutionOracle } from './interfaces.js';
19
+ import { buildLegacyOracleCallbacks } from './legacy_oracle_mappings.js';
20
+ import { packAsHintedNote } from './note_packing_utils.js';
21
+
22
+ export class UnavailableOracleError extends Error {
23
+ constructor(oracleName: string) {
24
+ super(`${oracleName} oracles not available with the current handler`);
25
+ }
26
+ }
27
+
28
+ /**
29
+ * A data source that has all the apis required by Aztec.nr.
30
+ */
31
+ export class Oracle {
32
+ constructor(private handler: IMiscOracle | IUtilityExecutionOracle | IPrivateExecutionOracle) {}
33
+
34
+ private handlerAsMisc(): IMiscOracle {
35
+ if (!('isMisc' in this.handler)) {
36
+ throw new UnavailableOracleError('Misc');
37
+ }
38
+
39
+ return this.handler;
40
+ }
41
+
42
+ private handlerAsUtility(): IUtilityExecutionOracle {
43
+ if (!('isUtility' in this.handler)) {
44
+ throw new UnavailableOracleError('Utility');
45
+ }
46
+
47
+ return this.handler;
48
+ }
49
+
50
+ private handlerAsPrivate(): IPrivateExecutionOracle {
51
+ if (!('isPrivate' in this.handler)) {
52
+ throw new UnavailableOracleError('Private');
53
+ }
54
+
55
+ return this.handler;
56
+ }
57
+
58
+ toACIRCallback(): ACIRCallback {
59
+ const excludedProps = [
60
+ 'handler',
61
+ 'constructor',
62
+ 'toACIRCallback',
63
+ 'handlerAsMisc',
64
+ 'handlerAsUtility',
65
+ 'handlerAsPrivate',
66
+ ] as const;
67
+
68
+ // Get all the oracle function names
69
+ const oracleNames = Object.getOwnPropertyNames(Oracle.prototype).filter(
70
+ name => !excludedProps.includes(name as (typeof excludedProps)[number]),
71
+ );
72
+
73
+ // Validate oracle names - these must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate their scope
74
+ // and must correspond to a function on the Oracle class.
75
+ oracleNames.forEach(name => {
76
+ if (!name.startsWith('aztec_prv_') && !name.startsWith('aztec_utl_')) {
77
+ throw new Error(
78
+ `Oracle function "${name}" must be prefixed with either "aztec_prv_" or "aztec_utl_" to indicate its scope`,
79
+ );
80
+ }
81
+
82
+ const method = this[name as keyof Omit<Oracle, (typeof excludedProps)[number]>];
83
+ if (typeof method !== 'function') {
84
+ throw new Error(`Oracle property "${name}" must be a function`);
85
+ }
86
+ });
87
+
88
+ // Build callback object and return it
89
+ const callback = oracleNames.reduce((acc, name) => {
90
+ const method = this[name as keyof Omit<Oracle, (typeof excludedProps)[number]>];
91
+ acc[name] = method.bind(this);
92
+ return acc;
93
+ }, {} as ACIRCallback);
94
+
95
+ return { ...callback, ...buildLegacyOracleCallbacks(this) };
96
+ }
97
+
98
+ // eslint-disable-next-line camelcase
99
+ aztec_utl_assertCompatibleOracleVersion([version]: ACVMField[]) {
100
+ this.handlerAsMisc().assertCompatibleOracleVersion(Fr.fromString(version).toNumber());
101
+ return Promise.resolve([]);
102
+ }
103
+
104
+ // eslint-disable-next-line camelcase
105
+ aztec_utl_getRandomField(): Promise<ACVMField[]> {
106
+ const val = this.handlerAsMisc().getRandomField();
107
+ return Promise.resolve([toACVMField(val)]);
108
+ }
109
+
110
+ // eslint-disable-next-line camelcase
111
+ aztec_prv_storeInExecutionCache(values: ACVMField[], [hash]: ACVMField[]): Promise<ACVMField[]> {
112
+ this.handlerAsPrivate().storeInExecutionCache(values.map(Fr.fromString), Fr.fromString(hash));
113
+ return Promise.resolve([]);
114
+ }
115
+
116
+ // eslint-disable-next-line camelcase
117
+ async aztec_prv_loadFromExecutionCache([returnsHash]: ACVMField[]): Promise<ACVMField[][]> {
118
+ const values = await this.handlerAsPrivate().loadFromExecutionCache(Fr.fromString(returnsHash));
119
+ return [values.map(toACVMField)];
120
+ }
121
+
122
+ // eslint-disable-next-line camelcase
123
+ aztec_utl_getUtilityContext(): Promise<(ACVMField | ACVMField[])[]> {
124
+ const context = this.handlerAsUtility().getUtilityContext();
125
+ return Promise.resolve(context.toNoirRepresentation());
126
+ }
127
+
128
+ // eslint-disable-next-line camelcase
129
+ async aztec_utl_getKeyValidationRequest([pkMHash]: ACVMField[]): Promise<ACVMField[]> {
130
+ const keyValidationRequest = await this.handlerAsUtility().getKeyValidationRequest(Fr.fromString(pkMHash));
131
+
132
+ return keyValidationRequest.toFields().map(toACVMField);
133
+ }
134
+
135
+ // eslint-disable-next-line camelcase
136
+ async aztec_utl_getContractInstance([address]: ACVMField[]): Promise<ACVMField[]> {
137
+ const instance = await this.handlerAsUtility().getContractInstance(AztecAddress.fromField(Fr.fromString(address)));
138
+
139
+ return [
140
+ instance.salt,
141
+ instance.deployer,
142
+ instance.currentContractClassId,
143
+ instance.initializationHash,
144
+ ...instance.publicKeys.toFields(),
145
+ ].map(toACVMField);
146
+ }
147
+
148
+ // eslint-disable-next-line camelcase
149
+ async aztec_utl_getNoteHashMembershipWitness(
150
+ [anchorBlockHash]: ACVMField[],
151
+ [noteHash]: ACVMField[],
152
+ ): Promise<(ACVMField | ACVMField[])[]> {
153
+ const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
154
+ const parsedNoteHash = Fr.fromString(noteHash);
155
+
156
+ const witness = await this.handlerAsUtility().getNoteHashMembershipWitness(parsedAnchorBlockHash, parsedNoteHash);
157
+ if (!witness) {
158
+ throw new Error(
159
+ `Note hash ${noteHash} not found in the note hash tree at anchor block hash ${parsedAnchorBlockHash.toString()}.`,
160
+ );
161
+ }
162
+ return witness.toNoirRepresentation();
163
+ }
164
+
165
+ // eslint-disable-next-line camelcase
166
+ async aztec_utl_getBlockHashMembershipWitness(
167
+ [anchorBlockHash]: ACVMField[],
168
+ [blockHash]: ACVMField[],
169
+ ): Promise<(ACVMField | ACVMField[])[]> {
170
+ const parsedAnchorBlockHash = BlockHash.fromString(anchorBlockHash);
171
+ const parsedBlockHash = BlockHash.fromString(blockHash);
172
+
173
+ const witness = await this.handlerAsUtility().getBlockHashMembershipWitness(parsedAnchorBlockHash, parsedBlockHash);
174
+ if (!witness) {
175
+ throw new Error(
176
+ `Block hash ${parsedBlockHash.toString()} not found in the archive tree at anchor block ${parsedAnchorBlockHash.toString()}.`,
177
+ );
178
+ }
179
+ return witness.toNoirRepresentation();
180
+ }
181
+
182
+ // eslint-disable-next-line camelcase
183
+ async aztec_utl_getNullifierMembershipWitness(
184
+ [blockHash]: ACVMField[],
185
+ [nullifier]: ACVMField[], // nullifier, we try to find the witness for (to prove inclusion)
186
+ ): Promise<(ACVMField | ACVMField[])[]> {
187
+ const parsedBlockHash = BlockHash.fromString(blockHash);
188
+ const parsedNullifier = Fr.fromString(nullifier);
189
+
190
+ const witness = await this.handlerAsUtility().getNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
191
+ if (!witness) {
192
+ throw new Error(
193
+ `Nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`,
194
+ );
195
+ }
196
+ return witness.toNoirRepresentation();
197
+ }
198
+
199
+ // eslint-disable-next-line camelcase
200
+ async aztec_utl_getLowNullifierMembershipWitness(
201
+ [blockHash]: ACVMField[],
202
+ [nullifier]: ACVMField[], // nullifier, we try to find the low nullifier witness for (to prove non-inclusion)
203
+ ): Promise<(ACVMField | ACVMField[])[]> {
204
+ const parsedBlockHash = BlockHash.fromString(blockHash);
205
+ const parsedNullifier = Fr.fromString(nullifier);
206
+
207
+ const witness = await this.handlerAsUtility().getLowNullifierMembershipWitness(parsedBlockHash, parsedNullifier);
208
+ if (!witness) {
209
+ throw new Error(
210
+ `Low nullifier witness not found for nullifier ${parsedNullifier} at block hash ${parsedBlockHash.toString()}.`,
211
+ );
212
+ }
213
+ return witness.toNoirRepresentation();
214
+ }
215
+
216
+ // eslint-disable-next-line camelcase
217
+ async aztec_utl_getPublicDataWitness(
218
+ [blockHash]: ACVMField[],
219
+ [leafSlot]: ACVMField[],
220
+ ): Promise<(ACVMField | ACVMField[])[]> {
221
+ const parsedBlockHash = BlockHash.fromString(blockHash);
222
+ const parsedLeafSlot = Fr.fromString(leafSlot);
223
+
224
+ const witness = await this.handlerAsUtility().getPublicDataWitness(parsedBlockHash, parsedLeafSlot);
225
+ if (!witness) {
226
+ throw new Error(
227
+ `Public data witness not found for slot ${parsedLeafSlot} at block hash ${parsedBlockHash.toString()}.`,
228
+ );
229
+ }
230
+ return witness.toNoirRepresentation();
231
+ }
232
+
233
+ // eslint-disable-next-line camelcase
234
+ async aztec_utl_getBlockHeader([blockNumber]: ACVMField[]): Promise<ACVMField[]> {
235
+ const parsedBlockNumber = Fr.fromString(blockNumber).toNumber();
236
+
237
+ const header = await this.handlerAsUtility().getBlockHeader(BlockNumber(parsedBlockNumber));
238
+ if (!header) {
239
+ throw new Error(`Block header not found for block ${parsedBlockNumber}.`);
240
+ }
241
+ return header.toFields().map(toACVMField);
242
+ }
243
+
244
+ // eslint-disable-next-line camelcase
245
+ async aztec_utl_getAuthWitness([messageHash]: ACVMField[]): Promise<ACVMField[][]> {
246
+ const messageHashField = Fr.fromString(messageHash);
247
+ const witness = await this.handlerAsUtility().getAuthWitness(messageHashField);
248
+ if (!witness) {
249
+ throw new Error(`Unknown auth witness for message hash ${messageHashField}`);
250
+ }
251
+ return [witness.map(toACVMField)];
252
+ }
253
+
254
+ // eslint-disable-next-line camelcase
255
+ async aztec_utl_tryGetPublicKeysAndPartialAddress([address]: ACVMField[]): Promise<(ACVMField | ACVMField[])[]> {
256
+ const parsedAddress = AztecAddress.fromField(Fr.fromString(address));
257
+ const result = await this.handlerAsUtility().tryGetPublicKeysAndPartialAddress(parsedAddress);
258
+
259
+ // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
260
+ // with two fields: `some` (a boolean) and `value` (a field array in this case).
261
+ if (result === undefined) {
262
+ // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
263
+ return [toACVMField(0), Array(13).fill(toACVMField(0))];
264
+ } else {
265
+ // Data was found so we set `some` to 1 and return it along with `value`.
266
+ return [toACVMField(1), [...result.publicKeys.toFields(), result.partialAddress].map(toACVMField)];
267
+ }
268
+ }
269
+
270
+ // eslint-disable-next-line camelcase
271
+ async aztec_utl_getNotes(
272
+ [ownerSome]: ACVMField[],
273
+ [ownerValue]: ACVMField[],
274
+ [storageSlot]: ACVMField[],
275
+ [numSelects]: ACVMField[],
276
+ selectByIndexes: ACVMField[],
277
+ selectByOffsets: ACVMField[],
278
+ selectByLengths: ACVMField[],
279
+ selectValues: ACVMField[],
280
+ selectComparators: ACVMField[],
281
+ sortByIndexes: ACVMField[],
282
+ sortByOffsets: ACVMField[],
283
+ sortByLengths: ACVMField[],
284
+ sortOrder: ACVMField[],
285
+ [limit]: ACVMField[],
286
+ [offset]: ACVMField[],
287
+ [status]: ACVMField[],
288
+ [maxNotes]: ACVMField[],
289
+ [packedHintedNoteLength]: ACVMField[],
290
+ ): Promise<(ACVMField | ACVMField[])[]> {
291
+ // Parse Option<AztecAddress>: ownerSome is 0 for None, 1 for Some
292
+ const owner = Fr.fromString(ownerSome).toNumber() === 1 ? AztecAddress.fromString(ownerValue) : undefined;
293
+ const noteDatas = await this.handlerAsUtility().getNotes(
294
+ owner,
295
+ Fr.fromString(storageSlot),
296
+ +numSelects,
297
+ selectByIndexes.map(s => +s),
298
+ selectByOffsets.map(s => +s),
299
+ selectByLengths.map(s => +s),
300
+ selectValues.map(Fr.fromString),
301
+ selectComparators.map(s => +s),
302
+ sortByIndexes.map(s => +s),
303
+ sortByOffsets.map(s => +s),
304
+ sortByLengths.map(s => +s),
305
+ sortOrder.map(s => +s),
306
+ +limit,
307
+ +offset,
308
+ +status,
309
+ );
310
+
311
+ const returnDataAsArrayOfPackedHintedNotes = noteDatas.map(noteData =>
312
+ packAsHintedNote({
313
+ contractAddress: noteData.contractAddress,
314
+ owner: noteData.owner,
315
+ randomness: noteData.randomness,
316
+ storageSlot: noteData.storageSlot,
317
+ noteNonce: noteData.noteNonce,
318
+ isPending: noteData.isPending,
319
+ note: noteData.note,
320
+ }),
321
+ );
322
+
323
+ // Now we convert each sub-array to an array of ACVMField
324
+ const returnDataAsArrayOfACVMFieldArrays = returnDataAsArrayOfPackedHintedNotes.map(subArray =>
325
+ subArray.map(toACVMField),
326
+ );
327
+
328
+ // At last we convert the array of arrays to a bounded vec of arrays
329
+ return arrayOfArraysToBoundedVecOfArrays(returnDataAsArrayOfACVMFieldArrays, +maxNotes, +packedHintedNoteLength);
330
+ }
331
+
332
+ // eslint-disable-next-line camelcase
333
+ aztec_prv_notifyCreatedNote(
334
+ [owner]: ACVMField[],
335
+ [storageSlot]: ACVMField[],
336
+ [randomness]: ACVMField[],
337
+ [noteTypeId]: ACVMField[],
338
+ note: ACVMField[],
339
+ [noteHash]: ACVMField[],
340
+ [counter]: ACVMField[],
341
+ ): Promise<ACVMField[]> {
342
+ this.handlerAsPrivate().notifyCreatedNote(
343
+ AztecAddress.fromString(owner),
344
+ Fr.fromString(storageSlot),
345
+ Fr.fromString(randomness),
346
+ NoteSelector.fromField(Fr.fromString(noteTypeId)),
347
+ note.map(Fr.fromString),
348
+ Fr.fromString(noteHash),
349
+ +counter,
350
+ );
351
+ return Promise.resolve([]);
352
+ }
353
+
354
+ // eslint-disable-next-line camelcase
355
+ async aztec_prv_notifyNullifiedNote(
356
+ [innerNullifier]: ACVMField[],
357
+ [noteHash]: ACVMField[],
358
+ [counter]: ACVMField[],
359
+ ): Promise<ACVMField[]> {
360
+ await this.handlerAsPrivate().notifyNullifiedNote(Fr.fromString(innerNullifier), Fr.fromString(noteHash), +counter);
361
+ return [];
362
+ }
363
+
364
+ // eslint-disable-next-line camelcase
365
+ async aztec_prv_notifyCreatedNullifier([innerNullifier]: ACVMField[]): Promise<ACVMField[]> {
366
+ await this.handlerAsPrivate().notifyCreatedNullifier(Fr.fromString(innerNullifier));
367
+ return [];
368
+ }
369
+
370
+ // eslint-disable-next-line camelcase
371
+ async aztec_prv_isNullifierPending(
372
+ [innerNullifier]: ACVMField[],
373
+ [contractAddress]: ACVMField[],
374
+ ): Promise<ACVMField[]> {
375
+ const isPending = await this.handlerAsPrivate().isNullifierPending(
376
+ Fr.fromString(innerNullifier),
377
+ AztecAddress.fromString(contractAddress),
378
+ );
379
+ return [toACVMField(isPending)];
380
+ }
381
+
382
+ // eslint-disable-next-line camelcase
383
+ async aztec_utl_checkNullifierExists([innerNullifier]: ACVMField[]): Promise<ACVMField[]> {
384
+ const exists = await this.handlerAsUtility().checkNullifierExists(Fr.fromString(innerNullifier));
385
+ return [toACVMField(exists)];
386
+ }
387
+
388
+ // eslint-disable-next-line camelcase
389
+ async aztec_utl_getL1ToL2MembershipWitness(
390
+ [contractAddress]: ACVMField[],
391
+ [messageHash]: ACVMField[],
392
+ [secret]: ACVMField[],
393
+ ): Promise<(ACVMField | ACVMField[])[]> {
394
+ const message = await this.handlerAsUtility().getL1ToL2MembershipWitness(
395
+ AztecAddress.fromString(contractAddress),
396
+ Fr.fromString(messageHash),
397
+ Fr.fromString(secret),
398
+ );
399
+ return message.toNoirRepresentation();
400
+ }
401
+
402
+ // eslint-disable-next-line camelcase
403
+ async aztec_utl_storageRead(
404
+ [blockHash]: ACVMField[],
405
+ [contractAddress]: ACVMField[],
406
+ [startStorageSlot]: ACVMField[],
407
+ [numberOfElements]: ACVMField[],
408
+ ): Promise<ACVMField[][]> {
409
+ const values = await this.handlerAsUtility().storageRead(
410
+ BlockHash.fromString(blockHash),
411
+ new AztecAddress(Fr.fromString(contractAddress)),
412
+ Fr.fromString(startStorageSlot),
413
+ +numberOfElements,
414
+ );
415
+ return [values.map(toACVMField)];
416
+ }
417
+
418
+ // eslint-disable-next-line camelcase
419
+ aztec_prv_notifyCreatedContractClassLog(
420
+ [contractAddress]: ACVMField[],
421
+ message: ACVMField[],
422
+ [length]: ACVMField[],
423
+ [counter]: ACVMField[],
424
+ ): Promise<ACVMField[]> {
425
+ const logFields = new ContractClassLogFields(message.map(Fr.fromString));
426
+ const log = new ContractClassLog(new AztecAddress(Fr.fromString(contractAddress)), logFields, +length);
427
+
428
+ this.handlerAsPrivate().notifyCreatedContractClassLog(log, +counter);
429
+ return Promise.resolve([]);
430
+ }
431
+
432
+ // eslint-disable-next-line camelcase
433
+ async aztec_utl_log(
434
+ level: ACVMField[],
435
+ message: ACVMField[],
436
+ _ignoredFieldsSize: ACVMField[],
437
+ fields: ACVMField[],
438
+ ): Promise<ACVMField[]> {
439
+ const levelFr = Fr.fromString(level[0]);
440
+ const messageStr = message.map(acvmField => String.fromCharCode(Fr.fromString(acvmField).toNumber())).join('');
441
+ const fieldsFr = fields.map(Fr.fromString);
442
+ await this.handlerAsMisc().log(levelFr.toNumber(), messageStr, fieldsFr);
443
+ return [];
444
+ }
445
+
446
+ // This function's name is directly hardcoded in `circuit_recorder.ts`. Don't forget to update it there if you
447
+ // change the name here.
448
+ // eslint-disable-next-line camelcase
449
+ async aztec_prv_callPrivateFunction(
450
+ [contractAddress]: ACVMField[],
451
+ [functionSelector]: ACVMField[],
452
+ [argsHash]: ACVMField[],
453
+ [sideEffectCounter]: ACVMField[],
454
+ [isStaticCall]: ACVMField[],
455
+ ): Promise<ACVMField[][]> {
456
+ const { endSideEffectCounter, returnsHash } = await this.handlerAsPrivate().callPrivateFunction(
457
+ AztecAddress.fromField(Fr.fromString(contractAddress)),
458
+ FunctionSelector.fromField(Fr.fromString(functionSelector)),
459
+ Fr.fromString(argsHash),
460
+ Fr.fromString(sideEffectCounter).toNumber(),
461
+ Fr.fromString(isStaticCall).toBool(),
462
+ );
463
+ return [[endSideEffectCounter, returnsHash].map(toACVMField)];
464
+ }
465
+
466
+ // eslint-disable-next-line camelcase
467
+ async aztec_prv_validatePublicCalldata([calldataHash]: ACVMField[]): Promise<ACVMField[]> {
468
+ await this.handlerAsPrivate().validatePublicCalldata(Fr.fromString(calldataHash));
469
+ return [];
470
+ }
471
+
472
+ // eslint-disable-next-line camelcase
473
+ async aztec_prv_notifyRevertiblePhaseStart([minRevertibleSideEffectCounter]: ACVMField[]): Promise<ACVMField[]> {
474
+ await this.handlerAsPrivate().notifyRevertiblePhaseStart(Fr.fromString(minRevertibleSideEffectCounter).toNumber());
475
+ return Promise.resolve([]);
476
+ }
477
+
478
+ // eslint-disable-next-line camelcase
479
+ async aztec_prv_inRevertiblePhase([sideEffectCounter]: ACVMField[]): Promise<ACVMField[]> {
480
+ const isRevertible = await this.handlerAsPrivate().inRevertiblePhase(Fr.fromString(sideEffectCounter).toNumber());
481
+ return Promise.resolve([toACVMField(isRevertible)]);
482
+ }
483
+
484
+ // eslint-disable-next-line camelcase
485
+ async aztec_prv_getNextAppTagAsSender([sender]: ACVMField[], [recipient]: ACVMField[]): Promise<ACVMField[]> {
486
+ const tag = await this.handlerAsPrivate().getNextAppTagAsSender(
487
+ AztecAddress.fromString(sender),
488
+ AztecAddress.fromString(recipient),
489
+ );
490
+ return [toACVMField(tag.value)];
491
+ }
492
+
493
+ // eslint-disable-next-line camelcase
494
+ async aztec_utl_fetchTaggedLogs([pendingTaggedLogArrayBaseSlot]: ACVMField[]): Promise<ACVMField[]> {
495
+ await this.handlerAsUtility().fetchTaggedLogs(Fr.fromString(pendingTaggedLogArrayBaseSlot));
496
+ return [];
497
+ }
498
+
499
+ // eslint-disable-next-line camelcase
500
+ async aztec_utl_validateAndStoreEnqueuedNotesAndEvents(
501
+ [contractAddress]: ACVMField[],
502
+ [noteValidationRequestsArrayBaseSlot]: ACVMField[],
503
+ [eventValidationRequestsArrayBaseSlot]: ACVMField[],
504
+ [maxNotePackedLen]: ACVMField[],
505
+ [maxEventSerializedLen]: ACVMField[],
506
+ ): Promise<ACVMField[]> {
507
+ await this.handlerAsUtility().validateAndStoreEnqueuedNotesAndEvents(
508
+ AztecAddress.fromString(contractAddress),
509
+ Fr.fromString(noteValidationRequestsArrayBaseSlot),
510
+ Fr.fromString(eventValidationRequestsArrayBaseSlot),
511
+ Fr.fromString(maxNotePackedLen).toNumber(),
512
+ Fr.fromString(maxEventSerializedLen).toNumber(),
513
+ );
514
+
515
+ return [];
516
+ }
517
+
518
+ // eslint-disable-next-line camelcase
519
+ async aztec_utl_bulkRetrieveLogs(
520
+ [contractAddress]: ACVMField[],
521
+ [logRetrievalRequestsArrayBaseSlot]: ACVMField[],
522
+ [logRetrievalResponsesArrayBaseSlot]: ACVMField[],
523
+ ): Promise<ACVMField[]> {
524
+ await this.handlerAsUtility().bulkRetrieveLogs(
525
+ AztecAddress.fromString(contractAddress),
526
+ Fr.fromString(logRetrievalRequestsArrayBaseSlot),
527
+ Fr.fromString(logRetrievalResponsesArrayBaseSlot),
528
+ );
529
+ return [];
530
+ }
531
+
532
+ // eslint-disable-next-line camelcase
533
+ async aztec_utl_utilityResolveMessageContexts(
534
+ [contractAddress]: ACVMField[],
535
+ [messageContextRequestsArrayBaseSlot]: ACVMField[],
536
+ [messageContextResponsesArrayBaseSlot]: ACVMField[],
537
+ ): Promise<ACVMField[]> {
538
+ await this.handlerAsUtility().utilityResolveMessageContexts(
539
+ AztecAddress.fromString(contractAddress),
540
+ Fr.fromString(messageContextRequestsArrayBaseSlot),
541
+ Fr.fromString(messageContextResponsesArrayBaseSlot),
542
+ );
543
+ return [];
544
+ }
545
+
546
+ // eslint-disable-next-line camelcase
547
+ async aztec_utl_storeCapsule(
548
+ [contractAddress]: ACVMField[],
549
+ [slot]: ACVMField[],
550
+ capsule: ACVMField[],
551
+ ): Promise<ACVMField[]> {
552
+ await this.handlerAsUtility().storeCapsule(
553
+ AztecAddress.fromField(Fr.fromString(contractAddress)),
554
+ Fr.fromString(slot),
555
+ capsule.map(Fr.fromString),
556
+ );
557
+ return [];
558
+ }
559
+
560
+ // eslint-disable-next-line camelcase
561
+ async aztec_utl_loadCapsule(
562
+ [contractAddress]: ACVMField[],
563
+ [slot]: ACVMField[],
564
+ [tSize]: ACVMField[],
565
+ ): Promise<(ACVMField | ACVMField[])[]> {
566
+ const values = await this.handlerAsUtility().loadCapsule(
567
+ AztecAddress.fromField(Fr.fromString(contractAddress)),
568
+ Fr.fromString(slot),
569
+ );
570
+
571
+ // We are going to return a Noir Option struct to represent the possibility of null values. Options are a struct
572
+ // with two fields: `some` (a boolean) and `value` (a field array in this case).
573
+ if (values === null) {
574
+ // No data was found so we set `some` to 0 and pad `value` with zeros get the correct return size.
575
+ return [toACVMField(0), Array(Fr.fromString(tSize).toNumber()).fill(toACVMField(0))];
576
+ } else {
577
+ // Data was found so we set `some` to 1 and return it along with `value`.
578
+ return [toACVMField(1), values.map(toACVMField)];
579
+ }
580
+ }
581
+
582
+ // eslint-disable-next-line camelcase
583
+ async aztec_utl_deleteCapsule([contractAddress]: ACVMField[], [slot]: ACVMField[]): Promise<ACVMField[]> {
584
+ await this.handlerAsUtility().deleteCapsule(
585
+ AztecAddress.fromField(Fr.fromString(contractAddress)),
586
+ Fr.fromString(slot),
587
+ );
588
+ return [];
589
+ }
590
+
591
+ // eslint-disable-next-line camelcase
592
+ async aztec_utl_copyCapsule(
593
+ [contractAddress]: ACVMField[],
594
+ [srcSlot]: ACVMField[],
595
+ [dstSlot]: ACVMField[],
596
+ [numEntries]: ACVMField[],
597
+ ): Promise<ACVMField[]> {
598
+ await this.handlerAsUtility().copyCapsule(
599
+ AztecAddress.fromField(Fr.fromString(contractAddress)),
600
+ Fr.fromString(srcSlot),
601
+ Fr.fromString(dstSlot),
602
+ Fr.fromString(numEntries).toNumber(),
603
+ );
604
+ return [];
605
+ }
606
+
607
+ // TODO(F-452): Return Option and wrap in try/catch so BB exceptions don't crash PXE.
608
+ // eslint-disable-next-line camelcase
609
+ async aztec_utl_aes128Decrypt(
610
+ ciphertextBVecStorage: ACVMField[],
611
+ [ciphertextLength]: ACVMField[],
612
+ iv: ACVMField[],
613
+ symKey: ACVMField[],
614
+ ): Promise<(ACVMField | ACVMField[])[]> {
615
+ const ciphertext = fromUintBoundedVec(ciphertextBVecStorage, ciphertextLength, 8);
616
+ const ivBuffer = fromUintArray(iv, 8);
617
+ const symKeyBuffer = fromUintArray(symKey, 8);
618
+
619
+ const plaintext = await this.handlerAsUtility().aes128Decrypt(ciphertext, ivBuffer, symKeyBuffer);
620
+ return bufferToBoundedVec(plaintext, ciphertextBVecStorage.length);
621
+ }
622
+
623
+ // eslint-disable-next-line camelcase
624
+ async aztec_utl_getSharedSecret(
625
+ [address]: ACVMField[],
626
+ [ephPKField0]: ACVMField[],
627
+ [ephPKField1]: ACVMField[],
628
+ [ephPKField2]: ACVMField[],
629
+ ): Promise<ACVMField[]> {
630
+ const secret = await this.handlerAsUtility().getSharedSecret(
631
+ AztecAddress.fromField(Fr.fromString(address)),
632
+ Point.fromFields([ephPKField0, ephPKField1, ephPKField2].map(Fr.fromString)),
633
+ );
634
+ return secret.toFields().map(toACVMField);
635
+ }
636
+
637
+ // eslint-disable-next-line camelcase
638
+ async aztec_utl_emitOffchainEffect(data: ACVMField[]) {
639
+ await this.handlerAsUtility().emitOffchainEffect(data.map(Fr.fromString));
640
+ return [];
641
+ }
642
+
643
+ // eslint-disable-next-line camelcase
644
+ async aztec_prv_getSenderForTags(): Promise<ACVMField[]> {
645
+ const sender = await this.handlerAsPrivate().getSenderForTags();
646
+ // Return [1, address] for Some(address), [0, 0] for None
647
+ return sender ? [toACVMField(1n), toACVMField(sender)] : [toACVMField(0n), toACVMField(0n)];
648
+ }
649
+
650
+ // eslint-disable-next-line camelcase
651
+ async aztec_prv_setSenderForTags([senderForTags]: ACVMField[]): Promise<ACVMField[]> {
652
+ await this.handlerAsPrivate().setSenderForTags(AztecAddress.fromField(Fr.fromString(senderForTags)));
653
+ return [];
654
+ }
655
+ }