@aztec/pxe 0.0.1-commit.c7c42ec → 0.0.1-commit.c949de6bc

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 (274) hide show
  1. package/dest/access_scopes.d.ts +9 -0
  2. package/dest/access_scopes.d.ts.map +1 -0
  3. package/dest/access_scopes.js +6 -0
  4. package/dest/bin/check_oracle_version.js +1 -1
  5. package/dest/block_synchronizer/block_synchronizer.d.ts +13 -5
  6. package/dest/block_synchronizer/block_synchronizer.d.ts.map +1 -1
  7. package/dest/block_synchronizer/block_synchronizer.js +74 -20
  8. package/dest/config/index.d.ts +3 -1
  9. package/dest/config/index.d.ts.map +1 -1
  10. package/dest/config/index.js +17 -0
  11. package/dest/config/package_info.js +1 -1
  12. package/dest/contract_function_simulator/benchmarked_node.d.ts +9 -0
  13. package/dest/contract_function_simulator/benchmarked_node.d.ts.map +1 -0
  14. package/dest/contract_function_simulator/benchmarked_node.js +77 -0
  15. package/dest/contract_function_simulator/contract_function_simulator.d.ts +57 -34
  16. package/dest/contract_function_simulator/contract_function_simulator.d.ts.map +1 -1
  17. package/dest/contract_function_simulator/contract_function_simulator.js +199 -81
  18. package/dest/contract_function_simulator/execution_note_cache.d.ts +18 -9
  19. package/dest/contract_function_simulator/execution_note_cache.d.ts.map +1 -1
  20. package/dest/contract_function_simulator/execution_note_cache.js +45 -28
  21. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts +5 -5
  22. package/dest/contract_function_simulator/execution_tagging_index_cache.d.ts.map +1 -1
  23. package/dest/contract_function_simulator/execution_tagging_index_cache.js +3 -3
  24. package/dest/contract_function_simulator/index.d.ts +2 -2
  25. package/dest/contract_function_simulator/index.d.ts.map +1 -1
  26. package/dest/contract_function_simulator/index.js +1 -1
  27. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts +4 -3
  28. package/dest/contract_function_simulator/noir-structs/event_validation_request.d.ts.map +1 -1
  29. package/dest/contract_function_simulator/noir-structs/event_validation_request.js +7 -4
  30. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts +3 -3
  31. package/dest/contract_function_simulator/noir-structs/note_validation_request.d.ts.map +1 -1
  32. package/dest/contract_function_simulator/noir-structs/note_validation_request.js +2 -2
  33. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts +4 -10
  34. package/dest/contract_function_simulator/noir-structs/utility_context.d.ts.map +1 -1
  35. package/dest/contract_function_simulator/noir-structs/utility_context.js +7 -18
  36. package/dest/contract_function_simulator/oracle/interfaces.d.ts +17 -13
  37. package/dest/contract_function_simulator/oracle/interfaces.d.ts.map +1 -1
  38. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts +3 -1
  39. package/dest/contract_function_simulator/oracle/message_load_oracle_inputs.d.ts.map +1 -1
  40. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts +6 -6
  41. package/dest/contract_function_simulator/oracle/note_packing_utils.d.ts.map +1 -1
  42. package/dest/contract_function_simulator/oracle/note_packing_utils.js +8 -8
  43. package/dest/contract_function_simulator/oracle/oracle.d.ts +12 -10
  44. package/dest/contract_function_simulator/oracle/oracle.d.ts.map +1 -1
  45. package/dest/contract_function_simulator/oracle/oracle.js +67 -44
  46. package/dest/contract_function_simulator/oracle/private_execution.d.ts +2 -26
  47. package/dest/contract_function_simulator/oracle/private_execution.d.ts.map +1 -1
  48. package/dest/contract_function_simulator/oracle/private_execution.js +1 -37
  49. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts +45 -47
  50. package/dest/contract_function_simulator/oracle/private_execution_oracle.d.ts.map +1 -1
  51. package/dest/contract_function_simulator/oracle/private_execution_oracle.js +91 -60
  52. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts +67 -33
  53. package/dest/contract_function_simulator/oracle/utility_execution_oracle.d.ts.map +1 -1
  54. package/dest/contract_function_simulator/oracle/utility_execution_oracle.js +131 -110
  55. package/dest/contract_logging.d.ts +22 -0
  56. package/dest/contract_logging.d.ts.map +1 -0
  57. package/dest/contract_logging.js +23 -0
  58. package/dest/contract_sync/contract_sync_service.d.ts +43 -0
  59. package/dest/contract_sync/contract_sync_service.d.ts.map +1 -0
  60. package/dest/contract_sync/contract_sync_service.js +97 -0
  61. package/dest/contract_sync/helpers.d.ts +29 -0
  62. package/dest/contract_sync/helpers.d.ts.map +1 -0
  63. package/dest/contract_sync/helpers.js +55 -0
  64. package/dest/debug/pxe_debug_utils.d.ts +24 -10
  65. package/dest/debug/pxe_debug_utils.d.ts.map +1 -1
  66. package/dest/debug/pxe_debug_utils.js +28 -17
  67. package/dest/entrypoints/client/bundle/index.d.ts +4 -1
  68. package/dest/entrypoints/client/bundle/index.d.ts.map +1 -1
  69. package/dest/entrypoints/client/bundle/index.js +3 -0
  70. package/dest/entrypoints/client/bundle/utils.d.ts +1 -1
  71. package/dest/entrypoints/client/bundle/utils.d.ts.map +1 -1
  72. package/dest/entrypoints/client/bundle/utils.js +31 -8
  73. package/dest/entrypoints/client/lazy/index.d.ts +4 -1
  74. package/dest/entrypoints/client/lazy/index.d.ts.map +1 -1
  75. package/dest/entrypoints/client/lazy/index.js +3 -0
  76. package/dest/entrypoints/client/lazy/utils.d.ts +2 -2
  77. package/dest/entrypoints/client/lazy/utils.d.ts.map +1 -1
  78. package/dest/entrypoints/client/lazy/utils.js +32 -9
  79. package/dest/entrypoints/pxe_creation_options.d.ts +5 -3
  80. package/dest/entrypoints/pxe_creation_options.d.ts.map +1 -1
  81. package/dest/entrypoints/server/index.d.ts +5 -1
  82. package/dest/entrypoints/server/index.d.ts.map +1 -1
  83. package/dest/entrypoints/server/index.js +4 -0
  84. package/dest/entrypoints/server/utils.d.ts +1 -1
  85. package/dest/entrypoints/server/utils.d.ts.map +1 -1
  86. package/dest/entrypoints/server/utils.js +39 -16
  87. package/dest/events/event_service.d.ts +6 -6
  88. package/dest/events/event_service.d.ts.map +1 -1
  89. package/dest/events/event_service.js +19 -22
  90. package/dest/events/private_event_filter_validator.d.ts +5 -5
  91. package/dest/events/private_event_filter_validator.d.ts.map +1 -1
  92. package/dest/events/private_event_filter_validator.js +5 -6
  93. package/dest/job_coordinator/job_coordinator.d.ts +75 -0
  94. package/dest/job_coordinator/job_coordinator.d.ts.map +1 -0
  95. package/dest/job_coordinator/job_coordinator.js +94 -0
  96. package/dest/logs/log_service.d.ts +8 -5
  97. package/dest/logs/log_service.d.ts.map +1 -1
  98. package/dest/logs/log_service.js +31 -33
  99. package/dest/notes/note_service.d.ts +10 -9
  100. package/dest/notes/note_service.d.ts.map +1 -1
  101. package/dest/notes/note_service.js +34 -38
  102. package/dest/notes_filter.d.ts +25 -0
  103. package/dest/notes_filter.d.ts.map +1 -0
  104. package/dest/notes_filter.js +4 -0
  105. package/dest/oracle_version.d.ts +3 -3
  106. package/dest/oracle_version.d.ts.map +1 -1
  107. package/dest/oracle_version.js +4 -3
  108. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts +4 -0
  109. package/dest/private_kernel/hints/compute_tx_expiration_timestamp.d.ts.map +1 -0
  110. package/dest/private_kernel/hints/{compute_tx_include_by_timestamp.js → compute_tx_expiration_timestamp.js} +12 -12
  111. package/dest/private_kernel/hints/index.d.ts +3 -3
  112. package/dest/private_kernel/hints/index.d.ts.map +1 -1
  113. package/dest/private_kernel/hints/index.js +2 -2
  114. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts +29 -0
  115. package/dest/private_kernel/hints/private_kernel_reset_private_inputs_builder.d.ts.map +1 -0
  116. package/dest/private_kernel/hints/{build_private_kernel_reset_private_inputs.js → private_kernel_reset_private_inputs_builder.js} +141 -74
  117. package/dest/private_kernel/hints/test_utils.d.ts +122 -0
  118. package/dest/private_kernel/hints/test_utils.d.ts.map +1 -0
  119. package/dest/private_kernel/hints/test_utils.js +203 -0
  120. package/dest/private_kernel/private_kernel_execution_prover.d.ts +3 -2
  121. package/dest/private_kernel/private_kernel_execution_prover.d.ts.map +1 -1
  122. package/dest/private_kernel/private_kernel_execution_prover.js +24 -17
  123. package/dest/private_kernel/private_kernel_oracle.d.ts +24 -24
  124. package/dest/private_kernel/private_kernel_oracle.d.ts.map +1 -1
  125. package/dest/private_kernel/private_kernel_oracle.js +94 -2
  126. package/dest/pxe.d.ts +76 -58
  127. package/dest/pxe.d.ts.map +1 -1
  128. package/dest/pxe.js +151 -136
  129. package/dest/storage/address_store/address_store.d.ts +1 -1
  130. package/dest/storage/address_store/address_store.d.ts.map +1 -1
  131. package/dest/storage/address_store/address_store.js +12 -11
  132. package/dest/storage/anchor_block_store/anchor_block_store.d.ts +9 -1
  133. package/dest/storage/anchor_block_store/anchor_block_store.d.ts.map +1 -1
  134. package/dest/storage/anchor_block_store/anchor_block_store.js +8 -1
  135. package/dest/storage/capsule_store/capsule_store.d.ts +24 -9
  136. package/dest/storage/capsule_store/capsule_store.d.ts.map +1 -1
  137. package/dest/storage/capsule_store/capsule_store.js +130 -23
  138. package/dest/storage/contract_store/contract_store.d.ts +42 -15
  139. package/dest/storage/contract_store/contract_store.d.ts.map +1 -1
  140. package/dest/storage/contract_store/contract_store.js +157 -72
  141. package/dest/storage/metadata.d.ts +1 -1
  142. package/dest/storage/metadata.js +1 -1
  143. package/dest/storage/note_store/note_store.d.ts +50 -51
  144. package/dest/storage/note_store/note_store.d.ts.map +1 -1
  145. package/dest/storage/note_store/note_store.js +284 -263
  146. package/dest/storage/note_store/stored_note.d.ts +16 -0
  147. package/dest/storage/note_store/stored_note.d.ts.map +1 -0
  148. package/dest/storage/note_store/stored_note.js +43 -0
  149. package/dest/storage/private_event_store/private_event_store.d.ts +47 -7
  150. package/dest/storage/private_event_store/private_event_store.d.ts.map +1 -1
  151. package/dest/storage/private_event_store/private_event_store.js +231 -73
  152. package/dest/storage/private_event_store/stored_private_event.d.ts +23 -0
  153. package/dest/storage/private_event_store/stored_private_event.d.ts.map +1 -0
  154. package/dest/storage/private_event_store/stored_private_event.js +56 -0
  155. package/dest/storage/tagging_store/recipient_tagging_store.d.ts +16 -9
  156. package/dest/storage/tagging_store/recipient_tagging_store.d.ts.map +1 -1
  157. package/dest/storage/tagging_store/recipient_tagging_store.js +88 -19
  158. package/dest/storage/tagging_store/sender_address_book_store.d.ts +1 -1
  159. package/dest/storage/tagging_store/sender_address_book_store.d.ts.map +1 -1
  160. package/dest/storage/tagging_store/sender_address_book_store.js +20 -14
  161. package/dest/storage/tagging_store/sender_tagging_store.d.ts +20 -10
  162. package/dest/storage/tagging_store/sender_tagging_store.d.ts.map +1 -1
  163. package/dest/storage/tagging_store/sender_tagging_store.js +254 -102
  164. package/dest/tagging/constants.d.ts +2 -0
  165. package/dest/tagging/constants.d.ts.map +1 -0
  166. package/dest/tagging/constants.js +10 -0
  167. package/dest/tagging/get_all_logs_by_tags.d.ts +24 -0
  168. package/dest/tagging/get_all_logs_by_tags.d.ts.map +1 -0
  169. package/dest/tagging/get_all_logs_by_tags.js +60 -0
  170. package/dest/tagging/index.d.ts +4 -3
  171. package/dest/tagging/index.d.ts.map +1 -1
  172. package/dest/tagging/index.js +3 -11
  173. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts +5 -5
  174. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.d.ts.map +1 -1
  175. package/dest/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.js +13 -13
  176. package/dest/tagging/recipient_sync/utils/find_highest_indexes.js +2 -2
  177. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts +7 -7
  178. package/dest/tagging/recipient_sync/utils/load_logs_for_range.d.ts.map +1 -1
  179. package/dest/tagging/recipient_sync/utils/load_logs_for_range.js +16 -12
  180. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts +5 -8
  181. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.d.ts.map +1 -1
  182. package/dest/tagging/sender_sync/sync_sender_tagging_indexes.js +9 -12
  183. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts +1 -1
  184. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.d.ts.map +1 -1
  185. package/dest/tagging/sender_sync/utils/get_status_change_of_pending.js +5 -8
  186. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts +7 -7
  187. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.d.ts.map +1 -1
  188. package/dest/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.js +23 -19
  189. package/package.json +27 -18
  190. package/src/access_scopes.ts +9 -0
  191. package/src/bin/check_oracle_version.ts +1 -0
  192. package/src/block_synchronizer/block_synchronizer.ts +93 -32
  193. package/src/config/index.ts +14 -0
  194. package/src/config/package_info.ts +1 -1
  195. package/src/contract_function_simulator/benchmarked_node.ts +103 -0
  196. package/src/contract_function_simulator/contract_function_simulator.ts +353 -140
  197. package/src/contract_function_simulator/execution_note_cache.ts +44 -25
  198. package/src/contract_function_simulator/execution_tagging_index_cache.ts +5 -5
  199. package/src/contract_function_simulator/index.ts +1 -1
  200. package/src/contract_function_simulator/noir-structs/event_validation_request.ts +6 -2
  201. package/src/contract_function_simulator/noir-structs/note_validation_request.ts +2 -2
  202. package/src/contract_function_simulator/noir-structs/utility_context.ts +6 -25
  203. package/src/contract_function_simulator/oracle/interfaces.ts +22 -12
  204. package/src/contract_function_simulator/oracle/note_packing_utils.ts +10 -10
  205. package/src/contract_function_simulator/oracle/oracle.ts +79 -47
  206. package/src/contract_function_simulator/oracle/private_execution.ts +1 -69
  207. package/src/contract_function_simulator/oracle/private_execution_oracle.ts +131 -140
  208. package/src/contract_function_simulator/oracle/utility_execution_oracle.ts +198 -115
  209. package/src/contract_logging.ts +39 -0
  210. package/src/contract_sync/contract_sync_service.ts +152 -0
  211. package/src/contract_sync/helpers.ts +98 -0
  212. package/src/debug/pxe_debug_utils.ts +63 -18
  213. package/src/entrypoints/client/bundle/index.ts +3 -0
  214. package/src/entrypoints/client/bundle/utils.ts +23 -16
  215. package/src/entrypoints/client/lazy/index.ts +3 -0
  216. package/src/entrypoints/client/lazy/utils.ts +24 -17
  217. package/src/entrypoints/pxe_creation_options.ts +4 -2
  218. package/src/entrypoints/server/index.ts +4 -0
  219. package/src/entrypoints/server/utils.ts +33 -41
  220. package/src/events/event_service.ts +19 -25
  221. package/src/events/private_event_filter_validator.ts +3 -5
  222. package/src/job_coordinator/job_coordinator.ts +150 -0
  223. package/src/logs/log_service.ts +51 -40
  224. package/src/notes/note_service.ts +41 -45
  225. package/src/notes_filter.ts +26 -0
  226. package/src/oracle_version.ts +4 -3
  227. package/src/private_kernel/hints/{compute_tx_include_by_timestamp.ts → compute_tx_expiration_timestamp.ts} +13 -13
  228. package/src/private_kernel/hints/index.ts +2 -2
  229. package/src/private_kernel/hints/{build_private_kernel_reset_private_inputs.ts → private_kernel_reset_private_inputs_builder.ts} +196 -138
  230. package/src/private_kernel/hints/test_utils.ts +325 -0
  231. package/src/private_kernel/private_kernel_execution_prover.ts +27 -19
  232. package/src/private_kernel/private_kernel_oracle.ts +116 -36
  233. package/src/pxe.ts +283 -202
  234. package/src/storage/address_store/address_store.ts +15 -15
  235. package/src/storage/anchor_block_store/anchor_block_store.ts +8 -0
  236. package/src/storage/capsule_store/capsule_store.ts +159 -23
  237. package/src/storage/contract_store/contract_store.ts +186 -76
  238. package/src/storage/metadata.ts +1 -1
  239. package/src/storage/note_store/note_store.ts +326 -320
  240. package/src/storage/note_store/stored_note.ts +48 -0
  241. package/src/storage/private_event_store/private_event_store.ts +301 -79
  242. package/src/storage/private_event_store/stored_private_event.ts +73 -0
  243. package/src/storage/tagging_store/recipient_tagging_store.ts +111 -21
  244. package/src/storage/tagging_store/sender_address_book_store.ts +20 -14
  245. package/src/storage/tagging_store/sender_tagging_store.ts +297 -112
  246. package/src/tagging/constants.ts +10 -0
  247. package/src/tagging/get_all_logs_by_tags.ts +92 -0
  248. package/src/tagging/index.ts +3 -12
  249. package/src/tagging/recipient_sync/load_private_logs_for_sender_recipient_pair.ts +27 -16
  250. package/src/tagging/recipient_sync/utils/find_highest_indexes.ts +2 -2
  251. package/src/tagging/recipient_sync/utils/load_logs_for_range.ts +17 -16
  252. package/src/tagging/sender_sync/sync_sender_tagging_indexes.ts +13 -15
  253. package/src/tagging/sender_sync/utils/get_status_change_of_pending.ts +5 -13
  254. package/src/tagging/sender_sync/utils/load_and_store_new_tagging_indexes.ts +26 -23
  255. package/dest/contract_function_simulator/proxied_node.d.ts +0 -9
  256. package/dest/contract_function_simulator/proxied_node.d.ts.map +0 -1
  257. package/dest/contract_function_simulator/proxied_node.js +0 -27
  258. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts +0 -28
  259. package/dest/private_kernel/hints/build_private_kernel_reset_private_inputs.d.ts.map +0 -1
  260. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts +0 -4
  261. package/dest/private_kernel/hints/compute_tx_include_by_timestamp.d.ts.map +0 -1
  262. package/dest/private_kernel/private_kernel_oracle_impl.d.ts +0 -46
  263. package/dest/private_kernel/private_kernel_oracle_impl.d.ts.map +0 -1
  264. package/dest/private_kernel/private_kernel_oracle_impl.js +0 -86
  265. package/dest/public_storage/public_storage_service.d.ts +0 -24
  266. package/dest/public_storage/public_storage_service.d.ts.map +0 -1
  267. package/dest/public_storage/public_storage_service.js +0 -26
  268. package/dest/tree_membership/tree_membership_service.d.ts +0 -52
  269. package/dest/tree_membership/tree_membership_service.d.ts.map +0 -1
  270. package/dest/tree_membership/tree_membership_service.js +0 -84
  271. package/src/contract_function_simulator/proxied_node.ts +0 -33
  272. package/src/private_kernel/private_kernel_oracle_impl.ts +0 -133
  273. package/src/public_storage/public_storage_service.ts +0 -33
  274. package/src/tree_membership/tree_membership_service.ts +0 -112
@@ -1,12 +1,16 @@
1
1
  import { BlockNumber } from '@aztec/foundation/branded-types';
2
- import { type Logger, createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
+ import type { AztecAsyncKVStore } from '@aztec/kv-store';
3
4
  import type { L2TipsKVStore } from '@aztec/kv-store/stores';
4
- import { L2BlockStream, type L2BlockStreamEvent, type L2BlockStreamEventHandler } from '@aztec/stdlib/block';
5
+ import { BlockHash, L2BlockStream, type L2BlockStreamEvent, type L2BlockStreamEventHandler } from '@aztec/stdlib/block';
5
6
  import type { AztecNode } from '@aztec/stdlib/interfaces/client';
7
+ import type { BlockHeader } from '@aztec/stdlib/tx';
6
8
 
7
- import type { PXEConfig } from '../config/index.js';
9
+ import type { BlockSynchronizerConfig } from '../config/index.js';
10
+ import type { ContractSyncService } from '../contract_sync/contract_sync_service.js';
8
11
  import type { AnchorBlockStore } from '../storage/anchor_block_store/anchor_block_store.js';
9
12
  import type { NoteStore } from '../storage/note_store/note_store.js';
13
+ import type { PrivateEventStore } from '../storage/private_event_store/private_event_store.js';
10
14
 
11
15
  /**
12
16
  * The BlockSynchronizer class orchestrates synchronization between PXE and Aztec node, maintaining an up-to-date
@@ -20,26 +24,32 @@ export class BlockSynchronizer implements L2BlockStreamEventHandler {
20
24
 
21
25
  constructor(
22
26
  private node: AztecNode,
27
+ private store: AztecAsyncKVStore,
23
28
  private anchorBlockStore: AnchorBlockStore,
24
29
  private noteStore: NoteStore,
30
+ private privateEventStore: PrivateEventStore,
25
31
  private l2TipsStore: L2TipsKVStore,
26
- config: Partial<Pick<PXEConfig, 'l2BlockBatchSize'>> = {},
27
- loggerOrSuffix?: string | Logger,
32
+ private contractSyncService: ContractSyncService,
33
+ private config: Partial<BlockSynchronizerConfig> = {},
34
+ bindings?: LoggerBindings,
28
35
  ) {
29
- this.log =
30
- !loggerOrSuffix || typeof loggerOrSuffix === 'string'
31
- ? createLogger(loggerOrSuffix ? `pxe:block_synchronizer:${loggerOrSuffix}` : `pxe:block_synchronizer`)
32
- : loggerOrSuffix;
36
+ this.log = createLogger('pxe:block_synchronizer', bindings);
33
37
  this.blockStream = this.createBlockStream(config);
34
38
  }
35
39
 
36
- protected createBlockStream(config: Partial<Pick<PXEConfig, 'l2BlockBatchSize'>>) {
37
- return new L2BlockStream(this.node, this.l2TipsStore, this, createLogger('pxe:block_stream'), {
38
- batchSize: config.l2BlockBatchSize,
39
- // Skipping finalized blocks makes us sync much faster - we only need to download blocks other than the latest one
40
- // in order to detect reorgs, and there can be no reorgs on finalized block, making this safe.
41
- skipFinalized: true,
42
- });
40
+ protected createBlockStream(config: Partial<BlockSynchronizerConfig>): L2BlockStream {
41
+ return new L2BlockStream(
42
+ this.node,
43
+ this.l2TipsStore,
44
+ this,
45
+ createLogger('pxe:block_stream', this.log.getBindings()),
46
+ {
47
+ batchSize: config.l2BlockBatchSize,
48
+ // Skipping finalized blocks makes us sync much faster - we only need to download blocks other than the latest one
49
+ // in order to detect reorgs, and there can be no reorgs on finalized block, making this safe.
50
+ skipFinalized: true,
51
+ },
52
+ );
43
53
  }
44
54
 
45
55
  /** Handle events emitted by the block stream. */
@@ -48,32 +58,83 @@ export class BlockSynchronizer implements L2BlockStreamEventHandler {
48
58
 
49
59
  switch (event.type) {
50
60
  case 'blocks-added': {
51
- const lastBlock = event.blocks.at(-1)!.block;
52
- this.log.verbose(`Updated pxe last block to ${lastBlock.number}`, {
53
- blockHash: lastBlock.hash(),
54
- archive: lastBlock.archive.root.toString(),
55
- header: lastBlock.header.toInspect(),
56
- });
57
- await this.anchorBlockStore.setHeader(lastBlock.getBlockHeader());
61
+ if (this.config.syncChainTip === undefined || this.config.syncChainTip === 'proposed') {
62
+ const lastBlock = event.blocks.at(-1)!;
63
+ await this.updateAnchorBlockHeader(lastBlock.header);
64
+ }
65
+ break;
66
+ }
67
+ case 'chain-checkpointed': {
68
+ if (this.config.syncChainTip === 'checkpointed') {
69
+ // Get the last block header from the checkpoint
70
+ const lastBlock = event.checkpoint.checkpoint.blocks.at(-1)!;
71
+ await this.updateAnchorBlockHeader(lastBlock.header);
72
+ }
73
+ break;
74
+ }
75
+ case 'chain-proven': {
76
+ if (this.config.syncChainTip === 'proven') {
77
+ const blockHeader = await this.node.getBlockHeader(BlockNumber(event.block.number));
78
+ if (blockHeader) {
79
+ await this.updateAnchorBlockHeader(blockHeader);
80
+ }
81
+ }
82
+ break;
83
+ }
84
+ case 'chain-finalized': {
85
+ if (this.config.syncChainTip === 'finalized') {
86
+ const blockHeader = await this.node.getBlockHeader(BlockNumber(event.block.number));
87
+ if (blockHeader) {
88
+ await this.updateAnchorBlockHeader(blockHeader);
89
+ }
90
+ }
58
91
  break;
59
92
  }
60
93
  case 'chain-pruned': {
94
+ const currentAnchorBlockHeader = await this.anchorBlockStore.getBlockHeader();
95
+ const currentAnchorBlockNumber = currentAnchorBlockHeader.getBlockNumber();
96
+ if (currentAnchorBlockNumber <= event.block.number) {
97
+ this.log.verbose(
98
+ `Ignoring prune event to block ${event.block.number} greater than current anchor block ${currentAnchorBlockNumber}`,
99
+ { pruneEvent: event, currentAnchorBlockHeader: currentAnchorBlockHeader.toInspect() },
100
+ );
101
+ return;
102
+ }
103
+
61
104
  this.log.warn(`Pruning data after block ${event.block.number} due to reorg`);
62
- // We first unnullify and then remove so that unnullified notes that were created after the block number end up deleted.
63
- const lastSynchedBlockNumber = (await this.anchorBlockStore.getBlockHeader()).getBlockNumber();
64
- await this.noteStore.rollbackNotesAndNullifiers(event.block.number, lastSynchedBlockNumber);
65
- // Update the header to the last block.
66
- const newHeader = await this.node.getBlockHeader(event.block.number);
67
- if (!newHeader) {
68
- this.log.error(`Block header not found for block number ${event.block.number} during chain prune`);
69
- } else {
70
- await this.anchorBlockStore.setHeader(newHeader);
105
+
106
+ // Note that the following is not necessarily the anchor block that will be used in the transaction - if
107
+ // the chain has already moved past the reorg, we'll also see blocks-added events that will push the anchor
108
+ // forward.
109
+ const newAnchorBlockHeader = await this.node.getBlockHeader(BlockHash.fromString(event.block.hash));
110
+
111
+ if (!newAnchorBlockHeader) {
112
+ throw new Error(
113
+ `Block header for block number ${event.block.number} and hash ${event.block.hash} not found during chain prune. This likely indicates a bug in the node, as we receive block stream events and fetch block headers from the same node.`,
114
+ );
71
115
  }
116
+
117
+ // Operations are wrapped in a single transaction to ensure atomicity.
118
+ await this.store.transactionAsync(async () => {
119
+ await this.noteStore.rollback(event.block.number, currentAnchorBlockNumber);
120
+ await this.privateEventStore.rollback(event.block.number, currentAnchorBlockNumber);
121
+ await this.updateAnchorBlockHeader(newAnchorBlockHeader);
122
+ });
72
123
  break;
73
124
  }
74
125
  }
75
126
  }
76
127
 
128
+ /** Updates the anchor block header to the target block */
129
+ private async updateAnchorBlockHeader(blockHeader: BlockHeader) {
130
+ // Whenever the anchor block header is updated, we need to synchronize the private state of contracts again.
131
+ // Therefore, we clear the contract synchronization cache here such that the sync is re-triggered upon new
132
+ // execution.
133
+ this.contractSyncService.wipe();
134
+ this.log.verbose(`Updated pxe last block to ${blockHeader.getBlockNumber()}`, blockHeader.toInspect());
135
+ await this.anchorBlockStore.setHeader(blockHeader);
136
+ }
137
+
77
138
  /**
78
139
  * Syncs PXE and the node by downloading the metadata of the latest blocks, allowing simulations to use
79
140
  * recent data (e.g. notes), and handling any reorgs that might have occurred.
@@ -24,6 +24,8 @@ export interface KernelProverConfig {
24
24
  export interface BlockSynchronizerConfig {
25
25
  /** Maximum amount of blocks to pull from the stream in one request when synchronizing */
26
26
  l2BlockBatchSize: number;
27
+ /** Which chain tip to sync to (proposed, checkpointed, proven, finalized) */
28
+ syncChainTip?: 'proposed' | 'checkpointed' | 'proven' | 'finalized';
27
29
  }
28
30
 
29
31
  export type PXEConfig = KernelProverConfig & DataStoreConfig & ChainConfig & BlockSynchronizerConfig;
@@ -53,6 +55,18 @@ export const pxeConfigMappings: ConfigMappingsType<PXEConfig> = {
53
55
  description: 'Enable real proofs',
54
56
  ...booleanConfigHelper(true),
55
57
  },
58
+ syncChainTip: {
59
+ env: 'PXE_SYNC_CHAIN_TIP',
60
+ description: 'Which chain tip to sync to (proposed, checkpointed, proven, finalized)',
61
+ defaultValue: 'proposed',
62
+ parseEnv: (val: string) => {
63
+ const allowedValues = ['proposed', 'checkpointed', 'proven', 'finalized'];
64
+ if (allowedValues.includes(val)) {
65
+ return val;
66
+ }
67
+ throw new Error(`Invalid value for PXE_SYNC_CHAIN_TIP: ${val}. Allowed values are: ${allowedValues.join(', ')}`);
68
+ },
69
+ },
56
70
  };
57
71
 
58
72
  /**
@@ -1,3 +1,3 @@
1
1
  export function getPackageInfo() {
2
- return { version: '3.0.0', name: '@aztec/pxe' };
2
+ return { version: '5.0.0', name: '@aztec/pxe' };
3
3
  }
@@ -0,0 +1,103 @@
1
+ import { Timer } from '@aztec/foundation/timer';
2
+ import type { AztecNode } from '@aztec/stdlib/interfaces/client';
3
+ import type { NodeStats, RoundTripStats } from '@aztec/stdlib/tx';
4
+
5
+ /*
6
+ * Proxy generator for an AztecNode that tracks the time taken for each RPC call and the number of round trips (actual
7
+ * blocking waits for node responses).
8
+ *
9
+ * A round trip is counted when we transition from 0 to 1 in-flight calls, and ends when all concurrent calls complete.
10
+ * This means parallel calls in Promise.all count as a single round trip.
11
+ *
12
+ * Note that batching of RPC calls in `safe_json_rpc_client.ts` could affect the round trip counts but in places we
13
+ * currently use this information we do not even use HTTP as we have direct access to the Aztec Node instance in TS
14
+ * (i.e. not running against external node) so this is not a problem for now.
15
+ *
16
+ * If you want to use this against external node and the info gets skewed by batching you can set the `maxBatchSize`
17
+ * value in `safe_json_rpc_client.ts` to 1 (the main motivation for batching was to get around parallel http requests
18
+ * limits in web browsers which is not a problem when debugging in node.js).
19
+ */
20
+ export type BenchmarkedNode = AztecNode & { getStats(): NodeStats };
21
+
22
+ export class BenchmarkedNodeFactory {
23
+ static create(node: AztecNode): BenchmarkedNode {
24
+ // Per-method call stats
25
+ const perMethod: Partial<Record<keyof AztecNode, { times: number[] }>> = {};
26
+
27
+ // Round trip tracking
28
+ let inFlightCount = 0;
29
+ let currentRoundTripTimer: Timer | null = null;
30
+ let currentRoundTripMethods: string[] = [];
31
+ const roundTrips: RoundTripStats = {
32
+ roundTrips: 0,
33
+ totalBlockingTime: 0,
34
+ roundTripDurations: [],
35
+ roundTripMethods: [],
36
+ };
37
+
38
+ return new Proxy(node, {
39
+ get(target, prop: keyof BenchmarkedNode) {
40
+ if (prop === 'getStats') {
41
+ return (): NodeStats => {
42
+ return { perMethod, roundTrips };
43
+ };
44
+ } else {
45
+ return function (...args: any[]) {
46
+ // Track per-method stats
47
+ if (!perMethod[prop]) {
48
+ perMethod[prop] = { times: [] };
49
+ }
50
+
51
+ // Start of a new round trip batch?
52
+ if (inFlightCount === 0) {
53
+ roundTrips.roundTrips++;
54
+ currentRoundTripTimer = new Timer();
55
+ currentRoundTripMethods = [];
56
+ }
57
+ inFlightCount++;
58
+ currentRoundTripMethods.push(prop);
59
+
60
+ const callTimer = new Timer();
61
+ const result = (target[prop] as any).apply(target, args);
62
+
63
+ // Handle completion - called when the call finishes (after Promise resolves)
64
+ const handleCompletion = () => {
65
+ const callTime = callTimer.ms();
66
+ perMethod[prop]!.times.push(callTime);
67
+
68
+ inFlightCount--;
69
+
70
+ // End of round trip batch - all concurrent calls completed
71
+ if (inFlightCount === 0 && currentRoundTripTimer) {
72
+ const roundTripTime = currentRoundTripTimer.ms();
73
+ roundTrips.totalBlockingTime += roundTripTime;
74
+ roundTrips.roundTripDurations.push(roundTripTime);
75
+ roundTrips.roundTripMethods.push(currentRoundTripMethods);
76
+ currentRoundTripTimer = null;
77
+ currentRoundTripMethods = [];
78
+ }
79
+ };
80
+
81
+ // If the result is a Promise, chain the completion handler
82
+ if (result && typeof result.then === 'function') {
83
+ return result.then(
84
+ (value: any) => {
85
+ handleCompletion();
86
+ return value;
87
+ },
88
+ (error: any) => {
89
+ handleCompletion();
90
+ throw error;
91
+ },
92
+ );
93
+ } else {
94
+ // Synchronous method - handle completion immediately
95
+ handleCompletion();
96
+ return result;
97
+ }
98
+ };
99
+ }
100
+ },
101
+ }) as BenchmarkedNode;
102
+ }
103
+ }