@aztec/stdlib 0.0.1-commit.6230efd → 0.0.1-commit.64b6bbb

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 (634) 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 +47 -9
  5. package/dest/abi/function_call.d.ts.map +1 -1
  6. package/dest/abi/function_call.js +20 -3
  7. package/dest/abi/selector.js +3 -1
  8. package/dest/abi/utils.d.ts +7 -1
  9. package/dest/abi/utils.d.ts.map +1 -1
  10. package/dest/abi/utils.js +7 -0
  11. package/dest/auth_witness/auth_witness.d.ts +2 -1
  12. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  13. package/dest/avm/avm.d.ts +62 -62
  14. package/dest/avm/avm_accumulated_data.d.ts +30 -3
  15. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  16. package/dest/avm/avm_accumulated_data.js +5 -2
  17. package/dest/avm/avm_circuit_public_inputs.d.ts +9 -9
  18. package/dest/avm/avm_circuit_public_inputs.js +3 -1
  19. package/dest/avm/avm_proving_request.d.ts +299 -299
  20. package/dest/avm/contract_storage_read.d.ts +13 -1
  21. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  22. package/dest/avm/contract_storage_update_request.d.ts +13 -1
  23. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  24. package/dest/avm/public_call_stack_item_compressed.d.ts +3 -1
  25. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  26. package/dest/avm/public_data_read.d.ts +10 -1
  27. package/dest/avm/public_data_read.d.ts.map +1 -1
  28. package/dest/avm/public_data_update_request.d.ts +10 -1
  29. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  30. package/dest/avm/public_data_update_request.js +3 -1
  31. package/dest/avm/public_data_write.d.ts +7 -1
  32. package/dest/avm/public_data_write.d.ts.map +1 -1
  33. package/dest/avm/public_inner_call_request.d.ts +4 -1
  34. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  35. package/dest/avm/public_inner_call_request.js +3 -1
  36. package/dest/avm/revert_code.d.ts +4 -4
  37. package/dest/avm/revert_code.d.ts.map +1 -1
  38. package/dest/avm/revert_code.js +3 -1
  39. package/dest/aztec-address/index.js +4 -2
  40. package/dest/block/attestation_info.d.ts +5 -5
  41. package/dest/block/attestation_info.d.ts.map +1 -1
  42. package/dest/block/attestation_info.js +4 -4
  43. package/dest/block/block_hash.d.ts +18 -14
  44. package/dest/block/block_hash.d.ts.map +1 -1
  45. package/dest/block/block_hash.js +22 -20
  46. package/dest/block/block_parameter.d.ts +4 -3
  47. package/dest/block/block_parameter.d.ts.map +1 -1
  48. package/dest/block/block_parameter.js +2 -0
  49. package/dest/block/body.d.ts +1 -1
  50. package/dest/block/body.d.ts.map +1 -1
  51. package/dest/block/body.js +5 -2
  52. package/dest/block/checkpointed_l2_block.d.ts +20 -137
  53. package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
  54. package/dest/block/checkpointed_l2_block.js +7 -45
  55. package/dest/block/in_block.d.ts +9 -9
  56. package/dest/block/in_block.d.ts.map +1 -1
  57. package/dest/block/in_block.js +5 -5
  58. package/dest/block/index.d.ts +1 -3
  59. package/dest/block/index.d.ts.map +1 -1
  60. package/dest/block/index.js +0 -2
  61. package/dest/block/l2_block.d.ts +57 -57
  62. package/dest/block/l2_block.d.ts.map +1 -1
  63. package/dest/block/l2_block.js +64 -108
  64. package/dest/block/l2_block_source.d.ts +298 -68
  65. package/dest/block/l2_block_source.d.ts.map +1 -1
  66. package/dest/block/l2_block_source.js +25 -6
  67. package/dest/block/l2_block_stream/index.d.ts +2 -1
  68. package/dest/block/l2_block_stream/index.d.ts.map +1 -1
  69. package/dest/block/l2_block_stream/index.js +1 -0
  70. package/dest/block/l2_block_stream/interfaces.d.ts +15 -5
  71. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  72. package/dest/block/l2_block_stream/l2_block_stream.d.ts +8 -3
  73. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  74. package/dest/block/l2_block_stream/l2_block_stream.js +106 -31
  75. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +24 -16
  76. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
  77. package/dest/block/l2_block_stream/l2_tips_memory_store.js +55 -61
  78. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
  79. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
  80. package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
  81. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  82. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  83. package/dest/block/test/l2_tips_store_test_suite.js +478 -38
  84. package/dest/block/validate_block_result.d.ts +24 -24
  85. package/dest/block/validate_block_result.d.ts.map +1 -1
  86. package/dest/block/validate_block_result.js +18 -17
  87. package/dest/checkpoint/checkpoint.d.ts +30 -20
  88. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  89. package/dest/checkpoint/checkpoint.js +19 -6
  90. package/dest/checkpoint/checkpoint_info.d.ts +32 -3
  91. package/dest/checkpoint/checkpoint_info.d.ts.map +1 -1
  92. package/dest/checkpoint/checkpoint_info.js +34 -1
  93. package/dest/checkpoint/index.d.ts +2 -1
  94. package/dest/checkpoint/index.d.ts.map +1 -1
  95. package/dest/checkpoint/index.js +1 -0
  96. package/dest/checkpoint/published_checkpoint.d.ts +17 -15
  97. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  98. package/dest/checkpoint/published_checkpoint.js +4 -3
  99. package/dest/config/index.d.ts +2 -1
  100. package/dest/config/index.d.ts.map +1 -1
  101. package/dest/config/index.js +1 -0
  102. package/dest/config/node-rpc-config.js +1 -1
  103. package/dest/config/sequencer-config.d.ts +10 -0
  104. package/dest/config/sequencer-config.d.ts.map +1 -0
  105. package/dest/config/sequencer-config.js +12 -0
  106. package/dest/contract/complete_address.d.ts +4 -1
  107. package/dest/contract/complete_address.d.ts.map +1 -1
  108. package/dest/contract/contract_address.js +1 -1
  109. package/dest/contract/contract_class_id.d.ts +1 -1
  110. package/dest/contract/contract_class_id.js +1 -1
  111. package/dest/contract/contract_deployment_data.d.ts +5 -5
  112. package/dest/contract/index.d.ts +1 -3
  113. package/dest/contract/index.d.ts.map +1 -1
  114. package/dest/contract/index.js +0 -2
  115. package/dest/contract/interfaces/contract_instance.d.ts +16 -16
  116. package/dest/contract/private_function.d.ts +1 -1
  117. package/dest/contract/private_function.d.ts.map +1 -1
  118. package/dest/contract/private_function.js +2 -3
  119. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  120. package/dest/contract/private_function_membership_proof.js +1 -1
  121. package/dest/database-version/database_version.d.ts +58 -0
  122. package/dest/database-version/database_version.d.ts.map +1 -0
  123. package/dest/database-version/database_version.js +69 -0
  124. package/dest/database-version/version_manager.d.ts +3 -49
  125. package/dest/database-version/version_manager.d.ts.map +1 -1
  126. package/dest/database-version/version_manager.js +1 -64
  127. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  128. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  129. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  130. package/dest/deserialization/index.d.ts +11 -0
  131. package/dest/deserialization/index.d.ts.map +1 -0
  132. package/dest/deserialization/index.js +10 -0
  133. package/dest/epoch-helpers/index.d.ts +7 -1
  134. package/dest/epoch-helpers/index.d.ts.map +1 -1
  135. package/dest/epoch-helpers/index.js +9 -3
  136. package/dest/errors/proving_error.d.ts +2 -2
  137. package/dest/errors/proving_error.d.ts.map +1 -1
  138. package/dest/gas/gas.js +3 -1
  139. package/dest/gas/gas_fees.js +3 -1
  140. package/dest/hash/hash.js +2 -2
  141. package/dest/hash/map_slot.d.ts +1 -1
  142. package/dest/hash/map_slot.d.ts.map +1 -1
  143. package/dest/hash/map_slot.js +4 -3
  144. package/dest/interfaces/api_limit.d.ts +3 -1
  145. package/dest/interfaces/api_limit.d.ts.map +1 -1
  146. package/dest/interfaces/api_limit.js +2 -0
  147. package/dest/interfaces/archiver.d.ts +6 -6
  148. package/dest/interfaces/archiver.d.ts.map +1 -1
  149. package/dest/interfaces/archiver.js +22 -17
  150. package/dest/interfaces/aztec-node-admin.d.ts +82 -31
  151. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  152. package/dest/interfaces/aztec-node-admin.js +5 -3
  153. package/dest/interfaces/aztec-node.d.ts +74 -76
  154. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  155. package/dest/interfaces/aztec-node.js +15 -16
  156. package/dest/interfaces/block-builder.d.ts +22 -14
  157. package/dest/interfaces/block-builder.d.ts.map +1 -1
  158. package/dest/interfaces/block-builder.js +7 -0
  159. package/dest/interfaces/configs.d.ts +12 -7
  160. package/dest/interfaces/configs.d.ts.map +1 -1
  161. package/dest/interfaces/configs.js +2 -1
  162. package/dest/interfaces/get_logs_response.d.ts +16 -9
  163. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  164. package/dest/interfaces/l2_logs_source.d.ts +14 -5
  165. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  166. package/dest/interfaces/p2p.d.ts +7 -9
  167. package/dest/interfaces/p2p.d.ts.map +1 -1
  168. package/dest/interfaces/p2p.js +3 -4
  169. package/dest/interfaces/prover-broker.d.ts +16 -1
  170. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  171. package/dest/interfaces/prover-broker.js +4 -1
  172. package/dest/interfaces/prover-client.d.ts +15 -1
  173. package/dest/interfaces/prover-client.d.ts.map +1 -1
  174. package/dest/interfaces/prover-client.js +12 -1
  175. package/dest/interfaces/proving-job.d.ts +52 -52
  176. package/dest/interfaces/proving-job.d.ts.map +1 -1
  177. package/dest/interfaces/proving-job.js +1 -7
  178. package/dest/interfaces/server_circuit_prover.d.ts +4 -3
  179. package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
  180. package/dest/interfaces/slasher.d.ts +9 -1
  181. package/dest/interfaces/slasher.d.ts.map +1 -1
  182. package/dest/interfaces/slasher.js +2 -0
  183. package/dest/interfaces/tx_provider.d.ts +3 -3
  184. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  185. package/dest/interfaces/validator.d.ts +155 -19
  186. package/dest/interfaces/validator.d.ts.map +1 -1
  187. package/dest/interfaces/validator.js +8 -3
  188. package/dest/kernel/claimed_length_array.js +3 -1
  189. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +6 -5
  190. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  191. package/dest/kernel/hints/build_note_hash_read_request_hints.js +19 -10
  192. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
  193. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  194. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
  195. package/dest/kernel/hints/key_validation_hint.d.ts +2 -1
  196. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  197. package/dest/kernel/hints/key_validation_request.d.ts +2 -1
  198. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  199. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +6 -1
  200. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +1 -1
  201. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  202. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  203. package/dest/kernel/hints/read_request.d.ts +7 -1
  204. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  205. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  206. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  207. package/dest/kernel/hints/transient_data_squashing_hint.js +3 -1
  208. package/dest/kernel/log_hash.js +3 -1
  209. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  210. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  211. package/dest/kernel/private_call_data.d.ts +25 -1
  212. package/dest/kernel/private_call_data.d.ts.map +1 -1
  213. package/dest/kernel/private_call_request.d.ts +16 -1
  214. package/dest/kernel/private_call_request.d.ts.map +1 -1
  215. package/dest/kernel/private_circuit_public_inputs.d.ts +74 -1
  216. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  217. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +31 -1
  218. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  219. package/dest/kernel/private_kernel_data.d.ts +7 -1
  220. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  221. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
  222. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  223. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  224. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  225. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  226. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  227. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +10 -1
  228. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  229. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +23 -1
  230. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  231. package/dest/kernel/private_log_data.js +5 -2
  232. package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
  233. package/dest/kernel/private_to_avm_accumulated_data.js +5 -2
  234. package/dest/kernel/private_to_public_accumulated_data.js +3 -1
  235. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
  236. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  237. package/dest/kernel/private_to_rollup_accumulated_data.js +3 -1
  238. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +16 -1
  239. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  240. package/dest/kernel/private_validation_requests.d.ts +10 -1
  241. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  242. package/dest/kernel/private_validation_requests.js +3 -1
  243. package/dest/kernel/public_call_request.d.ts +22 -1
  244. package/dest/kernel/public_call_request.d.ts.map +1 -1
  245. package/dest/kernel/public_call_request.js +5 -2
  246. package/dest/kernel/utils/optional_number.d.ts +7 -1
  247. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  248. package/dest/keys/derivation.d.ts +3 -3
  249. package/dest/keys/derivation.js +8 -8
  250. package/dest/keys/key_types.d.ts +1 -1
  251. package/dest/keys/public_keys.d.ts +5 -1
  252. package/dest/keys/public_keys.d.ts.map +1 -1
  253. package/dest/keys/utils.d.ts +1 -1
  254. package/dest/keys/utils.d.ts.map +1 -1
  255. package/dest/keys/utils.js +7 -3
  256. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  257. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  258. package/dest/l1-contracts/slash_factory.js +1 -0
  259. package/dest/logs/contract_class_log.js +3 -1
  260. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  261. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  262. package/dest/logs/extended_public_log.d.ts +17 -9
  263. package/dest/logs/extended_public_log.d.ts.map +1 -1
  264. package/dest/logs/log_id.d.ts +21 -14
  265. package/dest/logs/log_id.d.ts.map +1 -1
  266. package/dest/logs/log_id.js +20 -17
  267. package/dest/logs/private_log.js +3 -1
  268. package/dest/logs/public_log.js +3 -1
  269. package/dest/logs/siloed_tag.d.ts +1 -1
  270. package/dest/logs/siloed_tag.d.ts.map +1 -1
  271. package/dest/logs/siloed_tag.js +4 -3
  272. package/dest/messaging/in_hash.d.ts +4 -2
  273. package/dest/messaging/in_hash.d.ts.map +1 -1
  274. package/dest/messaging/in_hash.js +3 -1
  275. package/dest/messaging/inbox_leaf.d.ts +3 -1
  276. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  277. package/dest/messaging/l1_actor.d.ts +7 -1
  278. package/dest/messaging/l1_actor.d.ts.map +1 -1
  279. package/dest/messaging/l1_to_l2_message.d.ts +6 -1
  280. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  281. package/dest/messaging/l2_actor.d.ts +7 -1
  282. package/dest/messaging/l2_actor.d.ts.map +1 -1
  283. package/dest/messaging/l2_to_l1_membership.d.ts +88 -6
  284. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  285. package/dest/messaging/l2_to_l1_membership.js +160 -42
  286. package/dest/messaging/out_hash.d.ts +41 -3
  287. package/dest/messaging/out_hash.d.ts.map +1 -1
  288. package/dest/messaging/out_hash.js +54 -19
  289. package/dest/note/note_dao.d.ts +36 -5
  290. package/dest/note/note_dao.d.ts.map +1 -1
  291. package/dest/note/note_dao.js +15 -12
  292. package/dest/p2p/attestation_utils.d.ts +3 -3
  293. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  294. package/dest/p2p/attestation_utils.js +1 -1
  295. package/dest/p2p/block_proposal.d.ts +102 -23
  296. package/dest/p2p/block_proposal.d.ts.map +1 -1
  297. package/dest/p2p/block_proposal.js +140 -39
  298. package/dest/p2p/checkpoint_attestation.d.ts +81 -0
  299. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
  300. package/dest/p2p/{block_attestation.js → checkpoint_attestation.js} +22 -19
  301. package/dest/p2p/checkpoint_proposal.d.ts +174 -0
  302. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
  303. package/dest/p2p/checkpoint_proposal.js +238 -0
  304. package/dest/p2p/consensus_payload.d.ts +9 -9
  305. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  306. package/dest/p2p/consensus_payload.js +3 -5
  307. package/dest/p2p/constants.d.ts +5 -0
  308. package/dest/p2p/constants.d.ts.map +1 -0
  309. package/dest/p2p/constants.js +3 -0
  310. package/dest/p2p/gossipable.d.ts +4 -3
  311. package/dest/p2p/gossipable.d.ts.map +1 -1
  312. package/dest/p2p/gossipable.js +16 -5
  313. package/dest/p2p/index.d.ts +5 -2
  314. package/dest/p2p/index.d.ts.map +1 -1
  315. package/dest/p2p/index.js +4 -1
  316. package/dest/p2p/message_validator.d.ts +18 -3
  317. package/dest/p2p/message_validator.d.ts.map +1 -1
  318. package/dest/p2p/message_validator.js +2 -1
  319. package/dest/p2p/signature_utils.d.ts +5 -3
  320. package/dest/p2p/signature_utils.d.ts.map +1 -1
  321. package/dest/p2p/signature_utils.js +3 -1
  322. package/dest/p2p/signed_txs.d.ts +42 -0
  323. package/dest/p2p/signed_txs.d.ts.map +1 -0
  324. package/dest/p2p/signed_txs.js +75 -0
  325. package/dest/p2p/topic_type.d.ts +3 -2
  326. package/dest/p2p/topic_type.d.ts.map +1 -1
  327. package/dest/p2p/topic_type.js +10 -3
  328. package/dest/parity/parity_base_private_inputs.d.ts +3 -1
  329. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  330. package/dest/parity/parity_public_inputs.d.ts +4 -1
  331. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  332. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  333. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  334. package/dest/proofs/chonk_proof.d.ts +1 -1
  335. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  336. package/dest/proofs/chonk_proof.js +9 -4
  337. package/dest/proofs/proof.d.ts +4 -1
  338. package/dest/proofs/proof.d.ts.map +1 -1
  339. package/dest/proofs/recursive_proof.d.ts +10 -1
  340. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  341. package/dest/rollup/base_rollup_hints.d.ts +34 -1
  342. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  343. package/dest/rollup/block_constant_data.d.ts +12 -1
  344. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  345. package/dest/rollup/block_headers_hash.js +1 -1
  346. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  347. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  348. package/dest/rollup/block_rollup_public_inputs.d.ts +47 -11
  349. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  350. package/dest/rollup/block_rollup_public_inputs.js +8 -12
  351. package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
  352. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  353. package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
  354. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  355. package/dest/rollup/checkpoint_constant_data.js +3 -1
  356. package/dest/rollup/checkpoint_header.d.ts +42 -12
  357. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  358. package/dest/rollup/checkpoint_header.js +49 -19
  359. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  360. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  361. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +46 -6
  362. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  363. package/dest/rollup/checkpoint_rollup_public_inputs.js +11 -3
  364. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
  365. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  366. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
  367. package/dest/rollup/epoch_constant_data.d.ts +16 -1
  368. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  369. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  370. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  371. package/dest/rollup/root_rollup_public_inputs.d.ts +21 -6
  372. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  373. package/dest/rollup/root_rollup_public_inputs.js +10 -4
  374. package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
  375. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  376. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  377. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  378. package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
  379. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  380. package/dest/schemas/schemas.d.ts +1 -1
  381. package/dest/slashing/empire.d.ts +1 -1
  382. package/dest/slashing/empire.d.ts.map +1 -1
  383. package/dest/slashing/empire.js +2 -0
  384. package/dest/slashing/helpers.d.ts +2 -2
  385. package/dest/slashing/helpers.d.ts.map +1 -1
  386. package/dest/slashing/helpers.js +6 -0
  387. package/dest/slashing/tally.d.ts +2 -1
  388. package/dest/slashing/tally.d.ts.map +1 -1
  389. package/dest/slashing/tally.js +6 -2
  390. package/dest/slashing/types.d.ts +7 -3
  391. package/dest/slashing/types.d.ts.map +1 -1
  392. package/dest/slashing/types.js +13 -1
  393. package/dest/stats/stats.d.ts +1 -3
  394. package/dest/stats/stats.d.ts.map +1 -1
  395. package/dest/tests/factories.d.ts +16 -10
  396. package/dest/tests/factories.d.ts.map +1 -1
  397. package/dest/tests/factories.js +61 -26
  398. package/dest/tests/jest.js +1 -1
  399. package/dest/tests/mocks.d.ts +74 -19
  400. package/dest/tests/mocks.d.ts.map +1 -1
  401. package/dest/tests/mocks.js +123 -57
  402. package/dest/timetable/index.d.ts +37 -0
  403. package/dest/timetable/index.d.ts.map +1 -0
  404. package/dest/timetable/index.js +39 -0
  405. package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
  406. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  407. package/dest/trees/append_only_tree_snapshot.js +3 -1
  408. package/dest/trees/nullifier_leaf.d.ts +13 -1
  409. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  410. package/dest/trees/nullifier_membership_witness.d.ts +10 -1
  411. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  412. package/dest/trees/public_data_leaf.d.ts +17 -1
  413. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  414. package/dest/trees/public_data_leaf.js +7 -6
  415. package/dest/trees/public_data_witness.d.ts +11 -1
  416. package/dest/trees/public_data_witness.d.ts.map +1 -1
  417. package/dest/tx/block_header.d.ts +14 -2
  418. package/dest/tx/block_header.d.ts.map +1 -1
  419. package/dest/tx/block_header.js +8 -2
  420. package/dest/tx/call_context.d.ts +13 -1
  421. package/dest/tx/call_context.d.ts.map +1 -1
  422. package/dest/tx/call_context.js +3 -1
  423. package/dest/tx/capsule.d.ts +4 -1
  424. package/dest/tx/capsule.d.ts.map +1 -1
  425. package/dest/tx/execution_payload.d.ts +9 -1
  426. package/dest/tx/execution_payload.d.ts.map +1 -1
  427. package/dest/tx/function_data.d.ts +4 -2
  428. package/dest/tx/function_data.d.ts.map +1 -1
  429. package/dest/tx/global_variable_builder.d.ts +2 -2
  430. package/dest/tx/global_variable_builder.d.ts.map +1 -1
  431. package/dest/tx/global_variables.d.ts +9 -1
  432. package/dest/tx/global_variables.d.ts.map +1 -1
  433. package/dest/tx/global_variables.js +3 -1
  434. package/dest/tx/hashed_values.d.ts +7 -1
  435. package/dest/tx/hashed_values.d.ts.map +1 -1
  436. package/dest/tx/in_tx.d.ts +4 -4
  437. package/dest/tx/index.d.ts +1 -2
  438. package/dest/tx/index.d.ts.map +1 -1
  439. package/dest/tx/index.js +0 -1
  440. package/dest/tx/indexed_tx_effect.d.ts +5 -5
  441. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  442. package/dest/tx/indexed_tx_effect.js +3 -2
  443. package/dest/tx/partial_state_reference.d.ts +4 -1
  444. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  445. package/dest/tx/private_execution_result.d.ts +23 -6
  446. package/dest/tx/private_execution_result.d.ts.map +1 -1
  447. package/dest/tx/private_execution_result.js +4 -21
  448. package/dest/tx/private_tx_constant_data.d.ts +16 -1
  449. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  450. package/dest/tx/profiling.d.ts +149 -26
  451. package/dest/tx/profiling.d.ts.map +1 -1
  452. package/dest/tx/profiling.js +44 -7
  453. package/dest/tx/protocol_contracts.d.ts +1 -1
  454. package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
  455. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  456. package/dest/tx/public_call_request_with_calldata.js +3 -1
  457. package/dest/tx/state_reference.d.ts +3 -1
  458. package/dest/tx/state_reference.d.ts.map +1 -1
  459. package/dest/tx/state_reference.js +3 -1
  460. package/dest/tx/tree_snapshots.js +3 -1
  461. package/dest/tx/tx.d.ts +24 -1
  462. package/dest/tx/tx.d.ts.map +1 -1
  463. package/dest/tx/tx.js +9 -4
  464. package/dest/tx/tx_context.d.ts +2 -1
  465. package/dest/tx/tx_context.d.ts.map +1 -1
  466. package/dest/tx/tx_effect.d.ts +32 -6
  467. package/dest/tx/tx_effect.d.ts.map +1 -1
  468. package/dest/tx/tx_effect.js +3 -8
  469. package/dest/tx/tx_execution_request.d.ts +30 -1
  470. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  471. package/dest/tx/tx_execution_request.js +6 -2
  472. package/dest/tx/tx_hash.d.ts +2 -1
  473. package/dest/tx/tx_hash.d.ts.map +1 -1
  474. package/dest/tx/tx_receipt.d.ts +47 -13
  475. package/dest/tx/tx_receipt.d.ts.map +1 -1
  476. package/dest/tx/tx_receipt.js +46 -15
  477. package/dest/tx/tx_request.d.ts +6 -1
  478. package/dest/tx/tx_request.d.ts.map +1 -1
  479. package/dest/tx/validator/empty_validator.d.ts +2 -2
  480. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  481. package/dest/tx/validator/error_texts.d.ts +2 -1
  482. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  483. package/dest/tx/validator/error_texts.js +2 -0
  484. package/dest/tx/validator/tx_validator.d.ts +2 -2
  485. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  486. package/dest/types/shared.d.ts +4 -1
  487. package/dest/types/shared.d.ts.map +1 -1
  488. package/dest/validators/schemas.d.ts +8 -8
  489. package/dest/vks/verification_key.d.ts +22 -1
  490. package/dest/vks/verification_key.d.ts.map +1 -1
  491. package/dest/vks/vk_data.d.ts +7 -1
  492. package/dest/vks/vk_data.d.ts.map +1 -1
  493. package/dest/zkpassport/index.d.ts +3 -4
  494. package/dest/zkpassport/index.d.ts.map +1 -1
  495. package/dest/zkpassport/index.js +9 -9
  496. package/package.json +27 -13
  497. package/src/abi/contract_artifact.ts +10 -10
  498. package/src/abi/function_call.ts +25 -3
  499. package/src/abi/utils.ts +17 -0
  500. package/src/block/attestation_info.ts +9 -6
  501. package/src/block/block_hash.ts +26 -25
  502. package/src/block/block_parameter.ts +4 -2
  503. package/src/block/body.ts +2 -1
  504. package/src/block/checkpointed_l2_block.ts +8 -58
  505. package/src/block/in_block.ts +6 -6
  506. package/src/block/index.ts +0 -2
  507. package/src/block/l2_block.ts +102 -149
  508. package/src/block/l2_block_source.ts +123 -44
  509. package/src/block/l2_block_stream/index.ts +1 -0
  510. package/src/block/l2_block_stream/interfaces.ts +15 -4
  511. package/src/block/l2_block_stream/l2_block_stream.ts +130 -39
  512. package/src/block/l2_block_stream/l2_tips_memory_store.ts +62 -56
  513. package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
  514. package/src/block/test/l2_tips_store_test_suite.ts +480 -36
  515. package/src/block/validate_block_result.ts +40 -35
  516. package/src/checkpoint/checkpoint.ts +34 -11
  517. package/src/checkpoint/checkpoint_info.ts +45 -2
  518. package/src/checkpoint/index.ts +1 -0
  519. package/src/checkpoint/published_checkpoint.ts +4 -3
  520. package/src/config/index.ts +1 -0
  521. package/src/config/node-rpc-config.ts +1 -1
  522. package/src/config/sequencer-config.ts +19 -0
  523. package/src/contract/contract_address.ts +1 -1
  524. package/src/contract/contract_class_id.ts +1 -1
  525. package/src/contract/index.ts +0 -2
  526. package/src/contract/private_function.ts +2 -3
  527. package/src/contract/private_function_membership_proof.ts +1 -1
  528. package/src/database-version/database_version.ts +87 -0
  529. package/src/database-version/version_manager.ts +1 -77
  530. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  531. package/src/deserialization/index.ts +21 -0
  532. package/src/epoch-helpers/index.ts +13 -1
  533. package/src/hash/hash.ts +2 -2
  534. package/src/hash/map_slot.ts +3 -2
  535. package/src/interfaces/api_limit.ts +2 -0
  536. package/src/interfaces/archiver.ts +26 -24
  537. package/src/interfaces/aztec-node-admin.ts +8 -4
  538. package/src/interfaces/aztec-node.ts +109 -128
  539. package/src/interfaces/block-builder.ts +40 -23
  540. package/src/interfaces/configs.ts +3 -0
  541. package/src/interfaces/l2_logs_source.ts +17 -4
  542. package/src/interfaces/p2p.ts +8 -12
  543. package/src/interfaces/prover-broker.ts +22 -0
  544. package/src/interfaces/prover-client.ts +22 -0
  545. package/src/interfaces/proving-job.ts +2 -11
  546. package/src/interfaces/server_circuit_prover.ts +3 -2
  547. package/src/interfaces/slasher.ts +4 -0
  548. package/src/interfaces/tx_provider.ts +2 -2
  549. package/src/interfaces/validator.ts +72 -15
  550. package/src/kernel/hints/build_note_hash_read_request_hints.ts +20 -12
  551. package/src/kernel/hints/build_nullifier_read_request_hints.ts +17 -14
  552. package/src/keys/derivation.ts +8 -8
  553. package/src/keys/key_types.ts +1 -1
  554. package/src/keys/utils.ts +7 -3
  555. package/src/l1-contracts/slash_factory.ts +1 -0
  556. package/src/logs/log_id.ts +22 -18
  557. package/src/logs/siloed_tag.ts +3 -2
  558. package/src/messaging/in_hash.ts +3 -1
  559. package/src/messaging/l2_to_l1_membership.ts +178 -52
  560. package/src/messaging/out_hash.ts +62 -21
  561. package/src/note/note_dao.ts +18 -13
  562. package/src/p2p/attestation_utils.ts +3 -3
  563. package/src/p2p/block_proposal.ts +213 -46
  564. package/src/p2p/{block_attestation.ts → checkpoint_attestation.ts} +31 -25
  565. package/src/p2p/checkpoint_proposal.ts +365 -0
  566. package/src/p2p/consensus_payload.ts +5 -7
  567. package/src/p2p/constants.ts +6 -0
  568. package/src/p2p/gossipable.ts +14 -4
  569. package/src/p2p/index.ts +4 -1
  570. package/src/p2p/message_validator.ts +14 -2
  571. package/src/p2p/signature_utils.ts +3 -1
  572. package/src/p2p/signed_txs.ts +88 -0
  573. package/src/p2p/topic_type.ts +4 -3
  574. package/src/proofs/chonk_proof.ts +9 -5
  575. package/src/rollup/block_headers_hash.ts +1 -1
  576. package/src/rollup/block_rollup_public_inputs.ts +5 -11
  577. package/src/rollup/checkpoint_header.ts +63 -20
  578. package/src/rollup/checkpoint_rollup_public_inputs.ts +17 -5
  579. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
  580. package/src/rollup/root_rollup_public_inputs.ts +16 -7
  581. package/src/slashing/empire.ts +3 -1
  582. package/src/slashing/helpers.ts +8 -0
  583. package/src/slashing/tally.ts +8 -2
  584. package/src/slashing/types.ts +14 -0
  585. package/src/stats/stats.ts +0 -2
  586. package/src/tests/factories.ts +58 -42
  587. package/src/tests/jest.ts +1 -1
  588. package/src/tests/mocks.ts +213 -91
  589. package/src/timetable/index.ts +66 -0
  590. package/src/trees/public_data_leaf.ts +11 -5
  591. package/src/tx/block_header.ts +11 -3
  592. package/src/tx/global_variable_builder.ts +1 -1
  593. package/src/tx/index.ts +0 -1
  594. package/src/tx/indexed_tx_effect.ts +3 -2
  595. package/src/tx/private_execution_result.ts +1 -16
  596. package/src/tx/profiling.ts +46 -4
  597. package/src/tx/tx.ts +10 -9
  598. package/src/tx/tx_effect.ts +0 -9
  599. package/src/tx/tx_execution_request.ts +2 -0
  600. package/src/tx/tx_receipt.ts +75 -18
  601. package/src/tx/validator/empty_validator.ts +1 -1
  602. package/src/tx/validator/error_texts.ts +3 -0
  603. package/src/tx/validator/tx_validator.ts +1 -1
  604. package/src/zkpassport/index.ts +11 -12
  605. package/dest/block/l2_block_code_to_purge.d.ts +0 -12
  606. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  607. package/dest/block/l2_block_code_to_purge.js +0 -61
  608. package/dest/block/l2_block_header.d.ts +0 -98
  609. package/dest/block/l2_block_header.d.ts.map +0 -1
  610. package/dest/block/l2_block_header.js +0 -153
  611. package/dest/block/l2_block_new.d.ts +0 -135
  612. package/dest/block/l2_block_new.d.ts.map +0 -1
  613. package/dest/block/l2_block_new.js +0 -152
  614. package/dest/contract/contract_class_metadata.d.ts +0 -8
  615. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  616. package/dest/contract/contract_class_metadata.js +0 -1
  617. package/dest/contract/contract_metadata.d.ts +0 -7
  618. package/dest/contract/contract_metadata.d.ts.map +0 -1
  619. package/dest/contract/contract_metadata.js +0 -1
  620. package/dest/database-version/index.d.ts +0 -2
  621. package/dest/database-version/index.d.ts.map +0 -1
  622. package/dest/database-version/index.js +0 -1
  623. package/dest/p2p/block_attestation.d.ts +0 -80
  624. package/dest/p2p/block_attestation.d.ts.map +0 -1
  625. package/dest/tx/content_commitment.d.ts +0 -49
  626. package/dest/tx/content_commitment.d.ts.map +0 -1
  627. package/dest/tx/content_commitment.js +0 -90
  628. package/src/block/l2_block_code_to_purge.ts +0 -88
  629. package/src/block/l2_block_header.ts +0 -246
  630. package/src/block/l2_block_new.ts +0 -207
  631. package/src/contract/contract_class_metadata.ts +0 -8
  632. package/src/contract/contract_metadata.ts +0 -7
  633. package/src/database-version/index.ts +0 -1
  634. package/src/tx/content_commitment.ts +0 -113
@@ -5,57 +5,62 @@ import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
5
5
 
6
6
  import { z } from 'zod';
7
7
 
8
- import { BlockInfoSchema, type L2BlockInfo, deserializeBlockInfo, serializeBlockInfo } from './l2_block_info.js';
8
+ import {
9
+ type CheckpointInfo,
10
+ CheckpointInfoSchema,
11
+ deserializeCheckpointInfo,
12
+ serializeCheckpointInfo,
13
+ } from '../checkpoint/checkpoint_info.js';
14
+ import { MAX_COMMITTEE_SIZE } from '../deserialization/index.js';
9
15
  import { CommitteeAttestation } from './proposal/committee_attestation.js';
10
16
 
11
- /** Subtype for invalid block validation results */
12
- export type ValidateBlockNegativeResult =
17
+ /** Subtype for invalid checkpoint validation results */
18
+ export type ValidateCheckpointNegativeResult =
13
19
  | {
14
20
  valid: false;
15
- /** Identifiers from the invalid block */
16
- block: L2BlockInfo;
17
- /** Committee members at the epoch this block was proposed */
21
+ /** Identifiers from the invalid checkpoint */
22
+ checkpoint: CheckpointInfo;
23
+ /** Committee members at the epoch this checkpoint was proposed */
18
24
  committee: EthAddress[];
19
- /** Epoch in which this block was proposed */
25
+ /** Epoch in which this checkpoint was proposed */
20
26
  epoch: EpochNumber;
21
27
  /** Proposer selection seed for the epoch */
22
28
  seed: bigint;
23
- /** List of committee members who signed this block proposal */
29
+ /** List of committee members who signed this checkpoint proposal */
24
30
  attestors: EthAddress[];
25
- /** Committee attestations for this block as they were posted to L1 */
31
+ /** Committee attestations for this checkpoint as they were posted to L1 */
26
32
  attestations: CommitteeAttestation[];
27
- /** Reason for the block being invalid: not enough attestations were posted */
33
+ /** Reason for the checkpoint being invalid: not enough attestations were posted */
28
34
  reason: 'insufficient-attestations';
29
35
  }
30
36
  | {
31
37
  valid: false;
32
- /** Identifiers from the invalid block */
33
- block: L2BlockInfo;
34
- /** Committee members at the epoch this block was proposed */
38
+ /** Identifiers from the invalid checkpoint */
39
+ checkpoint: CheckpointInfo;
40
+ /** Committee members at the epoch this checkpoint was proposed */
35
41
  committee: EthAddress[];
36
- /** Epoch in which this block was proposed */
42
+ /** Epoch in which this checkpoint was proposed */
37
43
  epoch: EpochNumber;
38
44
  /** Proposer selection seed for the epoch */
39
45
  seed: bigint;
40
- /** List of committee members who signed this block proposal */
46
+ /** List of committee members who signed this checkpoint proposal */
41
47
  attestors: EthAddress[];
42
- /** Committee attestations for this block as they were posted to L1 */
48
+ /** Committee attestations for this checkpoint as they were posted to L1 */
43
49
  attestations: CommitteeAttestation[];
44
- /** Reason for the block being invalid: an invalid attestation was posted */
50
+ /** Reason for the checkpoint being invalid: an invalid attestation was posted */
45
51
  reason: 'invalid-attestation';
46
52
  /** Index in the attestations array of the invalid attestation posted */
47
53
  invalidIndex: number;
48
54
  };
49
55
 
50
- // TODO: Rename to ValidateAttestationsResult
51
- /** Result type for validating a block attestations */
52
- export type ValidateBlockResult = { valid: true } | ValidateBlockNegativeResult;
56
+ /** Result type for validating checkpoint attestations */
57
+ export type ValidateCheckpointResult = { valid: true } | ValidateCheckpointNegativeResult;
53
58
 
54
- export const ValidateBlockResultSchema: ZodFor<ValidateBlockResult> = z.union([
59
+ export const ValidateCheckpointResultSchema: ZodFor<ValidateCheckpointResult> = z.union([
55
60
  z.object({ valid: z.literal(true) }),
56
61
  z.object({
57
62
  valid: z.literal(false),
58
- block: BlockInfoSchema,
63
+ checkpoint: CheckpointInfoSchema,
59
64
  committee: z.array(schemas.EthAddress),
60
65
  epoch: EpochNumberSchema,
61
66
  seed: schemas.BigInt,
@@ -65,7 +70,7 @@ export const ValidateBlockResultSchema: ZodFor<ValidateBlockResult> = z.union([
65
70
  }),
66
71
  z.object({
67
72
  valid: z.literal(false),
68
- block: BlockInfoSchema,
73
+ checkpoint: CheckpointInfoSchema,
69
74
  committee: z.array(schemas.EthAddress),
70
75
  epoch: EpochNumberSchema,
71
76
  seed: schemas.BigInt,
@@ -76,17 +81,17 @@ export const ValidateBlockResultSchema: ZodFor<ValidateBlockResult> = z.union([
76
81
  }),
77
82
  ]);
78
83
 
79
- export function serializeValidateBlockResult(result: ValidateBlockResult): Buffer {
84
+ export function serializeValidateCheckpointResult(result: ValidateCheckpointResult): Buffer {
80
85
  if (result.valid) {
81
86
  return serializeToBuffer(true);
82
87
  }
83
88
 
84
- const l2Block = serializeBlockInfo(result.block);
89
+ const checkpointBuffer = serializeCheckpointInfo(result.checkpoint);
85
90
  return serializeToBuffer(
86
91
  result.valid,
87
92
  result.reason,
88
- l2Block.length,
89
- l2Block,
93
+ checkpointBuffer.length,
94
+ checkpointBuffer,
90
95
  result.committee.length,
91
96
  result.committee,
92
97
  result.epoch,
@@ -99,24 +104,24 @@ export function serializeValidateBlockResult(result: ValidateBlockResult): Buffe
99
104
  );
100
105
  }
101
106
 
102
- export function deserializeValidateBlockResult(bufferOrReader: Buffer | BufferReader): ValidateBlockResult {
107
+ export function deserializeValidateCheckpointResult(bufferOrReader: Buffer | BufferReader): ValidateCheckpointResult {
103
108
  const reader = BufferReader.asReader(bufferOrReader);
104
109
  const valid = reader.readBoolean();
105
110
  if (valid) {
106
111
  return { valid };
107
112
  }
108
- const reason = reader.readString() as 'insufficient-attestations' | 'invalid-attestation';
109
- const block = deserializeBlockInfo(reader.readBuffer());
110
- const committee = reader.readVector(EthAddress);
113
+ const reason = reader.readString(64) as 'insufficient-attestations' | 'invalid-attestation';
114
+ const checkpoint = deserializeCheckpointInfo(reader.readBuffer());
115
+ const committee = reader.readVector(EthAddress, MAX_COMMITTEE_SIZE);
111
116
  const epoch = EpochNumber(reader.readNumber());
112
117
  const seed = reader.readBigInt();
113
- const attestors = reader.readVector(EthAddress);
114
- const attestations = reader.readVector(CommitteeAttestation);
118
+ const attestors = reader.readVector(EthAddress, MAX_COMMITTEE_SIZE);
119
+ const attestations = reader.readVector(CommitteeAttestation, MAX_COMMITTEE_SIZE);
115
120
  const invalidIndex = reader.readNumber();
116
121
  if (reason === 'insufficient-attestations') {
117
- return { valid, reason, block, committee, epoch, seed, attestors, attestations: attestations };
122
+ return { valid, reason, checkpoint, committee, epoch, seed, attestors, attestations };
118
123
  } else if (reason === 'invalid-attestation') {
119
- return { valid, reason, block, committee, epoch, seed, attestors, invalidIndex, attestations: attestations };
124
+ return { valid, reason, checkpoint, committee, epoch, seed, attestors, invalidIndex, attestations };
120
125
  } else {
121
126
  const _: never = reason;
122
127
  throw new Error(`Unknown reason: ${reason}`);
@@ -1,5 +1,11 @@
1
1
  import { encodeCheckpointBlobDataFromBlocks } from '@aztec/blob-lib/encoding';
2
- import { BlockNumber, CheckpointNumber, CheckpointNumberSchema } from '@aztec/foundation/branded-types';
2
+ import {
3
+ BlockNumber,
4
+ CheckpointNumber,
5
+ CheckpointNumberSchema,
6
+ IndexWithinCheckpoint,
7
+ SlotNumber,
8
+ } from '@aztec/foundation/branded-types';
3
9
  import { sum } from '@aztec/foundation/collection';
4
10
  import { Fr } from '@aztec/foundation/curves/bn254';
5
11
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
@@ -7,11 +13,15 @@ import type { FieldsOf } from '@aztec/foundation/types';
7
13
 
8
14
  import { z } from 'zod';
9
15
 
10
- import { L2BlockNew } from '../block/l2_block_new.js';
16
+ import { L2Block } from '../block/l2_block.js';
17
+ import { MAX_BLOCKS_PER_CHECKPOINT } from '../deserialization/index.js';
18
+ import { computeCheckpointOutHash } from '../messaging/out_hash.js';
11
19
  import { CheckpointHeader } from '../rollup/checkpoint_header.js';
12
20
  import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
13
21
  import type { CheckpointInfo } from './checkpoint_info.js';
14
22
 
23
+ type FieldsOfCheckpoint = Omit<FieldsOf<Checkpoint>, 'slot'>;
24
+
15
25
  export class Checkpoint {
16
26
  constructor(
17
27
  /** Snapshot of archive tree after the checkpoint is added. */
@@ -19,27 +29,31 @@ export class Checkpoint {
19
29
  /** Header of the checkpoint. */
20
30
  public header: CheckpointHeader,
21
31
  /** L2 blocks in the checkpoint. */
22
- public blocks: L2BlockNew[],
32
+ public blocks: L2Block[],
23
33
  /** Number of the checkpoint. */
24
34
  public number: CheckpointNumber,
25
35
  ) {}
26
36
 
37
+ get slot(): SlotNumber {
38
+ return this.header.slotNumber;
39
+ }
40
+
27
41
  static get schema() {
28
42
  return z
29
43
  .object({
30
44
  archive: AppendOnlyTreeSnapshot.schema,
31
45
  header: CheckpointHeader.schema,
32
- blocks: z.array(L2BlockNew.schema),
46
+ blocks: z.array(L2Block.schema),
33
47
  number: CheckpointNumberSchema,
34
48
  })
35
49
  .transform(({ archive, header, blocks, number }) => new Checkpoint(archive, header, blocks, number));
36
50
  }
37
51
 
38
- static from(fields: FieldsOf<Checkpoint>) {
52
+ static from(fields: FieldsOfCheckpoint) {
39
53
  return new Checkpoint(...Checkpoint.getFields(fields));
40
54
  }
41
55
 
42
- static getFields(fields: FieldsOf<Checkpoint>) {
56
+ static getFields(fields: FieldsOfCheckpoint) {
43
57
  return [fields.archive, fields.header, fields.blocks, fields.number] as const;
44
58
  }
45
59
 
@@ -48,7 +62,7 @@ export class Checkpoint {
48
62
  return new Checkpoint(
49
63
  reader.readObject(AppendOnlyTreeSnapshot),
50
64
  reader.readObject(CheckpointHeader),
51
- reader.readVector(L2BlockNew),
65
+ reader.readVector(L2Block, MAX_BLOCKS_PER_CHECKPOINT),
52
66
  CheckpointNumber(reader.readNumber()),
53
67
  );
54
68
  }
@@ -66,6 +80,14 @@ export class Checkpoint {
66
80
  return this.header.hash();
67
81
  }
68
82
 
83
+ // Returns the out hash computed from all l2-to-l1 messages in this checkpoint.
84
+ // Note: This value is different from the out hash in the header, which is the **accumulated** out hash over all
85
+ // checkpoints up to and including this one in the epoch.
86
+ public getCheckpointOutHash(): Fr {
87
+ const msgs = this.blocks.map(block => block.body.txEffects.map(txEffect => txEffect.l2ToL1Msgs));
88
+ return computeCheckpointOutHash(msgs);
89
+ }
90
+
69
91
  public getState() {
70
92
  return this.blocks.at(-1)!.header.state;
71
93
  }
@@ -73,6 +95,7 @@ export class Checkpoint {
73
95
  public toCheckpointInfo(): CheckpointInfo {
74
96
  return {
75
97
  archive: this.archive.root,
98
+ lastArchive: this.header.lastArchiveRoot,
76
99
  slotNumber: this.header.slotNumber,
77
100
  checkpointNumber: this.number,
78
101
  timestamp: this.header.timestamp,
@@ -112,17 +135,17 @@ export class Checkpoint {
112
135
  startBlockNumber?: number;
113
136
  previousArchive?: AppendOnlyTreeSnapshot;
114
137
  } & Partial<Parameters<typeof CheckpointHeader.random>[0]> &
115
- Partial<Parameters<typeof L2BlockNew.random>[1]> = {},
138
+ Partial<Parameters<typeof L2Block.random>[1]> = {},
116
139
  ) {
117
140
  const header = CheckpointHeader.random(options);
118
141
 
119
142
  // Create blocks sequentially to chain archive roots properly.
120
143
  // Each block's header.lastArchive must equal the previous block's archive.
121
- const blocks: L2BlockNew[] = [];
144
+ const blocks: L2Block[] = [];
122
145
  let lastArchive = previousArchive;
123
146
  for (let i = 0; i < numBlocks; i++) {
124
- const block = await L2BlockNew.random(BlockNumber(startBlockNumber + i), {
125
- indexWithinCheckpoint: i,
147
+ const block = await L2Block.random(BlockNumber(startBlockNumber + i), {
148
+ indexWithinCheckpoint: IndexWithinCheckpoint(i),
126
149
  ...options,
127
150
  ...(lastArchive ? { lastArchive } : {}),
128
151
  });
@@ -1,9 +1,52 @@
1
- import type { CheckpointNumber } from '@aztec/foundation/branded-types';
2
- import type { Fr, SlotNumber } from '@aztec/foundation/schemas';
1
+ import {
2
+ CheckpointNumber,
3
+ CheckpointNumberSchema,
4
+ SlotNumber,
5
+ SlotNumberSchema,
6
+ } from '@aztec/foundation/branded-types';
7
+ import { Fr } from '@aztec/foundation/curves/bn254';
8
+ import { schemas } from '@aztec/foundation/schemas';
9
+ import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
10
+
11
+ import { z } from 'zod';
3
12
 
4
13
  export type CheckpointInfo = {
5
14
  archive: Fr;
15
+ lastArchive: Fr;
6
16
  slotNumber: SlotNumber;
7
17
  checkpointNumber: CheckpointNumber;
8
18
  timestamp: bigint;
9
19
  };
20
+
21
+ export function randomCheckpointInfo(checkpointNumber?: CheckpointNumber | number): CheckpointInfo {
22
+ return {
23
+ archive: Fr.random(),
24
+ lastArchive: Fr.random(),
25
+ slotNumber: SlotNumber(Math.floor(Math.random() * 100000) + 1),
26
+ checkpointNumber: CheckpointNumber(checkpointNumber ?? Math.floor(Math.random() * 100000) + 1),
27
+ timestamp: BigInt(Math.floor(Date.now() / 1000)),
28
+ };
29
+ }
30
+
31
+ export const CheckpointInfoSchema = z.object({
32
+ archive: schemas.Fr,
33
+ lastArchive: schemas.Fr,
34
+ slotNumber: SlotNumberSchema,
35
+ checkpointNumber: CheckpointNumberSchema,
36
+ timestamp: schemas.BigInt,
37
+ });
38
+
39
+ export function serializeCheckpointInfo(info: CheckpointInfo): Buffer {
40
+ return serializeToBuffer(info.archive, info.lastArchive, info.slotNumber, info.checkpointNumber, info.timestamp);
41
+ }
42
+
43
+ export function deserializeCheckpointInfo(buffer: Buffer | BufferReader): CheckpointInfo {
44
+ const reader = BufferReader.asReader(buffer);
45
+ return {
46
+ archive: reader.readObject(Fr),
47
+ lastArchive: reader.readObject(Fr),
48
+ slotNumber: SlotNumber(reader.readNumber()),
49
+ checkpointNumber: CheckpointNumber(reader.readNumber()),
50
+ timestamp: reader.readBigInt(),
51
+ };
52
+ }
@@ -1,2 +1,3 @@
1
1
  export * from './checkpoint.js';
2
+ export * from './checkpoint_info.js';
2
3
  export * from './published_checkpoint.js';
@@ -8,6 +8,7 @@ import type { FieldsOf } from '@aztec/foundation/types';
8
8
  import { z } from 'zod';
9
9
 
10
10
  import { CommitteeAttestation } from '../block/proposal/committee_attestation.js';
11
+ import { MAX_BLOCK_HASH_STRING_LENGTH, MAX_COMMITTEE_SIZE } from '../deserialization/index.js';
11
12
  import { Checkpoint } from './checkpoint.js';
12
13
 
13
14
  export class L1PublishedData {
@@ -42,7 +43,7 @@ export class L1PublishedData {
42
43
  static fromBuffer(bufferOrReader: Buffer | BufferReader): L1PublishedData {
43
44
  const reader = BufferReader.asReader(bufferOrReader);
44
45
  const l1BlockNumber = reader.readBigInt();
45
- const l1BlockHash = reader.readString();
46
+ const l1BlockHash = reader.readString(MAX_BLOCK_HASH_STRING_LENGTH);
46
47
  const l1Timestamp = reader.readBigInt();
47
48
  return new L1PublishedData(l1BlockNumber, l1Timestamp, l1BlockHash);
48
49
  }
@@ -82,9 +83,9 @@ export class PublishedCheckpoint {
82
83
  const reader = BufferReader.asReader(bufferOrReader);
83
84
  const checkpoint = reader.readObject(Checkpoint);
84
85
  const l1BlockNumber = reader.readBigInt();
85
- const l1BlockHash = reader.readString();
86
+ const l1BlockHash = reader.readString(MAX_BLOCK_HASH_STRING_LENGTH);
86
87
  const l1Timestamp = reader.readBigInt();
87
- const attestations = reader.readVector(CommitteeAttestation);
88
+ const attestations = reader.readVector(CommitteeAttestation, MAX_COMMITTEE_SIZE);
88
89
  return new PublishedCheckpoint(
89
90
  checkpoint,
90
91
  new L1PublishedData(l1BlockNumber, l1Timestamp, l1BlockHash),
@@ -1,2 +1,3 @@
1
1
  export * from './chain-config.js';
2
2
  export * from './node-rpc-config.js';
3
+ export * from './sequencer-config.js';
@@ -21,7 +21,7 @@ export const nodeRpcConfigMappings: ConfigMappingsType<NodeRPCConfig> = {
21
21
  rpcMaxBodySize: {
22
22
  env: 'RPC_MAX_BODY_SIZE',
23
23
  description: 'Maximum allowed batch size for JSON RPC batch requests.',
24
- defaultValue: '50mb',
24
+ defaultValue: '1mb',
25
25
  },
26
26
  };
27
27
 
@@ -0,0 +1,19 @@
1
+ import type { ConfigMappingsType } from '@aztec/foundation/config';
2
+
3
+ import type { SequencerConfig } from '../interfaces/configs.js';
4
+
5
+ /**
6
+ * Partial sequencer config mappings for fields that need to be shared across packages.
7
+ * The full sequencer config mappings remain in sequencer-client, but shared fields
8
+ * (like blockDurationMs needed by both p2p and sequencer-client) are defined here
9
+ * to avoid duplication.
10
+ */
11
+ export const sharedSequencerConfigMappings: ConfigMappingsType<Pick<SequencerConfig, 'blockDurationMs'>> = {
12
+ blockDurationMs: {
13
+ env: 'SEQ_BLOCK_DURATION_MS',
14
+ description:
15
+ 'Duration per block in milliseconds when building multiple blocks per slot. ' +
16
+ 'If undefined (default), builds a single block per slot using the full slot duration.',
17
+ parseEnv: (val: string) => (val ? parseInt(val, 10) : undefined),
18
+ },
19
+ };
@@ -87,5 +87,5 @@ export async function computeInitializationHashFromEncodedArgs(
87
87
  encodedArgs: Fr[],
88
88
  ): Promise<Fr> {
89
89
  const argsHash = await computeVarArgsHash(encodedArgs);
90
- return poseidon2HashWithSeparator([initFn, argsHash], GeneratorIndex.CONSTRUCTOR);
90
+ return poseidon2HashWithSeparator([initFn, argsHash], GeneratorIndex.INITIALIZER);
91
91
  }
@@ -13,7 +13,7 @@ import { computePrivateFunctionsRoot } from './private_function.js';
13
13
  *
14
14
  * ```
15
15
  * version = 1
16
- * private_function_leaves = private_functions.map(fn => pedersen([fn.function_selector as Field, fn.vk_hash], GENERATOR__FUNCTION_LEAF))
16
+ * private_function_leaves = private_functions.map(fn => pedersen([fn.function_selector as Field, fn.vk_hash], GENERATOR__PRIVATE_FUNCTION_LEAF))
17
17
  * private_functions_root = merkleize(private_function_leaves)
18
18
  * bytecode_commitment = calculate_commitment(packed_bytecode)
19
19
  * contract_class_id = pedersen([version, artifact_hash, private_functions_root, bytecode_commitment], GENERATOR__CLASS_IDENTIFIER)
@@ -1,11 +1,9 @@
1
1
  export * from './artifact_hash.js';
2
2
  export * from './contract_address.js';
3
3
  export * from './contract_class.js';
4
- export * from './contract_class_metadata.js';
5
4
  export * from './contract_class_id.js';
6
5
  export * from './contract_deployment_data.js';
7
6
  export * from './contract_instance.js';
8
- export * from './contract_metadata.js';
9
7
  export * from './contract_instance_update.js';
10
8
  export * from './private_function.js';
11
9
  export * from './private_function_membership_proof.js';
@@ -1,5 +1,4 @@
1
1
  import { FUNCTION_TREE_HEIGHT, GeneratorIndex } from '@aztec/constants';
2
- import { pedersenHash } from '@aztec/foundation/crypto/pedersen';
3
2
  import { poseidon2Hash, poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
4
3
  import { Fr } from '@aztec/foundation/curves/bn254';
5
4
  import { type MerkleTree, MerkleTreeCalculator } from '@aztec/foundation/trees';
@@ -32,13 +31,13 @@ function computePrivateFunctionLeaves(fns: PrivateFunction[]): Promise<Buffer[]>
32
31
 
33
32
  /** Returns the leaf for a given private function. */
34
33
  export async function computePrivateFunctionLeaf(fn: PrivateFunction): Promise<Buffer> {
35
- return (await poseidon2HashWithSeparator([fn.selector, fn.vkHash], GeneratorIndex.FUNCTION_LEAF)).toBuffer();
34
+ return (await poseidon2HashWithSeparator([fn.selector, fn.vkHash], GeneratorIndex.PRIVATE_FUNCTION_LEAF)).toBuffer();
36
35
  }
37
36
 
38
37
  async function getPrivateFunctionTreeCalculator(): Promise<MerkleTreeCalculator> {
39
38
  if (!privateFunctionTreeCalculator) {
40
39
  const functionTreeZeroLeaf = (
41
- await pedersenHash(new Array(PRIVATE_FUNCTION_SIZE).fill(0))
40
+ await poseidon2Hash(new Array(PRIVATE_FUNCTION_SIZE).fill(0))
42
41
  ).toBuffer() as Buffer<ArrayBuffer>;
43
42
  privateFunctionTreeCalculator = await MerkleTreeCalculator.create(
44
43
  FUNCTION_TREE_HEIGHT,
@@ -99,7 +99,7 @@ export async function createPrivateFunctionMembershipProof(
99
99
  * contract_class = db.get_contract_class(contract_class_id)
100
100
  *
101
101
  * // Compute function leaf and assert it belongs to the private functions tree
102
- * function_leaf = pedersen([selector as Field, vk_hash], GENERATOR__FUNCTION_LEAF)
102
+ * function_leaf = pedersen([selector as Field, vk_hash], GENERATOR__PRIVATE_FUNCTION_LEAF)
103
103
  * computed_private_function_tree_root = compute_root(function_leaf, private_function_tree_sibling_path)
104
104
  * assert computed_private_function_tree_root == contract_class.private_functions_root
105
105
  *
@@ -0,0 +1,87 @@
1
+ import { EthAddress } from '@aztec/foundation/eth-address';
2
+ import { jsonParseWithSchema, jsonStringify } from '@aztec/foundation/json-rpc';
3
+
4
+ import { z } from 'zod';
5
+
6
+ /**
7
+ * Symbol for Node.js custom inspect. Using Symbol.for() is the documented way to
8
+ * reference this without importing node:util. In browsers, objects with this symbol
9
+ * simply won't have custom inspect behavior (which is fine).
10
+ * @see https://nodejs.org/api/util.html#utilinspectcustom
11
+ */
12
+ const inspectCustomSymbol = Symbol.for('nodejs.util.inspect.custom');
13
+
14
+ /**
15
+ * Represents a version record for storing in a version file.
16
+ */
17
+ export class DatabaseVersion {
18
+ constructor(
19
+ /** The version of the data on disk. Used to perform upgrades */
20
+ public readonly schemaVersion: number,
21
+ /** The rollup the data pertains to */
22
+ public readonly rollupAddress: EthAddress,
23
+ ) {}
24
+
25
+ public toBuffer(): Buffer {
26
+ return Buffer.from(jsonStringify(this));
27
+ }
28
+
29
+ public static fromBuffer(buf: Buffer): DatabaseVersion {
30
+ try {
31
+ return jsonParseWithSchema(buf.toString('utf-8'), DatabaseVersion.schema);
32
+ } catch (err) {
33
+ throw new Error(`Failed to deserialize version information: ${err}`, { cause: err });
34
+ }
35
+ }
36
+
37
+ /**
38
+ * Compares two versions. If the rollups addresses are different then it returns undefined
39
+ */
40
+ public cmp(other: DatabaseVersion): undefined | -1 | 0 | 1 {
41
+ if (this.rollupAddress.equals(other.rollupAddress)) {
42
+ if (this.schemaVersion < other.schemaVersion) {
43
+ return -1;
44
+ } else if (this.schemaVersion > other.schemaVersion) {
45
+ return 1;
46
+ } else {
47
+ return 0;
48
+ }
49
+ }
50
+ return undefined;
51
+ }
52
+
53
+ /**
54
+ * Checks if two versions exactly match
55
+ */
56
+ public equals(other: DatabaseVersion): boolean {
57
+ return this.cmp(other) === 0;
58
+ }
59
+
60
+ /**
61
+ * Returns the schema for this class
62
+ */
63
+ static get schema() {
64
+ return z
65
+ .object({
66
+ schemaVersion: z.number(),
67
+ rollupAddress: EthAddress.schema,
68
+ })
69
+ .transform(({ schemaVersion, rollupAddress }) => new DatabaseVersion(schemaVersion, rollupAddress));
70
+ }
71
+
72
+ /** Allows for better introspection in Node.js console. Ignored in browser envs. */
73
+ public [inspectCustomSymbol](): string {
74
+ return this.toString();
75
+ }
76
+
77
+ public toString(): string {
78
+ return `DatabaseVersion{schemaVersion=${this.schemaVersion},rollupAddress=${this.rollupAddress}"}`;
79
+ }
80
+
81
+ /**
82
+ * Returns an empty instance
83
+ */
84
+ static empty() {
85
+ return new DatabaseVersion(0, EthAddress.ZERO);
86
+ }
87
+ }
@@ -1,86 +1,10 @@
1
1
  import { EthAddress } from '@aztec/foundation/eth-address';
2
- import { jsonParseWithSchema, jsonStringify } from '@aztec/foundation/json-rpc';
3
2
  import { type Logger, createLogger } from '@aztec/foundation/log';
4
3
 
5
4
  import fs from 'fs/promises';
6
- import { inspect } from 'node:util';
7
5
  import { join } from 'path';
8
- import { z } from 'zod';
9
6
 
10
- /**
11
- * Represents a version record for storing in a version file.
12
- */
13
- export class DatabaseVersion {
14
- constructor(
15
- /** The version of the data on disk. Used to perform upgrades */
16
- public readonly schemaVersion: number,
17
- /** The rollup the data pertains to */
18
- public readonly rollupAddress: EthAddress,
19
- ) {}
20
-
21
- public toBuffer(): Buffer {
22
- return Buffer.from(jsonStringify(this));
23
- }
24
-
25
- public static fromBuffer(buf: Buffer): DatabaseVersion {
26
- try {
27
- return jsonParseWithSchema(buf.toString('utf-8'), DatabaseVersion.schema);
28
- } catch (err) {
29
- throw new Error(`Failed to deserialize version information: ${err}`, { cause: err });
30
- }
31
- }
32
-
33
- /**
34
- * Compares two versions. If the rollups addresses are different then it returns undefined
35
- */
36
- public cmp(other: DatabaseVersion): undefined | -1 | 0 | 1 {
37
- if (this.rollupAddress.equals(other.rollupAddress)) {
38
- if (this.schemaVersion < other.schemaVersion) {
39
- return -1;
40
- } else if (this.schemaVersion > other.schemaVersion) {
41
- return 1;
42
- } else {
43
- return 0;
44
- }
45
- }
46
- return undefined;
47
- }
48
-
49
- /**
50
- * Checks if two versions exactly match
51
- */
52
- public equals(other: DatabaseVersion): boolean {
53
- return this.cmp(other) === 0;
54
- }
55
-
56
- /**
57
- * Returns the schema for this class
58
- */
59
- static get schema() {
60
- return z
61
- .object({
62
- schemaVersion: z.number(),
63
- rollupAddress: EthAddress.schema,
64
- })
65
- .transform(({ schemaVersion, rollupAddress }) => new DatabaseVersion(schemaVersion, rollupAddress));
66
- }
67
-
68
- /** Allows for better introspection. */
69
- public [inspect.custom](): string {
70
- return this.toString();
71
- }
72
-
73
- public toString(): string {
74
- return `DatabaseVersion{schemaVersion=${this.schemaVersion},rollupAddress=${this.rollupAddress}"}`;
75
- }
76
-
77
- /**
78
- * Returns an empty instance
79
- */
80
- static empty() {
81
- return new DatabaseVersion(0, EthAddress.ZERO);
82
- }
83
- }
7
+ import { DatabaseVersion } from './database_version.js';
84
8
 
85
9
  export type DatabaseVersionManagerFs = Pick<typeof fs, 'readFile' | 'writeFile' | 'rm' | 'mkdir'>;
86
10
 
@@ -68,23 +68,22 @@ export class DelayedPublicMutableValues {
68
68
  }
69
69
 
70
70
  static async readFromTree(delayedPublicMutableSlot: Fr, readStorage: (storageSlot: Fr) => Promise<Fr>) {
71
- const fields = [];
72
- for (let i = 0; i < DELAYED_PUBLIC_MUTABLE_VALUES_LEN; i++) {
73
- fields.push(await readStorage(delayedPublicMutableSlot.add(new Fr(i))));
74
- }
75
- return DelayedPublicMutableValues.fromFields(fields);
71
+ const fieldPromises = Array.from({ length: DELAYED_PUBLIC_MUTABLE_VALUES_LEN }).map((_, i) =>
72
+ readStorage(delayedPublicMutableSlot.add(new Fr(i))),
73
+ );
74
+ return DelayedPublicMutableValues.fromFields(await Promise.all(fieldPromises));
76
75
  }
77
76
 
78
77
  isEmpty(): boolean {
79
78
  return this.svc.isEmpty() && this.sdc.isEmpty();
80
79
  }
81
80
 
82
- async writeToTree(delayedPublicMutableSlot: Fr, storageWrite: (storageSlot: Fr, value: Fr) => Promise<void>) {
83
- const fields = this.toFields();
81
+ writeToTree(delayedPublicMutableSlot: Fr, storageWrite: (storageSlot: Fr, value: Fr) => Promise<void>) {
82
+ const fieldPromises = this.toFields().map((field, i) =>
83
+ storageWrite(delayedPublicMutableSlot.add(new Fr(i)), field),
84
+ );
84
85
 
85
- for (let i = 0; i < fields.length; i++) {
86
- await storageWrite(delayedPublicMutableSlot.add(new Fr(i)), fields[i]);
87
- }
86
+ return Promise.all(fieldPromises);
88
87
  }
89
88
 
90
89
  async hash(): Promise<Fr> {