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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (592) hide show
  1. package/dest/abi/contract_artifact.d.ts +2 -2
  2. package/dest/abi/contract_artifact.d.ts.map +1 -1
  3. package/dest/abi/contract_artifact.js +1 -1
  4. package/dest/abi/function_call.d.ts +9 -1
  5. package/dest/abi/function_call.d.ts.map +1 -1
  6. package/dest/abi/selector.js +3 -1
  7. package/dest/abi/utils.d.ts +7 -1
  8. package/dest/abi/utils.d.ts.map +1 -1
  9. package/dest/abi/utils.js +7 -0
  10. package/dest/auth_witness/auth_witness.d.ts +2 -1
  11. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  12. package/dest/avm/avm.d.ts +62 -62
  13. package/dest/avm/avm_accumulated_data.d.ts +30 -3
  14. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  15. package/dest/avm/avm_accumulated_data.js +5 -2
  16. package/dest/avm/avm_circuit_public_inputs.d.ts +9 -9
  17. package/dest/avm/avm_circuit_public_inputs.js +3 -1
  18. package/dest/avm/avm_proving_request.d.ts +299 -299
  19. package/dest/avm/contract_storage_read.d.ts +13 -1
  20. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  21. package/dest/avm/contract_storage_update_request.d.ts +13 -1
  22. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  23. package/dest/avm/public_call_stack_item_compressed.d.ts +3 -1
  24. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  25. package/dest/avm/public_data_read.d.ts +10 -1
  26. package/dest/avm/public_data_read.d.ts.map +1 -1
  27. package/dest/avm/public_data_update_request.d.ts +10 -1
  28. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  29. package/dest/avm/public_data_update_request.js +3 -1
  30. package/dest/avm/public_data_write.d.ts +7 -1
  31. package/dest/avm/public_data_write.d.ts.map +1 -1
  32. package/dest/avm/public_inner_call_request.d.ts +4 -1
  33. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  34. package/dest/avm/public_inner_call_request.js +3 -1
  35. package/dest/avm/revert_code.d.ts +4 -4
  36. package/dest/avm/revert_code.d.ts.map +1 -1
  37. package/dest/avm/revert_code.js +3 -1
  38. package/dest/aztec-address/index.js +4 -2
  39. package/dest/block/attestation_info.d.ts +5 -5
  40. package/dest/block/attestation_info.d.ts.map +1 -1
  41. package/dest/block/attestation_info.js +4 -4
  42. package/dest/block/block_hash.d.ts +18 -14
  43. package/dest/block/block_hash.d.ts.map +1 -1
  44. package/dest/block/block_hash.js +22 -20
  45. package/dest/block/block_parameter.d.ts +4 -3
  46. package/dest/block/block_parameter.d.ts.map +1 -1
  47. package/dest/block/block_parameter.js +2 -0
  48. package/dest/block/body.d.ts +1 -1
  49. package/dest/block/body.d.ts.map +1 -1
  50. package/dest/block/body.js +5 -2
  51. package/dest/block/checkpointed_l2_block.d.ts +20 -137
  52. package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
  53. package/dest/block/checkpointed_l2_block.js +7 -45
  54. package/dest/block/in_block.d.ts +9 -9
  55. package/dest/block/in_block.d.ts.map +1 -1
  56. package/dest/block/in_block.js +4 -4
  57. package/dest/block/index.d.ts +1 -3
  58. package/dest/block/index.d.ts.map +1 -1
  59. package/dest/block/index.js +0 -2
  60. package/dest/block/l2_block.d.ts +57 -57
  61. package/dest/block/l2_block.d.ts.map +1 -1
  62. package/dest/block/l2_block.js +64 -108
  63. package/dest/block/l2_block_source.d.ts +298 -68
  64. package/dest/block/l2_block_source.d.ts.map +1 -1
  65. package/dest/block/l2_block_source.js +25 -6
  66. package/dest/block/l2_block_stream/index.d.ts +2 -1
  67. package/dest/block/l2_block_stream/index.d.ts.map +1 -1
  68. package/dest/block/l2_block_stream/index.js +1 -0
  69. package/dest/block/l2_block_stream/interfaces.d.ts +15 -5
  70. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  71. package/dest/block/l2_block_stream/l2_block_stream.d.ts +8 -3
  72. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  73. package/dest/block/l2_block_stream/l2_block_stream.js +106 -31
  74. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +24 -16
  75. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
  76. package/dest/block/l2_block_stream/l2_tips_memory_store.js +55 -61
  77. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
  78. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
  79. package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
  80. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  81. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  82. package/dest/block/test/l2_tips_store_test_suite.js +478 -38
  83. package/dest/block/validate_block_result.d.ts +24 -24
  84. package/dest/block/validate_block_result.d.ts.map +1 -1
  85. package/dest/block/validate_block_result.js +18 -17
  86. package/dest/checkpoint/checkpoint.d.ts +30 -20
  87. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  88. package/dest/checkpoint/checkpoint.js +19 -6
  89. package/dest/checkpoint/checkpoint_info.d.ts +32 -3
  90. package/dest/checkpoint/checkpoint_info.d.ts.map +1 -1
  91. package/dest/checkpoint/checkpoint_info.js +34 -1
  92. package/dest/checkpoint/index.d.ts +2 -1
  93. package/dest/checkpoint/index.d.ts.map +1 -1
  94. package/dest/checkpoint/index.js +1 -0
  95. package/dest/checkpoint/published_checkpoint.d.ts +17 -15
  96. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  97. package/dest/checkpoint/published_checkpoint.js +4 -3
  98. package/dest/config/node-rpc-config.js +1 -1
  99. package/dest/contract/complete_address.d.ts +4 -1
  100. package/dest/contract/complete_address.d.ts.map +1 -1
  101. package/dest/contract/contract_address.js +1 -1
  102. package/dest/contract/contract_class_id.d.ts +1 -1
  103. package/dest/contract/contract_class_id.js +1 -1
  104. package/dest/contract/contract_deployment_data.d.ts +5 -5
  105. package/dest/contract/index.d.ts +1 -3
  106. package/dest/contract/index.d.ts.map +1 -1
  107. package/dest/contract/index.js +0 -2
  108. package/dest/contract/interfaces/contract_instance.d.ts +16 -16
  109. package/dest/contract/private_function.d.ts +1 -1
  110. package/dest/contract/private_function.d.ts.map +1 -1
  111. package/dest/contract/private_function.js +2 -3
  112. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  113. package/dest/contract/private_function_membership_proof.js +1 -1
  114. package/dest/database-version/database_version.d.ts +58 -0
  115. package/dest/database-version/database_version.d.ts.map +1 -0
  116. package/dest/database-version/database_version.js +69 -0
  117. package/dest/database-version/version_manager.d.ts +3 -49
  118. package/dest/database-version/version_manager.d.ts.map +1 -1
  119. package/dest/database-version/version_manager.js +1 -64
  120. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  121. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  122. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  123. package/dest/deserialization/index.d.ts +11 -0
  124. package/dest/deserialization/index.d.ts.map +1 -0
  125. package/dest/deserialization/index.js +10 -0
  126. package/dest/epoch-helpers/index.d.ts +3 -1
  127. package/dest/epoch-helpers/index.d.ts.map +1 -1
  128. package/dest/epoch-helpers/index.js +5 -1
  129. package/dest/errors/proving_error.d.ts +2 -2
  130. package/dest/errors/proving_error.d.ts.map +1 -1
  131. package/dest/gas/gas.js +3 -1
  132. package/dest/gas/gas_fees.js +3 -1
  133. package/dest/hash/hash.js +2 -2
  134. package/dest/hash/map_slot.d.ts +1 -1
  135. package/dest/hash/map_slot.d.ts.map +1 -1
  136. package/dest/hash/map_slot.js +4 -3
  137. package/dest/interfaces/api_limit.d.ts +3 -1
  138. package/dest/interfaces/api_limit.d.ts.map +1 -1
  139. package/dest/interfaces/api_limit.js +2 -0
  140. package/dest/interfaces/archiver.d.ts +6 -6
  141. package/dest/interfaces/archiver.d.ts.map +1 -1
  142. package/dest/interfaces/archiver.js +22 -17
  143. package/dest/interfaces/aztec-node-admin.d.ts +73 -31
  144. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  145. package/dest/interfaces/aztec-node-admin.js +5 -3
  146. package/dest/interfaces/aztec-node.d.ts +74 -76
  147. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  148. package/dest/interfaces/aztec-node.js +15 -16
  149. package/dest/interfaces/block-builder.d.ts +22 -14
  150. package/dest/interfaces/block-builder.d.ts.map +1 -1
  151. package/dest/interfaces/block-builder.js +7 -0
  152. package/dest/interfaces/configs.d.ts +12 -7
  153. package/dest/interfaces/configs.d.ts.map +1 -1
  154. package/dest/interfaces/configs.js +2 -1
  155. package/dest/interfaces/get_logs_response.d.ts +16 -9
  156. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  157. package/dest/interfaces/l2_logs_source.d.ts +14 -5
  158. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  159. package/dest/interfaces/p2p.d.ts +7 -9
  160. package/dest/interfaces/p2p.d.ts.map +1 -1
  161. package/dest/interfaces/p2p.js +3 -4
  162. package/dest/interfaces/prover-broker.d.ts +16 -1
  163. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  164. package/dest/interfaces/prover-broker.js +4 -1
  165. package/dest/interfaces/prover-client.d.ts +15 -1
  166. package/dest/interfaces/prover-client.d.ts.map +1 -1
  167. package/dest/interfaces/prover-client.js +12 -1
  168. package/dest/interfaces/proving-job.d.ts +218 -218
  169. package/dest/interfaces/proving-job.d.ts.map +1 -1
  170. package/dest/interfaces/proving-job.js +1 -7
  171. package/dest/interfaces/server_circuit_prover.d.ts +4 -3
  172. package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
  173. package/dest/interfaces/tx_provider.d.ts +3 -3
  174. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  175. package/dest/interfaces/validator.d.ts +140 -18
  176. package/dest/interfaces/validator.d.ts.map +1 -1
  177. package/dest/interfaces/validator.js +5 -3
  178. package/dest/kernel/claimed_length_array.js +3 -1
  179. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +6 -5
  180. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  181. package/dest/kernel/hints/build_note_hash_read_request_hints.js +19 -10
  182. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
  183. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  184. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
  185. package/dest/kernel/hints/key_validation_hint.d.ts +2 -1
  186. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  187. package/dest/kernel/hints/key_validation_request.d.ts +2 -1
  188. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  189. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +6 -1
  190. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +1 -1
  191. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  192. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  193. package/dest/kernel/hints/read_request.d.ts +7 -1
  194. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  195. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  196. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  197. package/dest/kernel/hints/transient_data_squashing_hint.js +3 -1
  198. package/dest/kernel/log_hash.js +3 -1
  199. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  200. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  201. package/dest/kernel/private_call_data.d.ts +25 -1
  202. package/dest/kernel/private_call_data.d.ts.map +1 -1
  203. package/dest/kernel/private_call_request.d.ts +16 -1
  204. package/dest/kernel/private_call_request.d.ts.map +1 -1
  205. package/dest/kernel/private_circuit_public_inputs.d.ts +74 -1
  206. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  207. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +31 -1
  208. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  209. package/dest/kernel/private_kernel_data.d.ts +7 -1
  210. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  211. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
  212. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  213. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  214. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  215. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  216. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  217. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +10 -1
  218. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  219. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +23 -1
  220. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  221. package/dest/kernel/private_log_data.js +5 -2
  222. package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
  223. package/dest/kernel/private_to_avm_accumulated_data.js +5 -2
  224. package/dest/kernel/private_to_public_accumulated_data.js +3 -1
  225. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
  226. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  227. package/dest/kernel/private_to_rollup_accumulated_data.js +3 -1
  228. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +16 -1
  229. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  230. package/dest/kernel/private_validation_requests.d.ts +10 -1
  231. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  232. package/dest/kernel/private_validation_requests.js +3 -1
  233. package/dest/kernel/public_call_request.d.ts +22 -1
  234. package/dest/kernel/public_call_request.d.ts.map +1 -1
  235. package/dest/kernel/public_call_request.js +5 -2
  236. package/dest/kernel/utils/optional_number.d.ts +7 -1
  237. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  238. package/dest/keys/derivation.d.ts +3 -3
  239. package/dest/keys/derivation.js +8 -8
  240. package/dest/keys/key_types.d.ts +1 -1
  241. package/dest/keys/public_keys.d.ts +5 -1
  242. package/dest/keys/public_keys.d.ts.map +1 -1
  243. package/dest/keys/utils.d.ts +1 -1
  244. package/dest/keys/utils.d.ts.map +1 -1
  245. package/dest/keys/utils.js +7 -3
  246. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  247. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  248. package/dest/l1-contracts/slash_factory.js +1 -0
  249. package/dest/logs/contract_class_log.js +3 -1
  250. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  251. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  252. package/dest/logs/extended_public_log.d.ts +17 -9
  253. package/dest/logs/extended_public_log.d.ts.map +1 -1
  254. package/dest/logs/log_id.d.ts +21 -14
  255. package/dest/logs/log_id.d.ts.map +1 -1
  256. package/dest/logs/log_id.js +20 -17
  257. package/dest/logs/private_log.js +3 -1
  258. package/dest/logs/public_log.js +3 -1
  259. package/dest/logs/siloed_tag.d.ts +1 -1
  260. package/dest/logs/siloed_tag.d.ts.map +1 -1
  261. package/dest/logs/siloed_tag.js +4 -3
  262. package/dest/messaging/in_hash.d.ts +4 -2
  263. package/dest/messaging/in_hash.d.ts.map +1 -1
  264. package/dest/messaging/in_hash.js +3 -1
  265. package/dest/messaging/inbox_leaf.d.ts +3 -1
  266. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  267. package/dest/messaging/l1_actor.d.ts +7 -1
  268. package/dest/messaging/l1_actor.d.ts.map +1 -1
  269. package/dest/messaging/l1_to_l2_message.d.ts +6 -1
  270. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  271. package/dest/messaging/l2_actor.d.ts +7 -1
  272. package/dest/messaging/l2_actor.d.ts.map +1 -1
  273. package/dest/messaging/l2_to_l1_membership.d.ts +88 -6
  274. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  275. package/dest/messaging/l2_to_l1_membership.js +160 -42
  276. package/dest/messaging/out_hash.d.ts +41 -3
  277. package/dest/messaging/out_hash.d.ts.map +1 -1
  278. package/dest/messaging/out_hash.js +54 -19
  279. package/dest/note/note_dao.d.ts +36 -5
  280. package/dest/note/note_dao.d.ts.map +1 -1
  281. package/dest/note/note_dao.js +15 -12
  282. package/dest/p2p/attestation_utils.d.ts +3 -3
  283. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  284. package/dest/p2p/attestation_utils.js +1 -1
  285. package/dest/p2p/block_proposal.d.ts +102 -23
  286. package/dest/p2p/block_proposal.d.ts.map +1 -1
  287. package/dest/p2p/block_proposal.js +140 -39
  288. package/dest/p2p/checkpoint_attestation.d.ts +81 -0
  289. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
  290. package/dest/p2p/{block_attestation.js → checkpoint_attestation.js} +22 -19
  291. package/dest/p2p/checkpoint_proposal.d.ts +167 -0
  292. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
  293. package/dest/p2p/checkpoint_proposal.js +229 -0
  294. package/dest/p2p/consensus_payload.d.ts +9 -9
  295. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  296. package/dest/p2p/consensus_payload.js +3 -5
  297. package/dest/p2p/constants.d.ts +3 -0
  298. package/dest/p2p/constants.d.ts.map +1 -0
  299. package/dest/p2p/constants.js +2 -0
  300. package/dest/p2p/gossipable.d.ts +4 -3
  301. package/dest/p2p/gossipable.d.ts.map +1 -1
  302. package/dest/p2p/gossipable.js +16 -5
  303. package/dest/p2p/index.d.ts +5 -2
  304. package/dest/p2p/index.d.ts.map +1 -1
  305. package/dest/p2p/index.js +4 -1
  306. package/dest/p2p/message_validator.d.ts +18 -3
  307. package/dest/p2p/message_validator.d.ts.map +1 -1
  308. package/dest/p2p/message_validator.js +2 -1
  309. package/dest/p2p/signature_utils.d.ts +5 -3
  310. package/dest/p2p/signature_utils.d.ts.map +1 -1
  311. package/dest/p2p/signature_utils.js +3 -1
  312. package/dest/p2p/signed_txs.d.ts +42 -0
  313. package/dest/p2p/signed_txs.d.ts.map +1 -0
  314. package/dest/p2p/signed_txs.js +75 -0
  315. package/dest/p2p/topic_type.d.ts +3 -2
  316. package/dest/p2p/topic_type.d.ts.map +1 -1
  317. package/dest/p2p/topic_type.js +10 -3
  318. package/dest/parity/parity_base_private_inputs.d.ts +3 -1
  319. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  320. package/dest/parity/parity_public_inputs.d.ts +4 -1
  321. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  322. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  323. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  324. package/dest/proofs/chonk_proof.d.ts +1 -1
  325. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  326. package/dest/proofs/chonk_proof.js +9 -4
  327. package/dest/proofs/proof.d.ts +4 -1
  328. package/dest/proofs/proof.d.ts.map +1 -1
  329. package/dest/proofs/recursive_proof.d.ts +10 -1
  330. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  331. package/dest/rollup/base_rollup_hints.d.ts +34 -1
  332. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  333. package/dest/rollup/block_constant_data.d.ts +12 -1
  334. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  335. package/dest/rollup/block_headers_hash.js +1 -1
  336. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  337. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  338. package/dest/rollup/block_rollup_public_inputs.d.ts +47 -11
  339. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  340. package/dest/rollup/block_rollup_public_inputs.js +8 -12
  341. package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
  342. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  343. package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
  344. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  345. package/dest/rollup/checkpoint_constant_data.js +3 -1
  346. package/dest/rollup/checkpoint_header.d.ts +42 -12
  347. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  348. package/dest/rollup/checkpoint_header.js +49 -19
  349. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  350. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  351. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +41 -1
  352. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  353. package/dest/rollup/checkpoint_rollup_public_inputs.js +10 -2
  354. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
  355. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  356. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
  357. package/dest/rollup/epoch_constant_data.d.ts +16 -1
  358. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  359. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  360. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  361. package/dest/rollup/root_rollup_public_inputs.d.ts +18 -3
  362. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  363. package/dest/rollup/root_rollup_public_inputs.js +9 -3
  364. package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
  365. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  366. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  367. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  368. package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
  369. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  370. package/dest/schemas/schemas.d.ts +1 -1
  371. package/dest/stats/stats.d.ts +1 -3
  372. package/dest/stats/stats.d.ts.map +1 -1
  373. package/dest/tests/factories.d.ts +16 -10
  374. package/dest/tests/factories.d.ts.map +1 -1
  375. package/dest/tests/factories.js +60 -25
  376. package/dest/tests/jest.js +1 -1
  377. package/dest/tests/mocks.d.ts +74 -19
  378. package/dest/tests/mocks.d.ts.map +1 -1
  379. package/dest/tests/mocks.js +123 -57
  380. package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
  381. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  382. package/dest/trees/append_only_tree_snapshot.js +3 -1
  383. package/dest/trees/nullifier_leaf.d.ts +13 -1
  384. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  385. package/dest/trees/nullifier_membership_witness.d.ts +10 -1
  386. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  387. package/dest/trees/public_data_leaf.d.ts +16 -1
  388. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  389. package/dest/trees/public_data_witness.d.ts +11 -1
  390. package/dest/trees/public_data_witness.d.ts.map +1 -1
  391. package/dest/tx/block_header.d.ts +14 -2
  392. package/dest/tx/block_header.d.ts.map +1 -1
  393. package/dest/tx/block_header.js +8 -2
  394. package/dest/tx/call_context.d.ts +13 -1
  395. package/dest/tx/call_context.d.ts.map +1 -1
  396. package/dest/tx/call_context.js +3 -1
  397. package/dest/tx/capsule.d.ts +4 -1
  398. package/dest/tx/capsule.d.ts.map +1 -1
  399. package/dest/tx/execution_payload.d.ts +9 -1
  400. package/dest/tx/execution_payload.d.ts.map +1 -1
  401. package/dest/tx/function_data.d.ts +4 -2
  402. package/dest/tx/function_data.d.ts.map +1 -1
  403. package/dest/tx/global_variable_builder.d.ts +2 -2
  404. package/dest/tx/global_variable_builder.d.ts.map +1 -1
  405. package/dest/tx/global_variables.d.ts +9 -1
  406. package/dest/tx/global_variables.d.ts.map +1 -1
  407. package/dest/tx/global_variables.js +3 -1
  408. package/dest/tx/hashed_values.d.ts +7 -1
  409. package/dest/tx/hashed_values.d.ts.map +1 -1
  410. package/dest/tx/in_tx.d.ts +4 -4
  411. package/dest/tx/index.d.ts +1 -2
  412. package/dest/tx/index.d.ts.map +1 -1
  413. package/dest/tx/index.js +0 -1
  414. package/dest/tx/indexed_tx_effect.d.ts +5 -5
  415. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  416. package/dest/tx/indexed_tx_effect.js +3 -2
  417. package/dest/tx/partial_state_reference.d.ts +4 -1
  418. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  419. package/dest/tx/private_execution_result.d.ts +23 -6
  420. package/dest/tx/private_execution_result.d.ts.map +1 -1
  421. package/dest/tx/private_execution_result.js +4 -21
  422. package/dest/tx/private_tx_constant_data.d.ts +16 -1
  423. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  424. package/dest/tx/profiling.d.ts +149 -26
  425. package/dest/tx/profiling.d.ts.map +1 -1
  426. package/dest/tx/profiling.js +44 -7
  427. package/dest/tx/protocol_contracts.d.ts +1 -1
  428. package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
  429. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  430. package/dest/tx/public_call_request_with_calldata.js +3 -1
  431. package/dest/tx/state_reference.d.ts +3 -1
  432. package/dest/tx/state_reference.d.ts.map +1 -1
  433. package/dest/tx/state_reference.js +3 -1
  434. package/dest/tx/tree_snapshots.js +3 -1
  435. package/dest/tx/tx.d.ts +24 -1
  436. package/dest/tx/tx.d.ts.map +1 -1
  437. package/dest/tx/tx.js +9 -4
  438. package/dest/tx/tx_context.d.ts +2 -1
  439. package/dest/tx/tx_context.d.ts.map +1 -1
  440. package/dest/tx/tx_effect.d.ts +32 -6
  441. package/dest/tx/tx_effect.d.ts.map +1 -1
  442. package/dest/tx/tx_effect.js +3 -8
  443. package/dest/tx/tx_execution_request.d.ts +30 -1
  444. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  445. package/dest/tx/tx_execution_request.js +6 -2
  446. package/dest/tx/tx_hash.d.ts +2 -1
  447. package/dest/tx/tx_hash.d.ts.map +1 -1
  448. package/dest/tx/tx_receipt.d.ts +47 -13
  449. package/dest/tx/tx_receipt.d.ts.map +1 -1
  450. package/dest/tx/tx_receipt.js +46 -15
  451. package/dest/tx/tx_request.d.ts +6 -1
  452. package/dest/tx/tx_request.d.ts.map +1 -1
  453. package/dest/tx/validator/error_texts.d.ts +2 -1
  454. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  455. package/dest/tx/validator/error_texts.js +2 -0
  456. package/dest/types/shared.d.ts +4 -1
  457. package/dest/types/shared.d.ts.map +1 -1
  458. package/dest/validators/schemas.d.ts +8 -8
  459. package/dest/vks/verification_key.d.ts +22 -1
  460. package/dest/vks/verification_key.d.ts.map +1 -1
  461. package/dest/vks/vk_data.d.ts +7 -1
  462. package/dest/vks/vk_data.d.ts.map +1 -1
  463. package/dest/zkpassport/index.d.ts +3 -4
  464. package/dest/zkpassport/index.d.ts.map +1 -1
  465. package/dest/zkpassport/index.js +9 -9
  466. package/package.json +25 -12
  467. package/src/abi/contract_artifact.ts +10 -10
  468. package/src/abi/utils.ts +17 -0
  469. package/src/block/attestation_info.ts +9 -6
  470. package/src/block/block_hash.ts +26 -25
  471. package/src/block/block_parameter.ts +4 -2
  472. package/src/block/body.ts +2 -1
  473. package/src/block/checkpointed_l2_block.ts +8 -58
  474. package/src/block/in_block.ts +5 -5
  475. package/src/block/index.ts +0 -2
  476. package/src/block/l2_block.ts +102 -149
  477. package/src/block/l2_block_source.ts +123 -44
  478. package/src/block/l2_block_stream/index.ts +1 -0
  479. package/src/block/l2_block_stream/interfaces.ts +15 -4
  480. package/src/block/l2_block_stream/l2_block_stream.ts +130 -39
  481. package/src/block/l2_block_stream/l2_tips_memory_store.ts +62 -56
  482. package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
  483. package/src/block/test/l2_tips_store_test_suite.ts +480 -36
  484. package/src/block/validate_block_result.ts +40 -35
  485. package/src/checkpoint/checkpoint.ts +34 -11
  486. package/src/checkpoint/checkpoint_info.ts +45 -2
  487. package/src/checkpoint/index.ts +1 -0
  488. package/src/checkpoint/published_checkpoint.ts +4 -3
  489. package/src/config/node-rpc-config.ts +1 -1
  490. package/src/contract/contract_address.ts +1 -1
  491. package/src/contract/contract_class_id.ts +1 -1
  492. package/src/contract/index.ts +0 -2
  493. package/src/contract/private_function.ts +2 -3
  494. package/src/contract/private_function_membership_proof.ts +1 -1
  495. package/src/database-version/database_version.ts +87 -0
  496. package/src/database-version/version_manager.ts +1 -77
  497. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  498. package/src/deserialization/index.ts +21 -0
  499. package/src/epoch-helpers/index.ts +10 -1
  500. package/src/hash/hash.ts +2 -2
  501. package/src/hash/map_slot.ts +3 -2
  502. package/src/interfaces/api_limit.ts +2 -0
  503. package/src/interfaces/archiver.ts +26 -24
  504. package/src/interfaces/aztec-node-admin.ts +8 -4
  505. package/src/interfaces/aztec-node.ts +109 -128
  506. package/src/interfaces/block-builder.ts +40 -23
  507. package/src/interfaces/configs.ts +3 -0
  508. package/src/interfaces/l2_logs_source.ts +17 -4
  509. package/src/interfaces/p2p.ts +8 -12
  510. package/src/interfaces/prover-broker.ts +22 -0
  511. package/src/interfaces/prover-client.ts +22 -0
  512. package/src/interfaces/proving-job.ts +2 -11
  513. package/src/interfaces/server_circuit_prover.ts +3 -2
  514. package/src/interfaces/tx_provider.ts +2 -2
  515. package/src/interfaces/validator.ts +62 -14
  516. package/src/kernel/hints/build_note_hash_read_request_hints.ts +20 -12
  517. package/src/kernel/hints/build_nullifier_read_request_hints.ts +17 -14
  518. package/src/keys/derivation.ts +8 -8
  519. package/src/keys/key_types.ts +1 -1
  520. package/src/keys/utils.ts +7 -3
  521. package/src/l1-contracts/slash_factory.ts +1 -0
  522. package/src/logs/log_id.ts +22 -18
  523. package/src/logs/siloed_tag.ts +3 -2
  524. package/src/messaging/in_hash.ts +3 -1
  525. package/src/messaging/l2_to_l1_membership.ts +178 -52
  526. package/src/messaging/out_hash.ts +62 -21
  527. package/src/note/note_dao.ts +18 -13
  528. package/src/p2p/attestation_utils.ts +3 -3
  529. package/src/p2p/block_proposal.ts +213 -46
  530. package/src/p2p/{block_attestation.ts → checkpoint_attestation.ts} +31 -25
  531. package/src/p2p/checkpoint_proposal.ts +355 -0
  532. package/src/p2p/consensus_payload.ts +5 -7
  533. package/src/p2p/constants.ts +3 -0
  534. package/src/p2p/gossipable.ts +14 -4
  535. package/src/p2p/index.ts +4 -1
  536. package/src/p2p/message_validator.ts +14 -2
  537. package/src/p2p/signature_utils.ts +3 -1
  538. package/src/p2p/signed_txs.ts +88 -0
  539. package/src/p2p/topic_type.ts +4 -3
  540. package/src/proofs/chonk_proof.ts +9 -5
  541. package/src/rollup/block_headers_hash.ts +1 -1
  542. package/src/rollup/block_rollup_public_inputs.ts +5 -11
  543. package/src/rollup/checkpoint_header.ts +63 -20
  544. package/src/rollup/checkpoint_rollup_public_inputs.ts +12 -0
  545. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
  546. package/src/rollup/root_rollup_public_inputs.ts +9 -0
  547. package/src/stats/stats.ts +0 -2
  548. package/src/tests/factories.ts +56 -40
  549. package/src/tests/jest.ts +1 -1
  550. package/src/tests/mocks.ts +213 -91
  551. package/src/tx/block_header.ts +11 -3
  552. package/src/tx/global_variable_builder.ts +1 -1
  553. package/src/tx/index.ts +0 -1
  554. package/src/tx/indexed_tx_effect.ts +3 -2
  555. package/src/tx/private_execution_result.ts +1 -16
  556. package/src/tx/profiling.ts +46 -4
  557. package/src/tx/tx.ts +10 -9
  558. package/src/tx/tx_effect.ts +0 -9
  559. package/src/tx/tx_execution_request.ts +2 -0
  560. package/src/tx/tx_receipt.ts +75 -18
  561. package/src/tx/validator/error_texts.ts +3 -0
  562. package/src/zkpassport/index.ts +11 -12
  563. package/dest/block/l2_block_code_to_purge.d.ts +0 -12
  564. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  565. package/dest/block/l2_block_code_to_purge.js +0 -61
  566. package/dest/block/l2_block_header.d.ts +0 -98
  567. package/dest/block/l2_block_header.d.ts.map +0 -1
  568. package/dest/block/l2_block_header.js +0 -153
  569. package/dest/block/l2_block_new.d.ts +0 -135
  570. package/dest/block/l2_block_new.d.ts.map +0 -1
  571. package/dest/block/l2_block_new.js +0 -152
  572. package/dest/contract/contract_class_metadata.d.ts +0 -8
  573. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  574. package/dest/contract/contract_class_metadata.js +0 -1
  575. package/dest/contract/contract_metadata.d.ts +0 -7
  576. package/dest/contract/contract_metadata.d.ts.map +0 -1
  577. package/dest/contract/contract_metadata.js +0 -1
  578. package/dest/database-version/index.d.ts +0 -2
  579. package/dest/database-version/index.d.ts.map +0 -1
  580. package/dest/database-version/index.js +0 -1
  581. package/dest/p2p/block_attestation.d.ts +0 -80
  582. package/dest/p2p/block_attestation.d.ts.map +0 -1
  583. package/dest/tx/content_commitment.d.ts +0 -49
  584. package/dest/tx/content_commitment.d.ts.map +0 -1
  585. package/dest/tx/content_commitment.js +0 -90
  586. package/src/block/l2_block_code_to_purge.ts +0 -88
  587. package/src/block/l2_block_header.ts +0 -246
  588. package/src/block/l2_block_new.ts +0 -207
  589. package/src/contract/contract_class_metadata.ts +0 -8
  590. package/src/contract/contract_metadata.ts +0 -7
  591. package/src/database-version/index.ts +0 -1
  592. package/src/tx/content_commitment.ts +0 -113
@@ -10,8 +10,8 @@ import type { KeyPrefix } from './key_types.js';
10
10
  import { PublicKeys } from './public_keys.js';
11
11
  import { getKeyGenerator } from './utils.js';
12
12
 
13
- export function computeAppNullifierSecretKey(masterNullifierSecretKey: GrumpkinScalar, app: AztecAddress): Promise<Fr> {
14
- return computeAppSecretKey(masterNullifierSecretKey, app, 'n'); // 'n' is the key prefix for nullifier secret key
13
+ export function computeAppNullifierHidingKey(masterNullifierHidingKey: GrumpkinScalar, app: AztecAddress): Promise<Fr> {
14
+ return computeAppSecretKey(masterNullifierHidingKey, app, 'n'); // 'n' is the key prefix for nullifier hiding key
15
15
  }
16
16
 
17
17
  export function computeAppSecretKey(skM: GrumpkinScalar, app: AztecAddress, keyPrefix: KeyPrefix): Promise<Fr> {
@@ -26,8 +26,8 @@ export async function computeOvskApp(ovsk: GrumpkinScalar, app: AztecAddress): P
26
26
  return GrumpkinScalar.fromBuffer(ovskAppFr.toBuffer());
27
27
  }
28
28
 
29
- export function deriveMasterNullifierSecretKey(secretKey: Fr): GrumpkinScalar {
30
- return sha512ToGrumpkinScalar([secretKey, GeneratorIndex.NSK_M]);
29
+ export function deriveMasterNullifierHidingKey(secretKey: Fr): GrumpkinScalar {
30
+ return sha512ToGrumpkinScalar([secretKey, GeneratorIndex.NHK_M]);
31
31
  }
32
32
 
33
33
  export function deriveMasterIncomingViewingSecretKey(secretKey: Fr): GrumpkinScalar {
@@ -93,15 +93,15 @@ export function derivePublicKeyFromSecretKey(secretKey: Fq) {
93
93
  * @returns The derived keys.
94
94
  */
95
95
  export async function deriveKeys(secretKey: Fr) {
96
- // First we derive master secret keys - we use sha512 here because this derivation will never take place
96
+ // First we derive master secret/hiding keys - we use sha512 here because this derivation will never take place
97
97
  // in a circuit
98
- const masterNullifierSecretKey = deriveMasterNullifierSecretKey(secretKey);
98
+ const masterNullifierHidingKey = deriveMasterNullifierHidingKey(secretKey);
99
99
  const masterIncomingViewingSecretKey = deriveMasterIncomingViewingSecretKey(secretKey);
100
100
  const masterOutgoingViewingSecretKey = deriveMasterOutgoingViewingSecretKey(secretKey);
101
101
  const masterTaggingSecretKey = sha512ToGrumpkinScalar([secretKey, GeneratorIndex.TSK_M]);
102
102
 
103
103
  // Then we derive master public keys
104
- const masterNullifierPublicKey = await derivePublicKeyFromSecretKey(masterNullifierSecretKey);
104
+ const masterNullifierPublicKey = await derivePublicKeyFromSecretKey(masterNullifierHidingKey);
105
105
  const masterIncomingViewingPublicKey = await derivePublicKeyFromSecretKey(masterIncomingViewingSecretKey);
106
106
  const masterOutgoingViewingPublicKey = await derivePublicKeyFromSecretKey(masterOutgoingViewingSecretKey);
107
107
  const masterTaggingPublicKey = await derivePublicKeyFromSecretKey(masterTaggingSecretKey);
@@ -115,7 +115,7 @@ export async function deriveKeys(secretKey: Fr) {
115
115
  );
116
116
 
117
117
  return {
118
- masterNullifierSecretKey,
118
+ masterNullifierHidingKey,
119
119
  masterIncomingViewingSecretKey,
120
120
  masterOutgoingViewingSecretKey,
121
121
  masterTaggingSecretKey,
@@ -1,5 +1,5 @@
1
1
  import type { GeneratorIndex } from '@aztec/constants';
2
2
 
3
- export type KeyGenerator = GeneratorIndex.NSK_M | GeneratorIndex.IVSK_M | GeneratorIndex.OVSK_M | GeneratorIndex.TSK_M;
3
+ export type KeyGenerator = GeneratorIndex.NHK_M | GeneratorIndex.IVSK_M | GeneratorIndex.OVSK_M | GeneratorIndex.TSK_M;
4
4
  export type KeyPrefix = 'n' | 'iv' | 'ov' | 't';
5
5
  export const KEY_PREFIXES: KeyPrefix[] = ['n', 'iv', 'ov', 't'];
package/src/keys/utils.ts CHANGED
@@ -3,7 +3,11 @@ import { GeneratorIndex } from '@aztec/constants';
3
3
  import type { KeyGenerator, KeyPrefix } from './key_types.js';
4
4
 
5
5
  export function getKeyGenerator(prefix: KeyPrefix): KeyGenerator {
6
- // We get enum key by capitalizing key prefix and concatenating it with 'SK_M'
7
- const enumKey = `${prefix.toUpperCase()}SK_M`;
8
- return GeneratorIndex[enumKey as keyof typeof GeneratorIndex] as KeyGenerator;
6
+ const map: Record<KeyPrefix, KeyGenerator> = {
7
+ n: GeneratorIndex.NHK_M,
8
+ iv: GeneratorIndex.IVSK_M,
9
+ ov: GeneratorIndex.OVSK_M,
10
+ t: GeneratorIndex.TSK_M,
11
+ };
12
+ return map[prefix];
9
13
  }
@@ -41,6 +41,7 @@ export class SlashFactoryContract {
41
41
 
42
42
  return {
43
43
  to: this.contract.address,
44
+ abi: SlashFactoryAbi,
44
45
  data: encodeFunctionData({
45
46
  abi: SlashFactoryAbi,
46
47
  functionName: 'createSlashPayload',
@@ -1,26 +1,24 @@
1
1
  import { INITIAL_L2_BLOCK_NUM } from '@aztec/constants';
2
2
  import { toBufferBE } from '@aztec/foundation/bigint-buffer';
3
3
  import { BlockNumber, BlockNumberSchema } from '@aztec/foundation/branded-types';
4
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
5
  import { BufferReader } from '@aztec/foundation/serialize';
5
6
 
6
7
  import { z } from 'zod';
7
8
 
8
- import { L2BlockHash } from '../block/block_hash.js';
9
+ import { BlockHash } from '../block/block_hash.js';
9
10
  import { schemas } from '../schemas/index.js';
11
+ import { TxHash } from '../tx/tx_hash.js';
10
12
 
11
13
  /** A globally unique log id. */
12
14
  export class LogId {
13
- /**
14
- * Parses a log id from a string.
15
- * @param blockNumber - The block number.
16
- * @param txIndex - The transaction index.
17
- * @param logIndex - The log index.
18
- */
19
15
  constructor(
20
16
  /** The block number the log was emitted in. */
21
17
  public readonly blockNumber: BlockNumber,
22
18
  /** The hash of the block the log was emitted in. */
23
- public readonly blockHash: L2BlockHash,
19
+ public readonly blockHash: BlockHash,
20
+ /** The hash of the transaction the log was emitted in. */
21
+ public readonly txHash: TxHash,
24
22
  /** The index of a tx in a block the log was emitted in. */
25
23
  public readonly txIndex: number,
26
24
  /** The index of a log the tx was emitted in. */
@@ -40,7 +38,8 @@ export class LogId {
40
38
  static random() {
41
39
  return new LogId(
42
40
  BlockNumber(Math.floor(Math.random() * 1000) + 1),
43
- L2BlockHash.random(),
41
+ BlockHash.random(),
42
+ TxHash.random(),
44
43
  Math.floor(Math.random() * 1000),
45
44
  Math.floor(Math.random() * 100),
46
45
  );
@@ -50,12 +49,14 @@ export class LogId {
50
49
  return z
51
50
  .object({
52
51
  blockNumber: BlockNumberSchema,
53
- blockHash: L2BlockHash.schema,
52
+ blockHash: BlockHash.schema,
53
+ txHash: TxHash.schema,
54
54
  txIndex: schemas.Integer,
55
55
  logIndex: schemas.Integer,
56
56
  })
57
57
  .transform(
58
- ({ blockNumber, blockHash, txIndex, logIndex }) => new LogId(blockNumber, blockHash, txIndex, logIndex),
58
+ ({ blockNumber, blockHash, txHash, txIndex, logIndex }) =>
59
+ new LogId(blockNumber, blockHash, txHash, txIndex, logIndex),
59
60
  );
60
61
  }
61
62
 
@@ -67,6 +68,7 @@ export class LogId {
67
68
  return Buffer.concat([
68
69
  toBufferBE(BigInt(this.blockNumber), 4),
69
70
  this.blockHash.toBuffer(),
71
+ this.txHash.toBuffer(),
70
72
  toBufferBE(BigInt(this.txIndex), 4),
71
73
  toBufferBE(BigInt(this.logIndex), 4),
72
74
  ]);
@@ -81,11 +83,12 @@ export class LogId {
81
83
  const reader = BufferReader.asReader(buffer);
82
84
 
83
85
  const blockNumber = BlockNumber(reader.readNumber());
84
- const blockHash = reader.readObject(L2BlockHash);
86
+ const blockHash = new BlockHash(reader.readObject(Fr));
87
+ const txHash = reader.readObject(TxHash);
85
88
  const txIndex = reader.readNumber();
86
89
  const logIndex = reader.readNumber();
87
90
 
88
- return new LogId(blockNumber, blockHash, txIndex, logIndex);
91
+ return new LogId(blockNumber, blockHash, txHash, txIndex, logIndex);
89
92
  }
90
93
 
91
94
  /**
@@ -93,7 +96,7 @@ export class LogId {
93
96
  * @returns A string representation of the log id.
94
97
  */
95
98
  public toString(): string {
96
- return `${this.blockNumber}-${this.txIndex}-${this.logIndex}-${this.blockHash.toString()}`;
99
+ return `${this.blockNumber}-${this.txIndex}-${this.logIndex}-${this.blockHash.toString()}-${this.txHash.toString()}`;
97
100
  }
98
101
 
99
102
  /**
@@ -102,13 +105,14 @@ export class LogId {
102
105
  * @returns A log id.
103
106
  */
104
107
  static fromString(data: string): LogId {
105
- const [rawBlockNumber, rawTxIndex, rawLogIndex, rawBlockHash] = data.split('-');
108
+ const [rawBlockNumber, rawTxIndex, rawLogIndex, rawBlockHash, rawTxHash] = data.split('-');
106
109
  const blockNumber = BlockNumber(Number(rawBlockNumber));
107
- const blockHash = L2BlockHash.fromString(rawBlockHash);
110
+ const blockHash = BlockHash.fromString(rawBlockHash);
111
+ const txHash = TxHash.fromString(rawTxHash);
108
112
  const txIndex = Number(rawTxIndex);
109
113
  const logIndex = Number(rawLogIndex);
110
114
 
111
- return new LogId(blockNumber, blockHash, txIndex, logIndex);
115
+ return new LogId(blockNumber, blockHash, txHash, txIndex, logIndex);
112
116
  }
113
117
 
114
118
  /**
@@ -116,6 +120,6 @@ export class LogId {
116
120
  * @returns A human readable representation of the log id.
117
121
  */
118
122
  public toHumanReadable(): string {
119
- return `logId: (blockNumber: ${this.blockNumber}, blockHash: ${this.blockHash.toString()}, txIndex: ${this.txIndex}, logIndex: ${this.logIndex})`;
123
+ return `logId: (blockNumber: ${this.blockNumber}, blockHash: ${this.blockHash.toString()}, txHash: ${this.txHash.toString()}, txIndex: ${this.txIndex}, logIndex: ${this.logIndex})`;
120
124
  }
121
125
  }
@@ -1,4 +1,5 @@
1
- import { poseidon2Hash } from '@aztec/foundation/crypto/poseidon';
1
+ import { GeneratorIndex } from '@aztec/constants';
2
+ import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
2
3
  import type { Fr } from '@aztec/foundation/curves/bn254';
3
4
  import type { ZodFor } from '@aztec/foundation/schemas';
4
5
 
@@ -22,7 +23,7 @@ export class SiloedTag {
22
23
  constructor(public readonly value: Fr) {}
23
24
 
24
25
  static async compute(tag: Tag, app: AztecAddress): Promise<SiloedTag> {
25
- const siloedTag = await poseidon2Hash([app, tag.value]);
26
+ const siloedTag = await poseidon2HashWithSeparator([app, tag.value], GeneratorIndex.PRIVATE_LOG_FIRST_FIELD);
26
27
  return new SiloedTag(siloedTag);
27
28
  }
28
29
 
@@ -3,7 +3,9 @@ import { padArrayEnd } from '@aztec/foundation/collection';
3
3
  import { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { computeBalancedShaRoot } from '@aztec/foundation/trees';
5
5
 
6
- /** Computes the inHash for a block's ContentCommitment given its l1 to l2 messages. */
6
+ /**
7
+ * Computes the inHash for a checkpoint (or the first block in a checkpoint) given its l1 to l2 messages.
8
+ */
7
9
  export function computeInHashFromL1ToL2Messages(unpaddedL1ToL2Messages: Fr[]): Fr {
8
10
  const l1ToL2Messages = padArrayEnd<Fr, number>(unpaddedL1ToL2Messages, Fr.ZERO, NUMBER_OF_L1_L2_MESSAGES_PER_ROLLUP);
9
11
  return new Fr(computeBalancedShaRoot(l1ToL2Messages.map(msg => msg.toBuffer())));
@@ -1,9 +1,99 @@
1
- import type { BlockNumber } from '@aztec/foundation/branded-types';
1
+ import { OUT_HASH_TREE_LEAF_COUNT } from '@aztec/constants';
2
+ import type { EpochNumber } from '@aztec/foundation/branded-types';
2
3
  import { Fr } from '@aztec/foundation/curves/bn254';
3
4
  import { SiblingPath, UnbalancedMerkleTreeCalculator, computeUnbalancedShaRoot } from '@aztec/foundation/trees';
4
5
 
6
+ /**
7
+ * # L2-to-L1 Message Tree Structure and Leaf IDs
8
+ *
9
+ * ## Overview
10
+ * L2-to-L1 messages are organized in a hierarchical 4-level tree structure within each epoch:
11
+ * Epoch → Checkpoints → Blocks → Transactions → Messages
12
+ *
13
+ * Each level uses an unbalanced Merkle tree, and some levels use compression (skipping zero hashes).
14
+ *
15
+ * ## Tree Levels
16
+ *
17
+ * 1. **Message Tree (TX Out Hash)**
18
+ * - Leaves: Individual L2-to-L1 messages within a transaction
19
+ * - Root: TX out hash
20
+ * - Type: Unbalanced, non-compressed (the circuits ensure that all messages are not empty.)
21
+ *
22
+ * 2. **Block Tree**
23
+ * - Leaves: TX out hashes from all transactions in a block
24
+ * - Root: Block out hash
25
+ * - Type: Unbalanced, compressed (zero hashes are skipped)
26
+ * - Compression: If a tx has no messages (out hash = 0), that branch is ignored
27
+ *
28
+ * 3. **Checkpoint Tree**
29
+ * - Leaves: Block out hashes from all blocks in a checkpoint
30
+ * - Root: Checkpoint out hash
31
+ * - Type: Unbalanced, compressed (zero hashes are skipped)
32
+ * - Compression: If a block has no messages (out hash = 0), that branch is ignored
33
+ *
34
+ * 4. **Epoch Tree**
35
+ * - Leaves: Checkpoint out hashes from all checkpoints in an epoch (padded to AZTEC_MAX_EPOCH_DURATION)
36
+ * - Root: Epoch out hash (set in the root rollup's public inputs and inserted into the Outbox on L1 when the epoch is proven)
37
+ * - Type: Unbalanced, non-compressed
38
+ * - **Important**: Padded with zeros up to AZTEC_MAX_EPOCH_DURATION to allow for proofs of partial epochs
39
+ *
40
+ * ## Combined Membership Proof
41
+ * To prove a message exists in an epoch, we combine the sibling paths from all 4 trees:
42
+ * [message siblings] + [tx siblings] + [block siblings] + [checkpoint siblings]
43
+ *
44
+ * ## Leaf ID: Stable Message Identification
45
+ *
46
+ * Each message gets a unique, stable **leaf ID** that identifies its position in the combined tree.
47
+ * The leaf ID is computed as:
48
+ * leafId = 2^pathSize + leafIndex
49
+ *
50
+ * Where:
51
+ * - `pathSize`: Total length of the combined sibling path (from all 4 tree levels)
52
+ * - `leafIndex`: The message's index in a balanced tree representation at that height
53
+ *
54
+ * ### Why Leaf IDs Are Stable
55
+ *
56
+ * The leaf ID is based on the message's position in the tree structure, which is determined by:
57
+ * - The checkpoint index within the epoch
58
+ * - The block index within the checkpoint
59
+ * - The transaction index within the block
60
+ * - The message index within the transaction
61
+ *
62
+ * These indices are structural and do NOT depend on the total number of blocks/checkpoints in the epoch.
63
+ *
64
+ * ### Critical Property: Preserving Consumed Status
65
+ *
66
+ * **Problem**: On L1, epoch proofs can be submitted incrementally. For example:
67
+ * - First, a proof for checkpoints 1-10 of epoch 0 is submitted (proves the first 10 checkpoints)
68
+ * - Later, a proof for checkpoints 1-20 of epoch 0 is submitted (proves all 20 checkpoints)
69
+ *
70
+ * When the longer proof is submitted, it updates the epoch's out hash root on L1 to reflect the complete epoch (all 20
71
+ * checkpoints). However, some messages from checkpoints 1-10 may have already been consumed.
72
+ *
73
+ * **Solution**: The Outbox on L1 tracks consumed messages using a bitmap indexed by leaf ID.
74
+ * Because leaf IDs are stable (they don't change when more checkpoints are added to the epoch), messages that were consumed
75
+ * under the shorter proof remain marked as consumed under the longer proof.
76
+ *
77
+ * This prevents double-spending of L2-to-L1 messages when longer epoch proofs are submitted.
78
+ */
79
+
80
+ /**
81
+ * Computes the unique leaf ID for an L2-to-L1 message.
82
+ *
83
+ * The leaf ID is stable across different epoch proof lengths and is used by the Outbox
84
+ * on L1 to track which messages have been consumed.
85
+ *
86
+ * @param membershipWitness - Contains the leafIndex and siblingPath for the message
87
+ * @returns The unique leaf ID used for tracking message consumption on L1
88
+ */
89
+ export function getL2ToL1MessageLeafId(
90
+ membershipWitness: Pick<L2ToL1MembershipWitness, 'leafIndex' | 'siblingPath'>,
91
+ ): bigint {
92
+ return 2n ** BigInt(membershipWitness.siblingPath.pathSize) + membershipWitness.leafIndex;
93
+ }
94
+
5
95
  export interface MessageRetrieval {
6
- getL2ToL1Messages(l2BlockNumber: BlockNumber): Promise<Fr[][] | undefined>;
96
+ getL2ToL1Messages(epoch: EpochNumber): Promise<Fr[][][][]>;
7
97
  }
8
98
 
9
99
  export type L2ToL1MembershipWitness = {
@@ -14,76 +104,101 @@ export type L2ToL1MembershipWitness = {
14
104
 
15
105
  export async function computeL2ToL1MembershipWitness(
16
106
  messageRetriever: MessageRetrieval,
17
- l2BlockNumber: BlockNumber,
107
+ epoch: EpochNumber,
18
108
  message: Fr,
19
109
  ): Promise<L2ToL1MembershipWitness | undefined> {
20
- const messagesForAllTxs = await messageRetriever.getL2ToL1Messages(l2BlockNumber);
21
- if (!messagesForAllTxs) {
110
+ const messagesInEpoch = await messageRetriever.getL2ToL1Messages(epoch);
111
+ if (messagesInEpoch.length === 0) {
22
112
  return undefined;
23
113
  }
24
114
 
25
- return computeL2ToL1MembershipWitnessFromMessagesForAllTxs(messagesForAllTxs, message);
115
+ return computeL2ToL1MembershipWitnessFromMessagesInEpoch(messagesInEpoch, message);
26
116
  }
27
117
 
28
118
  // TODO: Allow to specify the message to consume by its index or by an offset, in case there are multiple messages with
29
119
  // the same value.
30
- export function computeL2ToL1MembershipWitnessFromMessagesForAllTxs(
31
- messagesForAllTxs: Fr[][],
120
+ export function computeL2ToL1MembershipWitnessFromMessagesInEpoch(
121
+ messagesInEpoch: Fr[][][][],
32
122
  message: Fr,
33
123
  ): L2ToL1MembershipWitness {
34
- // Find index of message in subtree and index of tx in a block.
124
+ // Find the index of the message in the tx, index of the tx in the block, and index of the block in the epoch.
35
125
  let messageIndexInTx = -1;
36
- const txIndex = messagesForAllTxs.findIndex(messages => {
37
- messageIndexInTx = messages.findIndex(msg => msg.equals(message));
38
- return messageIndexInTx !== -1;
126
+ let txIndex = -1;
127
+ let blockIndex = -1;
128
+ const checkpointIndex = messagesInEpoch.findIndex(messagesInCheckpoint => {
129
+ blockIndex = messagesInCheckpoint.findIndex(messagesInBlock => {
130
+ txIndex = messagesInBlock.findIndex(messagesInTx => {
131
+ messageIndexInTx = messagesInTx.findIndex(msg => msg.equals(message));
132
+ return messageIndexInTx !== -1;
133
+ });
134
+ return txIndex !== -1;
135
+ });
136
+ return blockIndex !== -1;
39
137
  });
40
138
 
41
- if (txIndex === -1) {
139
+ if (checkpointIndex === -1) {
42
140
  throw new Error('The L2ToL1Message you are trying to prove inclusion of does not exist');
43
141
  }
44
142
 
45
- // Get the txOutHash and the sibling path of the message in the tx subtree.
46
- const txMessages = messagesForAllTxs[txIndex];
47
- const txOutHashTree = UnbalancedMerkleTreeCalculator.create(txMessages.map(msg => msg.toBuffer()));
48
- const txOutHash = txOutHashTree.getRoot();
49
- const messagePathInSubtree = txOutHashTree.getSiblingPath(message.toBuffer());
50
-
51
- // Calculate txOutHash for all txs.
52
- const txSubtreeRoots = messagesForAllTxs.map((messages, i) => {
53
- // For a tx with no messages, we have to set an out hash of 0 to match what the circuit does.
54
- if (messages.length === 0) {
55
- return Fr.ZERO;
56
- }
143
+ // Build the tx tree.
144
+ const messagesInTx = messagesInEpoch[checkpointIndex][blockIndex][txIndex];
145
+ const txTree = UnbalancedMerkleTreeCalculator.create(messagesInTx.map(msg => msg.toBuffer()));
146
+ // Get the sibling path of the target message in the tx tree.
147
+ const pathToMessageInTxSubtree = txTree.getSiblingPathByLeafIndex(messageIndexInTx);
57
148
 
58
- if (i === txIndex) {
59
- return Fr.fromBuffer(txOutHash);
60
- }
149
+ // Build the tree of the block containing the target message.
150
+ const blockTree = buildBlockTree(messagesInEpoch[checkpointIndex][blockIndex]);
151
+ // Get the sibling path of the tx out hash in the block tree.
152
+ const pathToTxOutHashInBlockTree = blockTree.getSiblingPathByLeafIndex(txIndex);
61
153
 
62
- const root = computeUnbalancedShaRoot(messages.map(msg => msg.toBuffer()));
63
- return Fr.fromBuffer(root);
64
- });
154
+ // Build the tree of the checkpoint containing the target message.
155
+ const checkpointTree = buildCheckpointTree(messagesInEpoch[checkpointIndex]);
156
+ // Get the sibling path of the block out hash in the checkpoint tree.
157
+ const pathToBlockOutHashInCheckpointTree = checkpointTree.getSiblingPathByLeafIndex(blockIndex);
65
158
 
66
- // Construct the top tree.
67
- // The leaves of this tree are the `txOutHashes`.
68
- // The root of this tree should match the `out_hash` calculated in the circuits. Zero hashes are compressed to reduce
69
- // cost if the non-zero leaves result in a shorter path.
70
- const valueToCompress = Buffer.alloc(32);
71
- const topTree = UnbalancedMerkleTreeCalculator.create(
72
- txSubtreeRoots.map(root => root.toBuffer()),
73
- valueToCompress,
159
+ // Compute the out hashes of all checkpoints in the epoch.
160
+ let checkpointOutHashes = messagesInEpoch.map((messagesInCheckpoint, i) => {
161
+ if (i === checkpointIndex) {
162
+ return checkpointTree.getRoot();
163
+ }
164
+ return buildCheckpointTree(messagesInCheckpoint).getRoot();
165
+ });
166
+ // Pad to AZTEC_MAX_EPOCH_DURATION with zeros.
167
+ checkpointOutHashes = checkpointOutHashes.concat(
168
+ Array.from({ length: OUT_HASH_TREE_LEAF_COUNT - messagesInEpoch.length }, () => Buffer.alloc(32)),
74
169
  );
75
- const root = Fr.fromBuffer(topTree.getRoot());
76
170
 
77
- // Compute the combined sibling path by appending the tx subtree path to the top tree path.
78
- const txPathInTopTree = topTree.getSiblingPath(txOutHash);
79
- const combinedPath = messagePathInSubtree.toBufferArray().concat(txPathInTopTree.toBufferArray());
171
+ // Build the epoch tree with all the checkpoint out hashes, including the padded zeros.
172
+ // Note: The epoch tree is actually a balanced tree, but we use an unbalanced tree calculator here to avoid turning
173
+ // this function into async.
174
+ const epochTree = UnbalancedMerkleTreeCalculator.create(checkpointOutHashes);
175
+ // Get the sibling path of the checkpoint out hash in the epoch tree.
176
+ const pathToCheckpointOutHashInEpochTree = epochTree.getSiblingPathByLeafIndex(checkpointIndex);
177
+
178
+ // The root of the epoch tree should match the `out_hash` in the root rollup's public inputs.
179
+ const root = Fr.fromBuffer(epochTree.getRoot());
180
+
181
+ // Compute the combined sibling path by appending the tx subtree path to the block tree path, then to the checkpoint
182
+ // tree path, then to the epoch tree path.
183
+ const combinedPath = pathToMessageInTxSubtree
184
+ .toBufferArray()
185
+ .concat(pathToTxOutHashInBlockTree.toBufferArray())
186
+ .concat(pathToBlockOutHashInCheckpointTree.toBufferArray())
187
+ .concat(pathToCheckpointOutHashInEpochTree.toBufferArray());
80
188
 
81
189
  // Compute the combined index.
82
- // It is the index of the message in the balanced tree at its current height.
83
- const txLeafIndexAtLevel = topTree.getLeafLocation(txIndex).index;
84
- const messageLeafPosition = txOutHashTree.getLeafLocation(messageIndexInTx);
85
- const numLeavesInLeftSubtrees = txLeafIndexAtLevel * (1 << messageLeafPosition.level);
86
- const combinedIndex = numLeavesInLeftSubtrees + messageLeafPosition.index;
190
+ // It is the index of the message in the balanced tree (by filling up the wonky tree with empty nodes) at its current
191
+ // height. It's used to validate the membership proof.
192
+ const messageLeafPosition = txTree.getLeafLocation(messageIndexInTx);
193
+ const txLeafPosition = blockTree.getLeafLocation(txIndex);
194
+ const blockLeafPosition = checkpointTree.getLeafLocation(blockIndex);
195
+ const checkpointLeafPosition = epochTree.getLeafLocation(checkpointIndex);
196
+ const numLeavesInLeftCheckpoints = checkpointLeafPosition.index * (1 << blockLeafPosition.level);
197
+ const indexAtCheckpointLevel = numLeavesInLeftCheckpoints + blockLeafPosition.index;
198
+ const numLeavesInLeftBlocks = indexAtCheckpointLevel * (1 << txLeafPosition.level);
199
+ const indexAtTxLevel = numLeavesInLeftBlocks + txLeafPosition.index;
200
+ const numLeavesInLeftTxs = indexAtTxLevel * (1 << messageLeafPosition.level);
201
+ const combinedIndex = numLeavesInLeftTxs + messageLeafPosition.index;
87
202
 
88
203
  return {
89
204
  root,
@@ -92,8 +207,19 @@ export function computeL2ToL1MembershipWitnessFromMessagesForAllTxs(
92
207
  };
93
208
  }
94
209
 
95
- export function getL2ToL1MessageLeafId(
96
- membershipWitness: Pick<L2ToL1MembershipWitness, 'leafIndex' | 'siblingPath'>,
97
- ): bigint {
98
- return 2n ** BigInt(membershipWitness.siblingPath.pathSize) + membershipWitness.leafIndex;
210
+ function buildCheckpointTree(messagesInCheckpoint: Fr[][][]) {
211
+ const blockOutHashes = messagesInCheckpoint.map(messagesInBlock => buildBlockTree(messagesInBlock).getRoot());
212
+ return buildCompressedTree(blockOutHashes);
213
+ }
214
+
215
+ function buildBlockTree(messagesInBlock: Fr[][]) {
216
+ const txOutHashes = messagesInBlock.map(messages => computeUnbalancedShaRoot(messages.map(msg => msg.toBuffer())));
217
+ return buildCompressedTree(txOutHashes);
218
+ }
219
+
220
+ function buildCompressedTree(leaves: Buffer[]) {
221
+ // Note: If a block or tx has no messages (i.e. leaf == Buffer.alloc(32)), we ignore that branch and only accumulate
222
+ // the non-zero hashes to match what the circuits do.
223
+ const valueToCompress = Buffer.alloc(32);
224
+ return UnbalancedMerkleTreeCalculator.create(leaves, valueToCompress);
99
225
  }
@@ -1,36 +1,77 @@
1
+ import { OUT_HASH_TREE_LEAF_COUNT } from '@aztec/constants';
2
+ import { padArrayEnd } from '@aztec/foundation/collection';
1
3
  import { Fr } from '@aztec/foundation/curves/bn254';
2
- import { UnbalancedMerkleTreeCalculator, computeUnbalancedShaRoot } from '@aztec/foundation/trees';
4
+ import { computeBalancedShaRoot, computeUnbalancedShaRoot, computeWonkyShaRoot } from '@aztec/foundation/trees';
3
5
 
6
+ /**
7
+ * Computes the out hash of a tx. It's the root of the unbalanced tree of all the L2-to-L1 messages emitted by the tx.
8
+ * @param messages - The L2-to-L1 messages emitted by the tx.
9
+ * @returns The out hash of the tx.
10
+ */
4
11
  export function computeTxOutHash(messages: Fr[]): Fr {
12
+ // Must match the implementation in `tx_base_public_inputs_composer.nr > compute_kernel_out_hash()`
5
13
  if (!messages.length) {
6
14
  return Fr.ZERO;
7
15
  }
8
- // Tx out hash is the root of the unbalanced merkle tree of all the messages.
9
- // Zero hashes (which should not happen) are not compressed.
16
+ // It's an unbalanced tree because zero hashes (which should not happen) will be included.
10
17
  return Fr.fromBuffer(computeUnbalancedShaRoot(messages.map(msg => msg.toBuffer())));
11
18
  }
12
19
 
13
- export function computeBlockOutHash(messagesPerBlock: Fr[][]): Fr {
14
- const txOutHashes = messagesPerBlock.map(messages => computeTxOutHash(messages));
15
- return aggregateOutHashes(txOutHashes);
20
+ /**
21
+ * Computes the out hash of a block. It's the root of the wonky tree of all the tx out hashes.
22
+ * @param messagesPerTx - The L2-to-L1 messages emitted by the txs in the block. This is an array of message arrays.
23
+ * The array at index 0 contains the messages emitted by the first tx, the array at index 1 contains the messages
24
+ * emitted by the second tx, and so on.
25
+ * @returns The out hash of the block.
26
+ */
27
+ export function computeBlockOutHash(messagesPerTx: Fr[][]): Fr {
28
+ // See how the tx out hashes are aggregated into a block out hash in `merge_tx_rollups.nr > accumulate_out_hash()`.
29
+ const txOutHashes = messagesPerTx.map(messages => computeTxOutHash(messages));
30
+ return Fr.fromBuffer(computeWonkyShaRoot(txOutHashes.map(hash => hash.toBuffer())));
16
31
  }
17
32
 
18
- export function computeCheckpointOutHash(messagesForAllTxs: Fr[][][]): Fr {
19
- const blockOutHashes = messagesForAllTxs.map(block => computeBlockOutHash(block));
20
- return aggregateOutHashes(blockOutHashes);
33
+ /**
34
+ * Computes the out hash of a checkpoint. It's the root of the wonky tree of all the block out hashes.
35
+ * @param messagesPerBlock - The L2-to-L1 messages emitted by the txs in the blocks in the checkpoint. This is an array
36
+ * of arrays of messages. The array at index 0 contains the arrays of messages emitted by the first block, the array at
37
+ * index 1 contains the arrays of messages emitted by the second block, and so on.
38
+ * @returns The out hash of the checkpoint.
39
+ */
40
+ export function computeCheckpointOutHash(messagesPerBlock: Fr[][][]): Fr {
41
+ // See how the block out hashes are aggregated into a checkpoint out hash in `merge_block_rollups.nr > accumulate_out_hash()`.
42
+ const blockOutHashes = messagesPerBlock.map(block => computeBlockOutHash(block));
43
+ return Fr.fromBuffer(computeWonkyShaRoot(blockOutHashes.map(hash => hash.toBuffer())));
21
44
  }
22
45
 
23
- // The root of this tree should match the `out_hash` calculated in the circuits. Zero hashes are compressed to reduce
24
- // cost if the non-zero leaves result in a shorter path.
25
- function aggregateOutHashes(outHashes: Fr[]): Fr {
26
- if (!outHashes.length) {
27
- return Fr.ZERO;
28
- }
29
-
30
- const valueToCompress = Buffer.alloc(32);
31
- const tree = UnbalancedMerkleTreeCalculator.create(
32
- outHashes.map(hash => hash.toBuffer()),
33
- valueToCompress,
46
+ /**
47
+ * Computes the accumulated (epoch) out hash of a checkpoint. It's the root of the balanced tree of all the out hashes
48
+ * from the first checkpoint in an epoch to the current checkpoint.
49
+ * It's this value that's set to the checkpoint header and validated on L1 instead of the checkpoint out hash.
50
+ * @param checkpointOutHashes - The out hashes of all checkpoints in the epoch.
51
+ * @returns The accumulated (epoch) out hash.
52
+ */
53
+ export function accumulateCheckpointOutHashes(checkpointOutHashes: Fr[]): Fr {
54
+ // See how the checkpoint out hashes are accumulated in `checkpoint_rollup_public_inputs_composer.nr > accumulate_checkpoint_out_hash()`.
55
+ const paddedOutHashes = padArrayEnd(
56
+ checkpointOutHashes.map(hash => hash.toBuffer()),
57
+ Buffer.alloc(32),
58
+ OUT_HASH_TREE_LEAF_COUNT,
34
59
  );
35
- return Fr.fromBuffer(tree.getRoot());
60
+ return Fr.fromBuffer(computeBalancedShaRoot(paddedOutHashes));
61
+ }
62
+
63
+ /**
64
+ * Computes the epoch out hash. It's the root of the balanced tree of all the checkpoint out hashes.
65
+ * It should match the **accumulated** out hash of the last checkpoint in the epoch.
66
+ * This value will be inserted into the Outbox on L1.
67
+ * @param messagesPerCheckpoint - The L2-to-L1 messages emitted by the txs in the blocks in the checkpoints in the epoch.
68
+ * This is an array of arrays of arrays of messages. The array at index 0 contains the arrays of arrays of messages
69
+ * emitted by the first checkpoint, the array at index 1 contains the arrays of arrays of messages emitted by the second
70
+ * checkpoint, and so on.
71
+ * @returns The epoch out hash.
72
+ */
73
+ export function computeEpochOutHash(messagesPerCheckpoint: Fr[][][][]): Fr {
74
+ // See how the accumulated out hash is assigned to the root rollup's public inputs in `root_rollup.nr`.
75
+ const checkpointOutHashes = messagesPerCheckpoint.map(checkpoint => computeCheckpointOutHash(checkpoint));
76
+ return accumulateCheckpointOutHashes(checkpointOutHashes);
36
77
  }