@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,13 +1,12 @@
1
1
  import type { FUNCTION_TREE_HEIGHT } from '@aztec/constants';
2
- import type { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { toArray } from '@aztec/foundation/iterable';
4
+ import { BufferReader, numToUInt8, serializeToBuffer } from '@aztec/foundation/serialize';
4
5
  import type { MembershipWitness } from '@aztec/foundation/trees';
5
6
  import type { AztecAsyncKVStore, AztecAsyncMap } from '@aztec/kv-store';
6
- import { isProtocolContract } from '@aztec/protocol-contracts';
7
7
  import {
8
8
  type ContractArtifact,
9
9
  type FunctionAbi,
10
- type FunctionArtifact,
11
10
  type FunctionArtifactWithContractName,
12
11
  FunctionCall,
13
12
  type FunctionDebugMetadata,
@@ -16,11 +15,14 @@ import {
16
15
  contractArtifactFromBuffer,
17
16
  contractArtifactToBuffer,
18
17
  encodeArguments,
18
+ findFunctionAbiBySelector,
19
+ findFunctionArtifactBySelector,
19
20
  getFunctionDebugMetadata,
20
21
  } from '@aztec/stdlib/abi';
21
22
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
22
23
  import {
23
- type ContractClass,
24
+ type ContractClassIdPreimage,
25
+ type ContractClassWithId,
24
26
  type ContractInstanceWithAddress,
25
27
  SerializableContractInstance,
26
28
  getContractClassFromArtifact,
@@ -28,6 +30,68 @@ import {
28
30
 
29
31
  import { PrivateFunctionsTree } from './private_functions_tree.js';
30
32
 
33
+ const VERSION = 1 as const;
34
+
35
+ /**
36
+ * All contract class data except the large packedBytecode.
37
+ * The expensive data from the ContractClass is precomputed and stored in this format to avoid redundant hashing.
38
+ * Since we have to store the artifacts anyway, the final ContractClass is reconstructed by combining this data
39
+ * with the packedBytecode obtained from the former. That way we can have quick class lookups without wasted storage.
40
+ */
41
+ export class SerializableContractClassData {
42
+ public readonly version = VERSION;
43
+ public readonly id: Fr;
44
+ public readonly artifactHash: Fr;
45
+ public readonly privateFunctionsRoot: Fr;
46
+ public readonly publicBytecodeCommitment: Fr;
47
+ public readonly privateFunctions: { selector: FunctionSelector; vkHash: Fr }[];
48
+
49
+ constructor(
50
+ data: ContractClassIdPreimage & {
51
+ id: Fr;
52
+ privateFunctions: { selector: FunctionSelector; vkHash: Fr }[];
53
+ },
54
+ ) {
55
+ this.id = data.id;
56
+ this.artifactHash = data.artifactHash;
57
+ this.privateFunctionsRoot = data.privateFunctionsRoot;
58
+ this.publicBytecodeCommitment = data.publicBytecodeCommitment;
59
+ this.privateFunctions = data.privateFunctions;
60
+ }
61
+
62
+ toBuffer(): Buffer {
63
+ return serializeToBuffer(
64
+ numToUInt8(this.version),
65
+ this.id,
66
+ this.artifactHash,
67
+ this.privateFunctionsRoot,
68
+ this.publicBytecodeCommitment,
69
+ this.privateFunctions.length,
70
+ ...this.privateFunctions.map(fn => serializeToBuffer(fn.selector, fn.vkHash)),
71
+ );
72
+ }
73
+
74
+ static fromBuffer(bufferOrReader: Buffer | BufferReader): SerializableContractClassData {
75
+ const reader = BufferReader.asReader(bufferOrReader);
76
+ const version = reader.readUInt8();
77
+ if (version !== VERSION) {
78
+ throw new Error(`Unexpected contract class data version ${version}`);
79
+ }
80
+ return new SerializableContractClassData({
81
+ id: reader.readObject(Fr),
82
+ artifactHash: reader.readObject(Fr),
83
+ privateFunctionsRoot: reader.readObject(Fr),
84
+ publicBytecodeCommitment: reader.readObject(Fr),
85
+ privateFunctions: reader.readVector({
86
+ fromBuffer: (r: BufferReader) => ({
87
+ selector: r.readObject(FunctionSelector),
88
+ vkHash: r.readObject(Fr),
89
+ }),
90
+ }),
91
+ });
92
+ }
93
+ }
94
+
31
95
  /**
32
96
  * ContractStore serves as a data manager and retriever for Aztec.nr contracts.
33
97
  * It provides methods to obtain contract addresses, function ABI, bytecode, and membership witnesses
@@ -40,71 +104,95 @@ export class ContractStore {
40
104
  // TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
41
105
  #privateFunctionTrees: Map<string, PrivateFunctionsTree> = new Map();
42
106
 
43
- /** Map from contract address to contract class id */
107
+ /**
108
+ * In-memory cache of deserialized ContractArtifact objects, keyed by class id string.
109
+ * Avoids repeated LMDB reads + JSON.parse + Zod validation on every oracle call.
110
+ * Artifacts are large but immutable after registration — safe to cache for the lifetime of the store.
111
+ */
112
+ // TODO: Update it to be LRU cache so that it doesn't keep all the data all the time.
113
+ #contractArtifactCache: Map<string, ContractArtifact> = new Map();
114
+
115
+ /** Map from contract address to contract class id (avoids KV round-trip on hot path). */
44
116
  #contractClassIdMap: Map<string, Fr> = new Map();
45
117
 
118
+ #store: AztecAsyncKVStore;
46
119
  #contractArtifacts: AztecAsyncMap<string, Buffer>;
120
+ #contractClassData: AztecAsyncMap<string, Buffer>;
47
121
  #contractInstances: AztecAsyncMap<string, Buffer>;
48
122
 
49
123
  constructor(store: AztecAsyncKVStore) {
124
+ this.#store = store;
50
125
  this.#contractArtifacts = store.openMap('contract_artifacts');
126
+ this.#contractClassData = store.openMap('contract_classes');
51
127
  this.#contractInstances = store.openMap('contracts_instances');
52
128
  }
53
129
 
54
130
  // Setters
55
131
 
56
- public async addContractArtifact(id: Fr, contract: ContractArtifact): Promise<void> {
132
+ /**
133
+ * Registers a new contract artifact and its corresponding class data.
134
+ * IMPORTANT: This method does not verify that the provided artifact matches the class data or that the class id matches the artifact.
135
+ * It is the caller's responsibility to ensure the consistency and correctness of the provided data.
136
+ * This is done to avoid redundant, expensive contract class computations
137
+ */
138
+ public async addContractArtifact(
139
+ contract: ContractArtifact,
140
+ contractClassWithIdAndPreimage?: ContractClassWithId & ContractClassIdPreimage,
141
+ ): Promise<Fr> {
142
+ const contractClass = contractClassWithIdAndPreimage ?? (await getContractClassFromArtifact(contract));
143
+ const key = contractClass.id.toString();
144
+
145
+ if (this.#contractArtifactCache.has(key)) {
146
+ return contractClass.id;
147
+ }
148
+
57
149
  const privateFunctions = contract.functions.filter(
58
150
  functionArtifact => functionArtifact.functionType === FunctionType.PRIVATE,
59
151
  );
60
-
61
152
  const privateSelectors = await Promise.all(
62
- privateFunctions.map(async privateFunctionArtifact =>
63
- (
64
- await FunctionSelector.fromNameAndParameters(privateFunctionArtifact.name, privateFunctionArtifact.parameters)
65
- ).toString(),
153
+ privateFunctions.map(async fn =>
154
+ (await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters)).toString(),
66
155
  ),
67
156
  );
68
-
69
157
  if (privateSelectors.length !== new Set(privateSelectors).size) {
70
158
  throw new Error('Repeated function selectors of private functions');
71
159
  }
72
160
 
73
- await this.#contractArtifacts.set(id.toString(), contractArtifactToBuffer(contract));
161
+ this.#contractArtifactCache.set(key, contract);
162
+
163
+ await this.#store.transactionAsync(async () => {
164
+ await this.#contractArtifacts.set(key, contractArtifactToBuffer(contract));
165
+ await this.#contractClassData.set(key, new SerializableContractClassData(contractClass).toBuffer());
166
+ });
167
+
168
+ return contractClass.id;
74
169
  }
75
170
 
76
171
  async addContractInstance(contract: ContractInstanceWithAddress): Promise<void> {
77
- this.#contractClassIdMap.set(contract.address.toString(), contract.currentContractClassId);
172
+ await this.#store.transactionAsync(async () => {
173
+ await this.#contractInstances.set(
174
+ contract.address.toString(),
175
+ new SerializableContractInstance(contract).toBuffer(),
176
+ );
177
+ });
78
178
 
79
- await this.#contractInstances.set(
80
- contract.address.toString(),
81
- new SerializableContractInstance(contract).toBuffer(),
82
- );
179
+ this.#contractClassIdMap.set(contract.address.toString(), contract.currentContractClassId);
83
180
  }
84
181
 
85
182
  // Private getters
86
183
 
87
184
  async #getContractClassId(contractAddress: AztecAddress): Promise<Fr | undefined> {
88
- if (!this.#contractClassIdMap.has(contractAddress.toString())) {
185
+ const key = contractAddress.toString();
186
+ if (!this.#contractClassIdMap.has(key)) {
89
187
  const instance = await this.getContractInstance(contractAddress);
90
188
  if (!instance) {
91
189
  return;
92
190
  }
93
- this.#contractClassIdMap.set(contractAddress.toString(), instance.currentContractClassId);
191
+ this.#contractClassIdMap.set(key, instance.currentContractClassId);
94
192
  }
95
- return this.#contractClassIdMap.get(contractAddress.toString());
193
+ return this.#contractClassIdMap.get(key);
96
194
  }
97
195
 
98
- /**
99
- * Retrieve or create a ContractTree instance based on the provided class id.
100
- * If an existing tree with the same class id is found in the cache, it will be returned.
101
- * Otherwise, a new ContractTree instance will be created using the contract data from the database
102
- * and added to the cache before returning.
103
- *
104
- * @param classId - The class id of the contract for which the ContractTree is required.
105
- * @returns A ContractTree instance associated with the specified contract address.
106
- * @throws An Error if the contract is not found in the ContractDatabase.
107
- */
108
196
  async #getPrivateFunctionTreeForClassId(classId: Fr): Promise<PrivateFunctionsTree | undefined> {
109
197
  if (!this.#privateFunctionTrees.has(classId.toString())) {
110
198
  const artifact = await this.getContractArtifact(classId);
@@ -117,34 +205,61 @@ export class ContractStore {
117
205
  return this.#privateFunctionTrees.get(classId.toString())!;
118
206
  }
119
207
 
120
- async #getContractArtifactByAddress(contractAddress: AztecAddress): Promise<ContractArtifact | undefined> {
121
- const contractClassId = await this.#getContractClassId(contractAddress);
122
- return contractClassId && this.getContractArtifact(contractClassId);
208
+ async #getArtifactByAddress(contractAddress: AztecAddress): Promise<ContractArtifact | undefined> {
209
+ const classId = await this.#getContractClassId(contractAddress);
210
+ return classId && this.getContractArtifact(classId);
123
211
  }
124
212
 
125
213
  // Public getters
126
214
 
127
- async getContractsAddresses(): Promise<AztecAddress[]> {
128
- const keys = await toArray(this.#contractInstances.keysAsync());
129
- return keys.map(AztecAddress.fromString);
215
+ getContractsAddresses(): Promise<AztecAddress[]> {
216
+ return this.#store.transactionAsync(async () => {
217
+ const keys = await toArray(this.#contractInstances.keysAsync());
218
+ return keys.map(AztecAddress.fromString);
219
+ });
130
220
  }
131
221
 
132
- /** Returns a contract instance for a given address. Throws if not found. */
133
- public async getContractInstance(contractAddress: AztecAddress): Promise<ContractInstanceWithAddress | undefined> {
134
- const contract = await this.#contractInstances.getAsync(contractAddress.toString());
135
- return contract && SerializableContractInstance.fromBuffer(contract).withAddress(contractAddress);
222
+ /** Returns a contract instance for a given address. */
223
+ public getContractInstance(contractAddress: AztecAddress): Promise<ContractInstanceWithAddress | undefined> {
224
+ return this.#store.transactionAsync(async () => {
225
+ const contract = await this.#contractInstances.getAsync(contractAddress.toString());
226
+ return contract && SerializableContractInstance.fromBuffer(contract).withAddress(contractAddress);
227
+ });
136
228
  }
137
229
 
230
+ /** Returns the raw contract artifact for a given class id. */
138
231
  public async getContractArtifact(contractClassId: Fr): Promise<ContractArtifact | undefined> {
139
- const contract = await this.#contractArtifacts.getAsync(contractClassId.toString());
140
- // TODO(@spalladino): AztecAsyncMap lies and returns Uint8Arrays instead of Buffers, hence the extra Buffer.from.
141
- return contract && contractArtifactFromBuffer(Buffer.from(contract));
232
+ const key = contractClassId.toString();
233
+ const cached = this.#contractArtifactCache.get(key);
234
+ if (cached) {
235
+ return cached;
236
+ }
237
+ const artifact = await this.#store.transactionAsync(async () => {
238
+ const buf = await this.#contractArtifacts.getAsync(key);
239
+ return buf && contractArtifactFromBuffer(buf);
240
+ });
241
+ if (artifact) {
242
+ this.#contractArtifactCache.set(key, artifact);
243
+ }
244
+ return artifact;
142
245
  }
143
246
 
144
- /** Returns a contract class for a given class id. Throws if not found. */
145
- public async getContractClass(contractClassId: Fr): Promise<ContractClass | undefined> {
247
+ /** Returns a contract class for a given class id. */
248
+ public async getContractClassWithPreimage(
249
+ contractClassId: Fr,
250
+ ): Promise<(ContractClassWithId & ContractClassIdPreimage) | undefined> {
251
+ const key = contractClassId.toString();
252
+ const buf = await this.#store.transactionAsync(() => this.#contractClassData.getAsync(key));
253
+ if (!buf) {
254
+ return undefined;
255
+ }
256
+ const classData = SerializableContractClassData.fromBuffer(buf);
146
257
  const artifact = await this.getContractArtifact(contractClassId);
147
- return artifact && getContractClassFromArtifact(artifact);
258
+ if (!artifact) {
259
+ return undefined;
260
+ }
261
+ const packedBytecode = artifact.functions.find(f => f.name === 'public_dispatch')?.bytecode ?? Buffer.alloc(0);
262
+ return { ...classData, packedBytecode };
148
263
  }
149
264
 
150
265
  public async getContract(
@@ -163,8 +278,6 @@ export class ContractStore {
163
278
 
164
279
  /**
165
280
  * Retrieves the artifact of a specified function within a given contract.
166
- * The function is identified by its selector, which is a unique code generated from the function's signature.
167
- * Throws an error if the contract address or function selector are invalid or not found.
168
281
  *
169
282
  * @param contractAddress - The AztecAddress representing the contract containing the function.
170
283
  * @param selector - The function selector.
@@ -174,9 +287,12 @@ export class ContractStore {
174
287
  contractAddress: AztecAddress,
175
288
  selector: FunctionSelector,
176
289
  ): Promise<FunctionArtifactWithContractName | undefined> {
177
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
178
- const fnArtifact = artifact && (await this.#findFunctionArtifactBySelector(artifact, selector));
179
- return fnArtifact && { ...fnArtifact, contractName: artifact.name };
290
+ const artifact = await this.#getArtifactByAddress(contractAddress);
291
+ if (!artifact) {
292
+ return undefined;
293
+ }
294
+ const fn = await findFunctionArtifactBySelector(artifact, selector);
295
+ return fn && { ...fn, contractName: artifact.name };
180
296
  }
181
297
 
182
298
  public async getFunctionArtifactWithDebugMetadata(
@@ -197,50 +313,48 @@ export class ContractStore {
197
313
  public async getPublicFunctionArtifact(
198
314
  contractAddress: AztecAddress,
199
315
  ): Promise<FunctionArtifactWithContractName | undefined> {
200
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
201
- const fnArtifact = artifact && artifact.functions.find(fn => fn.functionType === FunctionType.PUBLIC);
202
- return fnArtifact && { ...fnArtifact, contractName: artifact.name };
316
+ const artifact = await this.#getArtifactByAddress(contractAddress);
317
+ const fn = artifact && artifact.functions.find(f => f.functionType === FunctionType.PUBLIC);
318
+ return fn && { ...fn, contractName: artifact.name };
203
319
  }
204
320
 
205
321
  public async getFunctionAbi(
206
322
  contractAddress: AztecAddress,
207
323
  selector: FunctionSelector,
208
324
  ): Promise<FunctionAbi | undefined> {
209
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
210
- return artifact && (await this.#findFunctionAbiBySelector(artifact, selector));
325
+ const artifact = await this.#getArtifactByAddress(contractAddress);
326
+ return artifact && (await findFunctionAbiBySelector(artifact, selector));
211
327
  }
212
328
 
213
329
  /**
214
330
  * Retrieves the debug metadata of a specified function within a given contract.
215
- * The function is identified by its selector, which is a unique code generated from the function's signature.
216
- * Returns undefined if the debug metadata for the given function is not found.
217
- * Throws if the contract has not been added to the database.
218
331
  *
219
332
  * @param contractAddress - The AztecAddress representing the contract containing the function.
220
333
  * @param selector - The function selector.
221
- * @returns The corresponding function's artifact as an object.
334
+ * @returns The corresponding function's debug metadata, or undefined.
222
335
  */
223
336
  public async getFunctionDebugMetadata(
224
337
  contractAddress: AztecAddress,
225
338
  selector: FunctionSelector,
226
339
  ): Promise<FunctionDebugMetadata | undefined> {
227
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
228
- const fnArtifact = artifact && (await this.#findFunctionArtifactBySelector(artifact, selector));
229
- return fnArtifact && getFunctionDebugMetadata(artifact, fnArtifact);
340
+ const artifact = await this.#getArtifactByAddress(contractAddress);
341
+ if (!artifact) {
342
+ return undefined;
343
+ }
344
+ const fn = await findFunctionArtifactBySelector(artifact, selector);
345
+ return fn && getFunctionDebugMetadata(artifact, fn);
230
346
  }
231
347
 
232
348
  public async getPublicFunctionDebugMetadata(
233
349
  contractAddress: AztecAddress,
234
350
  ): Promise<FunctionDebugMetadata | undefined> {
235
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
236
- const fnArtifact = artifact && artifact.functions.find(fn => fn.functionType === FunctionType.PUBLIC);
237
- return fnArtifact && getFunctionDebugMetadata(artifact, fnArtifact);
351
+ const artifact = await this.#getArtifactByAddress(contractAddress);
352
+ const fn = artifact && artifact.functions.find(f => f.functionType === FunctionType.PUBLIC);
353
+ return fn && getFunctionDebugMetadata(artifact, fn);
238
354
  }
239
355
 
240
356
  /**
241
357
  * Retrieve the function membership witness for the given contract class and function selector.
242
- * The function membership witness represents a proof that the function belongs to the specified contract.
243
- * Throws an error if the contract address or function selector is unknown.
244
358
  *
245
359
  * @param contractClassId - The id of the class.
246
360
  * @param selector - The function selector.
@@ -255,42 +369,14 @@ export class ContractStore {
255
369
  }
256
370
 
257
371
  public async getDebugContractName(contractAddress: AztecAddress) {
258
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
372
+ const artifact = await this.#getArtifactByAddress(contractAddress);
259
373
  return artifact?.name;
260
374
  }
261
375
 
262
376
  public async getDebugFunctionName(contractAddress: AztecAddress, selector: FunctionSelector) {
263
- const artifact = await this.#getContractArtifactByAddress(contractAddress);
264
- const fnArtifact = artifact && (await this.#findFunctionAbiBySelector(artifact, selector));
265
- return `${artifact?.name ?? contractAddress}:${fnArtifact?.name ?? selector}`;
266
- }
267
-
268
- async #findFunctionArtifactBySelector(
269
- artifact: ContractArtifact,
270
- selector: FunctionSelector,
271
- ): Promise<FunctionArtifact | undefined> {
272
- const functions = artifact.functions;
273
- for (let i = 0; i < functions.length; i++) {
274
- const fn = functions[i];
275
- const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
276
- if (fnSelector.equals(selector)) {
277
- return fn;
278
- }
279
- }
280
- }
281
-
282
- async #findFunctionAbiBySelector(
283
- artifact: ContractArtifact,
284
- selector: FunctionSelector,
285
- ): Promise<FunctionAbi | undefined> {
286
- const functions = [...artifact.functions, ...(artifact.nonDispatchPublicFunctions ?? [])];
287
- for (let i = 0; i < functions.length; i++) {
288
- const fn = functions[i];
289
- const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
290
- if (fnSelector.equals(selector)) {
291
- return fn;
292
- }
293
- }
377
+ const artifact = await this.#getArtifactByAddress(contractAddress);
378
+ const fn = artifact && (await findFunctionAbiBySelector(artifact, selector));
379
+ return `${artifact?.name ?? contractAddress}:${fn?.name ?? selector}`;
294
380
  }
295
381
 
296
382
  public async getFunctionCall(functionName: string, args: any[], to: AztecAddress): Promise<FunctionCall> {
@@ -306,34 +392,17 @@ export class ContractStore {
306
392
  throw new Error(`Unknown function ${functionName} in contract ${contract.name}.`);
307
393
  }
308
394
 
309
- return {
395
+ const selector = await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters);
396
+
397
+ return FunctionCall.from({
310
398
  name: functionDao.name,
311
- args: encodeArguments(functionDao, args),
312
- selector: await FunctionSelector.fromNameAndParameters(functionDao.name, functionDao.parameters),
313
- type: functionDao.functionType,
314
399
  to,
400
+ selector,
401
+ type: functionDao.functionType,
315
402
  hideMsgSender: false,
316
403
  isStatic: functionDao.isStatic,
404
+ args: encodeArguments(functionDao, args),
317
405
  returnTypes: functionDao.returnTypes,
318
- };
319
- }
320
-
321
- // Synchronize target contract data
322
- public async syncPrivateState(
323
- contractAddress: AztecAddress,
324
- functionToInvokeAfterSync: FunctionSelector | null,
325
- utilityExecutor: (privateSyncCall: FunctionCall) => Promise<any>,
326
- ) {
327
- // Protocol contracts don't have private state to sync
328
- if (!isProtocolContract(contractAddress)) {
329
- const syncPrivateStateFunctionCall = await this.getFunctionCall('sync_private_state', [], contractAddress);
330
- if (functionToInvokeAfterSync && functionToInvokeAfterSync.equals(syncPrivateStateFunctionCall.selector)) {
331
- throw new Error(
332
- 'Forbidden `sync_private_state` invocation. `sync_private_state` can only be invoked by PXE, manual execution can lead to inconsistencies.',
333
- );
334
- }
335
-
336
- return utilityExecutor(syncPrivateStateFunctionCall);
337
- }
406
+ });
338
407
  }
339
408
  }
@@ -1 +1 @@
1
- export const PXE_DATA_SCHEMA_VERSION = 2;
1
+ export const PXE_DATA_SCHEMA_VERSION = 6;