@aztec/stdlib 0.0.1-commit.6c91f13 → 0.0.1-commit.6d63667d

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 (592) hide show
  1. package/dest/abi/contract_artifact.d.ts +2 -2
  2. package/dest/abi/contract_artifact.d.ts.map +1 -1
  3. package/dest/abi/contract_artifact.js +1 -1
  4. package/dest/abi/function_call.d.ts +9 -1
  5. package/dest/abi/function_call.d.ts.map +1 -1
  6. package/dest/abi/selector.js +3 -1
  7. package/dest/abi/utils.d.ts +7 -1
  8. package/dest/abi/utils.d.ts.map +1 -1
  9. package/dest/abi/utils.js +7 -0
  10. package/dest/auth_witness/auth_witness.d.ts +2 -1
  11. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  12. package/dest/avm/avm.d.ts +62 -62
  13. package/dest/avm/avm_accumulated_data.d.ts +30 -3
  14. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  15. package/dest/avm/avm_accumulated_data.js +5 -2
  16. package/dest/avm/avm_circuit_public_inputs.d.ts +9 -9
  17. package/dest/avm/avm_circuit_public_inputs.js +3 -1
  18. package/dest/avm/avm_proving_request.d.ts +299 -299
  19. package/dest/avm/contract_storage_read.d.ts +13 -1
  20. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  21. package/dest/avm/contract_storage_update_request.d.ts +13 -1
  22. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  23. package/dest/avm/public_call_stack_item_compressed.d.ts +3 -1
  24. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  25. package/dest/avm/public_data_read.d.ts +10 -1
  26. package/dest/avm/public_data_read.d.ts.map +1 -1
  27. package/dest/avm/public_data_update_request.d.ts +10 -1
  28. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  29. package/dest/avm/public_data_update_request.js +3 -1
  30. package/dest/avm/public_data_write.d.ts +7 -1
  31. package/dest/avm/public_data_write.d.ts.map +1 -1
  32. package/dest/avm/public_inner_call_request.d.ts +4 -1
  33. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  34. package/dest/avm/public_inner_call_request.js +3 -1
  35. package/dest/avm/revert_code.d.ts +4 -4
  36. package/dest/avm/revert_code.d.ts.map +1 -1
  37. package/dest/avm/revert_code.js +3 -1
  38. package/dest/aztec-address/index.js +4 -2
  39. package/dest/block/attestation_info.d.ts +5 -5
  40. package/dest/block/attestation_info.d.ts.map +1 -1
  41. package/dest/block/attestation_info.js +4 -4
  42. package/dest/block/block_hash.d.ts +18 -14
  43. package/dest/block/block_hash.d.ts.map +1 -1
  44. package/dest/block/block_hash.js +22 -20
  45. package/dest/block/block_parameter.d.ts +4 -3
  46. package/dest/block/block_parameter.d.ts.map +1 -1
  47. package/dest/block/block_parameter.js +2 -0
  48. package/dest/block/body.d.ts +1 -1
  49. package/dest/block/body.d.ts.map +1 -1
  50. package/dest/block/body.js +5 -2
  51. package/dest/block/checkpointed_l2_block.d.ts +20 -137
  52. package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
  53. package/dest/block/checkpointed_l2_block.js +7 -45
  54. package/dest/block/in_block.d.ts +9 -9
  55. package/dest/block/in_block.d.ts.map +1 -1
  56. package/dest/block/in_block.js +4 -4
  57. package/dest/block/index.d.ts +1 -3
  58. package/dest/block/index.d.ts.map +1 -1
  59. package/dest/block/index.js +0 -2
  60. package/dest/block/l2_block.d.ts +57 -57
  61. package/dest/block/l2_block.d.ts.map +1 -1
  62. package/dest/block/l2_block.js +64 -108
  63. package/dest/block/l2_block_source.d.ts +298 -68
  64. package/dest/block/l2_block_source.d.ts.map +1 -1
  65. package/dest/block/l2_block_source.js +25 -6
  66. package/dest/block/l2_block_stream/index.d.ts +2 -1
  67. package/dest/block/l2_block_stream/index.d.ts.map +1 -1
  68. package/dest/block/l2_block_stream/index.js +1 -0
  69. package/dest/block/l2_block_stream/interfaces.d.ts +15 -5
  70. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  71. package/dest/block/l2_block_stream/l2_block_stream.d.ts +8 -3
  72. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  73. package/dest/block/l2_block_stream/l2_block_stream.js +106 -31
  74. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +24 -16
  75. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
  76. package/dest/block/l2_block_stream/l2_tips_memory_store.js +55 -61
  77. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
  78. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
  79. package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
  80. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  81. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  82. package/dest/block/test/l2_tips_store_test_suite.js +478 -38
  83. package/dest/block/validate_block_result.d.ts +24 -24
  84. package/dest/block/validate_block_result.d.ts.map +1 -1
  85. package/dest/block/validate_block_result.js +18 -17
  86. package/dest/checkpoint/checkpoint.d.ts +30 -20
  87. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  88. package/dest/checkpoint/checkpoint.js +19 -6
  89. package/dest/checkpoint/checkpoint_info.d.ts +32 -3
  90. package/dest/checkpoint/checkpoint_info.d.ts.map +1 -1
  91. package/dest/checkpoint/checkpoint_info.js +34 -1
  92. package/dest/checkpoint/index.d.ts +2 -1
  93. package/dest/checkpoint/index.d.ts.map +1 -1
  94. package/dest/checkpoint/index.js +1 -0
  95. package/dest/checkpoint/published_checkpoint.d.ts +17 -15
  96. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  97. package/dest/checkpoint/published_checkpoint.js +4 -3
  98. package/dest/config/node-rpc-config.js +1 -1
  99. package/dest/contract/complete_address.d.ts +4 -1
  100. package/dest/contract/complete_address.d.ts.map +1 -1
  101. package/dest/contract/contract_address.js +1 -1
  102. package/dest/contract/contract_class_id.d.ts +1 -1
  103. package/dest/contract/contract_class_id.js +1 -1
  104. package/dest/contract/contract_deployment_data.d.ts +5 -5
  105. package/dest/contract/index.d.ts +1 -3
  106. package/dest/contract/index.d.ts.map +1 -1
  107. package/dest/contract/index.js +0 -2
  108. package/dest/contract/interfaces/contract_instance.d.ts +16 -16
  109. package/dest/contract/private_function.d.ts +1 -1
  110. package/dest/contract/private_function.d.ts.map +1 -1
  111. package/dest/contract/private_function.js +2 -3
  112. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  113. package/dest/contract/private_function_membership_proof.js +1 -1
  114. package/dest/database-version/database_version.d.ts +58 -0
  115. package/dest/database-version/database_version.d.ts.map +1 -0
  116. package/dest/database-version/database_version.js +69 -0
  117. package/dest/database-version/version_manager.d.ts +3 -49
  118. package/dest/database-version/version_manager.d.ts.map +1 -1
  119. package/dest/database-version/version_manager.js +1 -64
  120. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  121. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  122. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  123. package/dest/deserialization/index.d.ts +11 -0
  124. package/dest/deserialization/index.d.ts.map +1 -0
  125. package/dest/deserialization/index.js +10 -0
  126. package/dest/epoch-helpers/index.d.ts +3 -1
  127. package/dest/epoch-helpers/index.d.ts.map +1 -1
  128. package/dest/epoch-helpers/index.js +5 -1
  129. package/dest/errors/proving_error.d.ts +2 -2
  130. package/dest/errors/proving_error.d.ts.map +1 -1
  131. package/dest/gas/gas.js +3 -1
  132. package/dest/gas/gas_fees.js +3 -1
  133. package/dest/hash/hash.js +2 -2
  134. package/dest/hash/map_slot.d.ts +1 -1
  135. package/dest/hash/map_slot.d.ts.map +1 -1
  136. package/dest/hash/map_slot.js +4 -3
  137. package/dest/interfaces/api_limit.d.ts +3 -1
  138. package/dest/interfaces/api_limit.d.ts.map +1 -1
  139. package/dest/interfaces/api_limit.js +2 -0
  140. package/dest/interfaces/archiver.d.ts +6 -6
  141. package/dest/interfaces/archiver.d.ts.map +1 -1
  142. package/dest/interfaces/archiver.js +22 -17
  143. package/dest/interfaces/aztec-node-admin.d.ts +73 -31
  144. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  145. package/dest/interfaces/aztec-node-admin.js +5 -3
  146. package/dest/interfaces/aztec-node.d.ts +74 -76
  147. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  148. package/dest/interfaces/aztec-node.js +15 -16
  149. package/dest/interfaces/block-builder.d.ts +22 -14
  150. package/dest/interfaces/block-builder.d.ts.map +1 -1
  151. package/dest/interfaces/block-builder.js +7 -0
  152. package/dest/interfaces/configs.d.ts +12 -7
  153. package/dest/interfaces/configs.d.ts.map +1 -1
  154. package/dest/interfaces/configs.js +2 -1
  155. package/dest/interfaces/get_logs_response.d.ts +16 -9
  156. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  157. package/dest/interfaces/l2_logs_source.d.ts +14 -5
  158. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  159. package/dest/interfaces/p2p.d.ts +7 -9
  160. package/dest/interfaces/p2p.d.ts.map +1 -1
  161. package/dest/interfaces/p2p.js +3 -4
  162. package/dest/interfaces/prover-broker.d.ts +16 -1
  163. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  164. package/dest/interfaces/prover-broker.js +4 -1
  165. package/dest/interfaces/prover-client.d.ts +15 -1
  166. package/dest/interfaces/prover-client.d.ts.map +1 -1
  167. package/dest/interfaces/prover-client.js +12 -1
  168. package/dest/interfaces/proving-job.d.ts +218 -218
  169. package/dest/interfaces/proving-job.d.ts.map +1 -1
  170. package/dest/interfaces/proving-job.js +1 -7
  171. package/dest/interfaces/server_circuit_prover.d.ts +4 -3
  172. package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
  173. package/dest/interfaces/tx_provider.d.ts +3 -3
  174. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  175. package/dest/interfaces/validator.d.ts +140 -18
  176. package/dest/interfaces/validator.d.ts.map +1 -1
  177. package/dest/interfaces/validator.js +5 -3
  178. package/dest/kernel/claimed_length_array.js +3 -1
  179. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +6 -5
  180. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  181. package/dest/kernel/hints/build_note_hash_read_request_hints.js +19 -10
  182. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
  183. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  184. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
  185. package/dest/kernel/hints/key_validation_hint.d.ts +2 -1
  186. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  187. package/dest/kernel/hints/key_validation_request.d.ts +2 -1
  188. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  189. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +6 -1
  190. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +1 -1
  191. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  192. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  193. package/dest/kernel/hints/read_request.d.ts +7 -1
  194. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  195. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  196. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  197. package/dest/kernel/hints/transient_data_squashing_hint.js +3 -1
  198. package/dest/kernel/log_hash.js +3 -1
  199. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  200. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  201. package/dest/kernel/private_call_data.d.ts +25 -1
  202. package/dest/kernel/private_call_data.d.ts.map +1 -1
  203. package/dest/kernel/private_call_request.d.ts +16 -1
  204. package/dest/kernel/private_call_request.d.ts.map +1 -1
  205. package/dest/kernel/private_circuit_public_inputs.d.ts +74 -1
  206. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  207. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +31 -1
  208. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  209. package/dest/kernel/private_kernel_data.d.ts +7 -1
  210. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  211. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
  212. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  213. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  214. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  215. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  216. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  217. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +10 -1
  218. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  219. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +23 -1
  220. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  221. package/dest/kernel/private_log_data.js +5 -2
  222. package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
  223. package/dest/kernel/private_to_avm_accumulated_data.js +5 -2
  224. package/dest/kernel/private_to_public_accumulated_data.js +3 -1
  225. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
  226. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  227. package/dest/kernel/private_to_rollup_accumulated_data.js +3 -1
  228. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +16 -1
  229. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  230. package/dest/kernel/private_validation_requests.d.ts +10 -1
  231. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  232. package/dest/kernel/private_validation_requests.js +3 -1
  233. package/dest/kernel/public_call_request.d.ts +22 -1
  234. package/dest/kernel/public_call_request.d.ts.map +1 -1
  235. package/dest/kernel/public_call_request.js +5 -2
  236. package/dest/kernel/utils/optional_number.d.ts +7 -1
  237. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  238. package/dest/keys/derivation.d.ts +3 -3
  239. package/dest/keys/derivation.js +8 -8
  240. package/dest/keys/key_types.d.ts +1 -1
  241. package/dest/keys/public_keys.d.ts +5 -1
  242. package/dest/keys/public_keys.d.ts.map +1 -1
  243. package/dest/keys/utils.d.ts +1 -1
  244. package/dest/keys/utils.d.ts.map +1 -1
  245. package/dest/keys/utils.js +7 -3
  246. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  247. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  248. package/dest/l1-contracts/slash_factory.js +1 -0
  249. package/dest/logs/contract_class_log.js +3 -1
  250. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  251. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  252. package/dest/logs/extended_public_log.d.ts +17 -9
  253. package/dest/logs/extended_public_log.d.ts.map +1 -1
  254. package/dest/logs/log_id.d.ts +21 -14
  255. package/dest/logs/log_id.d.ts.map +1 -1
  256. package/dest/logs/log_id.js +20 -17
  257. package/dest/logs/private_log.js +3 -1
  258. package/dest/logs/public_log.js +3 -1
  259. package/dest/logs/siloed_tag.d.ts +1 -1
  260. package/dest/logs/siloed_tag.d.ts.map +1 -1
  261. package/dest/logs/siloed_tag.js +4 -3
  262. package/dest/messaging/in_hash.d.ts +4 -2
  263. package/dest/messaging/in_hash.d.ts.map +1 -1
  264. package/dest/messaging/in_hash.js +3 -1
  265. package/dest/messaging/inbox_leaf.d.ts +3 -1
  266. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  267. package/dest/messaging/l1_actor.d.ts +7 -1
  268. package/dest/messaging/l1_actor.d.ts.map +1 -1
  269. package/dest/messaging/l1_to_l2_message.d.ts +6 -1
  270. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  271. package/dest/messaging/l2_actor.d.ts +7 -1
  272. package/dest/messaging/l2_actor.d.ts.map +1 -1
  273. package/dest/messaging/l2_to_l1_membership.d.ts +88 -6
  274. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  275. package/dest/messaging/l2_to_l1_membership.js +160 -42
  276. package/dest/messaging/out_hash.d.ts +41 -3
  277. package/dest/messaging/out_hash.d.ts.map +1 -1
  278. package/dest/messaging/out_hash.js +54 -19
  279. package/dest/note/note_dao.d.ts +36 -5
  280. package/dest/note/note_dao.d.ts.map +1 -1
  281. package/dest/note/note_dao.js +15 -12
  282. package/dest/p2p/attestation_utils.d.ts +3 -3
  283. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  284. package/dest/p2p/attestation_utils.js +1 -1
  285. package/dest/p2p/block_proposal.d.ts +102 -23
  286. package/dest/p2p/block_proposal.d.ts.map +1 -1
  287. package/dest/p2p/block_proposal.js +140 -39
  288. package/dest/p2p/checkpoint_attestation.d.ts +81 -0
  289. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
  290. package/dest/p2p/{block_attestation.js → checkpoint_attestation.js} +22 -19
  291. package/dest/p2p/checkpoint_proposal.d.ts +167 -0
  292. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
  293. package/dest/p2p/checkpoint_proposal.js +229 -0
  294. package/dest/p2p/consensus_payload.d.ts +9 -9
  295. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  296. package/dest/p2p/consensus_payload.js +3 -5
  297. package/dest/p2p/constants.d.ts +3 -0
  298. package/dest/p2p/constants.d.ts.map +1 -0
  299. package/dest/p2p/constants.js +2 -0
  300. package/dest/p2p/gossipable.d.ts +4 -3
  301. package/dest/p2p/gossipable.d.ts.map +1 -1
  302. package/dest/p2p/gossipable.js +16 -5
  303. package/dest/p2p/index.d.ts +5 -2
  304. package/dest/p2p/index.d.ts.map +1 -1
  305. package/dest/p2p/index.js +4 -1
  306. package/dest/p2p/message_validator.d.ts +18 -3
  307. package/dest/p2p/message_validator.d.ts.map +1 -1
  308. package/dest/p2p/message_validator.js +2 -1
  309. package/dest/p2p/signature_utils.d.ts +5 -3
  310. package/dest/p2p/signature_utils.d.ts.map +1 -1
  311. package/dest/p2p/signature_utils.js +3 -1
  312. package/dest/p2p/signed_txs.d.ts +42 -0
  313. package/dest/p2p/signed_txs.d.ts.map +1 -0
  314. package/dest/p2p/signed_txs.js +75 -0
  315. package/dest/p2p/topic_type.d.ts +3 -2
  316. package/dest/p2p/topic_type.d.ts.map +1 -1
  317. package/dest/p2p/topic_type.js +10 -3
  318. package/dest/parity/parity_base_private_inputs.d.ts +3 -1
  319. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  320. package/dest/parity/parity_public_inputs.d.ts +4 -1
  321. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  322. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  323. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  324. package/dest/proofs/chonk_proof.d.ts +1 -1
  325. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  326. package/dest/proofs/chonk_proof.js +9 -4
  327. package/dest/proofs/proof.d.ts +4 -1
  328. package/dest/proofs/proof.d.ts.map +1 -1
  329. package/dest/proofs/recursive_proof.d.ts +10 -1
  330. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  331. package/dest/rollup/base_rollup_hints.d.ts +34 -1
  332. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  333. package/dest/rollup/block_constant_data.d.ts +12 -1
  334. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  335. package/dest/rollup/block_headers_hash.js +1 -1
  336. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  337. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  338. package/dest/rollup/block_rollup_public_inputs.d.ts +47 -11
  339. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  340. package/dest/rollup/block_rollup_public_inputs.js +8 -12
  341. package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
  342. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  343. package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
  344. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  345. package/dest/rollup/checkpoint_constant_data.js +3 -1
  346. package/dest/rollup/checkpoint_header.d.ts +42 -12
  347. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  348. package/dest/rollup/checkpoint_header.js +49 -19
  349. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  350. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  351. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +41 -1
  352. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  353. package/dest/rollup/checkpoint_rollup_public_inputs.js +10 -2
  354. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
  355. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  356. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
  357. package/dest/rollup/epoch_constant_data.d.ts +16 -1
  358. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  359. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  360. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  361. package/dest/rollup/root_rollup_public_inputs.d.ts +18 -3
  362. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  363. package/dest/rollup/root_rollup_public_inputs.js +9 -3
  364. package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
  365. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  366. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  367. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  368. package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
  369. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  370. package/dest/schemas/schemas.d.ts +1 -1
  371. package/dest/stats/stats.d.ts +1 -3
  372. package/dest/stats/stats.d.ts.map +1 -1
  373. package/dest/tests/factories.d.ts +16 -10
  374. package/dest/tests/factories.d.ts.map +1 -1
  375. package/dest/tests/factories.js +60 -25
  376. package/dest/tests/jest.js +1 -1
  377. package/dest/tests/mocks.d.ts +74 -19
  378. package/dest/tests/mocks.d.ts.map +1 -1
  379. package/dest/tests/mocks.js +123 -57
  380. package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
  381. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  382. package/dest/trees/append_only_tree_snapshot.js +3 -1
  383. package/dest/trees/nullifier_leaf.d.ts +13 -1
  384. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  385. package/dest/trees/nullifier_membership_witness.d.ts +10 -1
  386. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  387. package/dest/trees/public_data_leaf.d.ts +16 -1
  388. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  389. package/dest/trees/public_data_witness.d.ts +11 -1
  390. package/dest/trees/public_data_witness.d.ts.map +1 -1
  391. package/dest/tx/block_header.d.ts +14 -2
  392. package/dest/tx/block_header.d.ts.map +1 -1
  393. package/dest/tx/block_header.js +8 -2
  394. package/dest/tx/call_context.d.ts +13 -1
  395. package/dest/tx/call_context.d.ts.map +1 -1
  396. package/dest/tx/call_context.js +3 -1
  397. package/dest/tx/capsule.d.ts +4 -1
  398. package/dest/tx/capsule.d.ts.map +1 -1
  399. package/dest/tx/execution_payload.d.ts +9 -1
  400. package/dest/tx/execution_payload.d.ts.map +1 -1
  401. package/dest/tx/function_data.d.ts +4 -2
  402. package/dest/tx/function_data.d.ts.map +1 -1
  403. package/dest/tx/global_variable_builder.d.ts +2 -2
  404. package/dest/tx/global_variable_builder.d.ts.map +1 -1
  405. package/dest/tx/global_variables.d.ts +9 -1
  406. package/dest/tx/global_variables.d.ts.map +1 -1
  407. package/dest/tx/global_variables.js +3 -1
  408. package/dest/tx/hashed_values.d.ts +7 -1
  409. package/dest/tx/hashed_values.d.ts.map +1 -1
  410. package/dest/tx/in_tx.d.ts +4 -4
  411. package/dest/tx/index.d.ts +1 -2
  412. package/dest/tx/index.d.ts.map +1 -1
  413. package/dest/tx/index.js +0 -1
  414. package/dest/tx/indexed_tx_effect.d.ts +5 -5
  415. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  416. package/dest/tx/indexed_tx_effect.js +3 -2
  417. package/dest/tx/partial_state_reference.d.ts +4 -1
  418. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  419. package/dest/tx/private_execution_result.d.ts +23 -6
  420. package/dest/tx/private_execution_result.d.ts.map +1 -1
  421. package/dest/tx/private_execution_result.js +4 -21
  422. package/dest/tx/private_tx_constant_data.d.ts +16 -1
  423. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  424. package/dest/tx/profiling.d.ts +149 -26
  425. package/dest/tx/profiling.d.ts.map +1 -1
  426. package/dest/tx/profiling.js +44 -7
  427. package/dest/tx/protocol_contracts.d.ts +1 -1
  428. package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
  429. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  430. package/dest/tx/public_call_request_with_calldata.js +3 -1
  431. package/dest/tx/state_reference.d.ts +3 -1
  432. package/dest/tx/state_reference.d.ts.map +1 -1
  433. package/dest/tx/state_reference.js +3 -1
  434. package/dest/tx/tree_snapshots.js +3 -1
  435. package/dest/tx/tx.d.ts +24 -1
  436. package/dest/tx/tx.d.ts.map +1 -1
  437. package/dest/tx/tx.js +9 -4
  438. package/dest/tx/tx_context.d.ts +2 -1
  439. package/dest/tx/tx_context.d.ts.map +1 -1
  440. package/dest/tx/tx_effect.d.ts +32 -6
  441. package/dest/tx/tx_effect.d.ts.map +1 -1
  442. package/dest/tx/tx_effect.js +3 -8
  443. package/dest/tx/tx_execution_request.d.ts +30 -1
  444. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  445. package/dest/tx/tx_execution_request.js +6 -2
  446. package/dest/tx/tx_hash.d.ts +2 -1
  447. package/dest/tx/tx_hash.d.ts.map +1 -1
  448. package/dest/tx/tx_receipt.d.ts +47 -13
  449. package/dest/tx/tx_receipt.d.ts.map +1 -1
  450. package/dest/tx/tx_receipt.js +46 -15
  451. package/dest/tx/tx_request.d.ts +6 -1
  452. package/dest/tx/tx_request.d.ts.map +1 -1
  453. package/dest/tx/validator/error_texts.d.ts +2 -1
  454. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  455. package/dest/tx/validator/error_texts.js +2 -0
  456. package/dest/types/shared.d.ts +4 -1
  457. package/dest/types/shared.d.ts.map +1 -1
  458. package/dest/validators/schemas.d.ts +8 -8
  459. package/dest/vks/verification_key.d.ts +22 -1
  460. package/dest/vks/verification_key.d.ts.map +1 -1
  461. package/dest/vks/vk_data.d.ts +7 -1
  462. package/dest/vks/vk_data.d.ts.map +1 -1
  463. package/dest/zkpassport/index.d.ts +3 -4
  464. package/dest/zkpassport/index.d.ts.map +1 -1
  465. package/dest/zkpassport/index.js +9 -9
  466. package/package.json +25 -12
  467. package/src/abi/contract_artifact.ts +10 -10
  468. package/src/abi/utils.ts +17 -0
  469. package/src/block/attestation_info.ts +9 -6
  470. package/src/block/block_hash.ts +26 -25
  471. package/src/block/block_parameter.ts +4 -2
  472. package/src/block/body.ts +2 -1
  473. package/src/block/checkpointed_l2_block.ts +8 -58
  474. package/src/block/in_block.ts +5 -5
  475. package/src/block/index.ts +0 -2
  476. package/src/block/l2_block.ts +102 -149
  477. package/src/block/l2_block_source.ts +123 -44
  478. package/src/block/l2_block_stream/index.ts +1 -0
  479. package/src/block/l2_block_stream/interfaces.ts +15 -4
  480. package/src/block/l2_block_stream/l2_block_stream.ts +130 -39
  481. package/src/block/l2_block_stream/l2_tips_memory_store.ts +62 -56
  482. package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
  483. package/src/block/test/l2_tips_store_test_suite.ts +480 -36
  484. package/src/block/validate_block_result.ts +40 -35
  485. package/src/checkpoint/checkpoint.ts +34 -11
  486. package/src/checkpoint/checkpoint_info.ts +45 -2
  487. package/src/checkpoint/index.ts +1 -0
  488. package/src/checkpoint/published_checkpoint.ts +4 -3
  489. package/src/config/node-rpc-config.ts +1 -1
  490. package/src/contract/contract_address.ts +1 -1
  491. package/src/contract/contract_class_id.ts +1 -1
  492. package/src/contract/index.ts +0 -2
  493. package/src/contract/private_function.ts +2 -3
  494. package/src/contract/private_function_membership_proof.ts +1 -1
  495. package/src/database-version/database_version.ts +87 -0
  496. package/src/database-version/version_manager.ts +1 -77
  497. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  498. package/src/deserialization/index.ts +21 -0
  499. package/src/epoch-helpers/index.ts +10 -1
  500. package/src/hash/hash.ts +2 -2
  501. package/src/hash/map_slot.ts +3 -2
  502. package/src/interfaces/api_limit.ts +2 -0
  503. package/src/interfaces/archiver.ts +26 -24
  504. package/src/interfaces/aztec-node-admin.ts +8 -4
  505. package/src/interfaces/aztec-node.ts +109 -128
  506. package/src/interfaces/block-builder.ts +40 -23
  507. package/src/interfaces/configs.ts +3 -0
  508. package/src/interfaces/l2_logs_source.ts +17 -4
  509. package/src/interfaces/p2p.ts +8 -12
  510. package/src/interfaces/prover-broker.ts +22 -0
  511. package/src/interfaces/prover-client.ts +22 -0
  512. package/src/interfaces/proving-job.ts +2 -11
  513. package/src/interfaces/server_circuit_prover.ts +3 -2
  514. package/src/interfaces/tx_provider.ts +2 -2
  515. package/src/interfaces/validator.ts +62 -14
  516. package/src/kernel/hints/build_note_hash_read_request_hints.ts +20 -12
  517. package/src/kernel/hints/build_nullifier_read_request_hints.ts +17 -14
  518. package/src/keys/derivation.ts +8 -8
  519. package/src/keys/key_types.ts +1 -1
  520. package/src/keys/utils.ts +7 -3
  521. package/src/l1-contracts/slash_factory.ts +1 -0
  522. package/src/logs/log_id.ts +22 -18
  523. package/src/logs/siloed_tag.ts +3 -2
  524. package/src/messaging/in_hash.ts +3 -1
  525. package/src/messaging/l2_to_l1_membership.ts +178 -52
  526. package/src/messaging/out_hash.ts +62 -21
  527. package/src/note/note_dao.ts +18 -13
  528. package/src/p2p/attestation_utils.ts +3 -3
  529. package/src/p2p/block_proposal.ts +213 -46
  530. package/src/p2p/{block_attestation.ts → checkpoint_attestation.ts} +31 -25
  531. package/src/p2p/checkpoint_proposal.ts +355 -0
  532. package/src/p2p/consensus_payload.ts +5 -7
  533. package/src/p2p/constants.ts +3 -0
  534. package/src/p2p/gossipable.ts +14 -4
  535. package/src/p2p/index.ts +4 -1
  536. package/src/p2p/message_validator.ts +14 -2
  537. package/src/p2p/signature_utils.ts +3 -1
  538. package/src/p2p/signed_txs.ts +88 -0
  539. package/src/p2p/topic_type.ts +4 -3
  540. package/src/proofs/chonk_proof.ts +9 -5
  541. package/src/rollup/block_headers_hash.ts +1 -1
  542. package/src/rollup/block_rollup_public_inputs.ts +5 -11
  543. package/src/rollup/checkpoint_header.ts +63 -20
  544. package/src/rollup/checkpoint_rollup_public_inputs.ts +12 -0
  545. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
  546. package/src/rollup/root_rollup_public_inputs.ts +9 -0
  547. package/src/stats/stats.ts +0 -2
  548. package/src/tests/factories.ts +56 -40
  549. package/src/tests/jest.ts +1 -1
  550. package/src/tests/mocks.ts +213 -91
  551. package/src/tx/block_header.ts +11 -3
  552. package/src/tx/global_variable_builder.ts +1 -1
  553. package/src/tx/index.ts +0 -1
  554. package/src/tx/indexed_tx_effect.ts +3 -2
  555. package/src/tx/private_execution_result.ts +1 -16
  556. package/src/tx/profiling.ts +46 -4
  557. package/src/tx/tx.ts +10 -9
  558. package/src/tx/tx_effect.ts +0 -9
  559. package/src/tx/tx_execution_request.ts +2 -0
  560. package/src/tx/tx_receipt.ts +75 -18
  561. package/src/tx/validator/error_texts.ts +3 -0
  562. package/src/zkpassport/index.ts +11 -12
  563. package/dest/block/l2_block_code_to_purge.d.ts +0 -12
  564. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  565. package/dest/block/l2_block_code_to_purge.js +0 -61
  566. package/dest/block/l2_block_header.d.ts +0 -98
  567. package/dest/block/l2_block_header.d.ts.map +0 -1
  568. package/dest/block/l2_block_header.js +0 -153
  569. package/dest/block/l2_block_new.d.ts +0 -135
  570. package/dest/block/l2_block_new.d.ts.map +0 -1
  571. package/dest/block/l2_block_new.js +0 -152
  572. package/dest/contract/contract_class_metadata.d.ts +0 -8
  573. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  574. package/dest/contract/contract_class_metadata.js +0 -1
  575. package/dest/contract/contract_metadata.d.ts +0 -7
  576. package/dest/contract/contract_metadata.d.ts.map +0 -1
  577. package/dest/contract/contract_metadata.js +0 -1
  578. package/dest/database-version/index.d.ts +0 -2
  579. package/dest/database-version/index.d.ts.map +0 -1
  580. package/dest/database-version/index.js +0 -1
  581. package/dest/p2p/block_attestation.d.ts +0 -80
  582. package/dest/p2p/block_attestation.d.ts.map +0 -1
  583. package/dest/tx/content_commitment.d.ts +0 -49
  584. package/dest/tx/content_commitment.d.ts.map +0 -1
  585. package/dest/tx/content_commitment.js +0 -90
  586. package/src/block/l2_block_code_to_purge.ts +0 -88
  587. package/src/block/l2_block_header.ts +0 -246
  588. package/src/block/l2_block_new.ts +0 -207
  589. package/src/contract/contract_class_metadata.ts +0 -8
  590. package/src/contract/contract_metadata.ts +0 -7
  591. package/src/database-version/index.ts +0 -1
  592. package/src/tx/content_commitment.ts +0 -113
@@ -1,9 +1,9 @@
1
1
  import { recoverAddress } from '@aztec/foundation/crypto/secp256k1-signer';
2
2
  import type { EthAddress } from '@aztec/foundation/eth-address';
3
3
 
4
+ import { Checkpoint } from '../checkpoint/checkpoint.js';
4
5
  import { ConsensusPayload } from '../p2p/consensus_payload.js';
5
6
  import { SignatureDomainSeparator, getHashedSignaturePayloadEthSignedMessage } from '../p2p/signature_utils.js';
6
- import type { L2Block } from './l2_block.js';
7
7
  import type { CommitteeAttestation } from './proposal/committee_attestation.js';
8
8
 
9
9
  /**
@@ -29,14 +29,14 @@ export type AttestationInfo =
29
29
  };
30
30
 
31
31
  /**
32
- * Extracts attestation information from a published L2 block.
32
+ * Extracts attestation information from a published checkpoint.
33
33
  * Returns info for each attestation, preserving array indices.
34
34
  */
35
- export function getAttestationInfoFromPublishedL2Block(block: {
35
+ export function getAttestationInfoFromPublishedCheckpoint(block: {
36
36
  attestations: CommitteeAttestation[];
37
- block: L2Block;
37
+ checkpoint: Checkpoint;
38
38
  }): AttestationInfo[] {
39
- const payload = ConsensusPayload.fromBlock(block.block);
39
+ const payload = ConsensusPayload.fromCheckpoint(block.checkpoint);
40
40
  return getAttestationInfoFromPayload(payload, block.attestations);
41
41
  }
42
42
 
@@ -44,7 +44,10 @@ export function getAttestationInfoFromPayload(
44
44
  payload: ConsensusPayload,
45
45
  attestations: CommitteeAttestation[],
46
46
  ): AttestationInfo[] {
47
- const hashedPayload = getHashedSignaturePayloadEthSignedMessage(payload, SignatureDomainSeparator.blockAttestation);
47
+ const hashedPayload = getHashedSignaturePayloadEthSignedMessage(
48
+ payload,
49
+ SignatureDomainSeparator.checkpointAttestation,
50
+ );
48
51
 
49
52
  return attestations.map(attestation => {
50
53
  // If signature is empty, check if we have an address directly
@@ -1,44 +1,45 @@
1
- import { Buffer32 } from '@aztec/foundation/buffer';
2
1
  import { Fr } from '@aztec/foundation/curves/bn254';
3
- import { BufferReader } from '@aztec/foundation/serialize';
2
+ import type { ZodFor } from '@aztec/foundation/schemas';
4
3
 
5
- import { schemas } from '../schemas/schemas.js';
4
+ import { inspect } from 'util';
5
+
6
+ import { hexSchemaFor } from '../schemas/schemas.js';
7
+
8
+ const BLOCK_HASH_BRAND = Symbol.for('aztec.BlockHash');
6
9
 
7
10
  /** Hash of an L2 block. */
8
- export class L2BlockHash extends Buffer32 {
9
- constructor(
10
- /** The buffer containing the hash. */
11
- hash: Buffer,
12
- ) {
13
- super(hash);
14
- }
11
+ export class BlockHash extends Fr {
12
+ readonly [BLOCK_HASH_BRAND] = true as const;
15
13
 
16
- static override random() {
17
- return new L2BlockHash(Fr.random().toBuffer());
14
+ constructor(hash: Fr) {
15
+ super(hash);
18
16
  }
19
17
 
20
- static override fromNumber(num: number): L2BlockHash {
21
- return new L2BlockHash(super.fromNumber(num).toBuffer());
18
+ override [inspect.custom]() {
19
+ return `BlockHash<${this.toString()}>`;
22
20
  }
23
21
 
24
- static override fromBuffer(buffer: Buffer | BufferReader) {
25
- const reader = BufferReader.asReader(buffer);
26
- return new L2BlockHash(reader.readBytes(L2BlockHash.SIZE));
22
+ toFr(): Fr {
23
+ return new Fr(this.toBigInt());
27
24
  }
28
25
 
29
- static override fromString(str: string): Buffer32 {
30
- return new L2BlockHash(super.fromString(str).toBuffer());
26
+ /**
27
+ * Type guard that checks if a value is a BlockHash instance.
28
+ * Uses Symbol.for to ensure cross-module compatibility.
29
+ */
30
+ static isBlockHash(value: unknown): value is BlockHash {
31
+ return typeof value === 'object' && value !== null && BLOCK_HASH_BRAND in value;
31
32
  }
32
33
 
33
- static get schema() {
34
- return schemas.BufferHex.transform(value => new L2BlockHash(value));
34
+ static override random() {
35
+ return new BlockHash(Fr.random());
35
36
  }
36
37
 
37
- static zero() {
38
- return new L2BlockHash(Buffer32.ZERO.toBuffer());
38
+ static override fromString(str: string): BlockHash {
39
+ return new BlockHash(Fr.fromString(str));
39
40
  }
40
41
 
41
- static override fromField(hash: Fr) {
42
- return new L2BlockHash(hash.toBuffer());
42
+ static override get schema() {
43
+ return hexSchemaFor(BlockHash) as ZodFor<BlockHash>;
43
44
  }
44
45
  }
@@ -2,7 +2,9 @@ import { BlockNumberSchema } from '@aztec/foundation/branded-types';
2
2
 
3
3
  import { z } from 'zod';
4
4
 
5
- export const BlockParameterSchema = z.union([BlockNumberSchema, z.literal('latest')]);
5
+ import { BlockHash } from './block_hash.js';
6
6
 
7
- /** Block parameter - either a specific BlockNumber or 'latest' */
7
+ export const BlockParameterSchema = z.union([BlockHash.schema, BlockNumberSchema, z.literal('latest')]);
8
+
9
+ /** Block parameter - either a specific BlockNumber, block hash (BlockHash), or 'latest' */
8
10
  export type BlockParameter = z.infer<typeof BlockParameterSchema>;
package/src/block/body.ts CHANGED
@@ -5,6 +5,7 @@ import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
5
5
  import { inspect } from 'util';
6
6
  import { z } from 'zod';
7
7
 
8
+ import { MAX_TX_EFFECTS_PER_BODY } from '../deserialization/index.js';
8
9
  import type { ZodFor } from '../schemas/index.js';
9
10
  import { TxEffect } from '../tx/tx_effect.js';
10
11
 
@@ -40,7 +41,7 @@ export class Body {
40
41
  static fromBuffer(buf: Buffer | BufferReader) {
41
42
  const reader = BufferReader.asReader(buf);
42
43
 
43
- return new this(reader.readVector(TxEffect));
44
+ return new this(reader.readVector(TxEffect, MAX_TX_EFFECTS_PER_BODY));
44
45
  }
45
46
 
46
47
  /**
@@ -5,9 +5,9 @@ import type { FieldsOf } from '@aztec/foundation/types';
5
5
 
6
6
  import { z } from 'zod';
7
7
 
8
- import { L1PublishedData, PublishedCheckpoint } from '../checkpoint/published_checkpoint.js';
8
+ import { L1PublishedData } from '../checkpoint/published_checkpoint.js';
9
+ import { MAX_BLOCK_HASH_STRING_LENGTH, MAX_COMMITTEE_SIZE } from '../deserialization/index.js';
9
10
  import { L2Block } from './l2_block.js';
10
- import { L2BlockNew } from './l2_block_new.js';
11
11
  import { CommitteeAttestation } from './proposal/committee_attestation.js';
12
12
 
13
13
  /**
@@ -16,7 +16,7 @@ import { CommitteeAttestation } from './proposal/committee_attestation.js';
16
16
  export class CheckpointedL2Block {
17
17
  constructor(
18
18
  public checkpointNumber: CheckpointNumber,
19
- public block: L2BlockNew,
19
+ public block: L2Block,
20
20
  public l1: L1PublishedData,
21
21
  public attestations: CommitteeAttestation[],
22
22
  ) {}
@@ -24,7 +24,7 @@ export class CheckpointedL2Block {
24
24
  return z
25
25
  .object({
26
26
  checkpointNumber: CheckpointNumberSchema,
27
- block: L2BlockNew.schema,
27
+ block: L2Block.schema,
28
28
  l1: L1PublishedData.schema,
29
29
  attestations: z.array(CommitteeAttestation.schema),
30
30
  })
@@ -34,11 +34,11 @@ export class CheckpointedL2Block {
34
34
  static fromBuffer(bufferOrReader: Buffer | BufferReader): CheckpointedL2Block {
35
35
  const reader = BufferReader.asReader(bufferOrReader);
36
36
  const checkpointNumber = reader.readNumber();
37
- const block = reader.readObject(L2BlockNew);
37
+ const block = reader.readObject(L2Block);
38
38
  const l1BlockNumber = reader.readBigInt();
39
- const l1BlockHash = reader.readString();
39
+ const l1BlockHash = reader.readString(MAX_BLOCK_HASH_STRING_LENGTH);
40
40
  const l1Timestamp = reader.readBigInt();
41
- const attestations = reader.readVector(CommitteeAttestation);
41
+ const attestations = reader.readVector(CommitteeAttestation, MAX_COMMITTEE_SIZE);
42
42
  return new CheckpointedL2Block(
43
43
  CheckpointNumber(checkpointNumber),
44
44
  block,
@@ -58,6 +58,7 @@ export class CheckpointedL2Block {
58
58
 
59
59
  public toBuffer(): Buffer {
60
60
  return serializeToBuffer(
61
+ this.checkpointNumber,
61
62
  this.block,
62
63
  this.l1.blockNumber,
63
64
  this.l1.blockHash,
@@ -67,54 +68,3 @@ export class CheckpointedL2Block {
67
68
  );
68
69
  }
69
70
  }
70
-
71
- export class PublishedL2Block {
72
- constructor(
73
- public block: L2Block,
74
- public l1: L1PublishedData,
75
- public attestations: CommitteeAttestation[],
76
- ) {}
77
-
78
- static get schema() {
79
- return z
80
- .object({
81
- block: L2Block.schema,
82
- l1: L1PublishedData.schema,
83
- attestations: z.array(CommitteeAttestation.schema),
84
- })
85
- .transform(obj => PublishedL2Block.fromFields(obj));
86
- }
87
-
88
- static fromBuffer(bufferOrReader: Buffer | BufferReader): PublishedL2Block {
89
- const reader = BufferReader.asReader(bufferOrReader);
90
- const block = reader.readObject(L2Block);
91
- const l1BlockNumber = reader.readBigInt();
92
- const l1BlockHash = reader.readString();
93
- const l1Timestamp = reader.readBigInt();
94
- const attestations = reader.readVector(CommitteeAttestation);
95
- return new PublishedL2Block(block, new L1PublishedData(l1BlockNumber, l1Timestamp, l1BlockHash), attestations);
96
- }
97
-
98
- static fromFields(fields: FieldsOf<PublishedL2Block>) {
99
- return new PublishedL2Block(fields.block, fields.l1, fields.attestations);
100
- }
101
-
102
- public toBuffer(): Buffer {
103
- return serializeToBuffer(
104
- this.block,
105
- this.l1.blockNumber,
106
- this.l1.blockHash,
107
- this.l1.timestamp,
108
- this.attestations.length,
109
- this.attestations,
110
- );
111
- }
112
-
113
- public toPublishedCheckpoint() {
114
- return new PublishedCheckpoint(this.block.toCheckpoint(), this.l1, this.attestations);
115
- }
116
-
117
- static fromPublishedCheckpoint(checkpoint: PublishedCheckpoint) {
118
- return new PublishedL2Block(L2Block.fromCheckpoint(checkpoint.checkpoint), checkpoint.l1, checkpoint.attestations);
119
- }
120
- }
@@ -2,12 +2,12 @@ import { BlockNumber, BlockNumberSchema } from '@aztec/foundation/branded-types'
2
2
 
3
3
  import { type ZodTypeAny, z } from 'zod';
4
4
 
5
- import { L2BlockHash } from './block_hash.js';
5
+ import { BlockHash } from './block_hash.js';
6
6
  import type { L2Block } from './l2_block.js';
7
7
 
8
8
  export type InBlock = {
9
9
  l2BlockNumber: BlockNumber;
10
- l2BlockHash: L2BlockHash;
10
+ l2BlockHash: BlockHash;
11
11
  };
12
12
 
13
13
  // Note: If you expand this type with indexInBlock, then delete `IndexedTxEffect` and use this type instead.
@@ -18,7 +18,7 @@ export type DataInBlock<T> = {
18
18
  export function randomInBlock(): InBlock {
19
19
  return {
20
20
  l2BlockNumber: BlockNumber(Math.floor(Math.random() * 1000)),
21
- l2BlockHash: L2BlockHash.random(),
21
+ l2BlockHash: BlockHash.random(),
22
22
  };
23
23
  }
24
24
 
@@ -33,14 +33,14 @@ export async function wrapDataInBlock<T>(data: T, block: L2Block): Promise<DataI
33
33
  return {
34
34
  data,
35
35
  l2BlockNumber: block.number,
36
- l2BlockHash: L2BlockHash.fromField(await block.hash()),
36
+ l2BlockHash: await block.hash(),
37
37
  };
38
38
  }
39
39
 
40
40
  export function inBlockSchema() {
41
41
  return z.object({
42
42
  l2BlockNumber: BlockNumberSchema,
43
- l2BlockHash: L2BlockHash.schema,
43
+ l2BlockHash: BlockHash.schema,
44
44
  });
45
45
  }
46
46
 
@@ -1,6 +1,4 @@
1
1
  export * from './l2_block.js';
2
- export * from './l2_block_new.js';
3
- export * from './l2_block_header.js';
4
2
  export * from './l2_block_stream/index.js';
5
3
  export * from './in_block.js';
6
4
  export * from './body.js';
@@ -1,44 +1,66 @@
1
- import { type BlockBlobData, encodeBlockBlobData, encodeCheckpointBlobDataFromBlocks } from '@aztec/blob-lib/encoding';
2
- import { BlockNumber, CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
1
+ import { type BlockBlobData, encodeBlockBlobData } from '@aztec/blob-lib/encoding';
2
+ import {
3
+ BlockNumber,
4
+ CheckpointNumber,
5
+ CheckpointNumberSchema,
6
+ IndexWithinCheckpoint,
7
+ IndexWithinCheckpointSchema,
8
+ SlotNumber,
9
+ } from '@aztec/foundation/branded-types';
3
10
  import { Fr } from '@aztec/foundation/curves/bn254';
4
11
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
5
- import { bufferToHex, hexToBuffer } from '@aztec/foundation/string';
6
12
 
7
13
  import { z } from 'zod';
8
14
 
9
- import { Checkpoint } from '../checkpoint/checkpoint.js';
15
+ import type { PrivateLog } from '../logs/private_log.js';
10
16
  import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
11
- import type { BlockHeader } from '../tx/block_header.js';
17
+ import { BlockHeader } from '../tx/block_header.js';
18
+ import type { BlockHash } from './block_hash.js';
12
19
  import { Body } from './body.js';
13
- import { makeAppendOnlyTreeSnapshot, makeL2BlockHeader } from './l2_block_code_to_purge.js';
14
- import { L2BlockHeader } from './l2_block_header.js';
15
20
  import type { L2BlockInfo } from './l2_block_info.js';
16
- import { L2BlockNew } from './l2_block_new.js';
17
21
 
18
22
  /**
19
- * The data that makes up the rollup proof, with encoder decoder functions.
20
- *
21
- * @deprecated Use `L2BlockNew` instead.
23
+ * An L2 block with a header and a body.
22
24
  */
23
25
  export class L2Block {
24
26
  constructor(
25
27
  /** Snapshot of archive tree after the block is applied. */
26
28
  public archive: AppendOnlyTreeSnapshot,
27
- /** L2 block header. */
28
- public header: L2BlockHeader,
29
+ /** Header of the block. */
30
+ public header: BlockHeader,
29
31
  /** L2 block body. */
30
32
  public body: Body,
31
- private blockHash: Fr | undefined = undefined,
33
+ /** Number of the checkpoint that the block belongs to. */
34
+ public checkpointNumber: CheckpointNumber,
35
+ /** Index of the block within the checkpoint. */
36
+ public indexWithinCheckpoint: IndexWithinCheckpoint,
32
37
  ) {}
33
38
 
39
+ get number(): BlockNumber {
40
+ return this.header.globalVariables.blockNumber;
41
+ }
42
+
43
+ get slot(): SlotNumber {
44
+ return this.header.globalVariables.slotNumber;
45
+ }
46
+
47
+ get timestamp(): bigint {
48
+ return this.header.globalVariables.timestamp;
49
+ }
50
+
34
51
  static get schema() {
35
52
  return z
36
53
  .object({
37
54
  archive: AppendOnlyTreeSnapshot.schema,
38
- header: L2BlockHeader.schema,
55
+ header: BlockHeader.schema,
39
56
  body: Body.schema,
57
+ checkpointNumber: CheckpointNumberSchema,
58
+ indexWithinCheckpoint: IndexWithinCheckpointSchema,
40
59
  })
41
- .transform(({ archive, header, body }) => new L2Block(archive, header, body));
60
+ .transform(
61
+ ({ archive, header, body, checkpointNumber, indexWithinCheckpoint }) =>
62
+ new L2Block(archive, header, body, checkpointNumber, indexWithinCheckpoint),
63
+ );
42
64
  }
43
65
 
44
66
  /**
@@ -47,11 +69,13 @@ export class L2Block {
47
69
  */
48
70
  static fromBuffer(buf: Buffer | BufferReader) {
49
71
  const reader = BufferReader.asReader(buf);
50
- const header = reader.readObject(L2BlockHeader);
72
+ const header = reader.readObject(BlockHeader);
51
73
  const archive = reader.readObject(AppendOnlyTreeSnapshot);
52
74
  const body = reader.readObject(Body);
75
+ const checkpointNumber = CheckpointNumber(reader.readNumber());
76
+ const indexWithinCheckpoint = IndexWithinCheckpoint(reader.readNumber());
53
77
 
54
- return new L2Block(archive, header, body);
78
+ return new L2Block(archive, header, body, checkpointNumber, indexWithinCheckpoint);
55
79
  }
56
80
 
57
81
  /**
@@ -59,151 +83,39 @@ export class L2Block {
59
83
  * @returns A serialized L2 block as a Buffer.
60
84
  */
61
85
  toBuffer() {
62
- return serializeToBuffer(this.header, this.archive, this.body);
63
- }
64
-
65
- /**
66
- * Deserializes L2 block from a buffer.
67
- * @param str - A serialized L2 block.
68
- * @returns Deserialized L2 block.
69
- */
70
- static fromString(str: string): L2Block {
71
- return L2Block.fromBuffer(hexToBuffer(str));
72
- }
73
-
74
- /**
75
- * Serializes a block to a string.
76
- * @returns A serialized L2 block as a string.
77
- */
78
- toString(): string {
79
- return bufferToHex(this.toBuffer());
80
- }
81
-
82
- /**
83
- * Creates an L2 block containing random data.
84
- * @param l2BlockNum - The number of the L2 block.
85
- * @param txsPerBlock - The number of transactions to include in the block.
86
- * @param numPublicCallsPerTx - The number of public function calls to include in each transaction.
87
- * @param numPublicLogsPerCall - The number of public logs per 1 public function invocation.
88
- * @param inHash - The hash of the L1 to L2 messages subtree which got inserted in this block.
89
- * @returns The L2 block.
90
- */
91
- static async random(
92
- l2BlockNum: BlockNumber,
93
- txsPerBlock = 4,
94
- numPublicCallsPerTx = 3,
95
- numPublicLogsPerCall = 1,
96
- inHash: Fr | undefined = undefined,
97
- slotNumber: number | undefined = undefined,
98
- maxEffects: number | undefined = undefined,
99
- ): Promise<L2Block> {
100
- const body = await Body.random({ txsPerBlock, numPublicCallsPerTx, numPublicLogsPerCall, maxEffects });
101
-
102
- return new L2Block(
103
- makeAppendOnlyTreeSnapshot(l2BlockNum + 1),
104
- makeL2BlockHeader(0, l2BlockNum, slotNumber ?? l2BlockNum, {}, inHash),
105
- body,
106
- );
107
- }
108
-
109
- /**
110
- * Creates an L2 block containing empty data.
111
- * @returns The L2 block.
112
- */
113
- static empty(): L2Block {
114
- return new L2Block(AppendOnlyTreeSnapshot.empty(), L2BlockHeader.empty(), Body.empty());
115
- }
116
-
117
- get number(): BlockNumber {
118
- return this.header.getBlockNumber();
119
- }
120
-
121
- get slot(): SlotNumber {
122
- return this.header.getSlot();
123
- }
124
-
125
- get timestamp(): bigint {
126
- return this.header.globalVariables.timestamp;
86
+ return serializeToBuffer(this.header, this.archive, this.body, this.checkpointNumber, this.indexWithinCheckpoint);
127
87
  }
128
88
 
129
89
  /**
130
90
  * Returns the block's hash (hash of block header).
131
91
  * @returns The block's hash.
132
92
  */
133
- public async hash(): Promise<Fr> {
134
- if (this.blockHash === undefined) {
135
- this.blockHash = await this.getBlockHeader().hash();
136
- }
137
- return this.blockHash;
93
+ public hash(): Promise<BlockHash> {
94
+ return this.header.hash();
138
95
  }
139
96
 
140
97
  /**
141
- * @deprecated
142
- * This only works when there's one block per checkpoint.
143
- * TODO(#17027): Remove this method from L2Block and create a dedicated Checkpoint class.
98
+ * Checks if this block equals another block.
99
+ * @param other - The other block to compare with.
100
+ * @returns True if both blocks are equal.
144
101
  */
145
- public getCheckpointHeader() {
146
- return this.header.toCheckpointHeader();
147
- }
148
-
149
- // Temporary helper to get the actual block header.
150
- public getBlockHeader(): BlockHeader {
151
- return this.header.toBlockHeader();
152
- }
153
-
154
- public toL2Block() {
155
- return new L2BlockNew(
156
- this.archive,
157
- this.getBlockHeader(),
158
- this.body,
159
- CheckpointNumber.fromBlockNumber(this.number),
160
- 0, // indexWithinCheckpoint
102
+ public equals(other: this): boolean {
103
+ return (
104
+ this.archive.equals(other.archive) &&
105
+ this.header.equals(other.header) &&
106
+ this.body.equals(other.body) &&
107
+ this.checkpointNumber === other.checkpointNumber &&
108
+ this.indexWithinCheckpoint === other.indexWithinCheckpoint
161
109
  );
162
110
  }
163
111
 
164
- public toCheckpoint() {
165
- return new Checkpoint(
166
- this.archive,
167
- this.getCheckpointHeader(),
168
- [this.toL2Block()],
169
- CheckpointNumber.fromBlockNumber(this.number),
170
- );
171
- }
172
-
173
- static fromCheckpoint(checkpoint: Checkpoint) {
174
- const checkpointHeader = checkpoint.header;
175
- const block = checkpoint.blocks.at(-1)!;
176
- const header = new L2BlockHeader(
177
- new AppendOnlyTreeSnapshot(checkpointHeader.lastArchiveRoot, block.number),
178
- checkpointHeader.contentCommitment,
179
- block.header.state,
180
- block.header.globalVariables,
181
- block.header.totalFees,
182
- checkpointHeader.totalManaUsed,
183
- block.header.spongeBlobHash,
184
- checkpointHeader.blockHeadersHash,
185
- );
186
- return new L2Block(checkpoint.archive, header, block.body);
187
- }
188
-
189
- /**
190
- * @deprecated
191
- * This only works when there's one block per checkpoint.
192
- * TODO(#17027): Remove this method from L2Block and create a dedicated Checkpoint class.
193
- */
194
- public getCheckpointBlobFields() {
195
- const blockBlobData = this.toBlockBlobData();
196
- return encodeCheckpointBlobDataFromBlocks([blockBlobData]);
197
- }
198
-
199
112
  public toBlobFields(): Fr[] {
200
113
  const blockBlobData = this.toBlockBlobData();
201
114
  return encodeBlockBlobData(blockBlobData);
202
115
  }
203
116
 
204
117
  public toBlockBlobData(): BlockBlobData {
205
- // There's only one L2Block per checkpoint, so it's always the first block in the checkpoint.
206
- const isFirstBlock = true;
118
+ const isFirstBlock = this.indexWithinCheckpoint === 0;
207
119
  return {
208
120
  blockEndMarker: {
209
121
  numTxs: this.body.txEffects.length,
@@ -226,6 +138,48 @@ export class L2Block {
226
138
  };
227
139
  }
228
140
 
141
+ static empty(header?: BlockHeader) {
142
+ return new L2Block(
143
+ AppendOnlyTreeSnapshot.empty(),
144
+ header ?? BlockHeader.empty(),
145
+ Body.empty(),
146
+ CheckpointNumber(0),
147
+ IndexWithinCheckpoint(0),
148
+ );
149
+ }
150
+
151
+ /**
152
+ * Creates an L2 block containing random data.
153
+ * @param l2BlockNum - The number of the L2 block.
154
+ * @param txsPerBlock - The number of transactions to include in the block.
155
+ * @param numPublicCallsPerTx - The number of public function calls to include in each transaction.
156
+ * @param numPublicLogsPerCall - The number of public logs per 1 public function invocation.
157
+ * @param inHash - The hash of the L1 to L2 messages subtree which got inserted in this block.
158
+ * @returns The L2 block.
159
+ */
160
+ static async random(
161
+ blockNumber: BlockNumber,
162
+ {
163
+ checkpointNumber = CheckpointNumber(Number(blockNumber)),
164
+ indexWithinCheckpoint = IndexWithinCheckpoint(0),
165
+ txsPerBlock = 1,
166
+ txOptions = {},
167
+ makeTxOptions,
168
+ ...blockHeaderOverrides
169
+ }: {
170
+ checkpointNumber?: CheckpointNumber;
171
+ indexWithinCheckpoint?: IndexWithinCheckpoint;
172
+ txsPerBlock?: number;
173
+ txOptions?: Partial<Parameters<typeof Body.random>[0]>;
174
+ makeTxOptions?: (txIndex: number) => Partial<Parameters<typeof Body.random>[0]>;
175
+ } & Partial<Parameters<typeof BlockHeader.random>[0]> = {},
176
+ ): Promise<L2Block> {
177
+ const archive = new AppendOnlyTreeSnapshot(Fr.random(), blockNumber + 1);
178
+ const header = BlockHeader.random({ blockNumber, ...blockHeaderOverrides });
179
+ const body = await Body.random({ txsPerBlock, makeTxOptions, ...txOptions });
180
+ return new L2Block(archive, header, body, checkpointNumber, indexWithinCheckpoint);
181
+ }
182
+
229
183
  /**
230
184
  * Returns stats used for logging.
231
185
  * @returns Stats on tx count, number, and log size and count.
@@ -253,9 +207,12 @@ export class L2Block {
253
207
  };
254
208
  }
255
209
 
210
+ getPrivateLogs(): PrivateLog[] {
211
+ return this.body.txEffects.map(txEffect => txEffect.privateLogs).flat();
212
+ }
213
+
256
214
  toBlockInfo(): L2BlockInfo {
257
215
  return {
258
- blockHash: this.blockHash,
259
216
  archive: this.archive.root,
260
217
  lastArchive: this.header.lastArchive.root,
261
218
  blockNumber: this.number,
@@ -264,8 +221,4 @@ export class L2Block {
264
221
  timestamp: this.header.globalVariables.timestamp,
265
222
  };
266
223
  }
267
-
268
- equals(other: L2Block) {
269
- return this.archive.equals(other.archive) && this.header.equals(other.header) && this.body.equals(other.body);
270
- }
271
224
  }