@aztec/stdlib 0.0.1-commit.7d4e6cd → 0.0.1-commit.858058eac

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 (542) hide show
  1. package/dest/abi/function_call.d.ts +47 -9
  2. package/dest/abi/function_call.d.ts.map +1 -1
  3. package/dest/abi/function_call.js +20 -3
  4. package/dest/abi/utils.d.ts +7 -1
  5. package/dest/abi/utils.d.ts.map +1 -1
  6. package/dest/abi/utils.js +7 -0
  7. package/dest/auth_witness/auth_witness.d.ts +2 -1
  8. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  9. package/dest/avm/avm.d.ts +62 -62
  10. package/dest/avm/avm_accumulated_data.d.ts +30 -3
  11. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  12. package/dest/avm/avm_circuit_public_inputs.d.ts +9 -9
  13. package/dest/avm/avm_proving_request.d.ts +299 -299
  14. package/dest/avm/contract_storage_read.d.ts +13 -1
  15. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  16. package/dest/avm/contract_storage_update_request.d.ts +13 -1
  17. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  18. package/dest/avm/public_call_stack_item_compressed.d.ts +3 -1
  19. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  20. package/dest/avm/public_data_read.d.ts +10 -1
  21. package/dest/avm/public_data_read.d.ts.map +1 -1
  22. package/dest/avm/public_data_update_request.d.ts +10 -1
  23. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  24. package/dest/avm/public_data_write.d.ts +7 -1
  25. package/dest/avm/public_data_write.d.ts.map +1 -1
  26. package/dest/avm/public_inner_call_request.d.ts +4 -1
  27. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  28. package/dest/avm/revert_code.d.ts +4 -4
  29. package/dest/avm/revert_code.d.ts.map +1 -1
  30. package/dest/block/block_hash.d.ts +18 -14
  31. package/dest/block/block_hash.d.ts.map +1 -1
  32. package/dest/block/block_hash.js +22 -20
  33. package/dest/block/block_parameter.d.ts +4 -3
  34. package/dest/block/block_parameter.d.ts.map +1 -1
  35. package/dest/block/block_parameter.js +2 -0
  36. package/dest/block/body.d.ts +1 -1
  37. package/dest/block/body.d.ts.map +1 -1
  38. package/dest/block/body.js +2 -1
  39. package/dest/block/checkpointed_l2_block.d.ts +20 -137
  40. package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
  41. package/dest/block/checkpointed_l2_block.js +7 -45
  42. package/dest/block/in_block.d.ts +9 -9
  43. package/dest/block/in_block.d.ts.map +1 -1
  44. package/dest/block/in_block.js +5 -5
  45. package/dest/block/index.d.ts +1 -3
  46. package/dest/block/index.d.ts.map +1 -1
  47. package/dest/block/index.js +0 -2
  48. package/dest/block/l2_block.d.ts +56 -59
  49. package/dest/block/l2_block.d.ts.map +1 -1
  50. package/dest/block/l2_block.js +64 -110
  51. package/dest/block/l2_block_source.d.ts +65 -39
  52. package/dest/block/l2_block_source.d.ts.map +1 -1
  53. package/dest/block/l2_block_source.js +2 -1
  54. package/dest/block/l2_block_stream/interfaces.d.ts +9 -6
  55. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  56. package/dest/block/l2_block_stream/l2_block_stream.d.ts +6 -3
  57. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  58. package/dest/block/l2_block_stream/l2_block_stream.js +37 -34
  59. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +3 -3
  60. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -1
  61. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  62. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  63. package/dest/block/test/l2_tips_store_test_suite.js +2 -7
  64. package/dest/block/validate_block_result.d.ts +1 -1
  65. package/dest/block/validate_block_result.d.ts.map +1 -1
  66. package/dest/block/validate_block_result.js +5 -4
  67. package/dest/checkpoint/checkpoint.d.ts +30 -20
  68. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  69. package/dest/checkpoint/checkpoint.js +18 -6
  70. package/dest/checkpoint/published_checkpoint.d.ts +17 -15
  71. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  72. package/dest/checkpoint/published_checkpoint.js +4 -3
  73. package/dest/config/index.d.ts +2 -1
  74. package/dest/config/index.d.ts.map +1 -1
  75. package/dest/config/index.js +1 -0
  76. package/dest/config/node-rpc-config.js +1 -1
  77. package/dest/config/sequencer-config.d.ts +10 -0
  78. package/dest/config/sequencer-config.d.ts.map +1 -0
  79. package/dest/config/sequencer-config.js +12 -0
  80. package/dest/contract/complete_address.d.ts +4 -1
  81. package/dest/contract/complete_address.d.ts.map +1 -1
  82. package/dest/contract/contract_address.js +1 -1
  83. package/dest/contract/contract_class_id.d.ts +1 -1
  84. package/dest/contract/contract_class_id.js +1 -1
  85. package/dest/contract/contract_deployment_data.d.ts +5 -5
  86. package/dest/contract/index.d.ts +1 -3
  87. package/dest/contract/index.d.ts.map +1 -1
  88. package/dest/contract/index.js +0 -2
  89. package/dest/contract/interfaces/contract_instance.d.ts +16 -16
  90. package/dest/contract/interfaces/node-info.d.ts +3 -1
  91. package/dest/contract/interfaces/node-info.d.ts.map +1 -1
  92. package/dest/contract/interfaces/node-info.js +2 -1
  93. package/dest/contract/private_function.d.ts +1 -1
  94. package/dest/contract/private_function.d.ts.map +1 -1
  95. package/dest/contract/private_function.js +2 -3
  96. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  97. package/dest/contract/private_function_membership_proof.js +1 -1
  98. package/dest/database-version/database_version.d.ts +58 -0
  99. package/dest/database-version/database_version.d.ts.map +1 -0
  100. package/dest/database-version/database_version.js +69 -0
  101. package/dest/database-version/version_manager.d.ts +3 -49
  102. package/dest/database-version/version_manager.d.ts.map +1 -1
  103. package/dest/database-version/version_manager.js +1 -66
  104. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  105. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  106. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  107. package/dest/deserialization/index.d.ts +11 -0
  108. package/dest/deserialization/index.d.ts.map +1 -0
  109. package/dest/deserialization/index.js +10 -0
  110. package/dest/epoch-helpers/index.d.ts +7 -1
  111. package/dest/epoch-helpers/index.d.ts.map +1 -1
  112. package/dest/epoch-helpers/index.js +9 -3
  113. package/dest/errors/proving_error.d.ts +2 -2
  114. package/dest/errors/proving_error.d.ts.map +1 -1
  115. package/dest/hash/hash.js +2 -2
  116. package/dest/hash/map_slot.d.ts +1 -1
  117. package/dest/hash/map_slot.d.ts.map +1 -1
  118. package/dest/hash/map_slot.js +4 -3
  119. package/dest/interfaces/api_limit.d.ts +2 -1
  120. package/dest/interfaces/api_limit.d.ts.map +1 -1
  121. package/dest/interfaces/api_limit.js +1 -0
  122. package/dest/interfaces/archiver.d.ts +1 -1
  123. package/dest/interfaces/archiver.d.ts.map +1 -1
  124. package/dest/interfaces/archiver.js +18 -15
  125. package/dest/interfaces/aztec-node-admin.d.ts +72 -27
  126. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  127. package/dest/interfaces/aztec-node-admin.js +3 -1
  128. package/dest/interfaces/aztec-node.d.ts +65 -68
  129. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  130. package/dest/interfaces/aztec-node.js +10 -16
  131. package/dest/interfaces/block-builder.d.ts +22 -14
  132. package/dest/interfaces/block-builder.d.ts.map +1 -1
  133. package/dest/interfaces/block-builder.js +7 -0
  134. package/dest/interfaces/configs.d.ts +8 -8
  135. package/dest/interfaces/configs.d.ts.map +1 -1
  136. package/dest/interfaces/get_logs_response.d.ts +16 -9
  137. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  138. package/dest/interfaces/l2_logs_source.d.ts +14 -5
  139. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  140. package/dest/interfaces/p2p.d.ts +2 -2
  141. package/dest/interfaces/p2p.d.ts.map +1 -1
  142. package/dest/interfaces/prover-broker.d.ts +16 -1
  143. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  144. package/dest/interfaces/prover-broker.js +4 -1
  145. package/dest/interfaces/prover-client.d.ts +15 -1
  146. package/dest/interfaces/prover-client.d.ts.map +1 -1
  147. package/dest/interfaces/prover-client.js +12 -1
  148. package/dest/interfaces/proving-job.d.ts +214 -214
  149. package/dest/interfaces/slasher.d.ts +9 -1
  150. package/dest/interfaces/slasher.d.ts.map +1 -1
  151. package/dest/interfaces/slasher.js +2 -0
  152. package/dest/interfaces/tx_provider.d.ts +3 -3
  153. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  154. package/dest/interfaces/validator.d.ts +117 -15
  155. package/dest/interfaces/validator.d.ts.map +1 -1
  156. package/dest/interfaces/validator.js +6 -3
  157. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +1 -1
  158. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  159. package/dest/kernel/hints/build_note_hash_read_request_hints.js +16 -6
  160. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
  161. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  162. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
  163. package/dest/kernel/hints/key_validation_hint.d.ts +2 -1
  164. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  165. package/dest/kernel/hints/key_validation_request.d.ts +2 -1
  166. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  167. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +6 -1
  168. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +1 -1
  169. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  170. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  171. package/dest/kernel/hints/read_request.d.ts +7 -1
  172. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  173. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  174. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  175. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  176. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  177. package/dest/kernel/private_call_data.d.ts +25 -1
  178. package/dest/kernel/private_call_data.d.ts.map +1 -1
  179. package/dest/kernel/private_call_request.d.ts +16 -1
  180. package/dest/kernel/private_call_request.d.ts.map +1 -1
  181. package/dest/kernel/private_circuit_public_inputs.d.ts +74 -1
  182. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  183. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +31 -1
  184. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  185. package/dest/kernel/private_kernel_data.d.ts +7 -1
  186. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  187. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
  188. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  189. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  190. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  191. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  192. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  193. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +10 -1
  194. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  195. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +23 -1
  196. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  197. package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
  198. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
  199. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  200. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +16 -1
  201. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  202. package/dest/kernel/private_validation_requests.d.ts +10 -1
  203. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  204. package/dest/kernel/public_call_request.d.ts +22 -1
  205. package/dest/kernel/public_call_request.d.ts.map +1 -1
  206. package/dest/kernel/utils/optional_number.d.ts +7 -1
  207. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  208. package/dest/keys/derivation.d.ts +3 -3
  209. package/dest/keys/derivation.js +8 -8
  210. package/dest/keys/key_types.d.ts +1 -1
  211. package/dest/keys/public_keys.d.ts +5 -1
  212. package/dest/keys/public_keys.d.ts.map +1 -1
  213. package/dest/keys/utils.d.ts +1 -1
  214. package/dest/keys/utils.d.ts.map +1 -1
  215. package/dest/keys/utils.js +7 -3
  216. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  217. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  218. package/dest/l1-contracts/slash_factory.js +1 -0
  219. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  220. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  221. package/dest/logs/extended_public_log.d.ts +17 -9
  222. package/dest/logs/extended_public_log.d.ts.map +1 -1
  223. package/dest/logs/log_id.d.ts +21 -14
  224. package/dest/logs/log_id.d.ts.map +1 -1
  225. package/dest/logs/log_id.js +20 -17
  226. package/dest/logs/siloed_tag.d.ts +1 -1
  227. package/dest/logs/siloed_tag.d.ts.map +1 -1
  228. package/dest/logs/siloed_tag.js +4 -3
  229. package/dest/messaging/inbox_leaf.d.ts +3 -1
  230. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  231. package/dest/messaging/l1_actor.d.ts +7 -1
  232. package/dest/messaging/l1_actor.d.ts.map +1 -1
  233. package/dest/messaging/l1_to_l2_message.d.ts +6 -1
  234. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  235. package/dest/messaging/l2_actor.d.ts +7 -1
  236. package/dest/messaging/l2_actor.d.ts.map +1 -1
  237. package/dest/messaging/l2_to_l1_membership.d.ts +3 -3
  238. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  239. package/dest/messaging/l2_to_l1_membership.js +8 -6
  240. package/dest/messaging/out_hash.d.ts +41 -4
  241. package/dest/messaging/out_hash.d.ts.map +1 -1
  242. package/dest/messaging/out_hash.js +52 -26
  243. package/dest/note/note_dao.d.ts +36 -5
  244. package/dest/note/note_dao.d.ts.map +1 -1
  245. package/dest/note/note_dao.js +15 -12
  246. package/dest/p2p/block_proposal.d.ts +23 -8
  247. package/dest/p2p/block_proposal.d.ts.map +1 -1
  248. package/dest/p2p/block_proposal.js +25 -7
  249. package/dest/p2p/checkpoint_attestation.d.ts +5 -1
  250. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -1
  251. package/dest/p2p/checkpoint_proposal.d.ts +27 -7
  252. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
  253. package/dest/p2p/checkpoint_proposal.js +26 -5
  254. package/dest/p2p/consensus_payload.d.ts +4 -3
  255. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  256. package/dest/p2p/consensus_payload.js +0 -3
  257. package/dest/p2p/constants.d.ts +5 -0
  258. package/dest/p2p/constants.d.ts.map +1 -0
  259. package/dest/p2p/constants.js +3 -0
  260. package/dest/p2p/index.d.ts +2 -1
  261. package/dest/p2p/index.d.ts.map +1 -1
  262. package/dest/p2p/index.js +1 -0
  263. package/dest/p2p/message_validator.d.ts +18 -3
  264. package/dest/p2p/message_validator.d.ts.map +1 -1
  265. package/dest/p2p/message_validator.js +2 -1
  266. package/dest/p2p/signed_txs.d.ts +3 -1
  267. package/dest/p2p/signed_txs.d.ts.map +1 -1
  268. package/dest/p2p/signed_txs.js +6 -1
  269. package/dest/p2p/topic_type.js +2 -1
  270. package/dest/parity/parity_base_private_inputs.d.ts +3 -1
  271. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  272. package/dest/parity/parity_public_inputs.d.ts +4 -1
  273. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  274. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  275. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  276. package/dest/proofs/chonk_proof.d.ts +1 -1
  277. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  278. package/dest/proofs/chonk_proof.js +9 -4
  279. package/dest/proofs/proof.d.ts +4 -1
  280. package/dest/proofs/proof.d.ts.map +1 -1
  281. package/dest/proofs/recursive_proof.d.ts +10 -1
  282. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  283. package/dest/rollup/base_rollup_hints.d.ts +34 -1
  284. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  285. package/dest/rollup/block_constant_data.d.ts +12 -1
  286. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  287. package/dest/rollup/block_headers_hash.js +1 -1
  288. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  289. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  290. package/dest/rollup/block_rollup_public_inputs.d.ts +44 -3
  291. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  292. package/dest/rollup/block_rollup_public_inputs.js +2 -2
  293. package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
  294. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  295. package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
  296. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  297. package/dest/rollup/checkpoint_header.d.ts +29 -2
  298. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  299. package/dest/rollup/checkpoint_header.js +21 -5
  300. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  301. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  302. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +45 -10
  303. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  304. package/dest/rollup/checkpoint_rollup_public_inputs.js +11 -7
  305. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
  306. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  307. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
  308. package/dest/rollup/epoch_constant_data.d.ts +16 -1
  309. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  310. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  311. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  312. package/dest/rollup/root_rollup_public_inputs.d.ts +17 -7
  313. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  314. package/dest/rollup/root_rollup_public_inputs.js +7 -4
  315. package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
  316. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  317. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  318. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  319. package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
  320. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  321. package/dest/schemas/schemas.d.ts +1 -1
  322. package/dest/slashing/empire.d.ts +1 -1
  323. package/dest/slashing/empire.d.ts.map +1 -1
  324. package/dest/slashing/empire.js +2 -0
  325. package/dest/slashing/helpers.d.ts +2 -2
  326. package/dest/slashing/helpers.d.ts.map +1 -1
  327. package/dest/slashing/helpers.js +6 -0
  328. package/dest/slashing/tally.d.ts +2 -1
  329. package/dest/slashing/tally.d.ts.map +1 -1
  330. package/dest/slashing/tally.js +6 -2
  331. package/dest/slashing/types.d.ts +7 -3
  332. package/dest/slashing/types.d.ts.map +1 -1
  333. package/dest/slashing/types.js +13 -1
  334. package/dest/stats/stats.d.ts +1 -3
  335. package/dest/stats/stats.d.ts.map +1 -1
  336. package/dest/tests/factories.d.ts +2 -4
  337. package/dest/tests/factories.d.ts.map +1 -1
  338. package/dest/tests/factories.js +8 -17
  339. package/dest/tests/jest.js +1 -1
  340. package/dest/tests/mocks.d.ts +20 -14
  341. package/dest/tests/mocks.d.ts.map +1 -1
  342. package/dest/tests/mocks.js +45 -27
  343. package/dest/timetable/index.d.ts +37 -0
  344. package/dest/timetable/index.d.ts.map +1 -0
  345. package/dest/timetable/index.js +39 -0
  346. package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
  347. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  348. package/dest/trees/nullifier_leaf.d.ts +13 -1
  349. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  350. package/dest/trees/nullifier_membership_witness.d.ts +10 -1
  351. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  352. package/dest/trees/public_data_leaf.d.ts +17 -1
  353. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  354. package/dest/trees/public_data_leaf.js +7 -6
  355. package/dest/trees/public_data_witness.d.ts +11 -1
  356. package/dest/trees/public_data_witness.d.ts.map +1 -1
  357. package/dest/tx/block_header.d.ts +14 -2
  358. package/dest/tx/block_header.d.ts.map +1 -1
  359. package/dest/tx/block_header.js +5 -1
  360. package/dest/tx/call_context.d.ts +13 -1
  361. package/dest/tx/call_context.d.ts.map +1 -1
  362. package/dest/tx/capsule.d.ts +4 -1
  363. package/dest/tx/capsule.d.ts.map +1 -1
  364. package/dest/tx/execution_payload.d.ts +9 -1
  365. package/dest/tx/execution_payload.d.ts.map +1 -1
  366. package/dest/tx/function_data.d.ts +4 -2
  367. package/dest/tx/function_data.d.ts.map +1 -1
  368. package/dest/tx/global_variables.d.ts +9 -1
  369. package/dest/tx/global_variables.d.ts.map +1 -1
  370. package/dest/tx/hashed_values.d.ts +7 -1
  371. package/dest/tx/hashed_values.d.ts.map +1 -1
  372. package/dest/tx/in_tx.d.ts +4 -4
  373. package/dest/tx/indexed_tx_effect.d.ts +5 -5
  374. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  375. package/dest/tx/indexed_tx_effect.js +3 -2
  376. package/dest/tx/partial_state_reference.d.ts +4 -1
  377. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  378. package/dest/tx/private_execution_result.d.ts +23 -2
  379. package/dest/tx/private_execution_result.d.ts.map +1 -1
  380. package/dest/tx/private_execution_result.js +1 -1
  381. package/dest/tx/private_tx_constant_data.d.ts +16 -1
  382. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  383. package/dest/tx/profiling.d.ts +149 -26
  384. package/dest/tx/profiling.d.ts.map +1 -1
  385. package/dest/tx/profiling.js +44 -7
  386. package/dest/tx/protocol_contracts.d.ts +1 -1
  387. package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
  388. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  389. package/dest/tx/state_reference.d.ts +3 -1
  390. package/dest/tx/state_reference.d.ts.map +1 -1
  391. package/dest/tx/tx.d.ts +24 -1
  392. package/dest/tx/tx.d.ts.map +1 -1
  393. package/dest/tx/tx.js +6 -3
  394. package/dest/tx/tx_context.d.ts +2 -1
  395. package/dest/tx/tx_context.d.ts.map +1 -1
  396. package/dest/tx/tx_effect.d.ts +32 -6
  397. package/dest/tx/tx_effect.d.ts.map +1 -1
  398. package/dest/tx/tx_effect.js +0 -7
  399. package/dest/tx/tx_execution_request.d.ts +30 -1
  400. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  401. package/dest/tx/tx_hash.d.ts +2 -1
  402. package/dest/tx/tx_hash.d.ts.map +1 -1
  403. package/dest/tx/tx_receipt.d.ts +47 -13
  404. package/dest/tx/tx_receipt.d.ts.map +1 -1
  405. package/dest/tx/tx_receipt.js +46 -15
  406. package/dest/tx/tx_request.d.ts +6 -1
  407. package/dest/tx/tx_request.d.ts.map +1 -1
  408. package/dest/tx/validator/empty_validator.d.ts +2 -2
  409. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  410. package/dest/tx/validator/error_texts.d.ts +2 -1
  411. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  412. package/dest/tx/validator/error_texts.js +2 -0
  413. package/dest/tx/validator/tx_validator.d.ts +2 -2
  414. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  415. package/dest/types/shared.d.ts +4 -1
  416. package/dest/types/shared.d.ts.map +1 -1
  417. package/dest/validators/schemas.d.ts +8 -8
  418. package/dest/vks/verification_key.d.ts +22 -1
  419. package/dest/vks/verification_key.d.ts.map +1 -1
  420. package/dest/vks/vk_data.d.ts +7 -1
  421. package/dest/vks/vk_data.d.ts.map +1 -1
  422. package/dest/zkpassport/index.d.ts +3 -4
  423. package/dest/zkpassport/index.d.ts.map +1 -1
  424. package/dest/zkpassport/index.js +9 -9
  425. package/package.json +27 -13
  426. package/src/abi/function_call.ts +25 -3
  427. package/src/abi/utils.ts +17 -0
  428. package/src/block/block_hash.ts +26 -25
  429. package/src/block/block_parameter.ts +4 -2
  430. package/src/block/body.ts +2 -1
  431. package/src/block/checkpointed_l2_block.ts +8 -58
  432. package/src/block/in_block.ts +6 -6
  433. package/src/block/index.ts +0 -2
  434. package/src/block/l2_block.ts +102 -150
  435. package/src/block/l2_block_source.ts +71 -42
  436. package/src/block/l2_block_stream/interfaces.ts +8 -5
  437. package/src/block/l2_block_stream/l2_block_stream.ts +45 -37
  438. package/src/block/l2_block_stream/l2_tips_store_base.ts +2 -2
  439. package/src/block/test/l2_tips_store_test_suite.ts +4 -9
  440. package/src/block/validate_block_result.ts +5 -4
  441. package/src/checkpoint/checkpoint.ts +33 -11
  442. package/src/checkpoint/published_checkpoint.ts +4 -3
  443. package/src/config/index.ts +1 -0
  444. package/src/config/node-rpc-config.ts +1 -1
  445. package/src/config/sequencer-config.ts +19 -0
  446. package/src/contract/contract_address.ts +1 -1
  447. package/src/contract/contract_class_id.ts +1 -1
  448. package/src/contract/index.ts +0 -2
  449. package/src/contract/interfaces/node-info.ts +3 -0
  450. package/src/contract/private_function.ts +2 -3
  451. package/src/contract/private_function_membership_proof.ts +1 -1
  452. package/src/database-version/database_version.ts +87 -0
  453. package/src/database-version/version_manager.ts +1 -77
  454. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  455. package/src/deserialization/index.ts +21 -0
  456. package/src/epoch-helpers/index.ts +13 -1
  457. package/src/hash/hash.ts +2 -2
  458. package/src/hash/map_slot.ts +3 -2
  459. package/src/interfaces/api_limit.ts +1 -0
  460. package/src/interfaces/archiver.ts +18 -24
  461. package/src/interfaces/aztec-node-admin.ts +3 -2
  462. package/src/interfaces/aztec-node.ts +85 -134
  463. package/src/interfaces/block-builder.ts +40 -23
  464. package/src/interfaces/configs.ts +1 -3
  465. package/src/interfaces/l2_logs_source.ts +17 -4
  466. package/src/interfaces/p2p.ts +1 -1
  467. package/src/interfaces/prover-broker.ts +22 -0
  468. package/src/interfaces/prover-client.ts +22 -0
  469. package/src/interfaces/slasher.ts +4 -0
  470. package/src/interfaces/tx_provider.ts +2 -2
  471. package/src/interfaces/validator.ts +19 -12
  472. package/src/kernel/hints/build_note_hash_read_request_hints.ts +17 -6
  473. package/src/kernel/hints/build_nullifier_read_request_hints.ts +17 -14
  474. package/src/keys/derivation.ts +8 -8
  475. package/src/keys/key_types.ts +1 -1
  476. package/src/keys/utils.ts +7 -3
  477. package/src/l1-contracts/slash_factory.ts +1 -0
  478. package/src/logs/log_id.ts +22 -18
  479. package/src/logs/siloed_tag.ts +3 -2
  480. package/src/messaging/l2_to_l1_membership.ts +8 -6
  481. package/src/messaging/out_hash.ts +60 -29
  482. package/src/note/note_dao.ts +18 -13
  483. package/src/p2p/block_proposal.ts +36 -13
  484. package/src/p2p/checkpoint_proposal.ts +39 -11
  485. package/src/p2p/consensus_payload.ts +0 -5
  486. package/src/p2p/constants.ts +6 -0
  487. package/src/p2p/index.ts +1 -0
  488. package/src/p2p/message_validator.ts +14 -2
  489. package/src/p2p/signed_txs.ts +6 -1
  490. package/src/p2p/topic_type.ts +1 -1
  491. package/src/proofs/chonk_proof.ts +9 -5
  492. package/src/rollup/block_headers_hash.ts +1 -1
  493. package/src/rollup/block_rollup_public_inputs.ts +2 -2
  494. package/src/rollup/checkpoint_header.ts +20 -0
  495. package/src/rollup/checkpoint_rollup_public_inputs.ts +16 -10
  496. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
  497. package/src/rollup/root_rollup_public_inputs.ts +11 -8
  498. package/src/slashing/empire.ts +3 -1
  499. package/src/slashing/helpers.ts +8 -0
  500. package/src/slashing/tally.ts +8 -2
  501. package/src/slashing/types.ts +14 -0
  502. package/src/stats/stats.ts +0 -2
  503. package/src/tests/factories.ts +11 -31
  504. package/src/tests/jest.ts +1 -1
  505. package/src/tests/mocks.ts +62 -42
  506. package/src/timetable/index.ts +66 -0
  507. package/src/trees/public_data_leaf.ts +11 -5
  508. package/src/tx/block_header.ts +11 -3
  509. package/src/tx/indexed_tx_effect.ts +3 -2
  510. package/src/tx/private_execution_result.ts +1 -1
  511. package/src/tx/profiling.ts +46 -4
  512. package/src/tx/tx.ts +8 -9
  513. package/src/tx/tx_effect.ts +0 -9
  514. package/src/tx/tx_receipt.ts +75 -18
  515. package/src/tx/validator/empty_validator.ts +1 -1
  516. package/src/tx/validator/error_texts.ts +3 -0
  517. package/src/tx/validator/tx_validator.ts +1 -1
  518. package/src/zkpassport/index.ts +11 -12
  519. package/dest/block/l2_block_code_to_purge.d.ts +0 -11
  520. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  521. package/dest/block/l2_block_code_to_purge.js +0 -55
  522. package/dest/block/l2_block_header.d.ts +0 -94
  523. package/dest/block/l2_block_header.d.ts.map +0 -1
  524. package/dest/block/l2_block_header.js +0 -160
  525. package/dest/block/l2_block_new.d.ts +0 -134
  526. package/dest/block/l2_block_new.d.ts.map +0 -1
  527. package/dest/block/l2_block_new.js +0 -155
  528. package/dest/contract/contract_class_metadata.d.ts +0 -8
  529. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  530. package/dest/contract/contract_class_metadata.js +0 -1
  531. package/dest/contract/contract_metadata.d.ts +0 -7
  532. package/dest/contract/contract_metadata.d.ts.map +0 -1
  533. package/dest/contract/contract_metadata.js +0 -1
  534. package/dest/database-version/index.d.ts +0 -2
  535. package/dest/database-version/index.d.ts.map +0 -1
  536. package/dest/database-version/index.js +0 -1
  537. package/src/block/l2_block_code_to_purge.ts +0 -80
  538. package/src/block/l2_block_header.ts +0 -255
  539. package/src/block/l2_block_new.ts +0 -211
  540. package/src/contract/contract_class_metadata.ts +0 -8
  541. package/src/contract/contract_metadata.ts +0 -7
  542. package/src/database-version/index.ts +0 -1
@@ -20,9 +20,9 @@ import type { BlockHeader } from '../tx/block_header.js';
20
20
  import type { IndexedTxEffect } from '../tx/indexed_tx_effect.js';
21
21
  import type { TxHash } from '../tx/tx_hash.js';
22
22
  import type { TxReceipt } from '../tx/tx_receipt.js';
23
- import { type CheckpointedL2Block, PublishedL2Block } from './checkpointed_l2_block.js';
23
+ import type { BlockHash } from './block_hash.js';
24
+ import type { CheckpointedL2Block } from './checkpointed_l2_block.js';
24
25
  import type { L2Block } from './l2_block.js';
25
- import type { L2BlockNew } from './l2_block_new.js';
26
26
  import type { ValidateCheckpointNegativeResult, ValidateCheckpointResult } from './validate_block_result.js';
27
27
 
28
28
  /**
@@ -53,6 +53,20 @@ export interface L2BlockSource {
53
53
  */
54
54
  getProvenBlockNumber(): Promise<BlockNumber>;
55
55
 
56
+ /**
57
+ * Gets the number of the latest L2 block checkpointed seen by the block source implementation.
58
+ * @returns The number of the latest L2 block checkpointed seen by the block source implementation.
59
+ */
60
+ getCheckpointedL2BlockNumber(): Promise<BlockNumber>;
61
+
62
+ /**
63
+ * Computes the finalized block number based on the proven block number.
64
+ * A block is considered finalized when it's 2 epochs behind the proven block.
65
+ * TODO(#13569): Compute proper finalized block number based on L1 finalized block.
66
+ * @returns The finalized block number.
67
+ */
68
+ getFinalizedL2BlockNumber(): Promise<BlockNumber>;
69
+
56
70
  /**
57
71
  * Gets an l2 block header.
58
72
  * @param number - The block number to return or 'latest' for the most recent one.
@@ -68,15 +82,15 @@ export interface L2BlockSource {
68
82
  */
69
83
  getCheckpointedBlock(number: BlockNumber): Promise<CheckpointedL2Block | undefined>;
70
84
 
71
- getCheckpointedBlocks(from: BlockNumber, limit: number, proven?: boolean): Promise<CheckpointedL2Block[]>;
85
+ getCheckpointedBlocks(from: BlockNumber, limit: number): Promise<CheckpointedL2Block[]>;
72
86
 
73
87
  /**
74
- * Retrieves a collection of published checkpoints
75
- * @param checkpointNumber The first checkpoint to be retrieved
76
- * @param limit The number of checkpoints to be retrieved
77
- * @returns The collection of complete checkpoints
88
+ * Retrieves a collection of checkpoints.
89
+ * @param checkpointNumber The first checkpoint to be retrieved.
90
+ * @param limit The number of checkpoints to be retrieved.
91
+ * @returns The collection of complete checkpoints.
78
92
  */
79
- getPublishedCheckpoints(checkpointNumber: CheckpointNumber, limit: number): Promise<PublishedCheckpoint[]>;
93
+ getCheckpoints(checkpointNumber: CheckpointNumber, limit: number): Promise<PublishedCheckpoint[]>;
80
94
 
81
95
  /**
82
96
  * Gets the checkpoints for a given epoch
@@ -89,7 +103,7 @@ export interface L2BlockSource {
89
103
  * @param blockHash - The block hash to retrieve.
90
104
  * @returns The requested block header (or undefined if not found).
91
105
  */
92
- getBlockHeaderByHash(blockHash: Fr): Promise<BlockHeader | undefined>;
106
+ getBlockHeaderByHash(blockHash: BlockHash): Promise<BlockHeader | undefined>;
93
107
 
94
108
  /**
95
109
  * Gets a block header by its archive root.
@@ -103,7 +117,21 @@ export interface L2BlockSource {
103
117
  * @param number - The block number to return.
104
118
  * @returns The requested L2 block (or undefined if not found).
105
119
  */
106
- getL2BlockNew(number: BlockNumber): Promise<L2BlockNew | undefined>;
120
+ getL2Block(number: BlockNumber): Promise<L2Block | undefined>;
121
+
122
+ /**
123
+ * Gets an L2 block by its hash.
124
+ * @param blockHash - The block hash to retrieve.
125
+ * @returns The requested L2 block (or undefined if not found).
126
+ */
127
+ getL2BlockByHash(blockHash: BlockHash): Promise<L2Block | undefined>;
128
+
129
+ /**
130
+ * Gets an L2 block by its archive root.
131
+ * @param archive - The archive root to retrieve.
132
+ * @returns The requested L2 block (or undefined if not found).
133
+ */
134
+ getL2BlockByArchive(archive: Fr): Promise<L2Block | undefined>;
107
135
 
108
136
  /**
109
137
  * Gets a tx effect.
@@ -130,11 +158,11 @@ export interface L2BlockSource {
130
158
  getL2EpochNumber(): Promise<EpochNumber | undefined>;
131
159
 
132
160
  /**
133
- * Returns all block headers for a given epoch.
161
+ * Returns all checkpointed block headers for a given epoch.
134
162
  * @dev Use this method only with recent epochs, since it walks the block list backwards.
135
163
  * @param epochNumber - The epoch number to return headers for.
136
164
  */
137
- getBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]>;
165
+ getCheckpointedBlockHeadersForEpoch(epochNumber: EpochNumber): Promise<BlockHeader[]>;
138
166
 
139
167
  /**
140
168
  * Returns whether the given epoch is completed on L1, based on the current L1 and L2 block numbers.
@@ -179,46 +207,44 @@ export interface L2BlockSource {
179
207
  * Gets an l2 block. If a negative number is passed, the block returned is the most recent.
180
208
  * @param number - The block number to return (inclusive).
181
209
  * @returns The requested L2 block.
182
- * @deprecated Use getL2BlockNew instead.
183
210
  */
184
211
  getBlock(number: BlockNumber): Promise<L2Block | undefined>;
185
212
 
186
- getL2BlockNew(number: BlockNumber): Promise<L2BlockNew | undefined>;
187
-
188
- getL2BlocksNew(from: BlockNumber, limit: number, proven?: boolean): Promise<L2BlockNew[]>;
189
-
190
213
  /**
191
- * Returns all blocks for a given epoch.
214
+ * Returns all checkpointed blocks for a given epoch.
192
215
  * @dev Use this method only with recent epochs, since it walks the block list backwards.
193
216
  * @param epochNumber - The epoch number to return blocks for.
194
217
  */
195
- getBlocksForEpoch(epochNumber: EpochNumber): Promise<L2Block[]>;
218
+ getCheckpointedBlocksForEpoch(epochNumber: EpochNumber): Promise<CheckpointedL2Block[]>;
196
219
 
197
220
  /**
198
- * Gets a published block by its block hash.
221
+ * Returns all blocks for a given slot.
222
+ * @dev Use this method only with recent slots, since it walks the block list backwards.
223
+ * @param slotNumber - The slot number to return blocks for.
224
+ */
225
+ getBlocksForSlot(slotNumber: SlotNumber): Promise<L2Block[]>;
226
+
227
+ /**
228
+ * Gets a checkpointed block by its block hash.
199
229
  * @param blockHash - The block hash to retrieve.
200
230
  * @returns The requested block (or undefined if not found).
201
231
  */
202
- getPublishedBlockByHash(blockHash: Fr): Promise<PublishedL2Block | undefined>;
232
+ getCheckpointedBlockByHash(blockHash: BlockHash): Promise<CheckpointedL2Block | undefined>;
203
233
 
204
234
  /**
205
- * Gets a published block by its archive root.
235
+ * Gets a checkpointed block by its archive root.
206
236
  * @param archive - The archive root to retrieve.
207
237
  * @returns The requested block (or undefined if not found).
208
238
  */
209
- getPublishedBlockByArchive(archive: Fr): Promise<PublishedL2Block | undefined>;
239
+ getCheckpointedBlockByArchive(archive: Fr): Promise<CheckpointedL2Block | undefined>;
210
240
 
211
241
  /**
212
242
  * Gets up to `limit` amount of L2 blocks starting from `from`.
213
243
  * @param from - Number of the first block to return (inclusive).
214
244
  * @param limit - The maximum number of blocks to return.
215
- * @param proven - If true, only return blocks that have been proven.
216
245
  * @returns The requested L2 blocks.
217
246
  */
218
- getBlocks(from: BlockNumber, limit: number, proven?: boolean): Promise<L2Block[]>;
219
-
220
- /** Equivalent to getBlocks but includes publish data. */
221
- getPublishedBlocks(from: BlockNumber, limit: number, proven?: boolean): Promise<PublishedL2Block[]>;
247
+ getBlocks(from: BlockNumber, limit: number): Promise<L2Block[]>;
222
248
  }
223
249
 
224
250
  /**
@@ -230,7 +256,7 @@ export interface L2BlockSink {
230
256
  * @param block - The L2 block to add.
231
257
  * @throws If block number is not incremental (i.e., not exactly one more than the last stored block).
232
258
  */
233
- addBlock(block: L2BlockNew): Promise<void>;
259
+ addBlock(block: L2Block): Promise<void>;
234
260
  }
235
261
 
236
262
  /**
@@ -238,12 +264,15 @@ export interface L2BlockSink {
238
264
  * see L2BlockSourceEvents for the events emitted.
239
265
  */
240
266
  export type ArchiverEmitter = TypedEventEmitter<{
241
- [L2BlockSourceEvents.L2PruneDetected]: (args: L2BlockPruneEvent) => void;
267
+ [L2BlockSourceEvents.L2PruneUnproven]: (args: L2PruneUnprovenEvent) => void;
268
+ [L2BlockSourceEvents.L2PruneUncheckpointed]: (args: L2PruneUncheckpointedEvent) => void;
242
269
  [L2BlockSourceEvents.L2BlockProven]: (args: L2BlockProvenEvent) => void;
243
270
  [L2BlockSourceEvents.InvalidAttestationsCheckpointDetected]: (args: InvalidCheckpointDetectedEvent) => void;
244
271
  [L2BlockSourceEvents.L2BlocksCheckpointed]: (args: L2CheckpointEvent) => void;
245
272
  }>;
246
- export interface L2BlockSourceEventEmitter extends L2BlockSource, ArchiverEmitter {}
273
+ export interface L2BlockSourceEventEmitter extends L2BlockSource {
274
+ events: ArchiverEmitter;
275
+ }
247
276
 
248
277
  /**
249
278
  * Identifier for L2 block tags.
@@ -254,13 +283,6 @@ export interface L2BlockSourceEventEmitter extends L2BlockSource, ArchiverEmitte
254
283
  */
255
284
  export type L2BlockTag = 'proposed' | 'checkpointed' | 'proven' | 'finalized';
256
285
 
257
- /**
258
- * Reason for L2 block prune.
259
- * - uncheckpointed: L2 blocks were pruned due to a failure to checkpoint.
260
- * - unproven: L2 blocks were pruned due to a failure to prove.
261
- */
262
- export type L2BlockPruneReason = 'uncheckpointed' | 'unproven';
263
-
264
286
  /** Tips of the L2 chain. */
265
287
  export type L2Tips = {
266
288
  proposed: L2BlockId;
@@ -314,7 +336,8 @@ export const L2TipsSchema = z.object({
314
336
  });
315
337
 
316
338
  export enum L2BlockSourceEvents {
317
- L2PruneDetected = 'l2PruneDetected',
339
+ L2PruneUnproven = 'l2PruneUnproven',
340
+ L2PruneUncheckpointed = 'l2PruneUncheckpointed',
318
341
  L2BlockProven = 'l2BlockProven',
319
342
  L2BlocksCheckpointed = 'l2BlocksCheckpointed',
320
343
  InvalidAttestationsCheckpointDetected = 'invalidCheckpointDetected',
@@ -327,10 +350,16 @@ export type L2BlockProvenEvent = {
327
350
  epochNumber: EpochNumber;
328
351
  };
329
352
 
330
- export type L2BlockPruneEvent = {
331
- type: 'l2PruneDetected';
353
+ export type L2PruneUnprovenEvent = {
354
+ type: 'l2PruneUnproven';
332
355
  epochNumber: EpochNumber;
333
- blocks: L2BlockNew[];
356
+ blocks: L2Block[];
357
+ };
358
+
359
+ export type L2PruneUncheckpointedEvent = {
360
+ type: 'l2PruneUncheckpointed';
361
+ slotNumber: SlotNumber;
362
+ blocks: L2Block[];
334
363
  };
335
364
 
336
365
  export type L2CheckpointEvent = {
@@ -1,6 +1,6 @@
1
1
  import type { PublishedCheckpoint } from '../../checkpoint/published_checkpoint.js';
2
- import type { L2BlockNew } from '../l2_block_new.js';
3
- import type { CheckpointId, L2BlockId, L2BlockPruneReason, L2Tips } from '../l2_block_source.js';
2
+ import type { L2Block } from '../l2_block.js';
3
+ import type { CheckpointId, L2BlockId, L2Tips } from '../l2_block_source.js';
4
4
 
5
5
  /** Interface to the local view of the chain. Implemented by world-state and l2-tips-store. */
6
6
  export interface L2BlockStreamLocalDataProvider {
@@ -16,16 +16,19 @@ export interface L2BlockStreamEventHandler {
16
16
  export type L2BlockStreamEvent =
17
17
  | /** Emits blocks added to the chain. */ {
18
18
  type: 'blocks-added';
19
- blocks: L2BlockNew[];
19
+ blocks: L2Block[];
20
20
  }
21
21
  | /** Emits checkpoints published to L1. */ {
22
22
  type: 'chain-checkpointed';
23
23
  checkpoint: PublishedCheckpoint;
24
24
  block: L2BlockId;
25
25
  }
26
- | /** Reports last correct block (new tip of the proposed chain). */ {
26
+ | /**
27
+ * Reports last correct block (new tip of the proposed chain). Note that this is not necessarily the anchor block
28
+ * that will be used in the transaction - if the chain has already moved past the reorg, we'll also see blocks-added
29
+ * events that will push the anchor block forward.
30
+ */ {
27
31
  type: 'chain-pruned';
28
- reason: L2BlockPruneReason;
29
32
  block: L2BlockId;
30
33
  checkpoint: CheckpointId;
31
34
  }
@@ -4,9 +4,12 @@ import { createLogger } from '@aztec/foundation/log';
4
4
  import { RunningPromise } from '@aztec/foundation/running-promise';
5
5
 
6
6
  import type { PublishedCheckpoint } from '../../checkpoint/published_checkpoint.js';
7
- import { type L2BlockId, type L2BlockPruneReason, type L2BlockSource, makeL2BlockId } from '../l2_block_source.js';
7
+ import { type L2BlockId, type L2BlockSource, makeL2BlockId } from '../l2_block_source.js';
8
8
  import type { L2BlockStreamEvent, L2BlockStreamEventHandler, L2BlockStreamLocalDataProvider } from './interfaces.js';
9
9
 
10
+ /** Maximum number of checkpoints to prefetch at once during sync. Matches MAX_RPC_CHECKPOINTS_LEN. */
11
+ export const CHECKPOINT_PREFETCH_LIMIT = 50;
12
+
10
13
  /** Creates a stream of events for new blocks, chain tips updates, and reorgs, out of polling an archiver or a node. */
11
14
  export class L2BlockStream {
12
15
  private readonly runningPromise: RunningPromise;
@@ -16,13 +19,12 @@ export class L2BlockStream {
16
19
  constructor(
17
20
  private l2BlockSource: Pick<
18
21
  L2BlockSource,
19
- 'getL2BlocksNew' | 'getBlockHeader' | 'getL2Tips' | 'getPublishedCheckpoints' | 'getCheckpointedBlocks'
22
+ 'getBlocks' | 'getBlockHeader' | 'getL2Tips' | 'getCheckpoints' | 'getCheckpointedBlocks'
20
23
  >,
21
24
  private localData: L2BlockStreamLocalDataProvider,
22
25
  private handler: L2BlockStreamEventHandler,
23
26
  private readonly log = createLogger('types:block_stream'),
24
27
  private opts: {
25
- proven?: boolean;
26
28
  pollIntervalMS?: number;
27
29
  batchSize?: number;
28
30
  startingBlock?: number;
@@ -30,6 +32,8 @@ export class L2BlockStream {
30
32
  skipFinalized?: boolean;
31
33
  /** When true, checkpoint events will not be emitted. Blocks are still fetched via checkpoints but only blocks-added events are emitted. */
32
34
  ignoreCheckpoints?: boolean;
35
+ /** Maximum number of checkpoints to prefetch at once during sync. Defaults to CHECKPOINT_PREFETCH_LIMIT (50). */
36
+ checkpointPrefetchLimit?: number;
33
37
  } = {},
34
38
  ) {
35
39
  // Note that RunningPromise is in stopped state by default. This promise won't run until someone invokes `start`,
@@ -85,18 +89,9 @@ export class L2BlockStream {
85
89
  this.log.verbose(
86
90
  `Reorg detected. Pruning blocks from ${latestBlockNumber + 1} to ${localTips.proposed.number}.`,
87
91
  );
88
- // This check is not 100% accurate
89
- // If the local tips are sufficiently behind the source tips, such that we are missing at least one checkpoint
90
- // that has now been re-orged due to a proof failure then this will indicate a failure to checkpoint rather than a failure to prove
91
- // TODO: (mbps/PhilWindle): Improve re-org detection accuracy when we come to do re-orgs
92
- let reason: L2BlockPruneReason = 'unproven';
93
- if (latestBlockNumber === localTips.checkpointed.block.number && !this.opts.ignoreCheckpoints) {
94
- reason = 'uncheckpointed';
95
- }
96
92
  await this.emitEvent({
97
93
  type: 'chain-pruned',
98
94
  block: makeL2BlockId(latestBlockNumber, hash),
99
- reason,
100
95
  checkpoint: sourceTips.checkpointed.checkpoint,
101
96
  });
102
97
  }
@@ -133,7 +128,7 @@ export class L2BlockStream {
133
128
  if (!this.opts.ignoreCheckpoints) {
134
129
  let loop1Iterations = 0;
135
130
  while (nextCheckpointToEmit <= sourceTips.checkpointed.checkpoint.number) {
136
- const checkpoints = await this.l2BlockSource.getPublishedCheckpoints(nextCheckpointToEmit, 1);
131
+ const checkpoints = await this.l2BlockSource.getCheckpoints(nextCheckpointToEmit, 1);
137
132
  if (checkpoints.length === 0) {
138
133
  break;
139
134
  }
@@ -159,27 +154,36 @@ export class L2BlockStream {
159
154
  }
160
155
  }
161
156
 
162
- // Loop 2: Fetch new checkpointed blocks. For each block, get its checkpoint, emit all blocks
157
+ // Loop 2: Fetch new checkpointed blocks. For each checkpoint, emit all blocks
163
158
  // from that checkpoint that we need, then emit the checkpoint event.
164
- // We cache the current checkpoint to avoid redundant fetches when batchSize < checkpoint size.
165
- let checkpoint: PublishedCheckpoint | undefined;
166
- while (nextBlockNumber <= sourceTips.checkpointed.block.number) {
167
- const limit = Math.min(this.opts.batchSize ?? 50, sourceTips.checkpointed.block.number - nextBlockNumber + 1);
159
+ // We prefetch multiple checkpoints, then process them one by one.
160
+ let prefetchedCheckpoints: PublishedCheckpoint[] = [];
161
+ let prefetchIdx = 0;
162
+ let nextCheckpointNumber: CheckpointNumber | undefined;
168
163
 
169
- // Check if we need to fetch a new checkpoint (nextBlockNumber is beyond the cached one)
170
- if (!checkpoint || nextBlockNumber > checkpoint.checkpoint.blocks.at(-1)!.number) {
171
- const blocks = await this.l2BlockSource.getCheckpointedBlocks(BlockNumber(nextBlockNumber), 1);
172
- if (blocks.length === 0) {
173
- break;
174
- }
175
- const checkpoints = await this.l2BlockSource.getPublishedCheckpoints(blocks[0].checkpointNumber, 1);
176
- if (checkpoints.length === 0) {
164
+ // Find the starting checkpoint number
165
+ if (nextBlockNumber <= sourceTips.checkpointed.block.number) {
166
+ const blocks = await this.l2BlockSource.getCheckpointedBlocks(BlockNumber(nextBlockNumber), 1);
167
+ if (blocks.length > 0) {
168
+ nextCheckpointNumber = blocks[0].checkpointNumber;
169
+ }
170
+ }
171
+
172
+ while (nextBlockNumber <= sourceTips.checkpointed.block.number && nextCheckpointNumber !== undefined) {
173
+ // Refill the prefetch buffer when exhausted
174
+ if (prefetchIdx >= prefetchedCheckpoints.length) {
175
+ const prefetchLimit = this.opts.checkpointPrefetchLimit ?? CHECKPOINT_PREFETCH_LIMIT;
176
+ prefetchedCheckpoints = await this.l2BlockSource.getCheckpoints(nextCheckpointNumber, prefetchLimit);
177
+ prefetchIdx = 0;
178
+ if (prefetchedCheckpoints.length === 0) {
177
179
  break;
178
180
  }
179
- checkpoint = checkpoints[0];
180
181
  }
181
182
 
183
+ const checkpoint = prefetchedCheckpoints[prefetchIdx]!;
184
+
182
185
  // Get all blocks from this checkpoint that we need, respecting batchSize
186
+ const limit = Math.min(this.opts.batchSize ?? 50, sourceTips.checkpointed.block.number - nextBlockNumber + 1);
183
187
  const blocksForCheckpoint = checkpoint.checkpoint.blocks
184
188
  .filter(b => b.number >= nextBlockNumber)
185
189
  .slice(0, limit);
@@ -189,23 +193,27 @@ export class L2BlockStream {
189
193
  await this.emitEvent({ type: 'blocks-added', blocks: blocksForCheckpoint });
190
194
  nextBlockNumber = blocksForCheckpoint.at(-1)!.number + 1;
191
195
 
192
- // If we've reached the end of this checkpoint, emit the checkpoint event
196
+ // If we've reached the end of this checkpoint, emit the checkpoint event and move to next
193
197
  const lastBlockInCheckpoint = checkpoint.checkpoint.blocks.at(-1)!;
194
- if (!this.opts.ignoreCheckpoints && nextBlockNumber > lastBlockInCheckpoint.number) {
195
- const lastBlockHash = await lastBlockInCheckpoint.hash();
196
- await this.emitEvent({
197
- type: 'chain-checkpointed',
198
- checkpoint,
199
- block: makeL2BlockId(lastBlockInCheckpoint.number, lastBlockHash.toString()),
200
- });
198
+ if (nextBlockNumber > lastBlockInCheckpoint.number) {
199
+ if (!this.opts.ignoreCheckpoints) {
200
+ const lastBlockHash = await lastBlockInCheckpoint.hash();
201
+ await this.emitEvent({
202
+ type: 'chain-checkpointed',
203
+ checkpoint,
204
+ block: makeL2BlockId(lastBlockInCheckpoint.number, lastBlockHash.toString()),
205
+ });
206
+ }
207
+ prefetchIdx++;
208
+ nextCheckpointNumber = CheckpointNumber(nextCheckpointNumber + 1);
201
209
  }
202
210
  }
203
211
 
204
212
  // Loop 3: Fetch any remaining uncheckpointed (proposed) blocks.
205
213
  while (nextBlockNumber <= sourceTips.proposed.number) {
206
214
  const limit = Math.min(this.opts.batchSize ?? 50, sourceTips.proposed.number - nextBlockNumber + 1);
207
- this.log.trace(`Requesting blocks from ${nextBlockNumber} limit ${limit} proven=${this.opts.proven}`);
208
- const blocks = await this.l2BlockSource.getL2BlocksNew(BlockNumber(nextBlockNumber), limit, this.opts.proven);
215
+ this.log.trace(`Requesting blocks from ${nextBlockNumber} limit ${limit}`);
216
+ const blocks = await this.l2BlockSource.getBlocks(BlockNumber(nextBlockNumber), BlockNumber(limit));
209
217
  if (blocks.length === 0) {
210
218
  break;
211
219
  }
@@ -2,7 +2,7 @@ import { GENESIS_BLOCK_HEADER_HASH } from '@aztec/constants';
2
2
  import { BlockNumber, CheckpointNumber } from '@aztec/foundation/branded-types';
3
3
 
4
4
  import type { PublishedCheckpoint } from '../../checkpoint/published_checkpoint.js';
5
- import type { L2BlockNew } from '../l2_block_new.js';
5
+ import type { L2Block } from '../l2_block.js';
6
6
  import {
7
7
  type CheckpointId,
8
8
  GENESIS_CHECKPOINT_HEADER_HASH,
@@ -109,7 +109,7 @@ export abstract class L2TipsStoreBase implements L2BlockStreamEventHandler, L2Bl
109
109
  }
110
110
 
111
111
  // Protected helper that subclasses can override for block hash computation
112
- protected computeBlockHash(block: L2BlockNew): Promise<string> {
112
+ protected computeBlockHash(block: L2Block): Promise<string> {
113
113
  return block.hash().then(hash => hash.toString());
114
114
  }
115
115
 
@@ -5,8 +5,8 @@ import { Fr } from '@aztec/foundation/curves/bn254';
5
5
  import {
6
6
  type CheckpointId,
7
7
  GENESIS_CHECKPOINT_HEADER_HASH,
8
+ L2Block,
8
9
  type L2BlockId,
9
- L2BlockNew,
10
10
  type L2TipId,
11
11
  } from '@aztec/stdlib/block';
12
12
  import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
@@ -31,8 +31,8 @@ export function testL2TipsStore(makeTipsStore: () => Promise<L2TipsStore>) {
31
31
  blockToCheckpoint.clear();
32
32
  });
33
33
 
34
- const makeBlock = async (number: number): Promise<L2BlockNew> => {
35
- const block = await L2BlockNew.random(BlockNumber(number));
34
+ const makeBlock = async (number: number): Promise<L2Block> => {
35
+ const block = await L2Block.random(BlockNumber(number));
36
36
  blockHashes.set(number, (await block.hash()).toString());
37
37
  return block;
38
38
  };
@@ -74,7 +74,7 @@ export function testL2TipsStore(makeTipsStore: () => Promise<L2TipsStore>) {
74
74
  checkpointed: makeTipId(checkpointed),
75
75
  });
76
76
 
77
- const makeCheckpoint = async (checkpointNumber: number, blocks: L2BlockNew[]): Promise<PublishedCheckpoint> => {
77
+ const makeCheckpoint = async (checkpointNumber: number, blocks: L2Block[]): Promise<PublishedCheckpoint> => {
78
78
  const checkpoint = await Checkpoint.random(CheckpointNumber(checkpointNumber), {
79
79
  numBlocks: blocks.length,
80
80
  startBlockNumber: blocks[0].number,
@@ -243,7 +243,6 @@ export function testL2TipsStore(makeTipsStore: () => Promise<L2TipsStore>) {
243
243
  await tipsStore.handleBlockStreamEvent({
244
244
  type: 'chain-pruned',
245
245
  block: makeBlockId(5),
246
- reason: 'unproven',
247
246
  checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
248
247
  });
249
248
 
@@ -268,7 +267,6 @@ export function testL2TipsStore(makeTipsStore: () => Promise<L2TipsStore>) {
268
267
  await tipsStore.handleBlockStreamEvent({
269
268
  type: 'chain-pruned',
270
269
  block: makeTip(0),
271
- reason: 'unproven',
272
270
  checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
273
271
  });
274
272
 
@@ -334,7 +332,6 @@ export function testL2TipsStore(makeTipsStore: () => Promise<L2TipsStore>) {
334
332
  await tipsStore.handleBlockStreamEvent({
335
333
  type: 'chain-pruned',
336
334
  block: makeBlockId(5),
337
- reason: 'unproven',
338
335
  checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
339
336
  });
340
337
 
@@ -399,7 +396,6 @@ export function testL2TipsStore(makeTipsStore: () => Promise<L2TipsStore>) {
399
396
  await tipsStore.handleBlockStreamEvent({
400
397
  type: 'chain-pruned',
401
398
  block: makeBlockId(3),
402
- reason: 'unproven',
403
399
  checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
404
400
  });
405
401
 
@@ -478,7 +474,6 @@ export function testL2TipsStore(makeTipsStore: () => Promise<L2TipsStore>) {
478
474
  await tipsStore.handleBlockStreamEvent({
479
475
  type: 'chain-pruned',
480
476
  block: makeBlockId(3),
481
- reason: 'unproven',
482
477
  checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
483
478
  });
484
479
 
@@ -11,6 +11,7 @@ import {
11
11
  deserializeCheckpointInfo,
12
12
  serializeCheckpointInfo,
13
13
  } from '../checkpoint/checkpoint_info.js';
14
+ import { MAX_COMMITTEE_SIZE } from '../deserialization/index.js';
14
15
  import { CommitteeAttestation } from './proposal/committee_attestation.js';
15
16
 
16
17
  /** Subtype for invalid checkpoint validation results */
@@ -109,13 +110,13 @@ export function deserializeValidateCheckpointResult(bufferOrReader: Buffer | Buf
109
110
  if (valid) {
110
111
  return { valid };
111
112
  }
112
- const reason = reader.readString() as 'insufficient-attestations' | 'invalid-attestation';
113
+ const reason = reader.readString(64) as 'insufficient-attestations' | 'invalid-attestation';
113
114
  const checkpoint = deserializeCheckpointInfo(reader.readBuffer());
114
- const committee = reader.readVector(EthAddress);
115
+ const committee = reader.readVector(EthAddress, MAX_COMMITTEE_SIZE);
115
116
  const epoch = EpochNumber(reader.readNumber());
116
117
  const seed = reader.readBigInt();
117
- const attestors = reader.readVector(EthAddress);
118
- const attestations = reader.readVector(CommitteeAttestation);
118
+ const attestors = reader.readVector(EthAddress, MAX_COMMITTEE_SIZE);
119
+ const attestations = reader.readVector(CommitteeAttestation, MAX_COMMITTEE_SIZE);
119
120
  const invalidIndex = reader.readNumber();
120
121
  if (reason === 'insufficient-attestations') {
121
122
  return { valid, reason, checkpoint, committee, epoch, seed, attestors, attestations };
@@ -1,5 +1,11 @@
1
1
  import { encodeCheckpointBlobDataFromBlocks } from '@aztec/blob-lib/encoding';
2
- import { BlockNumber, CheckpointNumber, CheckpointNumberSchema } from '@aztec/foundation/branded-types';
2
+ import {
3
+ BlockNumber,
4
+ CheckpointNumber,
5
+ CheckpointNumberSchema,
6
+ IndexWithinCheckpoint,
7
+ SlotNumber,
8
+ } from '@aztec/foundation/branded-types';
3
9
  import { sum } from '@aztec/foundation/collection';
4
10
  import { Fr } from '@aztec/foundation/curves/bn254';
5
11
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
@@ -7,11 +13,15 @@ import type { FieldsOf } from '@aztec/foundation/types';
7
13
 
8
14
  import { z } from 'zod';
9
15
 
10
- import { L2BlockNew } from '../block/l2_block_new.js';
16
+ import { L2Block } from '../block/l2_block.js';
17
+ import { MAX_BLOCKS_PER_CHECKPOINT } from '../deserialization/index.js';
18
+ import { computeCheckpointOutHash } from '../messaging/out_hash.js';
11
19
  import { CheckpointHeader } from '../rollup/checkpoint_header.js';
12
20
  import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
13
21
  import type { CheckpointInfo } from './checkpoint_info.js';
14
22
 
23
+ type FieldsOfCheckpoint = Omit<FieldsOf<Checkpoint>, 'slot'>;
24
+
15
25
  export class Checkpoint {
16
26
  constructor(
17
27
  /** Snapshot of archive tree after the checkpoint is added. */
@@ -19,27 +29,31 @@ export class Checkpoint {
19
29
  /** Header of the checkpoint. */
20
30
  public header: CheckpointHeader,
21
31
  /** L2 blocks in the checkpoint. */
22
- public blocks: L2BlockNew[],
32
+ public blocks: L2Block[],
23
33
  /** Number of the checkpoint. */
24
34
  public number: CheckpointNumber,
25
35
  ) {}
26
36
 
37
+ get slot(): SlotNumber {
38
+ return this.header.slotNumber;
39
+ }
40
+
27
41
  static get schema() {
28
42
  return z
29
43
  .object({
30
44
  archive: AppendOnlyTreeSnapshot.schema,
31
45
  header: CheckpointHeader.schema,
32
- blocks: z.array(L2BlockNew.schema),
46
+ blocks: z.array(L2Block.schema),
33
47
  number: CheckpointNumberSchema,
34
48
  })
35
49
  .transform(({ archive, header, blocks, number }) => new Checkpoint(archive, header, blocks, number));
36
50
  }
37
51
 
38
- static from(fields: FieldsOf<Checkpoint>) {
52
+ static from(fields: FieldsOfCheckpoint) {
39
53
  return new Checkpoint(...Checkpoint.getFields(fields));
40
54
  }
41
55
 
42
- static getFields(fields: FieldsOf<Checkpoint>) {
56
+ static getFields(fields: FieldsOfCheckpoint) {
43
57
  return [fields.archive, fields.header, fields.blocks, fields.number] as const;
44
58
  }
45
59
 
@@ -48,7 +62,7 @@ export class Checkpoint {
48
62
  return new Checkpoint(
49
63
  reader.readObject(AppendOnlyTreeSnapshot),
50
64
  reader.readObject(CheckpointHeader),
51
- reader.readVector(L2BlockNew),
65
+ reader.readVector(L2Block, MAX_BLOCKS_PER_CHECKPOINT),
52
66
  CheckpointNumber(reader.readNumber()),
53
67
  );
54
68
  }
@@ -66,6 +80,14 @@ export class Checkpoint {
66
80
  return this.header.hash();
67
81
  }
68
82
 
83
+ // Returns the out hash computed from all l2-to-l1 messages in this checkpoint.
84
+ // Note: This value is different from the out hash in the header, which is the **accumulated** out hash over all
85
+ // checkpoints up to and including this one in the epoch.
86
+ public getCheckpointOutHash(): Fr {
87
+ const msgs = this.blocks.map(block => block.body.txEffects.map(txEffect => txEffect.l2ToL1Msgs));
88
+ return computeCheckpointOutHash(msgs);
89
+ }
90
+
69
91
  public getState() {
70
92
  return this.blocks.at(-1)!.header.state;
71
93
  }
@@ -113,17 +135,17 @@ export class Checkpoint {
113
135
  startBlockNumber?: number;
114
136
  previousArchive?: AppendOnlyTreeSnapshot;
115
137
  } & Partial<Parameters<typeof CheckpointHeader.random>[0]> &
116
- Partial<Parameters<typeof L2BlockNew.random>[1]> = {},
138
+ Partial<Parameters<typeof L2Block.random>[1]> = {},
117
139
  ) {
118
140
  const header = CheckpointHeader.random(options);
119
141
 
120
142
  // Create blocks sequentially to chain archive roots properly.
121
143
  // Each block's header.lastArchive must equal the previous block's archive.
122
- const blocks: L2BlockNew[] = [];
144
+ const blocks: L2Block[] = [];
123
145
  let lastArchive = previousArchive;
124
146
  for (let i = 0; i < numBlocks; i++) {
125
- const block = await L2BlockNew.random(BlockNumber(startBlockNumber + i), {
126
- indexWithinCheckpoint: i,
147
+ const block = await L2Block.random(BlockNumber(startBlockNumber + i), {
148
+ indexWithinCheckpoint: IndexWithinCheckpoint(i),
127
149
  ...options,
128
150
  ...(lastArchive ? { lastArchive } : {}),
129
151
  });