@aztec/stdlib 0.0.1-commit.fcb71a6 → 0.0.1-commit.fffb133c

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 (531) 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 +9 -2
  43. package/dest/block/block_hash.d.ts.map +1 -1
  44. package/dest/block/block_hash.js +15 -0
  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/index.d.ts +1 -3
  55. package/dest/block/index.d.ts.map +1 -1
  56. package/dest/block/index.js +0 -2
  57. package/dest/block/l2_block.d.ts +56 -57
  58. package/dest/block/l2_block.d.ts.map +1 -1
  59. package/dest/block/l2_block.js +64 -107
  60. package/dest/block/l2_block_source.d.ts +296 -67
  61. package/dest/block/l2_block_source.d.ts.map +1 -1
  62. package/dest/block/l2_block_source.js +25 -6
  63. package/dest/block/l2_block_stream/index.d.ts +2 -1
  64. package/dest/block/l2_block_stream/index.d.ts.map +1 -1
  65. package/dest/block/l2_block_stream/index.js +1 -0
  66. package/dest/block/l2_block_stream/interfaces.d.ts +15 -5
  67. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  68. package/dest/block/l2_block_stream/l2_block_stream.d.ts +8 -3
  69. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  70. package/dest/block/l2_block_stream/l2_block_stream.js +106 -31
  71. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +24 -16
  72. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
  73. package/dest/block/l2_block_stream/l2_tips_memory_store.js +55 -61
  74. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
  75. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
  76. package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
  77. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  78. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  79. package/dest/block/test/l2_tips_store_test_suite.js +478 -38
  80. package/dest/block/validate_block_result.d.ts +24 -24
  81. package/dest/block/validate_block_result.d.ts.map +1 -1
  82. package/dest/block/validate_block_result.js +18 -17
  83. package/dest/checkpoint/checkpoint.d.ts +30 -20
  84. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  85. package/dest/checkpoint/checkpoint.js +19 -6
  86. package/dest/checkpoint/checkpoint_info.d.ts +32 -3
  87. package/dest/checkpoint/checkpoint_info.d.ts.map +1 -1
  88. package/dest/checkpoint/checkpoint_info.js +34 -1
  89. package/dest/checkpoint/index.d.ts +2 -1
  90. package/dest/checkpoint/index.d.ts.map +1 -1
  91. package/dest/checkpoint/index.js +1 -0
  92. package/dest/checkpoint/published_checkpoint.d.ts +17 -15
  93. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  94. package/dest/checkpoint/published_checkpoint.js +4 -3
  95. package/dest/config/node-rpc-config.js +1 -1
  96. package/dest/contract/complete_address.d.ts +4 -1
  97. package/dest/contract/complete_address.d.ts.map +1 -1
  98. package/dest/contract/contract_deployment_data.d.ts +5 -5
  99. package/dest/contract/index.d.ts +1 -3
  100. package/dest/contract/index.d.ts.map +1 -1
  101. package/dest/contract/index.js +0 -2
  102. package/dest/contract/interfaces/contract_instance.d.ts +16 -16
  103. package/dest/contract/private_function.d.ts +1 -1
  104. package/dest/contract/private_function.d.ts.map +1 -1
  105. package/dest/contract/private_function.js +1 -2
  106. package/dest/database-version/version_manager.d.ts +4 -2
  107. package/dest/database-version/version_manager.d.ts.map +1 -1
  108. package/dest/database-version/version_manager.js +3 -1
  109. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  110. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  111. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  112. package/dest/deserialization/index.d.ts +11 -0
  113. package/dest/deserialization/index.d.ts.map +1 -0
  114. package/dest/deserialization/index.js +10 -0
  115. package/dest/epoch-helpers/index.js +1 -1
  116. package/dest/errors/proving_error.d.ts +2 -2
  117. package/dest/errors/proving_error.d.ts.map +1 -1
  118. package/dest/gas/gas.js +3 -1
  119. package/dest/gas/gas_fees.js +3 -1
  120. package/dest/interfaces/api_limit.d.ts +3 -1
  121. package/dest/interfaces/api_limit.d.ts.map +1 -1
  122. package/dest/interfaces/api_limit.js +2 -0
  123. package/dest/interfaces/archiver.d.ts +6 -6
  124. package/dest/interfaces/archiver.d.ts.map +1 -1
  125. package/dest/interfaces/archiver.js +20 -16
  126. package/dest/interfaces/aztec-node-admin.d.ts +67 -31
  127. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  128. package/dest/interfaces/aztec-node-admin.js +2 -2
  129. package/dest/interfaces/aztec-node.d.ts +70 -51
  130. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  131. package/dest/interfaces/aztec-node.js +12 -9
  132. package/dest/interfaces/block-builder.d.ts +16 -14
  133. package/dest/interfaces/block-builder.d.ts.map +1 -1
  134. package/dest/interfaces/configs.d.ts +12 -7
  135. package/dest/interfaces/configs.d.ts.map +1 -1
  136. package/dest/interfaces/configs.js +2 -1
  137. package/dest/interfaces/get_logs_response.d.ts +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 +7 -9
  141. package/dest/interfaces/p2p.d.ts.map +1 -1
  142. package/dest/interfaces/p2p.js +3 -4
  143. package/dest/interfaces/prover-client.d.ts +10 -1
  144. package/dest/interfaces/prover-client.d.ts.map +1 -1
  145. package/dest/interfaces/prover-client.js +7 -1
  146. package/dest/interfaces/proving-job.d.ts +184 -184
  147. package/dest/interfaces/proving-job.d.ts.map +1 -1
  148. package/dest/interfaces/proving-job.js +1 -7
  149. package/dest/interfaces/server_circuit_prover.d.ts +4 -3
  150. package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
  151. package/dest/interfaces/tx_provider.d.ts +3 -3
  152. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  153. package/dest/interfaces/validator.d.ts +108 -18
  154. package/dest/interfaces/validator.d.ts.map +1 -1
  155. package/dest/interfaces/validator.js +5 -3
  156. package/dest/kernel/claimed_length_array.js +3 -1
  157. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +6 -5
  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 +19 -10
  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/hints/transient_data_squashing_hint.js +3 -1
  176. package/dest/kernel/log_hash.js +3 -1
  177. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  178. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  179. package/dest/kernel/private_call_data.d.ts +25 -1
  180. package/dest/kernel/private_call_data.d.ts.map +1 -1
  181. package/dest/kernel/private_call_request.d.ts +16 -1
  182. package/dest/kernel/private_call_request.d.ts.map +1 -1
  183. package/dest/kernel/private_circuit_public_inputs.d.ts +74 -1
  184. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  185. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +31 -1
  186. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  187. package/dest/kernel/private_kernel_data.d.ts +7 -1
  188. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  189. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
  190. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  191. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  192. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  193. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  194. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  195. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +10 -1
  196. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  197. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +23 -1
  198. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  199. package/dest/kernel/private_log_data.js +5 -2
  200. package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
  201. package/dest/kernel/private_to_avm_accumulated_data.js +5 -2
  202. package/dest/kernel/private_to_public_accumulated_data.js +3 -1
  203. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
  204. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  205. package/dest/kernel/private_to_rollup_accumulated_data.js +3 -1
  206. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +16 -1
  207. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  208. package/dest/kernel/private_validation_requests.d.ts +10 -1
  209. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  210. package/dest/kernel/private_validation_requests.js +3 -1
  211. package/dest/kernel/public_call_request.d.ts +22 -1
  212. package/dest/kernel/public_call_request.d.ts.map +1 -1
  213. package/dest/kernel/public_call_request.js +5 -2
  214. package/dest/kernel/utils/optional_number.d.ts +7 -1
  215. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  216. package/dest/keys/public_keys.d.ts +5 -1
  217. package/dest/keys/public_keys.d.ts.map +1 -1
  218. package/dest/logs/contract_class_log.js +3 -1
  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 +5 -3
  222. package/dest/logs/extended_public_log.d.ts.map +1 -1
  223. package/dest/logs/log_id.d.ts +5 -1
  224. package/dest/logs/log_id.d.ts.map +1 -1
  225. package/dest/logs/private_log.js +3 -1
  226. package/dest/logs/public_log.js +3 -1
  227. package/dest/messaging/in_hash.d.ts +4 -2
  228. package/dest/messaging/in_hash.d.ts.map +1 -1
  229. package/dest/messaging/in_hash.js +3 -1
  230. package/dest/messaging/inbox_leaf.d.ts +3 -1
  231. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  232. package/dest/messaging/l1_actor.d.ts +7 -1
  233. package/dest/messaging/l1_actor.d.ts.map +1 -1
  234. package/dest/messaging/l1_to_l2_message.d.ts +6 -1
  235. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  236. package/dest/messaging/l2_actor.d.ts +7 -1
  237. package/dest/messaging/l2_actor.d.ts.map +1 -1
  238. package/dest/messaging/l2_to_l1_membership.d.ts +88 -6
  239. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  240. package/dest/messaging/l2_to_l1_membership.js +160 -42
  241. package/dest/messaging/out_hash.d.ts +41 -3
  242. package/dest/messaging/out_hash.d.ts.map +1 -1
  243. package/dest/messaging/out_hash.js +54 -19
  244. package/dest/note/note_dao.d.ts +36 -5
  245. package/dest/note/note_dao.d.ts.map +1 -1
  246. package/dest/note/note_dao.js +15 -12
  247. package/dest/p2p/attestation_utils.d.ts +3 -3
  248. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  249. package/dest/p2p/attestation_utils.js +1 -1
  250. package/dest/p2p/block_proposal.d.ts +93 -21
  251. package/dest/p2p/block_proposal.d.ts.map +1 -1
  252. package/dest/p2p/block_proposal.js +140 -39
  253. package/dest/p2p/checkpoint_attestation.d.ts +81 -0
  254. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
  255. package/dest/p2p/{block_attestation.js → checkpoint_attestation.js} +22 -19
  256. package/dest/p2p/checkpoint_proposal.d.ts +160 -0
  257. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
  258. package/dest/p2p/checkpoint_proposal.js +229 -0
  259. package/dest/p2p/consensus_payload.d.ts +9 -9
  260. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  261. package/dest/p2p/consensus_payload.js +3 -5
  262. package/dest/p2p/constants.d.ts +3 -0
  263. package/dest/p2p/constants.d.ts.map +1 -0
  264. package/dest/p2p/constants.js +2 -0
  265. package/dest/p2p/gossipable.d.ts +4 -3
  266. package/dest/p2p/gossipable.d.ts.map +1 -1
  267. package/dest/p2p/gossipable.js +16 -5
  268. package/dest/p2p/index.d.ts +5 -2
  269. package/dest/p2p/index.d.ts.map +1 -1
  270. package/dest/p2p/index.js +4 -1
  271. package/dest/p2p/message_validator.d.ts +18 -3
  272. package/dest/p2p/message_validator.d.ts.map +1 -1
  273. package/dest/p2p/message_validator.js +2 -1
  274. package/dest/p2p/signature_utils.d.ts +5 -3
  275. package/dest/p2p/signature_utils.d.ts.map +1 -1
  276. package/dest/p2p/signature_utils.js +3 -1
  277. package/dest/p2p/signed_txs.d.ts +42 -0
  278. package/dest/p2p/signed_txs.d.ts.map +1 -0
  279. package/dest/p2p/signed_txs.js +75 -0
  280. package/dest/p2p/topic_type.d.ts +3 -2
  281. package/dest/p2p/topic_type.d.ts.map +1 -1
  282. package/dest/p2p/topic_type.js +10 -3
  283. package/dest/parity/parity_base_private_inputs.d.ts +3 -1
  284. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  285. package/dest/parity/parity_public_inputs.d.ts +4 -1
  286. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  287. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  288. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  289. package/dest/proofs/chonk_proof.d.ts +1 -1
  290. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  291. package/dest/proofs/chonk_proof.js +9 -4
  292. package/dest/proofs/proof.d.ts +4 -1
  293. package/dest/proofs/proof.d.ts.map +1 -1
  294. package/dest/proofs/recursive_proof.d.ts +10 -1
  295. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  296. package/dest/rollup/base_rollup_hints.d.ts +34 -1
  297. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  298. package/dest/rollup/block_constant_data.d.ts +12 -1
  299. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  300. package/dest/rollup/block_headers_hash.js +1 -1
  301. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  302. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  303. package/dest/rollup/block_rollup_public_inputs.d.ts +47 -11
  304. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  305. package/dest/rollup/block_rollup_public_inputs.js +8 -12
  306. package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
  307. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  308. package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
  309. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  310. package/dest/rollup/checkpoint_constant_data.js +3 -1
  311. package/dest/rollup/checkpoint_header.d.ts +42 -12
  312. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  313. package/dest/rollup/checkpoint_header.js +49 -19
  314. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  315. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  316. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +41 -1
  317. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  318. package/dest/rollup/checkpoint_rollup_public_inputs.js +10 -2
  319. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
  320. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  321. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
  322. package/dest/rollup/epoch_constant_data.d.ts +16 -1
  323. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  324. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  325. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  326. package/dest/rollup/root_rollup_public_inputs.d.ts +18 -3
  327. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  328. package/dest/rollup/root_rollup_public_inputs.js +9 -3
  329. package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
  330. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  331. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  332. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  333. package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
  334. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  335. package/dest/schemas/schemas.d.ts +1 -1
  336. package/dest/tests/factories.d.ts +16 -10
  337. package/dest/tests/factories.d.ts.map +1 -1
  338. package/dest/tests/factories.js +60 -25
  339. package/dest/tests/jest.js +1 -1
  340. package/dest/tests/mocks.d.ts +69 -18
  341. package/dest/tests/mocks.d.ts.map +1 -1
  342. package/dest/tests/mocks.js +119 -54
  343. package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
  344. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  345. package/dest/trees/append_only_tree_snapshot.js +3 -1
  346. package/dest/trees/nullifier_leaf.d.ts +13 -1
  347. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  348. package/dest/trees/nullifier_membership_witness.d.ts +10 -1
  349. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  350. package/dest/trees/public_data_leaf.d.ts +16 -1
  351. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  352. package/dest/trees/public_data_witness.d.ts +11 -1
  353. package/dest/trees/public_data_witness.d.ts.map +1 -1
  354. package/dest/tx/block_header.d.ts +14 -2
  355. package/dest/tx/block_header.d.ts.map +1 -1
  356. package/dest/tx/block_header.js +8 -2
  357. package/dest/tx/call_context.d.ts +13 -1
  358. package/dest/tx/call_context.d.ts.map +1 -1
  359. package/dest/tx/call_context.js +3 -1
  360. package/dest/tx/capsule.d.ts +4 -1
  361. package/dest/tx/capsule.d.ts.map +1 -1
  362. package/dest/tx/execution_payload.d.ts +9 -1
  363. package/dest/tx/execution_payload.d.ts.map +1 -1
  364. package/dest/tx/function_data.d.ts +4 -2
  365. package/dest/tx/function_data.d.ts.map +1 -1
  366. package/dest/tx/global_variable_builder.d.ts +2 -2
  367. package/dest/tx/global_variable_builder.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/global_variables.js +3 -1
  371. package/dest/tx/hashed_values.d.ts +7 -1
  372. package/dest/tx/hashed_values.d.ts.map +1 -1
  373. package/dest/tx/in_tx.d.ts +1 -1
  374. package/dest/tx/index.d.ts +1 -2
  375. package/dest/tx/index.d.ts.map +1 -1
  376. package/dest/tx/index.js +0 -1
  377. package/dest/tx/partial_state_reference.d.ts +4 -1
  378. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  379. package/dest/tx/private_execution_result.d.ts +23 -6
  380. package/dest/tx/private_execution_result.d.ts.map +1 -1
  381. package/dest/tx/private_execution_result.js +4 -21
  382. package/dest/tx/private_tx_constant_data.d.ts +16 -1
  383. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  384. package/dest/tx/profiling.d.ts +149 -26
  385. package/dest/tx/profiling.d.ts.map +1 -1
  386. package/dest/tx/profiling.js +44 -7
  387. package/dest/tx/protocol_contracts.d.ts +1 -1
  388. package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
  389. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  390. package/dest/tx/public_call_request_with_calldata.js +3 -1
  391. package/dest/tx/state_reference.d.ts +3 -1
  392. package/dest/tx/state_reference.d.ts.map +1 -1
  393. package/dest/tx/state_reference.js +3 -1
  394. package/dest/tx/tree_snapshots.js +3 -1
  395. package/dest/tx/tx.d.ts +24 -1
  396. package/dest/tx/tx.d.ts.map +1 -1
  397. package/dest/tx/tx.js +9 -4
  398. package/dest/tx/tx_context.d.ts +2 -1
  399. package/dest/tx/tx_context.d.ts.map +1 -1
  400. package/dest/tx/tx_effect.d.ts +32 -6
  401. package/dest/tx/tx_effect.d.ts.map +1 -1
  402. package/dest/tx/tx_effect.js +3 -8
  403. package/dest/tx/tx_execution_request.d.ts +30 -1
  404. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  405. package/dest/tx/tx_execution_request.js +6 -2
  406. package/dest/tx/tx_hash.d.ts +2 -1
  407. package/dest/tx/tx_hash.d.ts.map +1 -1
  408. package/dest/tx/tx_receipt.d.ts +44 -10
  409. package/dest/tx/tx_receipt.d.ts.map +1 -1
  410. package/dest/tx/tx_receipt.js +44 -13
  411. package/dest/tx/tx_request.d.ts +6 -1
  412. package/dest/tx/tx_request.d.ts.map +1 -1
  413. package/dest/tx/validator/error_texts.d.ts +2 -1
  414. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  415. package/dest/tx/validator/error_texts.js +2 -0
  416. package/dest/types/shared.d.ts +4 -1
  417. package/dest/types/shared.d.ts.map +1 -1
  418. package/dest/validators/schemas.d.ts +8 -8
  419. package/dest/vks/verification_key.d.ts +22 -1
  420. package/dest/vks/verification_key.d.ts.map +1 -1
  421. package/dest/vks/vk_data.d.ts +7 -1
  422. package/dest/vks/vk_data.d.ts.map +1 -1
  423. package/dest/zkpassport/index.d.ts +3 -4
  424. package/dest/zkpassport/index.d.ts.map +1 -1
  425. package/dest/zkpassport/index.js +9 -9
  426. package/package.json +12 -10
  427. package/src/abi/contract_artifact.ts +10 -10
  428. package/src/abi/utils.ts +17 -0
  429. package/src/block/attestation_info.ts +9 -6
  430. package/src/block/block_hash.ts +27 -1
  431. package/src/block/block_parameter.ts +4 -2
  432. package/src/block/body.ts +2 -1
  433. package/src/block/checkpointed_l2_block.ts +8 -58
  434. package/src/block/index.ts +0 -2
  435. package/src/block/l2_block.ts +101 -148
  436. package/src/block/l2_block_source.ts +121 -43
  437. package/src/block/l2_block_stream/index.ts +1 -0
  438. package/src/block/l2_block_stream/interfaces.ts +15 -4
  439. package/src/block/l2_block_stream/l2_block_stream.ts +130 -39
  440. package/src/block/l2_block_stream/l2_tips_memory_store.ts +62 -56
  441. package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
  442. package/src/block/test/l2_tips_store_test_suite.ts +480 -36
  443. package/src/block/validate_block_result.ts +40 -35
  444. package/src/checkpoint/checkpoint.ts +34 -11
  445. package/src/checkpoint/checkpoint_info.ts +45 -2
  446. package/src/checkpoint/index.ts +1 -0
  447. package/src/checkpoint/published_checkpoint.ts +4 -3
  448. package/src/config/node-rpc-config.ts +1 -1
  449. package/src/contract/index.ts +0 -2
  450. package/src/contract/private_function.ts +1 -2
  451. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  452. package/src/deserialization/index.ts +21 -0
  453. package/src/epoch-helpers/index.ts +1 -1
  454. package/src/interfaces/api_limit.ts +2 -0
  455. package/src/interfaces/archiver.ts +24 -23
  456. package/src/interfaces/aztec-node-admin.ts +5 -2
  457. package/src/interfaces/aztec-node.ts +100 -68
  458. package/src/interfaces/block-builder.ts +31 -24
  459. package/src/interfaces/configs.ts +3 -0
  460. package/src/interfaces/l2_logs_source.ts +17 -4
  461. package/src/interfaces/p2p.ts +8 -12
  462. package/src/interfaces/prover-client.ts +15 -0
  463. package/src/interfaces/proving-job.ts +2 -11
  464. package/src/interfaces/server_circuit_prover.ts +3 -2
  465. package/src/interfaces/tx_provider.ts +2 -2
  466. package/src/interfaces/validator.ts +63 -14
  467. package/src/kernel/hints/build_note_hash_read_request_hints.ts +20 -12
  468. package/src/kernel/hints/build_nullifier_read_request_hints.ts +17 -14
  469. package/src/messaging/in_hash.ts +3 -1
  470. package/src/messaging/l2_to_l1_membership.ts +178 -52
  471. package/src/messaging/out_hash.ts +62 -21
  472. package/src/note/note_dao.ts +18 -13
  473. package/src/p2p/attestation_utils.ts +3 -3
  474. package/src/p2p/block_proposal.ts +204 -44
  475. package/src/p2p/{block_attestation.ts → checkpoint_attestation.ts} +31 -25
  476. package/src/p2p/checkpoint_proposal.ts +348 -0
  477. package/src/p2p/consensus_payload.ts +5 -7
  478. package/src/p2p/constants.ts +3 -0
  479. package/src/p2p/gossipable.ts +14 -4
  480. package/src/p2p/index.ts +4 -1
  481. package/src/p2p/message_validator.ts +14 -2
  482. package/src/p2p/signature_utils.ts +3 -1
  483. package/src/p2p/signed_txs.ts +88 -0
  484. package/src/p2p/topic_type.ts +4 -3
  485. package/src/proofs/chonk_proof.ts +9 -5
  486. package/src/rollup/block_headers_hash.ts +1 -1
  487. package/src/rollup/block_rollup_public_inputs.ts +5 -11
  488. package/src/rollup/checkpoint_header.ts +63 -20
  489. package/src/rollup/checkpoint_rollup_public_inputs.ts +12 -0
  490. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
  491. package/src/rollup/root_rollup_public_inputs.ts +9 -0
  492. package/src/tests/factories.ts +56 -40
  493. package/src/tests/jest.ts +1 -1
  494. package/src/tests/mocks.ts +207 -87
  495. package/src/tx/block_header.ts +11 -3
  496. package/src/tx/global_variable_builder.ts +1 -1
  497. package/src/tx/index.ts +0 -1
  498. package/src/tx/private_execution_result.ts +1 -16
  499. package/src/tx/profiling.ts +46 -4
  500. package/src/tx/tx.ts +10 -9
  501. package/src/tx/tx_effect.ts +0 -9
  502. package/src/tx/tx_execution_request.ts +2 -0
  503. package/src/tx/tx_receipt.ts +72 -15
  504. package/src/tx/validator/error_texts.ts +3 -0
  505. package/src/zkpassport/index.ts +11 -12
  506. package/dest/block/l2_block_code_to_purge.d.ts +0 -12
  507. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  508. package/dest/block/l2_block_code_to_purge.js +0 -61
  509. package/dest/block/l2_block_header.d.ts +0 -98
  510. package/dest/block/l2_block_header.d.ts.map +0 -1
  511. package/dest/block/l2_block_header.js +0 -153
  512. package/dest/block/l2_block_new.d.ts +0 -135
  513. package/dest/block/l2_block_new.d.ts.map +0 -1
  514. package/dest/block/l2_block_new.js +0 -152
  515. package/dest/contract/contract_class_metadata.d.ts +0 -8
  516. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  517. package/dest/contract/contract_class_metadata.js +0 -1
  518. package/dest/contract/contract_metadata.d.ts +0 -7
  519. package/dest/contract/contract_metadata.d.ts.map +0 -1
  520. package/dest/contract/contract_metadata.js +0 -1
  521. package/dest/p2p/block_attestation.d.ts +0 -80
  522. package/dest/p2p/block_attestation.d.ts.map +0 -1
  523. package/dest/tx/content_commitment.d.ts +0 -49
  524. package/dest/tx/content_commitment.d.ts.map +0 -1
  525. package/dest/tx/content_commitment.js +0 -90
  526. package/src/block/l2_block_code_to_purge.ts +0 -88
  527. package/src/block/l2_block_header.ts +0 -246
  528. package/src/block/l2_block_new.ts +0 -207
  529. package/src/contract/contract_class_metadata.ts +0 -8
  530. package/src/contract/contract_metadata.ts +0 -7
  531. package/src/tx/content_commitment.ts +0 -113
@@ -2,7 +2,7 @@ import { SlotNumber } from '@aztec/foundation/branded-types';
2
2
  import { Buffer32 } from '@aztec/foundation/buffer';
3
3
  import { keccak256 } from '@aztec/foundation/crypto/keccak';
4
4
  import { tryRecoverAddress } from '@aztec/foundation/crypto/secp256k1-signer';
5
- import { Fr } from '@aztec/foundation/curves/bn254';
5
+ import type { Fr } from '@aztec/foundation/curves/bn254';
6
6
  import type { EthAddress } from '@aztec/foundation/eth-address';
7
7
  import { Signature } from '@aztec/foundation/eth-signature';
8
8
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
@@ -10,25 +10,26 @@ import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
10
10
  import { z } from 'zod';
11
11
 
12
12
  import type { ZodFor } from '../schemas/index.js';
13
+ import { CheckpointProposal } from './checkpoint_proposal.js';
13
14
  import { ConsensusPayload } from './consensus_payload.js';
14
15
  import { Gossipable } from './gossipable.js';
15
16
  import { SignatureDomainSeparator, getHashedSignaturePayloadEthSignedMessage } from './signature_utils.js';
16
17
  import { TopicType } from './topic_type.js';
17
18
 
18
- export class BlockAttestationHash extends Buffer32 {
19
+ export class CheckpointAttestationHash extends Buffer32 {
19
20
  constructor(hash: Buffer) {
20
21
  super(hash);
21
22
  }
22
23
  }
23
24
 
24
25
  /**
25
- * BlockAttestation
26
+ * CheckpointAttestation
26
27
  *
27
- * A validator that has attested to seeing the contents of a block
28
- * will produce a block attestation over the header of the block
28
+ * A validator that has attested to seeing all blocks in a checkpoint
29
+ * will produce a checkpoint attestation over the checkpoint header.
29
30
  */
30
- export class BlockAttestation extends Gossipable {
31
- static override p2pTopic = TopicType.block_attestation;
31
+ export class CheckpointAttestation extends Gossipable {
32
+ static override p2pTopic = TopicType.checkpoint_attestation;
32
33
 
33
34
  private sender: EthAddress | undefined;
34
35
  private proposer: EthAddress | undefined;
@@ -37,27 +38,27 @@ export class BlockAttestation extends Gossipable {
37
38
  /** The payload of the message, and what the signature is over */
38
39
  public readonly payload: ConsensusPayload,
39
40
 
40
- /** The signature of the block attester */
41
+ /** The signature of the checkpoint attester */
41
42
  public readonly signature: Signature,
42
43
 
43
- /** The signature from the block proposer */
44
+ /** The signature from the checkpoint proposer */
44
45
  public readonly proposerSignature: Signature,
45
46
  ) {
46
47
  super();
47
48
  }
48
49
 
49
- static get schema(): ZodFor<BlockAttestation> {
50
+ static get schema(): ZodFor<CheckpointAttestation> {
50
51
  return z
51
52
  .object({
52
53
  payload: ConsensusPayload.schema,
53
54
  signature: Signature.schema,
54
55
  proposerSignature: Signature.schema,
55
56
  })
56
- .transform(obj => new BlockAttestation(obj.payload, obj.signature, obj.proposerSignature));
57
+ .transform(obj => new CheckpointAttestation(obj.payload, obj.signature, obj.proposerSignature));
57
58
  }
58
59
 
59
60
  override generateP2PMessageIdentifier(): Promise<Buffer32> {
60
- return Promise.resolve(new BlockAttestationHash(keccak256(this.signature.toBuffer())));
61
+ return Promise.resolve(new CheckpointAttestationHash(keccak256(this.signature.toBuffer())));
61
62
  }
62
63
 
63
64
  get archive(): Fr {
@@ -75,7 +76,10 @@ export class BlockAttestation extends Gossipable {
75
76
  getSender(): EthAddress | undefined {
76
77
  if (!this.sender) {
77
78
  // Recover the sender from the attestation
78
- const hashed = getHashedSignaturePayloadEthSignedMessage(this.payload, SignatureDomainSeparator.blockAttestation);
79
+ const hashed = getHashedSignaturePayloadEthSignedMessage(
80
+ this.payload,
81
+ SignatureDomainSeparator.checkpointAttestation,
82
+ );
79
83
  // Cache the sender for later use
80
84
  this.sender = tryRecoverAddress(hashed, this.signature);
81
85
  }
@@ -84,43 +88,45 @@ export class BlockAttestation extends Gossipable {
84
88
  }
85
89
 
86
90
  /**
87
- * Lazily evaluate and cache the proposer of the block
88
- * @returns The proposer of the block
91
+ * Lazily evaluate and cache the proposer of the checkpoint
92
+ * @returns The proposer of the checkpoint
89
93
  */
90
94
  getProposer(): EthAddress | undefined {
91
95
  if (!this.proposer) {
92
- // Recover the proposer from the proposal signature
93
- const hashed = getHashedSignaturePayloadEthSignedMessage(this.payload, SignatureDomainSeparator.blockProposal);
96
+ // Create a temporary CheckpointProposal to recover the proposer address.
97
+ // We need to use CheckpointProposal because it has a different getPayloadToSign()
98
+ // implementation than ConsensusPayload (uses serializeToBuffer vs ABI encoding).
99
+ const proposal = new CheckpointProposal(this.payload.header, this.payload.archive, this.proposerSignature);
94
100
  // Cache the proposer for later use
95
- this.proposer = tryRecoverAddress(hashed, this.proposerSignature);
101
+ this.proposer = proposal.getSender();
96
102
  }
97
103
 
98
104
  return this.proposer;
99
105
  }
100
106
 
101
107
  getPayload(): Buffer {
102
- return this.payload.getPayloadToSign(SignatureDomainSeparator.blockAttestation);
108
+ return this.payload.getPayloadToSign(SignatureDomainSeparator.checkpointAttestation);
103
109
  }
104
110
 
105
111
  toBuffer(): Buffer {
106
112
  return serializeToBuffer([this.payload, this.signature, this.proposerSignature]);
107
113
  }
108
114
 
109
- static fromBuffer(buf: Buffer | BufferReader): BlockAttestation {
115
+ static fromBuffer(buf: Buffer | BufferReader): CheckpointAttestation {
110
116
  const reader = BufferReader.asReader(buf);
111
- return new BlockAttestation(
117
+ return new CheckpointAttestation(
112
118
  reader.readObject(ConsensusPayload),
113
119
  reader.readObject(Signature),
114
120
  reader.readObject(Signature),
115
121
  );
116
122
  }
117
123
 
118
- static empty(): BlockAttestation {
119
- return new BlockAttestation(ConsensusPayload.empty(), Signature.empty(), Signature.empty());
124
+ static empty(): CheckpointAttestation {
125
+ return new CheckpointAttestation(ConsensusPayload.empty(), Signature.empty(), Signature.empty());
120
126
  }
121
127
 
122
- static random(): BlockAttestation {
123
- return new BlockAttestation(ConsensusPayload.random(), Signature.random(), Signature.random());
128
+ static random(): CheckpointAttestation {
129
+ return new CheckpointAttestation(ConsensusPayload.random(), Signature.random(), Signature.random());
124
130
  }
125
131
 
126
132
  getSize(): number {
@@ -0,0 +1,348 @@
1
+ import { BlockNumber, IndexWithinCheckpoint, SlotNumber } from '@aztec/foundation/branded-types';
2
+ import { Buffer32 } from '@aztec/foundation/buffer';
3
+ import { keccak256 } from '@aztec/foundation/crypto/keccak';
4
+ import { tryRecoverAddress } from '@aztec/foundation/crypto/secp256k1-signer';
5
+ import { Fr } from '@aztec/foundation/curves/bn254';
6
+ import type { EthAddress } from '@aztec/foundation/eth-address';
7
+ import { Signature } from '@aztec/foundation/eth-signature';
8
+ import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
9
+ import { DutyType, type SigningContext } from '@aztec/validator-ha-signer/types';
10
+
11
+ import type { L2BlockInfo } from '../block/l2_block_info.js';
12
+ import { MAX_TXS_PER_BLOCK } from '../deserialization/index.js';
13
+ import { CheckpointHeader } from '../rollup/checkpoint_header.js';
14
+ import { BlockHeader } from '../tx/block_header.js';
15
+ import { TxHash } from '../tx/index.js';
16
+ import type { Tx } from '../tx/tx.js';
17
+ import { BlockProposal } from './block_proposal.js';
18
+ import { Gossipable } from './gossipable.js';
19
+ import {
20
+ SignatureDomainSeparator,
21
+ getHashedSignaturePayload,
22
+ getHashedSignaturePayloadEthSignedMessage,
23
+ } from './signature_utils.js';
24
+ import { SignedTxs } from './signed_txs.js';
25
+ import { TopicType } from './topic_type.js';
26
+
27
+ // REFACTOR(palla): Use a branded type instead of a subclass of Buffer32
28
+ export class CheckpointProposalHash extends Buffer32 {
29
+ constructor(hash: Buffer) {
30
+ super(hash);
31
+ }
32
+ }
33
+
34
+ export type CheckpointProposalOptions = {
35
+ publishFullTxs: boolean;
36
+ /** Whether to generate an invalid checkpoint proposal for broadcasting. Use only for testing. */
37
+ broadcastInvalidCheckpointProposal?: boolean;
38
+ };
39
+
40
+ /** Data for the last block included in a checkpoint proposal */
41
+ export type CheckpointLastBlockData = {
42
+ /** The per-block header for the last block in the checkpoint */
43
+ blockHeader: BlockHeader;
44
+ /** Index of this block within the checkpoint (should be the last index, e.g., numBlocks - 1) */
45
+ indexWithinCheckpoint: IndexWithinCheckpoint;
46
+ /** The sequence of transactions in the last block */
47
+ txHashes: TxHash[];
48
+ /** The tx in the last block (optional, for DA guarantees) */
49
+ txs?: Tx[];
50
+ };
51
+
52
+ /** Last block included in a checkpoint proposal */
53
+ export type CheckpointLastBlock = Omit<CheckpointLastBlockData, 'txs'> & {
54
+ /** The proposer's signature over the block data (separate from checkpoint signature) */
55
+ signature: Signature;
56
+ /** The signed transactions in the last block (optional, for DA guarantees) */
57
+ signedTxs?: SignedTxs;
58
+ };
59
+
60
+ /**
61
+ * A checkpoint proposal is created by the leader of the chain for the last block in a checkpoint.
62
+ * It includes the aggregated checkpoint header that validators will attest to, plus optionally
63
+ * the last block's info for nodes to re-execute. This marks the completion of a slot's worth of blocks.
64
+ */
65
+ export class CheckpointProposal extends Gossipable {
66
+ static override p2pTopic = TopicType.checkpoint_proposal;
67
+
68
+ private sender: EthAddress | undefined;
69
+
70
+ constructor(
71
+ /** The aggregated checkpoint header for consensus */
72
+ public readonly checkpointHeader: CheckpointHeader,
73
+
74
+ /** Archive root after this checkpoint is applied */
75
+ public readonly archive: Fr,
76
+
77
+ /** The proposer's signature over the checkpoint payload (checkpointHeader + archive) */
78
+ public readonly signature: Signature,
79
+
80
+ /** Optional last block info, including its own signature for BlockProposal extraction */
81
+ public readonly lastBlock?: CheckpointLastBlock,
82
+ ) {
83
+ super();
84
+ }
85
+
86
+ override generateP2PMessageIdentifier(): Promise<Buffer32> {
87
+ return Promise.resolve(new CheckpointProposalHash(keccak256(this.signature.toBuffer())));
88
+ }
89
+
90
+ get slotNumber(): SlotNumber {
91
+ return this.checkpointHeader.slotNumber;
92
+ }
93
+
94
+ get blockNumber(): BlockNumber {
95
+ if (!this.lastBlock) {
96
+ throw new Error('Cannot get blockNumber without lastBlock');
97
+ }
98
+ return this.lastBlock.blockHeader.getBlockNumber();
99
+ }
100
+
101
+ /** Convenience getter for txHashes from lastBlock */
102
+ get txHashes(): TxHash[] {
103
+ return this.lastBlock?.txHashes ?? [];
104
+ }
105
+
106
+ /** Convenience getter for txs from lastBlock */
107
+ get txs(): Tx[] | undefined {
108
+ return this.lastBlock?.signedTxs?.txs;
109
+ }
110
+
111
+ /**
112
+ * Extract a BlockProposal from the last block info.
113
+ * Uses inHash from checkpointHeader.contentCommitment.inHash
114
+ */
115
+ getBlockProposal(): BlockProposal | undefined {
116
+ if (!this.lastBlock) {
117
+ return undefined;
118
+ }
119
+
120
+ return new BlockProposal(
121
+ this.lastBlock.blockHeader,
122
+ this.lastBlock.indexWithinCheckpoint,
123
+ this.checkpointHeader.inHash,
124
+ this.archive,
125
+ this.lastBlock.txHashes,
126
+ this.lastBlock.signature,
127
+ this.lastBlock.signedTxs,
128
+ );
129
+ }
130
+
131
+ toBlockInfo(): Omit<L2BlockInfo, 'blockNumber'> {
132
+ if (!this.lastBlock) {
133
+ throw new Error('Cannot get blockInfo without lastBlock');
134
+ }
135
+ return {
136
+ slotNumber: this.slotNumber,
137
+ lastArchive: this.lastBlock.blockHeader.lastArchive.root,
138
+ timestamp: this.lastBlock.blockHeader.globalVariables.timestamp,
139
+ archive: this.archive,
140
+ txCount: this.lastBlock.txHashes.length,
141
+ };
142
+ }
143
+
144
+ /**
145
+ * Get the payload to sign for this checkpoint proposal.
146
+ * The signature is over the checkpoint header + archive root (for consensus).
147
+ */
148
+ getPayloadToSign(domainSeparator: SignatureDomainSeparator): Buffer {
149
+ return serializeToBuffer([domainSeparator, this.checkpointHeader, this.archive]);
150
+ }
151
+
152
+ static async createProposalFromSigner(
153
+ checkpointHeader: CheckpointHeader,
154
+ archiveRoot: Fr,
155
+ lastBlockInfo: CheckpointLastBlockData | undefined,
156
+ payloadSigner: (payload: Buffer32, context: SigningContext) => Promise<Signature>,
157
+ ): Promise<CheckpointProposal> {
158
+ // Sign the checkpoint payload with CHECKPOINT_PROPOSAL duty type
159
+ const tempProposal = new CheckpointProposal(checkpointHeader, archiveRoot, Signature.empty(), undefined);
160
+ const checkpointHash = getHashedSignaturePayload(tempProposal, SignatureDomainSeparator.checkpointProposal);
161
+
162
+ const checkpointContext: SigningContext = {
163
+ slot: checkpointHeader.slotNumber,
164
+ blockNumber: lastBlockInfo?.blockHeader?.globalVariables.blockNumber ?? BlockNumber(0),
165
+ dutyType: DutyType.CHECKPOINT_PROPOSAL,
166
+ };
167
+ const checkpointSignature = await payloadSigner(checkpointHash, checkpointContext);
168
+
169
+ if (!lastBlockInfo) {
170
+ return new CheckpointProposal(checkpointHeader, archiveRoot, checkpointSignature);
171
+ }
172
+
173
+ const lastBlockProposal = await BlockProposal.createProposalFromSigner(
174
+ lastBlockInfo.blockHeader,
175
+ lastBlockInfo.indexWithinCheckpoint,
176
+ checkpointHeader.inHash,
177
+ archiveRoot,
178
+ lastBlockInfo.txHashes,
179
+ lastBlockInfo.txs,
180
+ payloadSigner,
181
+ );
182
+
183
+ return new CheckpointProposal(checkpointHeader, archiveRoot, checkpointSignature, {
184
+ blockHeader: lastBlockInfo.blockHeader,
185
+ indexWithinCheckpoint: lastBlockInfo.indexWithinCheckpoint,
186
+ txHashes: lastBlockInfo.txHashes,
187
+ signature: lastBlockProposal.signature,
188
+ signedTxs: lastBlockProposal.signedTxs,
189
+ });
190
+ }
191
+
192
+ /**
193
+ * Lazily evaluate the sender of the proposal; result is cached.
194
+ * If there's a lastBlock, also verifies the block proposal sender matches the checkpoint sender.
195
+ * @returns The sender address, or undefined if signature recovery fails or senders don't match
196
+ */
197
+ getSender(): EthAddress | undefined {
198
+ if (!this.sender) {
199
+ const hashed = getHashedSignaturePayloadEthSignedMessage(this, SignatureDomainSeparator.checkpointProposal);
200
+ const checkpointSender = tryRecoverAddress(hashed, this.signature);
201
+
202
+ // If there's a lastBlock, verify the block proposal sender matches
203
+ if (checkpointSender && this.lastBlock) {
204
+ const blockProposal = this.getBlockProposal();
205
+ const blockSender = blockProposal?.getSender();
206
+ if (!blockSender || !blockSender.equals(checkpointSender)) {
207
+ return undefined; // Sender mismatch - fail
208
+ }
209
+ }
210
+
211
+ // Cache the sender for later use
212
+ this.sender = checkpointSender;
213
+ }
214
+
215
+ return this.sender;
216
+ }
217
+
218
+ getPayload() {
219
+ return this.getPayloadToSign(SignatureDomainSeparator.checkpointProposal);
220
+ }
221
+
222
+ toBuffer(): Buffer {
223
+ const buffer: any[] = [this.checkpointHeader, this.archive, this.signature];
224
+
225
+ if (this.lastBlock) {
226
+ buffer.push(1); // hasLastBlock = true
227
+ buffer.push(this.lastBlock.blockHeader);
228
+ buffer.push(this.lastBlock.indexWithinCheckpoint);
229
+ buffer.push(this.lastBlock.signature);
230
+ buffer.push(this.lastBlock.txHashes.length);
231
+ buffer.push(this.lastBlock.txHashes);
232
+ if (this.lastBlock.signedTxs) {
233
+ buffer.push(1); // hasSignedTxs = true
234
+ buffer.push(this.lastBlock.signedTxs.toBuffer());
235
+ } else {
236
+ buffer.push(0); // hasSignedTxs = false
237
+ }
238
+ } else {
239
+ buffer.push(0); // hasLastBlock = false
240
+ }
241
+
242
+ return serializeToBuffer(buffer);
243
+ }
244
+
245
+ static fromBuffer(buf: Buffer | BufferReader): CheckpointProposal {
246
+ const reader = BufferReader.asReader(buf);
247
+
248
+ const checkpointHeader = reader.readObject(CheckpointHeader);
249
+ const archive = reader.readObject(Fr);
250
+ const signature = reader.readObject(Signature);
251
+
252
+ const hasLastBlock = reader.readNumber();
253
+
254
+ if (hasLastBlock) {
255
+ const blockHeader = reader.readObject(BlockHeader);
256
+ const indexWithinCheckpoint = IndexWithinCheckpoint(reader.readNumber());
257
+ const blockSignature = reader.readObject(Signature);
258
+ const txHashCount = reader.readNumber();
259
+ if (txHashCount > MAX_TXS_PER_BLOCK) {
260
+ throw new Error(`txHashes count ${txHashCount} exceeds maximum ${MAX_TXS_PER_BLOCK}`);
261
+ }
262
+ const txHashes = reader.readArray(txHashCount, TxHash);
263
+
264
+ let signedTxs: SignedTxs | undefined;
265
+ if (!reader.isEmpty()) {
266
+ const hasSignedTxs = reader.readNumber();
267
+ if (hasSignedTxs) {
268
+ signedTxs = SignedTxs.fromBuffer(reader);
269
+ }
270
+ }
271
+
272
+ return new CheckpointProposal(checkpointHeader, archive, signature, {
273
+ blockHeader,
274
+ indexWithinCheckpoint,
275
+ txHashes,
276
+ signature: blockSignature,
277
+ signedTxs,
278
+ });
279
+ }
280
+
281
+ return new CheckpointProposal(checkpointHeader, archive, signature);
282
+ }
283
+
284
+ getSize(): number {
285
+ let size =
286
+ this.checkpointHeader.toBuffer().length +
287
+ this.archive.size +
288
+ this.signature.getSize() +
289
+ 4; /* hasLastBlock flag */
290
+
291
+ if (this.lastBlock) {
292
+ size +=
293
+ this.lastBlock.blockHeader.getSize() +
294
+ 4 /* indexWithinCheckpoint */ +
295
+ this.lastBlock.signature.getSize() +
296
+ 4 /* txHashes.length */ +
297
+ this.lastBlock.txHashes.length * TxHash.SIZE +
298
+ 4 /* hasSignedTxs flag */ +
299
+ (this.lastBlock.signedTxs ? this.lastBlock.signedTxs.getSize() : 0);
300
+ }
301
+
302
+ return size;
303
+ }
304
+
305
+ static empty(): CheckpointProposal {
306
+ return new CheckpointProposal(CheckpointHeader.empty(), Fr.ZERO, Signature.empty());
307
+ }
308
+
309
+ static random(): CheckpointProposal {
310
+ return new CheckpointProposal(CheckpointHeader.random(), Fr.random(), Signature.random(), {
311
+ blockHeader: BlockHeader.random(),
312
+ indexWithinCheckpoint: IndexWithinCheckpoint(Math.floor(Math.random() * 5)),
313
+ txHashes: [TxHash.random(), TxHash.random()],
314
+ signature: Signature.random(),
315
+ });
316
+ }
317
+
318
+ toInspect() {
319
+ return {
320
+ checkpointHeader: this.checkpointHeader.toInspect(),
321
+ archive: this.archive.toString(),
322
+ signature: this.signature.toString(),
323
+ lastBlock: this.lastBlock
324
+ ? {
325
+ blockHeader: this.lastBlock.blockHeader.toInspect(),
326
+ indexWithinCheckpoint: this.lastBlock.indexWithinCheckpoint,
327
+ txHashes: this.lastBlock.txHashes.map(h => h.toString()),
328
+ signature: this.lastBlock.signature.toString(),
329
+ }
330
+ : undefined,
331
+ };
332
+ }
333
+
334
+ /**
335
+ * Returns a copy of this proposal without lastBlock info, as a CheckpointProposalCore.
336
+ * Used when the lastBlock has been extracted and stored separately.
337
+ */
338
+ toCore(): CheckpointProposalCore {
339
+ return new CheckpointProposal(this.checkpointHeader, this.archive, this.signature);
340
+ }
341
+ }
342
+
343
+ /**
344
+ * A checkpoint proposal without the lastBlock info.
345
+ * Used when the lastBlock has been extracted and handled separately as a BlockProposal.
346
+ * This type makes it clear that lastBlock and getBlockProposal() are not available.
347
+ */
348
+ export type CheckpointProposalCore = Omit<CheckpointProposal, 'lastBlock' | 'getBlockProposal' | 'toCore'>;
@@ -7,11 +7,12 @@ import type { FieldsOf } from '@aztec/foundation/types';
7
7
  import { encodeAbiParameters, parseAbiParameters } from 'viem';
8
8
  import { z } from 'zod';
9
9
 
10
- import type { L2Block } from '../block/l2_block.js';
11
10
  import type { Checkpoint } from '../checkpoint/checkpoint.js';
12
11
  import { CheckpointHeader } from '../rollup/checkpoint_header.js';
12
+ import type { CheckpointProposal, CheckpointProposalCore } from './checkpoint_proposal.js';
13
13
  import type { Signable, SignatureDomainSeparator } from './signature_utils.js';
14
14
 
15
+ /** Checkpoint consensus payload as signed by validators and verified on L1. */
15
16
  export class ConsensusPayload implements Signable {
16
17
  private size: number | undefined;
17
18
 
@@ -59,8 +60,9 @@ export class ConsensusPayload implements Signable {
59
60
  return serializeToBuffer([this.header, this.archive]);
60
61
  }
61
62
 
62
- public equals(other: ConsensusPayload): boolean {
63
- return this.header.equals(other.header) && this.archive.equals(other.archive);
63
+ public equals(other: ConsensusPayload | CheckpointProposal | CheckpointProposalCore): boolean {
64
+ const otherHeader = 'checkpointHeader' in other ? other.checkpointHeader : other.header;
65
+ return this.header.equals(otherHeader) && this.archive.equals(other.archive);
64
66
  }
65
67
 
66
68
  static fromBuffer(buf: Buffer | BufferReader): ConsensusPayload {
@@ -73,10 +75,6 @@ export class ConsensusPayload implements Signable {
73
75
  return new ConsensusPayload(fields.header, fields.archive);
74
76
  }
75
77
 
76
- static fromBlock(block: L2Block): ConsensusPayload {
77
- return new ConsensusPayload(block.header.toCheckpointHeader(), block.archive.root);
78
- }
79
-
80
78
  static fromCheckpoint(checkpoint: Checkpoint): ConsensusPayload {
81
79
  return new ConsensusPayload(checkpoint.header, checkpoint.archive.root);
82
80
  }
@@ -0,0 +1,3 @@
1
+ export const MAX_TX_SIZE_KB: number = 512;
2
+
3
+ export const MAX_MESSAGE_SIZE_KB: number = 10 * 1024;
@@ -7,23 +7,33 @@ export class P2PMessage {
7
7
  constructor(
8
8
  public readonly payload: Buffer,
9
9
  public readonly timestamp?: Date,
10
+ public readonly traceContext?: string,
10
11
  ) {}
11
12
 
12
- static fromGossipable(message: Gossipable, instrumentMessages = false): P2PMessage {
13
- return new P2PMessage(message.toBuffer(), instrumentMessages ? new Date() : undefined);
13
+ static fromGossipable(message: Gossipable, instrumentMessages = false, traceContext?: string): P2PMessage {
14
+ if (!instrumentMessages) {
15
+ return new P2PMessage(message.toBuffer());
16
+ }
17
+ return new P2PMessage(message.toBuffer(), new Date(), traceContext);
14
18
  }
15
19
 
16
20
  static fromMessageData(messageData: Buffer, instrumentMessages = false): P2PMessage {
17
21
  const reader = new BufferReader(messageData);
18
- const timestamp = instrumentMessages ? new Date(Number(reader.readUInt64())) : undefined;
22
+ let timestamp: Date | undefined;
23
+ let traceContext: string | undefined;
24
+ if (instrumentMessages) {
25
+ timestamp = new Date(Number(reader.readUInt64()));
26
+ traceContext = reader.readString();
27
+ }
19
28
  const payload = reader.readBuffer();
20
- return new P2PMessage(payload, timestamp);
29
+ return new P2PMessage(payload, timestamp, traceContext);
21
30
  }
22
31
 
23
32
  toMessageData(): Buffer {
24
33
  const arr: Buffer[] = [];
25
34
  if (this.timestamp) {
26
35
  arr.push(bigintToUInt64BE(BigInt(this.timestamp.getTime())));
36
+ arr.push(serializeToBuffer(this.traceContext ?? ''));
27
37
  }
28
38
  arr.push(serializeToBuffer(this.payload.length, this.payload));
29
39
  return serializeToBuffer(arr);
package/src/p2p/index.ts CHANGED
@@ -1,11 +1,14 @@
1
1
  export * from './attestation_utils.js';
2
- export * from './block_attestation.js';
3
2
  export * from './block_proposal.js';
3
+ export * from './checkpoint_attestation.js';
4
+ export * from './checkpoint_proposal.js';
4
5
  export * from './consensus_payload.js';
5
6
  export * from './gossipable.js';
6
7
  export * from './interface.js';
7
8
  export * from './signature_utils.js';
9
+ export * from './signed_txs.js';
8
10
  export * from './topic_type.js';
9
11
  export * from './client_type.js';
10
12
  export * from './message_validator.js';
11
13
  export * from './peer_error.js';
14
+ export * from './constants.js';
@@ -1,10 +1,22 @@
1
1
  import type { PeerErrorSeverity } from './peer_error.js';
2
2
 
3
+ /**
4
+ * Result of validating a P2P message.
5
+ * - 'accept': Message is valid and should be accepted and processed
6
+ * - 'ignore': Message should be ignored (not propagated or processed, but sender not penalized)
7
+ * - 'reject': Message is invalid (rejected and sender penalized)
8
+ */
9
+ export type ValidationResult =
10
+ | { result: 'accept' }
11
+ | { result: 'ignore' }
12
+ | { result: 'reject'; severity: PeerErrorSeverity };
13
+
3
14
  /**
4
15
  * P2PValidator
5
16
  *
6
- * A validator for P2P messages, which returns a severity of error to be applied to the peer
17
+ * A validator for P2P messages, which returns a ValidationResult indicating
18
+ * whether to accept, ignore, or reject the message
7
19
  */
8
20
  export interface P2PValidator<T> {
9
- validate(message: T): Promise<PeerErrorSeverity | undefined>;
21
+ validate(message: T): Promise<ValidationResult>;
10
22
  }
@@ -4,8 +4,10 @@ import { makeEthSignDigest } from '@aztec/foundation/crypto/secp256k1-signer';
4
4
 
5
5
  export enum SignatureDomainSeparator {
6
6
  blockProposal = 0,
7
- blockAttestation = 1,
7
+ checkpointAttestation = 1,
8
8
  attestationsAndSigners = 2,
9
+ checkpointProposal = 3,
10
+ signedTxs = 4,
9
11
  }
10
12
 
11
13
  export interface Signable {