@aztec/pxe 0.0.1-commit.e558bd1c → 0.0.1-commit.e57c76e

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 (345) hide show
  1. package/dest/bin/check_oracle_version.js +43 -99
  2. package/dest/bin/index.d.ts +2 -0
  3. package/dest/bin/index.d.ts.map +1 -0
  4. package/dest/bin/index.js +1 -0
  5. package/dest/bin/oracle_version_helpers.d.ts +26 -0
  6. package/dest/bin/oracle_version_helpers.d.ts.map +1 -0
  7. package/dest/bin/oracle_version_helpers.js +93 -0
  8. package/dest/block_synchronizer/block_stream_source.d.ts +10 -0
  9. package/dest/block_synchronizer/block_stream_source.d.ts.map +1 -0
  10. package/dest/block_synchronizer/block_stream_source.js +62 -0
  11. package/dest/block_synchronizer/block_synchronizer.d.ts +6 -2
  12. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  13. package/dest/block_synchronizer/block_synchronizer.js +30 -10
  14. package/dest/config/index.d.ts +8 -2
  15. package/dest/config/index.d.ts.map +1 -1
  16. package/dest/config/index.js +13 -15
  17. package/dest/config/package_info.js +1 -1
  18. package/dest/contract_function_simulator/contract_function_simulator.d.ts +65 -30
  19. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/contract_function_simulator.js +215 -76
  21. package/dest/contract_function_simulator/ephemeral_array_service.d.ts +28 -0
  22. package/dest/contract_function_simulator/ephemeral_array_service.d.ts.map +1 -0
  23. package/dest/contract_function_simulator/ephemeral_array_service.js +78 -0
  24. package/dest/contract_function_simulator/execution_note_cache.d.ts +2 -2
  25. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  26. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +7 -11
  27. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  28. package/dest/contract_function_simulator/execution_tagging_index_cache.js +19 -15
  29. package/dest/contract_function_simulator/index.d.ts +14 -2
  30. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  31. package/dest/contract_function_simulator/index.js +11 -0
  32. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts +48 -0
  33. package/dest/contract_function_simulator/noir-structs/bounded_vec.d.ts.map +1 -0
  34. package/dest/contract_function_simulator/noir-structs/bounded_vec.js +45 -0
  35. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts +37 -0
  36. package/dest/contract_function_simulator/noir-structs/ephemeral_array.d.ts.map +1 -0
  37. package/dest/contract_function_simulator/noir-structs/ephemeral_array.js +59 -0
  38. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +3 -4
  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 +8 -9
  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_data.d.ts +27 -0
  48. package/dest/contract_function_simulator/noir-structs/note_data.d.ts.map +1 -0
  49. package/dest/contract_function_simulator/noir-structs/note_data.js +3 -0
  50. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -5
  51. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  52. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +6 -10
  53. package/dest/contract_function_simulator/noir-structs/option.d.ts +61 -0
  54. package/dest/contract_function_simulator/noir-structs/option.d.ts.map +1 -0
  55. package/dest/contract_function_simulator/noir-structs/option.js +62 -0
  56. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts +11 -0
  57. package/dest/contract_function_simulator/noir-structs/provided_secret.d.ts.map +1 -0
  58. package/dest/contract_function_simulator/noir-structs/provided_secret.js +24 -0
  59. package/dest/contract_function_simulator/oracle/interfaces.d.ts +16 -98
  60. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  61. package/dest/contract_function_simulator/oracle/interfaces.js +2 -2
  62. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +2 -2
  63. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  64. package/dest/contract_function_simulator/oracle/note_packing_utils.js +2 -2
  65. package/dest/contract_function_simulator/oracle/oracle.d.ts +75 -46
  66. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  67. package/dest/contract_function_simulator/oracle/oracle.js +471 -287
  68. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts +127 -0
  69. package/dest/contract_function_simulator/oracle/oracle_registry.d.ts.map +1 -0
  70. package/dest/contract_function_simulator/oracle/oracle_registry.js +786 -0
  71. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts +139 -0
  72. package/dest/contract_function_simulator/oracle/oracle_type_mappings.d.ts.map +1 -0
  73. package/dest/contract_function_simulator/oracle/oracle_type_mappings.js +560 -0
  74. package/dest/contract_function_simulator/oracle/private_execution.js +5 -3
  75. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +68 -97
  76. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  77. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +140 -109
  78. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +146 -72
  79. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  80. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +433 -157
  81. package/dest/contract_function_simulator/pick_notes.d.ts +1 -1
  82. package/dest/contract_function_simulator/pick_notes.d.ts.map +1 -1
  83. package/dest/contract_function_simulator/pick_notes.js +20 -3
  84. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts +1 -1
  85. package/dest/contract_function_simulator/proxied_contract_data_source.d.ts.map +1 -1
  86. package/dest/contract_function_simulator/proxied_contract_data_source.js +35 -64
  87. package/dest/contract_logging.d.ts +27 -0
  88. package/dest/contract_logging.d.ts.map +1 -0
  89. package/dest/contract_logging.js +38 -0
  90. package/dest/contract_sync/contract_sync_service.d.ts +8 -7
  91. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -1
  92. package/dest/contract_sync/contract_sync_service.js +93 -40
  93. package/dest/contract_sync/helpers.d.ts +2 -3
  94. package/dest/contract_sync/helpers.d.ts.map +1 -1
  95. package/dest/contract_sync/helpers.js +12 -14
  96. package/dest/debug/pxe_debug_utils.d.ts +5 -11
  97. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  98. package/dest/debug/pxe_debug_utils.js +4 -13
  99. package/dest/entrypoints/client/bundle/index.d.ts +3 -1
  100. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  101. package/dest/entrypoints/client/bundle/index.js +2 -0
  102. package/dest/entrypoints/client/bundle/utils.d.ts +2 -2
  103. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  104. package/dest/entrypoints/client/bundle/utils.js +21 -5
  105. package/dest/entrypoints/client/lazy/index.d.ts +3 -1
  106. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  107. package/dest/entrypoints/client/lazy/index.js +2 -0
  108. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  109. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  110. package/dest/entrypoints/client/lazy/utils.js +21 -5
  111. package/dest/entrypoints/pxe_creation_options.d.ts +9 -1
  112. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  113. package/dest/entrypoints/pxe_creation_options.js +3 -1
  114. package/dest/entrypoints/server/index.d.ts +4 -2
  115. package/dest/entrypoints/server/index.d.ts.map +1 -1
  116. package/dest/entrypoints/server/index.js +3 -1
  117. package/dest/entrypoints/server/utils.d.ts +4 -3
  118. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  119. package/dest/entrypoints/server/utils.js +21 -5
  120. package/dest/events/event_service.d.ts +15 -6
  121. package/dest/events/event_service.d.ts.map +1 -1
  122. package/dest/events/event_service.js +44 -11
  123. package/dest/events/private_event_filter_validator.d.ts +3 -2
  124. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  125. package/dest/events/private_event_filter_validator.js +15 -0
  126. package/dest/hooks/authorize_utility_call.d.ts +41 -0
  127. package/dest/hooks/authorize_utility_call.d.ts.map +1 -0
  128. package/dest/hooks/authorize_utility_call.js +4 -0
  129. package/dest/hooks/execution_hooks.d.ts +42 -0
  130. package/dest/hooks/execution_hooks.d.ts.map +1 -0
  131. package/dest/hooks/execution_hooks.js +9 -0
  132. package/dest/hooks/index.d.ts +4 -0
  133. package/dest/hooks/index.d.ts.map +1 -0
  134. package/dest/hooks/index.js +1 -0
  135. package/dest/logs/log_service.d.ts +9 -8
  136. package/dest/logs/log_service.d.ts.map +1 -1
  137. package/dest/logs/log_service.js +130 -81
  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 +55 -0
  141. package/dest/notes/note_service.d.ts +27 -5
  142. package/dest/notes/note_service.d.ts.map +1 -1
  143. package/dest/notes/note_service.js +83 -58
  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 -10
  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 +1 -1
  157. package/dest/private_kernel/hints/index.js +1 -1
  158. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +4 -3
  159. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -1
  160. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.js +130 -69
  161. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  162. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  163. package/dest/private_kernel/hints/test_utils.js +202 -0
  164. package/dest/private_kernel/private_kernel_execution_prover.d.ts +6 -2
  165. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  166. package/dest/private_kernel/private_kernel_execution_prover.js +166 -65
  167. package/dest/private_kernel/private_kernel_oracle.d.ts +15 -11
  168. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  169. package/dest/private_kernel/private_kernel_oracle.js +31 -25
  170. package/dest/pxe.d.ts +119 -24
  171. package/dest/pxe.d.ts.map +1 -1
  172. package/dest/pxe.js +223 -137
  173. package/dest/storage/anchor_block_store/anchor_block_store.js +1 -1
  174. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts +42 -0
  175. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.d.ts.map +1 -0
  176. package/dest/storage/backwards_compatibility_tests/kv_store_snapshot.js +93 -0
  177. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts +15 -0
  178. package/dest/storage/backwards_compatibility_tests/schema_tests.d.ts.map +1 -0
  179. package/dest/storage/backwards_compatibility_tests/schema_tests.js +591 -0
  180. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts +19 -0
  181. package/dest/storage/backwards_compatibility_tests/store_spy.d.ts.map +1 -0
  182. package/dest/storage/backwards_compatibility_tests/store_spy.js +63 -0
  183. package/dest/storage/capsule_store/capsule_service.d.ts +21 -0
  184. package/dest/storage/capsule_store/capsule_service.d.ts.map +1 -0
  185. package/dest/storage/capsule_store/capsule_service.js +50 -0
  186. package/dest/storage/capsule_store/capsule_store.d.ts +9 -9
  187. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  188. package/dest/storage/capsule_store/capsule_store.js +36 -28
  189. package/dest/storage/capsule_store/index.d.ts +2 -1
  190. package/dest/storage/capsule_store/index.d.ts.map +1 -1
  191. package/dest/storage/capsule_store/index.js +1 -0
  192. package/dest/storage/contract_store/contract_store.d.ts +42 -15
  193. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  194. package/dest/storage/contract_store/contract_store.js +146 -87
  195. package/dest/storage/metadata.d.ts +1 -1
  196. package/dest/storage/metadata.js +1 -1
  197. package/dest/storage/note_store/note_store.d.ts +3 -3
  198. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  199. package/dest/storage/note_store/note_store.js +3 -4
  200. package/dest/storage/open_pxe_stores.d.ts +33 -0
  201. package/dest/storage/open_pxe_stores.d.ts.map +1 -0
  202. package/dest/storage/open_pxe_stores.js +27 -0
  203. package/dest/storage/private_event_store/private_event_store.d.ts +1 -1
  204. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  205. package/dest/storage/private_event_store/private_event_store.js +3 -0
  206. package/dest/storage/private_event_store/stored_private_event.js +1 -1
  207. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +6 -6
  208. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  209. package/dest/storage/tagging_store/sender_tagging_store.d.ts +29 -28
  210. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  211. package/dest/storage/tagging_store/sender_tagging_store.js +141 -115
  212. package/dest/tagging/get_all_logs_by_tags.d.ts +34 -10
  213. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -1
  214. package/dest/tagging/get_all_logs_by_tags.js +45 -32
  215. package/dest/tagging/index.d.ts +6 -5
  216. package/dest/tagging/index.d.ts.map +1 -1
  217. package/dest/tagging/index.js +4 -3
  218. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts +29 -0
  219. package/dest/tagging/persist_sender_tagging_index_ranges.d.ts.map +1 -0
  220. package/dest/tagging/persist_sender_tagging_index_ranges.js +42 -0
  221. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts +56 -0
  222. package/dest/tagging/recipient_sync/sync_tagged_private_logs.d.ts.map +1 -0
  223. package/dest/tagging/recipient_sync/sync_tagged_private_logs.js +163 -0
  224. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts +3 -3
  225. package/dest/tagging/recipient_sync/utils/find_highest_indexes.d.ts.map +1 -1
  226. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  227. package/dest/tagging/reconcile_tagging_index_ranges.d.ts +36 -0
  228. package/dest/tagging/reconcile_tagging_index_ranges.d.ts.map +1 -0
  229. package/dest/tagging/reconcile_tagging_index_ranges.js +74 -0
  230. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +4 -9
  231. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  232. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +32 -14
  233. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +13 -7
  234. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  235. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +41 -10
  236. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +5 -7
  237. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  238. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +37 -25
  239. package/package.json +20 -17
  240. package/src/bin/check_oracle_version.ts +49 -122
  241. package/src/bin/index.ts +1 -0
  242. package/src/bin/oracle_version_helpers.ts +121 -0
  243. package/src/block_synchronizer/block_stream_source.ts +81 -0
  244. package/src/block_synchronizer/block_synchronizer.ts +33 -11
  245. package/src/config/index.ts +15 -9
  246. package/src/config/package_info.ts +1 -1
  247. package/src/contract_function_simulator/contract_function_simulator.ts +390 -138
  248. package/src/contract_function_simulator/ephemeral_array_service.ts +110 -0
  249. package/src/contract_function_simulator/execution_note_cache.ts +1 -1
  250. package/src/contract_function_simulator/execution_tagging_index_cache.ts +19 -18
  251. package/src/contract_function_simulator/index.ts +51 -1
  252. package/src/contract_function_simulator/noir-structs/bounded_vec.ts +55 -0
  253. package/src/contract_function_simulator/noir-structs/ephemeral_array.ts +66 -0
  254. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +9 -8
  255. package/src/contract_function_simulator/noir-structs/log_retrieval_request.ts +36 -3
  256. package/src/contract_function_simulator/noir-structs/log_retrieval_response.ts +2 -5
  257. package/src/contract_function_simulator/noir-structs/note_data.ts +27 -0
  258. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +4 -9
  259. package/src/contract_function_simulator/noir-structs/option.ts +69 -0
  260. package/src/contract_function_simulator/noir-structs/provided_secret.ts +27 -0
  261. package/src/contract_function_simulator/oracle/interfaces.ts +12 -176
  262. package/src/contract_function_simulator/oracle/note_packing_utils.ts +3 -3
  263. package/src/contract_function_simulator/oracle/oracle.ts +559 -485
  264. package/src/contract_function_simulator/oracle/oracle_registry.ts +585 -0
  265. package/src/contract_function_simulator/oracle/oracle_type_mappings.ts +553 -0
  266. package/src/contract_function_simulator/oracle/private_execution.ts +4 -4
  267. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +170 -203
  268. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +646 -236
  269. package/src/contract_function_simulator/pick_notes.ts +22 -3
  270. package/src/contract_function_simulator/proxied_contract_data_source.ts +41 -64
  271. package/src/contract_logging.ts +52 -0
  272. package/src/contract_sync/contract_sync_service.ts +125 -65
  273. package/src/contract_sync/helpers.ts +13 -20
  274. package/src/debug/pxe_debug_utils.ts +11 -22
  275. package/src/entrypoints/client/bundle/index.ts +2 -0
  276. package/src/entrypoints/client/bundle/utils.ts +19 -6
  277. package/src/entrypoints/client/lazy/index.ts +2 -0
  278. package/src/entrypoints/client/lazy/utils.ts +19 -6
  279. package/src/entrypoints/pxe_creation_options.ts +14 -0
  280. package/src/entrypoints/server/index.ts +3 -1
  281. package/src/entrypoints/server/utils.ts +22 -13
  282. package/src/events/event_service.ts +69 -21
  283. package/src/events/private_event_filter_validator.ts +21 -1
  284. package/src/hooks/authorize_utility_call.ts +44 -0
  285. package/src/hooks/execution_hooks.ts +48 -0
  286. package/src/hooks/index.ts +7 -0
  287. package/src/logs/log_service.ts +160 -143
  288. package/src/messages/message_context_service.ts +62 -0
  289. package/src/notes/note_service.ts +120 -85
  290. package/src/notes_filter.ts +24 -0
  291. package/src/oracle_version.ts +20 -10
  292. package/src/private_kernel/batch_planner.ts +169 -0
  293. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  294. package/src/private_kernel/hints/index.ts +1 -1
  295. package/src/private_kernel/hints/private_kernel_reset_private_inputs_builder.ts +165 -118
  296. package/src/private_kernel/hints/test_utils.ts +318 -0
  297. package/src/private_kernel/private_kernel_execution_prover.ts +254 -89
  298. package/src/private_kernel/private_kernel_oracle.ts +42 -32
  299. package/src/pxe.ts +393 -178
  300. package/src/storage/anchor_block_store/anchor_block_store.ts +1 -1
  301. package/src/storage/backwards_compatibility_tests/__snapshots__/AddressStore.json +22 -0
  302. package/src/storage/backwards_compatibility_tests/__snapshots__/AnchorBlockStore.json +3 -0
  303. package/src/storage/backwards_compatibility_tests/__snapshots__/CapsuleStore.json +16 -0
  304. package/src/storage/backwards_compatibility_tests/__snapshots__/ContractStore.json +28 -0
  305. package/src/storage/backwards_compatibility_tests/__snapshots__/KeyStore.json +52 -0
  306. package/src/storage/backwards_compatibility_tests/__snapshots__/L2TipsKVStore.json +46 -0
  307. package/src/storage/backwards_compatibility_tests/__snapshots__/NoteStore.json +36 -0
  308. package/src/storage/backwards_compatibility_tests/__snapshots__/PrivateEventStore.json +44 -0
  309. package/src/storage/backwards_compatibility_tests/__snapshots__/RecipientTaggingStore.json +18 -0
  310. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderAddressBookStore.json +16 -0
  311. package/src/storage/backwards_compatibility_tests/__snapshots__/SenderTaggingStore.json +22 -0
  312. package/src/storage/backwards_compatibility_tests/__snapshots__/opened_stores.json +97 -0
  313. package/src/storage/backwards_compatibility_tests/kv_store_snapshot.ts +122 -0
  314. package/src/storage/backwards_compatibility_tests/schema_tests.ts +712 -0
  315. package/src/storage/backwards_compatibility_tests/store_spy.ts +73 -0
  316. package/src/storage/capsule_store/capsule_service.ts +90 -0
  317. package/src/storage/capsule_store/capsule_store.ts +44 -26
  318. package/src/storage/capsule_store/index.ts +1 -0
  319. package/src/storage/contract_store/contract_store.ts +182 -104
  320. package/src/storage/metadata.ts +1 -1
  321. package/src/storage/note_store/note_store.ts +5 -5
  322. package/src/storage/open_pxe_stores.ts +49 -0
  323. package/src/storage/private_event_store/private_event_store.ts +4 -0
  324. package/src/storage/private_event_store/stored_private_event.ts +1 -1
  325. package/src/storage/tagging_store/recipient_tagging_store.ts +5 -5
  326. package/src/storage/tagging_store/sender_tagging_store.ts +185 -138
  327. package/src/tagging/get_all_logs_by_tags.ts +87 -35
  328. package/src/tagging/index.ts +5 -4
  329. package/src/tagging/persist_sender_tagging_index_ranges.ts +57 -0
  330. package/src/tagging/recipient_sync/sync_tagged_private_logs.ts +240 -0
  331. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +4 -4
  332. package/src/tagging/reconcile_tagging_index_ranges.ts +102 -0
  333. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +52 -17
  334. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +44 -14
  335. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +27 -27
  336. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  337. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  338. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +0 -15
  339. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +0 -1
  340. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +0 -99
  341. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +0 -15
  342. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +0 -1
  343. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +0 -32
  344. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +0 -143
  345. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +0 -49
@@ -85,9 +85,24 @@ interface ContainsNote {
85
85
  }
86
86
 
87
87
  const selectPropertyFromPackedNoteContent = (noteData: Fr[], selector: PropertySelector): Fr => {
88
+ if (selector.index >= noteData.length) {
89
+ throw new Error(`Property selector index ${selector.index} out of bounds for note with ${noteData.length} fields`);
90
+ }
91
+ if (selector.offset + selector.length > Fr.SIZE_IN_BYTES) {
92
+ throw new Error(
93
+ `Property selector range (offset=${selector.offset}, length=${selector.length}) exceeds Fr buffer size of ${Fr.SIZE_IN_BYTES} bytes`,
94
+ );
95
+ }
88
96
  const noteValueBuffer = noteData[selector.index].toBuffer();
89
- const noteValue = noteValueBuffer.subarray(selector.offset, selector.offset + selector.length);
90
- return Fr.fromBuffer(noteValue);
97
+ // Noir's PropertySelector counts offset from the LSB (last byte of the big-endian buffer),
98
+ // so offset=0,length=Fr.SIZE_IN_BYTES reads the entire field, and offset=0,length=1 reads the last byte.
99
+ const start = Fr.SIZE_IN_BYTES - selector.offset - selector.length;
100
+ const end = Fr.SIZE_IN_BYTES - selector.offset;
101
+ const noteValue = noteValueBuffer.subarray(start, end);
102
+ // Left-pad to Fr.SIZE_IN_BYTES so Fr.fromBuffer interprets the value correctly.
103
+ const padded = Buffer.alloc(Fr.SIZE_IN_BYTES);
104
+ noteValue.copy(padded, Fr.SIZE_IN_BYTES - noteValue.length);
105
+ return Fr.fromBuffer(padded);
91
106
  };
92
107
 
93
108
  const selectNotes = <T extends ContainsNote>(noteDatas: T[], selects: Select[]): T[] =>
@@ -103,7 +118,11 @@ const selectNotes = <T extends ContainsNote>(noteDatas: T[], selects: Select[]):
103
118
  [Comparator.GTE]: () => !noteValueFr.lt(value),
104
119
  };
105
120
 
106
- return comparatorSelector[comparator]();
121
+ const fn = comparatorSelector[comparator];
122
+ if (!fn) {
123
+ throw new Error(`Invalid comparator value: ${comparator}`);
124
+ }
125
+ return fn();
107
126
  }),
108
127
  );
109
128
 
@@ -1,13 +1,20 @@
1
- import { FunctionSelector } from '@aztec/stdlib/abi';
2
- import { AztecAddress } from '@aztec/stdlib/aztec-address';
1
+ import { type FunctionSelector, findFunctionArtifactBySelector } from '@aztec/stdlib/abi';
2
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
3
3
  import type { ContractOverrides } from '@aztec/stdlib/tx';
4
4
 
5
5
  import type { ContractStore } from '../storage/contract_store/contract_store.js';
6
6
 
7
7
  /*
8
- * Proxy generator for a ContractStore that allows overriding contract instances and artifacts, so
9
- * the contract function simulator can execute different bytecode on certain addresses. An example use case
10
- * would be overriding your own account contract so that valid signatures don't have to be provided while simulating.
8
+ * Proxy generator for a ContractStore that allows overriding contract instances at given addresses,
9
+ * so the contract function simulator can execute different bytecode on certain addresses. An example
10
+ * use case would be overriding your own account contract so that valid signatures don't have to be
11
+ * provided while simulating.
12
+ *
13
+ * Function artifact lookups for an overridden address are routed via the override-instance's
14
+ * `currentContractClassId` rather than the underlying ContractStore's address→class mapping —
15
+ * `ContractStore.getFunctionArtifact` calls `this.getContractInstance` internally, which the proxy
16
+ * cannot intercept (the binding sees the raw target, not the proxy). The target class must be
17
+ * registered ahead of time via `pxe.registerContractClass(...)`.
11
18
  */
12
19
  export class ProxiedContractStoreFactory {
13
20
  static create(contractStore: ContractStore, overrides?: ContractOverrides) {
@@ -17,67 +24,37 @@ export class ProxiedContractStoreFactory {
17
24
 
18
25
  return new Proxy(contractStore, {
19
26
  get(target, prop: keyof ContractStore) {
20
- switch (prop) {
21
- case 'getContractInstance': {
22
- return async (address: AztecAddress) => {
23
- if (overrides[address.toString()]) {
24
- const { instance } = overrides[address.toString()]!;
25
- instance.address = address;
26
- const realInstance = await target.getContractInstance(address);
27
- if (!realInstance) {
28
- throw new Error(`Contract instance not found for address: ${address}`);
29
- }
30
- instance.currentContractClassId = realInstance.currentContractClassId;
31
- instance.originalContractClassId = realInstance.originalContractClassId;
32
- return instance;
33
- } else {
34
- return target.getContractInstance(address);
35
- }
36
- };
37
- }
38
- case 'getFunctionArtifact': {
39
- return async (contractAddress: AztecAddress, selector: FunctionSelector) => {
40
- if (overrides[contractAddress.toString()]) {
41
- const { artifact } = overrides[contractAddress.toString()]!;
42
- const functions = artifact.functions;
43
- for (let i = 0; i < functions.length; i++) {
44
- const fn = functions[i];
45
- const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
46
- if (fnSelector.equals(selector)) {
47
- return fn;
48
- }
49
- }
50
- } else {
51
- return target.getFunctionArtifact(contractAddress, selector);
52
- }
53
- };
54
- }
55
- case 'getFunctionArtifactWithDebugMetadata': {
56
- return async (contractAddress: AztecAddress, selector: FunctionSelector) => {
57
- if (overrides[contractAddress.toString()]) {
58
- const { artifact } = overrides[contractAddress.toString()]!;
59
- const functions = artifact.functions;
60
- for (let i = 0; i < functions.length; i++) {
61
- const fn = functions[i];
62
- const fnSelector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
63
- if (fnSelector.equals(selector)) {
64
- return fn;
65
- }
66
- }
67
- } else {
68
- return target.getFunctionArtifactWithDebugMetadata(contractAddress, selector);
69
- }
70
- };
71
- }
72
- default: {
73
- const value = Reflect.get(target, prop);
74
- if (typeof value === 'function') {
75
- return value.bind(target);
27
+ if (prop === 'getContractInstance') {
28
+ return (address: AztecAddress) => {
29
+ const override = overrides[address.toString()];
30
+ return override ? Promise.resolve(override.instance) : target.getContractInstance(address);
31
+ };
32
+ }
33
+ if (prop === 'getFunctionArtifact' || prop === 'getFunctionArtifactWithDebugMetadata') {
34
+ return async (contractAddress: AztecAddress, selector: FunctionSelector) => {
35
+ const override = overrides[contractAddress.toString()];
36
+ if (!override) {
37
+ return (target[prop] as Function).call(target, contractAddress, selector);
38
+ }
39
+ const artifact = await target.getContractArtifact(override.instance.currentContractClassId);
40
+ if (!artifact) {
41
+ throw new Error(
42
+ `No artifact registered for override class ${override.instance.currentContractClassId} ` +
43
+ `at ${contractAddress}. Register it via pxe.registerContractClass(...) before simulating.`,
44
+ );
45
+ }
46
+ const fn = await findFunctionArtifactBySelector(artifact, selector);
47
+ if (!fn) {
48
+ throw new Error(
49
+ `Function with selector ${selector} not found in stub artifact for overridden contract at ${contractAddress}.`,
50
+ );
76
51
  }
77
- return value;
78
- }
52
+ return { ...fn, contractName: artifact.name };
53
+ };
79
54
  }
55
+ const value = Reflect.get(target, prop);
56
+ return typeof value === 'function' ? value.bind(target) : value;
80
57
  },
81
- });
58
+ }) satisfies ContractStore;
82
59
  }
83
60
  }
@@ -0,0 +1,52 @@
1
+ import type { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { type LogLevel, type Logger, applyStringFormatting, createLogger } from '@aztec/foundation/log';
3
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
+ import type { DebugLog } from '@aztec/stdlib/logs';
5
+
6
+ /** Resolves a contract address to a human-readable name, if available. */
7
+ export type ContractNameResolver = (address: AztecAddress) => Promise<string | undefined>;
8
+ export type CONTRACT_LOG_KIND = 'aztecnr' | 'user';
9
+
10
+ /**
11
+ * Creates a logger whose output is prefixed with `contract:<name>(<addrAbbrev>)`.
12
+ */
13
+ export async function createContractLogger(
14
+ contractAddress: AztecAddress,
15
+ getContractName: ContractNameResolver,
16
+ kind: CONTRACT_LOG_KIND,
17
+ options?: { instanceId?: string },
18
+ ): Promise<Logger> {
19
+ const addrAbbrev = contractAddress.toString().slice(0, 10);
20
+ const name = await getContractName(contractAddress);
21
+
22
+ const prefix = kind == 'aztecnr' ? 'aztecnr' : 'contract';
23
+ const module = name ? `${prefix}:${name}(${addrAbbrev})` : `${prefix}:Unknown(${addrAbbrev})`;
24
+ return createLogger(module, options);
25
+ }
26
+
27
+ /**
28
+ * Formats and emits a single contract log message through the given logger.
29
+ */
30
+ export function logContractMessage(logger: Logger, level: LogLevel, message: string, fields: Fr[]): void {
31
+ logger[level](applyStringFormatting(message, fields));
32
+ }
33
+
34
+ /**
35
+ * Displays debug logs collected during public function simulation,
36
+ * using the `contract:` prefixed logger format.
37
+ */
38
+ export async function displayDebugLogs(debugLogs: DebugLog[], getContractName: ContractNameResolver): Promise<void> {
39
+ for (const log of debugLogs) {
40
+ const { kind, message } = stripAztecnrLogPrefix(log.message);
41
+ const logger = await createContractLogger(log.contractAddress, getContractName, kind);
42
+ logContractMessage(logger, log.level, message, log.fields);
43
+ }
44
+ }
45
+
46
+ export function stripAztecnrLogPrefix(message: string): { kind: CONTRACT_LOG_KIND; message: string } {
47
+ if (message.startsWith('[aztec-nr] ')) {
48
+ return { kind: 'aztecnr', message: message.slice('[aztec-nr] '.length) };
49
+ } else {
50
+ return { kind: 'user', message };
51
+ }
52
+ }
@@ -1,13 +1,19 @@
1
1
  import type { Logger } from '@aztec/foundation/log';
2
+ import { Semaphore } from '@aztec/foundation/queue';
3
+ import { isProtocolContract } from '@aztec/protocol-contracts';
2
4
  import type { FunctionCall, FunctionSelector } from '@aztec/stdlib/abi';
3
5
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
6
  import type { AztecNode } from '@aztec/stdlib/interfaces/client';
5
7
  import type { BlockHeader } from '@aztec/stdlib/tx';
6
8
 
7
9
  import type { StagedStore } from '../job_coordinator/job_coordinator.js';
10
+ import { NoteService } from '../notes/note_service.js';
8
11
  import type { ContractStore } from '../storage/contract_store/contract_store.js';
9
12
  import type { NoteStore } from '../storage/note_store/note_store.js';
10
- import { syncState, verifyCurrentClassId } from './helpers.js';
13
+ import { syncScope, verifyCurrentClassId } from './helpers.js';
14
+
15
+ /** Maximum number of scope syncs running concurrently across the PXE. */
16
+ const MAX_CONCURRENT_SCOPE_SYNCS = 5;
11
17
 
12
18
  /**
13
19
  * Service for syncing the private state of contracts and verifying that the PXE holds the current class artifact.
@@ -18,12 +24,19 @@ import { syncState, verifyCurrentClassId } from './helpers.js';
18
24
  export class ContractSyncService implements StagedStore {
19
25
  readonly storeName = 'contract_sync';
20
26
 
21
- // Tracks contracts synced since last wipe. Key is contract address string, value is a promise that resolves when
22
- // the contract is synced.
27
+ // Tracks contracts synced since last wipe. The cache is keyed per individual scope address
28
+ // (`contractAddress:scopeAddress`), or `contractAddress:*` for all scopes (all accounts).
29
+ // The value is a promise that resolves when the contract is synced.
23
30
  private syncedContracts: Map<string, Promise<void>> = new Map();
24
31
 
25
- // Per-job overridden contract addresses - these contracts should not be synced.
26
- private overriddenContracts: Map<string, Set<string>> = new Map();
32
+ // Tracks class ID verification per contract. Keyed by contract address only (no scope), since
33
+ // class ID verification is scope-independent. Cleared on wipe/discard.
34
+ private classIdVerificationCache: Map<string, Promise<void>> = new Map();
35
+
36
+ // Bounds the number of scope syncs running concurrently. Scopes beyond this limit queue here. Sized to trade off
37
+ // parallelism on non-ACIR work (node RPC, note store reads) against memory pressure from concurrent circuit
38
+ // execution.
39
+ #syncSlot = new Semaphore(MAX_CONCURRENT_SCOPE_SYNCS);
27
40
 
28
41
  constructor(
29
42
  private aztecNode: AztecNode,
@@ -32,11 +45,6 @@ export class ContractSyncService implements StagedStore {
32
45
  private log: Logger,
33
46
  ) {}
34
47
 
35
- /** Sets contracts that should be skipped during sync for a specific job. */
36
- setOverriddenContracts(jobId: string, addresses: Set<string>): void {
37
- this.overriddenContracts.set(jobId, addresses);
38
- }
39
-
40
48
  /**
41
49
  * Ensures a contract's private state is synchronized and that the PXE holds the current class artifact.
42
50
  * Uses a cache to avoid redundant sync operations - the cache is wiped when the anchor block changes.
@@ -44,86 +52,138 @@ export class ContractSyncService implements StagedStore {
44
52
  * @param functionToInvokeAfterSync - The function selector that will be called after sync (used to validate it's
45
53
  * not sync_state itself).
46
54
  * @param utilityExecutor - Executor function for running the sync_state utility function.
55
+ * @param scopes - Access scopes to pass through to the utility executor (affects whose account's private state is discovered).
47
56
  */
48
57
  async ensureContractSynced(
49
58
  contractAddress: AztecAddress,
50
59
  functionToInvokeAfterSync: FunctionSelector | null,
51
- utilityExecutor: (call: FunctionCall) => Promise<any>,
60
+ utilityExecutor: (call: FunctionCall, scopes: AztecAddress[]) => Promise<any>,
52
61
  anchorBlockHeader: BlockHeader,
53
62
  jobId: string,
63
+ scopes: AztecAddress[],
54
64
  ): Promise<void> {
55
- const key = contractAddress.toString();
56
-
57
- // Skip sync if this contract has an override for this job
58
- const overrides = this.overriddenContracts.get(jobId);
59
- if (overrides?.has(key)) {
60
- return;
61
- }
62
-
63
- const existing = this.syncedContracts.get(key);
64
- if (existing) {
65
- return existing;
66
- }
67
-
68
- const syncPromise = this.#doSync(
69
- contractAddress,
70
- functionToInvokeAfterSync,
71
- utilityExecutor,
72
- anchorBlockHeader,
73
- jobId,
65
+ this.#startSyncIfNeeded(contractAddress, scopes, anchorBlockHeader, jobId, scope =>
66
+ syncScope(contractAddress, this.contractStore, functionToInvokeAfterSync, utilityExecutor, scope),
74
67
  );
75
- this.syncedContracts.set(key, syncPromise);
76
68
 
77
- try {
78
- await syncPromise;
79
- } catch (err) {
80
- // There was an error syncing the contract, so we remove it from the cache so that it can be retried.
81
- this.syncedContracts.delete(key);
82
- throw err;
83
- }
69
+ await this.#awaitSync(contractAddress, scopes);
84
70
  }
85
71
 
86
- async #doSync(
87
- contractAddress: AztecAddress,
88
- functionToInvokeAfterSync: FunctionSelector | null,
89
- utilityExecutor: (call: FunctionCall) => Promise<any>,
90
- anchorBlockHeader: BlockHeader,
91
- jobId: string,
92
- ): Promise<void> {
93
- this.log.debug(`Syncing contract ${contractAddress}`);
94
- await Promise.all([
95
- syncState(
96
- contractAddress,
97
- this.contractStore,
98
- functionToInvokeAfterSync,
99
- utilityExecutor,
100
- this.noteStore,
101
- this.aztecNode,
102
- anchorBlockHeader,
103
- jobId,
104
- ),
105
- verifyCurrentClassId(contractAddress, this.aztecNode, this.contractStore, anchorBlockHeader),
106
- ]);
107
- this.log.debug(`Contract ${contractAddress} synced`);
72
+ /** Clears sync cache entries for the given scopes of a contract. */
73
+ invalidateContractForScopes(contractAddress: AztecAddress, scopes: AztecAddress[]): void {
74
+ if (scopes.length === 0) {
75
+ return;
76
+ }
77
+ scopes.forEach(scope => this.syncedContracts.delete(toKey(contractAddress, scope)));
108
78
  }
109
79
 
110
80
  /** Clears sync cache. Called by BlockSynchronizer when anchor block changes. */
111
81
  wipe(): void {
112
82
  this.log.debug(`Wiping contract sync cache (${this.syncedContracts.size} entries)`);
113
83
  this.syncedContracts.clear();
84
+ this.classIdVerificationCache.clear();
114
85
  }
115
86
 
116
- commit(jobId: string): Promise<void> {
117
- // Clear overridden contracts for this job
118
- this.overriddenContracts.delete(jobId);
87
+ commit(_jobId: string): Promise<void> {
119
88
  return Promise.resolve();
120
89
  }
121
90
 
122
- discardStaged(jobId: string): Promise<void> {
91
+ discardStaged(_jobId: string): Promise<void> {
123
92
  // We clear the synced contracts cache here because, when the job is discarded, any associated database writes from
124
93
  // the sync are also undone.
125
94
  this.syncedContracts.clear();
126
- this.overriddenContracts.delete(jobId);
95
+ this.classIdVerificationCache.clear();
127
96
  return Promise.resolve();
128
97
  }
98
+
99
+ /**
100
+ * For each unsynced scope, creates a promise that waits on:
101
+ * 1. Class ID verification (cached per contract, scope-independent).
102
+ * 2. Note nullifier sync (shared, batched across all unsynced scopes).
103
+ * 3. Per-scope sync (individual, semaphore-bounded).
104
+ */
105
+ #startSyncIfNeeded(
106
+ contractAddress: AztecAddress,
107
+ scopes: AztecAddress[],
108
+ anchorBlockHeader: BlockHeader,
109
+ jobId: string,
110
+ syncScopeFn: (scope: AztecAddress) => Promise<void>,
111
+ ): void {
112
+ const scopesToSync = scopes.filter(scope => !this.syncedContracts.has(toKey(contractAddress, scope)));
113
+ if (scopesToSync.length === 0) {
114
+ return;
115
+ }
116
+
117
+ this.log.debug(`Syncing contract ${contractAddress} for ${scopesToSync.length} scope(s)`);
118
+
119
+ const verifyPromise = this.#verifyClassId(contractAddress, anchorBlockHeader);
120
+ const syncNullifiersPromise = this.#syncNoteNullifiers(contractAddress, anchorBlockHeader, jobId, scopesToSync);
121
+
122
+ for (const scope of scopesToSync) {
123
+ const key = toKey(contractAddress, scope);
124
+ const promise = Promise.all([verifyPromise, syncNullifiersPromise, this.#runBounded(() => syncScopeFn(scope))])
125
+ .then(() => {})
126
+ .catch(err => {
127
+ this.syncedContracts.delete(key);
128
+ throw err;
129
+ });
130
+ this.syncedContracts.set(key, promise);
131
+ }
132
+ }
133
+
134
+ /** Verifies the local class ID matches the on-chain value (cached, evicts on failure so retries re-verify). */
135
+ #verifyClassId(contractAddress: AztecAddress, anchorBlockHeader: BlockHeader): Promise<void> {
136
+ const contractKey = contractAddress.toString();
137
+ const cached = this.classIdVerificationCache.get(contractKey);
138
+ if (cached) {
139
+ return cached;
140
+ }
141
+ const promise = verifyCurrentClassId(contractAddress, this.aztecNode, this.contractStore, anchorBlockHeader).catch(
142
+ err => {
143
+ this.classIdVerificationCache.delete(contractKey);
144
+ throw err;
145
+ },
146
+ );
147
+ this.classIdVerificationCache.set(contractKey, promise);
148
+ return promise;
149
+ }
150
+
151
+ /** Syncs note nullifiers across all unsynced scopes in a single batched call. */
152
+ async #syncNoteNullifiers(
153
+ contractAddress: AztecAddress,
154
+ anchorBlockHeader: BlockHeader,
155
+ jobId: string,
156
+ scopes: AztecAddress[],
157
+ ): Promise<void> {
158
+ // Protocol contracts don't have private state to sync
159
+ if (isProtocolContract(contractAddress)) {
160
+ return;
161
+ }
162
+ // This runs in parallel with per-scope sync (which also writes to the note store). That's safe because
163
+ // the note store handles concurrent operations.
164
+ const noteService = new NoteService(this.noteStore, this.aztecNode, anchorBlockHeader, jobId);
165
+ await noteService.syncNoteNullifiers(contractAddress, scopes);
166
+ }
167
+
168
+ /** Runs fn while holding a slot in #syncSlot, bounding total concurrent scope syncs. */
169
+ async #runBounded<T>(fn: () => Promise<T>): Promise<T> {
170
+ await this.#syncSlot.acquire();
171
+ try {
172
+ return await fn();
173
+ } finally {
174
+ this.#syncSlot.release();
175
+ }
176
+ }
177
+
178
+ /** Collects all relevant scope promises (including in-flight ones from concurrent calls) and awaits them. */
179
+ async #awaitSync(contractAddress: AztecAddress, scopes: AztecAddress[]): Promise<void> {
180
+ const promises = scopes
181
+ .map(scope => this.syncedContracts.get(toKey(contractAddress, scope)))
182
+ .filter(p => p !== undefined);
183
+ await Promise.all(promises);
184
+ }
185
+ }
186
+
187
+ function toKey(contract: AztecAddress, scope: AztecAddress) {
188
+ return `${contract.toString()}:${scope.toString()}`;
129
189
  }
@@ -6,9 +6,7 @@ import { DelayedPublicMutableValues, DelayedPublicMutableValuesWithHash } from '
6
6
  import type { AztecNode } from '@aztec/stdlib/interfaces/client';
7
7
  import type { BlockHeader } from '@aztec/stdlib/tx';
8
8
 
9
- import { NoteService } from '../notes/note_service.js';
10
9
  import type { ContractStore } from '../storage/contract_store/contract_store.js';
11
- import type { NoteStore } from '../storage/note_store/note_store.js';
12
10
 
13
11
  /**
14
12
  * Read the current class id of a contract from the execution data provider or AztecNode. If not found, class id
@@ -38,31 +36,26 @@ export async function readCurrentClassId(
38
36
  return currentClassId;
39
37
  }
40
38
 
41
- export async function syncState(
39
+ export async function syncScope(
42
40
  contractAddress: AztecAddress,
43
41
  contractStore: ContractStore,
44
42
  functionToInvokeAfterSync: FunctionSelector | null,
45
- utilityExecutor: (privateSyncCall: FunctionCall) => Promise<any>,
46
- noteStore: NoteStore,
47
- aztecNode: AztecNode,
48
- anchorBlockHeader: BlockHeader,
49
- jobId: string,
43
+ utilityExecutor: (privateSyncCall: FunctionCall, scopes: AztecAddress[]) => Promise<any>,
44
+ scope: AztecAddress,
50
45
  ) {
51
46
  // Protocol contracts don't have private state to sync
52
- if (!isProtocolContract(contractAddress)) {
53
- const syncStateFunctionCall = await contractStore.getFunctionCall('sync_state', [], contractAddress);
54
- if (functionToInvokeAfterSync && functionToInvokeAfterSync.equals(syncStateFunctionCall.selector)) {
55
- throw new Error(
56
- 'Forbidden `sync_state` invocation. `sync_state` can only be invoked by PXE, manual execution can lead to inconsistencies.',
57
- );
58
- }
59
-
60
- const noteService = new NoteService(noteStore, aztecNode, anchorBlockHeader, jobId);
47
+ if (isProtocolContract(contractAddress)) {
48
+ return;
49
+ }
61
50
 
62
- // Both sync_state and syncNoteNullifiers interact with the note store, but running them in parallel is safe
63
- // because note store is designed to handle concurrent operations.
64
- await Promise.all([utilityExecutor(syncStateFunctionCall), noteService.syncNoteNullifiers(contractAddress)]);
51
+ const syncStateFunctionCall = await contractStore.getFunctionCall('sync_state', [scope], contractAddress);
52
+ if (functionToInvokeAfterSync && functionToInvokeAfterSync.equals(syncStateFunctionCall.selector)) {
53
+ throw new Error(
54
+ 'Forbidden `sync_state` invocation. `sync_state` can only be invoked by PXE, manual execution can lead to inconsistencies.',
55
+ );
65
56
  }
57
+
58
+ await utilityExecutor(syncStateFunctionCall, [scope]);
66
59
  }
67
60
 
68
61
  /**
@@ -1,12 +1,13 @@
1
1
  import type { FunctionCall } from '@aztec/stdlib/abi';
2
2
  import type { AuthWitness } from '@aztec/stdlib/auth-witness';
3
3
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
- import type { NoteDao, NotesFilter } from '@aztec/stdlib/note';
5
- import type { BlockHeader, ContractOverrides } from '@aztec/stdlib/tx';
4
+ import type { NoteDao } from '@aztec/stdlib/note';
5
+ import type { ContractOverrides } from '@aztec/stdlib/tx';
6
6
 
7
7
  import type { BlockSynchronizer } from '../block_synchronizer/block_synchronizer.js';
8
8
  import type { ContractFunctionSimulator } from '../contract_function_simulator/contract_function_simulator.js';
9
9
  import type { ContractSyncService } from '../contract_sync/contract_sync_service.js';
10
+ import type { NotesFilter } from '../notes_filter.js';
10
11
  import type { AnchorBlockStore } from '../storage/index.js';
11
12
  import type { NoteStore } from '../storage/note_store/note_store.js';
12
13
 
@@ -17,11 +18,11 @@ import type { NoteStore } from '../storage/note_store/note_store.js';
17
18
  export class PXEDebugUtils {
18
19
  #putJobInQueue!: <T>(job: (jobId: string) => Promise<T>) => Promise<T>;
19
20
  #getSimulatorForTx!: (overrides?: { contracts?: ContractOverrides }) => ContractFunctionSimulator;
20
- #simulateUtility!: (
21
+ #executeUtility!: (
21
22
  contractFunctionSimulator: ContractFunctionSimulator,
22
23
  call: FunctionCall,
23
24
  authWitnesses: AuthWitness[] | undefined,
24
- scopes: AztecAddress[] | undefined,
25
+ scopes: AztecAddress[],
25
26
  jobId: string,
26
27
  ) => Promise<any>;
27
28
 
@@ -36,17 +37,17 @@ export class PXEDebugUtils {
36
37
  public setPXEHelpers(
37
38
  putJobInQueue: <T>(job: (jobId: string) => Promise<T>) => Promise<T>,
38
39
  getSimulatorForTx: (overrides?: { contracts?: ContractOverrides }) => ContractFunctionSimulator,
39
- simulateUtility: (
40
+ executeUtility: (
40
41
  contractFunctionSimulator: ContractFunctionSimulator,
41
42
  call: FunctionCall,
42
43
  authWitnesses: AuthWitness[] | undefined,
43
- scopes: AztecAddress[] | undefined,
44
+ scopes: AztecAddress[],
44
45
  jobId: string,
45
46
  ) => Promise<any>,
46
47
  ) {
47
48
  this.#putJobInQueue = putJobInQueue;
48
49
  this.#getSimulatorForTx = getSimulatorForTx;
49
- this.#simulateUtility = simulateUtility;
50
+ this.#executeUtility = executeUtility;
50
51
  }
51
52
 
52
53
  /**
@@ -71,26 +72,14 @@ export class PXEDebugUtils {
71
72
  await this.contractSyncService.ensureContractSynced(
72
73
  filter.contractAddress,
73
74
  null,
74
- async privateSyncCall =>
75
- await this.#simulateUtility(contractFunctionSimulator, privateSyncCall, [], undefined, jobId),
75
+ async (privateSyncCall, execScopes) =>
76
+ await this.#executeUtility(contractFunctionSimulator, privateSyncCall, [], execScopes, jobId),
76
77
  anchorBlockHeader,
77
78
  jobId,
79
+ filter.scopes,
78
80
  );
79
81
 
80
82
  return this.noteStore.getNotes(filter, jobId);
81
83
  });
82
84
  }
83
-
84
- /** Returns the block header up to which the PXE has synced. */
85
- public getSyncedBlockHeader(): Promise<BlockHeader> {
86
- return this.anchorBlockStore.getBlockHeader();
87
- }
88
-
89
- /**
90
- * Triggers a sync of the PXE with the node.
91
- * Blocks until the sync is complete.
92
- */
93
- public sync(): Promise<void> {
94
- return this.#putJobInQueue(() => this.blockStateSynchronizer.sync());
95
- }
96
85
  }
@@ -1,6 +1,8 @@
1
+ export * from '../../../notes_filter.js';
1
2
  export * from '../../../pxe.js';
2
3
  export * from '../../../config/index.js';
3
4
  export * from '../../../error_enriching.js';
5
+ export * from '../../../contract_logging.js';
4
6
  export * from '../../../storage/index.js';
5
7
  export * from './utils.js';
6
8
  export type { PXECreationOptions } from '../../pxe_creation_options.js';