@aztec/stdlib 0.0.1-commit.9b94fc1 → 0.0.1-commit.9d2bcf6d

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 (1054) hide show
  1. package/dest/abi/abi.d.ts +603 -5
  2. package/dest/abi/abi.d.ts.map +1 -1
  3. package/dest/abi/abi.js +7 -7
  4. package/dest/abi/authorization_selector.d.ts +2 -2
  5. package/dest/abi/authorization_selector.d.ts.map +1 -1
  6. package/dest/abi/authorization_selector.js +2 -1
  7. package/dest/abi/buffer.d.ts +2 -2
  8. package/dest/abi/buffer.d.ts.map +1 -1
  9. package/dest/abi/buffer.js +1 -1
  10. package/dest/abi/contract_artifact.d.ts +2 -2
  11. package/dest/abi/contract_artifact.d.ts.map +1 -1
  12. package/dest/abi/contract_artifact.js +1 -1
  13. package/dest/abi/decoder.d.ts +2 -2
  14. package/dest/abi/decoder.d.ts.map +1 -1
  15. package/dest/abi/encoder.d.ts +2 -2
  16. package/dest/abi/encoder.d.ts.map +1 -1
  17. package/dest/abi/encoder.js +1 -1
  18. package/dest/abi/event_selector.d.ts +2 -2
  19. package/dest/abi/event_selector.d.ts.map +1 -1
  20. package/dest/abi/event_selector.js +2 -1
  21. package/dest/abi/function_call.d.ts +10 -2
  22. package/dest/abi/function_call.d.ts.map +1 -1
  23. package/dest/abi/function_selector.d.ts +3 -2
  24. package/dest/abi/function_selector.d.ts.map +1 -1
  25. package/dest/abi/function_selector.js +9 -1
  26. package/dest/abi/note_selector.d.ts +2 -2
  27. package/dest/abi/note_selector.d.ts.map +1 -1
  28. package/dest/abi/note_selector.js +2 -2
  29. package/dest/abi/selector.d.ts +2 -2
  30. package/dest/abi/selector.d.ts.map +1 -1
  31. package/dest/abi/selector.js +4 -2
  32. package/dest/abi/utils.d.ts +7 -1
  33. package/dest/abi/utils.d.ts.map +1 -1
  34. package/dest/abi/utils.js +7 -0
  35. package/dest/auth_witness/auth_witness.d.ts +3 -2
  36. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  37. package/dest/auth_witness/auth_witness.js +2 -2
  38. package/dest/avm/avm.d.ts +598 -386
  39. package/dest/avm/avm.d.ts.map +1 -1
  40. package/dest/avm/avm.js +238 -22
  41. package/dest/avm/avm_accumulated_data.d.ts +31 -4
  42. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  43. package/dest/avm/avm_accumulated_data.js +6 -3
  44. package/dest/avm/avm_circuit_public_inputs.d.ts +14 -12
  45. package/dest/avm/avm_circuit_public_inputs.d.ts.map +1 -1
  46. package/dest/avm/avm_circuit_public_inputs.js +4 -2
  47. package/dest/avm/avm_proving_request.d.ts +306 -302
  48. package/dest/avm/avm_proving_request.d.ts.map +1 -1
  49. package/dest/avm/contract_storage_read.d.ts +14 -2
  50. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  51. package/dest/avm/contract_storage_read.js +1 -1
  52. package/dest/avm/contract_storage_update_request.d.ts +14 -2
  53. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  54. package/dest/avm/contract_storage_update_request.js +1 -1
  55. package/dest/avm/message_pack.d.ts +1 -1
  56. package/dest/avm/message_pack.d.ts.map +1 -1
  57. package/dest/avm/message_pack.js +2 -1
  58. package/dest/avm/public_call_stack_item_compressed.d.ts +4 -2
  59. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  60. package/dest/avm/public_call_stack_item_compressed.js +1 -1
  61. package/dest/avm/public_data_read.d.ts +11 -2
  62. package/dest/avm/public_data_read.d.ts.map +1 -1
  63. package/dest/avm/public_data_read.js +1 -1
  64. package/dest/avm/public_data_update_request.d.ts +11 -2
  65. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  66. package/dest/avm/public_data_update_request.js +4 -2
  67. package/dest/avm/public_data_write.d.ts +8 -2
  68. package/dest/avm/public_data_write.d.ts.map +1 -1
  69. package/dest/avm/public_data_write.js +1 -1
  70. package/dest/avm/public_inner_call_request.d.ts +5 -2
  71. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  72. package/dest/avm/public_inner_call_request.js +3 -1
  73. package/dest/avm/revert_code.d.ts +5 -5
  74. package/dest/avm/revert_code.d.ts.map +1 -1
  75. package/dest/avm/revert_code.js +4 -2
  76. package/dest/aztec-address/index.d.ts +3 -2
  77. package/dest/aztec-address/index.d.ts.map +1 -1
  78. package/dest/aztec-address/index.js +5 -2
  79. package/dest/block/attestation_info.d.ts +5 -5
  80. package/dest/block/attestation_info.d.ts.map +1 -1
  81. package/dest/block/attestation_info.js +5 -5
  82. package/dest/block/block_hash.d.ts +19 -15
  83. package/dest/block/block_hash.d.ts.map +1 -1
  84. package/dest/block/block_hash.js +23 -21
  85. package/dest/block/block_parameter.d.ts +6 -0
  86. package/dest/block/block_parameter.d.ts.map +1 -0
  87. package/dest/block/block_parameter.js +8 -0
  88. package/dest/block/body.d.ts +1 -1
  89. package/dest/block/body.d.ts.map +1 -1
  90. package/dest/block/body.js +5 -2
  91. package/dest/block/checkpointed_l2_block.d.ts +150 -0
  92. package/dest/block/checkpointed_l2_block.d.ts.map +1 -0
  93. package/dest/block/checkpointed_l2_block.js +46 -0
  94. package/dest/block/in_block.d.ts +34 -15
  95. package/dest/block/in_block.d.ts.map +1 -1
  96. package/dest/block/in_block.js +21 -12
  97. package/dest/block/index.d.ts +3 -5
  98. package/dest/block/index.d.ts.map +1 -1
  99. package/dest/block/index.js +2 -4
  100. package/dest/block/l2_block.d.ts +59 -59
  101. package/dest/block/l2_block.d.ts.map +1 -1
  102. package/dest/block/l2_block.js +69 -110
  103. package/dest/block/l2_block_info.d.ts +16 -11
  104. package/dest/block/l2_block_info.d.ts.map +1 -1
  105. package/dest/block/l2_block_info.js +8 -7
  106. package/dest/block/l2_block_source.d.ts +371 -151
  107. package/dest/block/l2_block_source.d.ts.map +1 -1
  108. package/dest/block/l2_block_source.js +29 -16
  109. package/dest/block/l2_block_stream/index.d.ts +2 -1
  110. package/dest/block/l2_block_stream/index.d.ts.map +1 -1
  111. package/dest/block/l2_block_stream/index.js +1 -0
  112. package/dest/block/l2_block_stream/interfaces.d.ts +15 -5
  113. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  114. package/dest/block/l2_block_stream/l2_block_stream.d.ts +13 -3
  115. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  116. package/dest/block/l2_block_stream/l2_block_stream.js +116 -32
  117. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +24 -15
  118. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
  119. package/dest/block/l2_block_stream/l2_tips_memory_store.js +55 -59
  120. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
  121. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
  122. package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
  123. package/dest/block/proposal/attestations_and_signers.d.ts +2 -2
  124. package/dest/block/proposal/attestations_and_signers.d.ts.map +1 -1
  125. package/dest/block/proposal/committee_attestation.d.ts +2 -2
  126. package/dest/block/proposal/committee_attestation.d.ts.map +1 -1
  127. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  128. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  129. package/dest/block/test/l2_tips_store_test_suite.js +482 -43
  130. package/dest/block/validate_block_result.d.ts +24 -24
  131. package/dest/block/validate_block_result.d.ts.map +1 -1
  132. package/dest/block/validate_block_result.js +18 -17
  133. package/dest/checkpoint/checkpoint.d.ts +57 -15
  134. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  135. package/dest/checkpoint/checkpoint.js +61 -10
  136. package/dest/checkpoint/checkpoint_info.d.ts +38 -0
  137. package/dest/checkpoint/checkpoint_info.d.ts.map +1 -0
  138. package/dest/checkpoint/checkpoint_info.js +34 -0
  139. package/dest/checkpoint/index.d.ts +2 -1
  140. package/dest/checkpoint/index.d.ts.map +1 -1
  141. package/dest/checkpoint/index.js +1 -0
  142. package/dest/checkpoint/published_checkpoint.d.ts +42 -14
  143. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  144. package/dest/checkpoint/published_checkpoint.js +15 -4
  145. package/dest/config/node-rpc-config.js +1 -1
  146. package/dest/contract/artifact_hash.d.ts +2 -2
  147. package/dest/contract/artifact_hash.d.ts.map +1 -1
  148. package/dest/contract/artifact_hash.js +2 -2
  149. package/dest/contract/complete_address.d.ts +5 -2
  150. package/dest/contract/complete_address.d.ts.map +1 -1
  151. package/dest/contract/complete_address.js +1 -1
  152. package/dest/contract/contract_address.d.ts +2 -2
  153. package/dest/contract/contract_address.d.ts.map +1 -1
  154. package/dest/contract/contract_address.js +3 -3
  155. package/dest/contract/contract_class.d.ts +2 -2
  156. package/dest/contract/contract_class.d.ts.map +1 -1
  157. package/dest/contract/contract_class.js +1 -1
  158. package/dest/contract/contract_class_id.d.ts +3 -3
  159. package/dest/contract/contract_class_id.d.ts.map +1 -1
  160. package/dest/contract/contract_class_id.js +4 -4
  161. package/dest/contract/contract_deployment_data.d.ts +5 -5
  162. package/dest/contract/contract_instance.d.ts +2 -2
  163. package/dest/contract/contract_instance.d.ts.map +1 -1
  164. package/dest/contract/contract_instance.js +1 -1
  165. package/dest/contract/contract_instance_update.d.ts +2 -2
  166. package/dest/contract/contract_instance_update.d.ts.map +1 -1
  167. package/dest/contract/contract_instance_update.js +1 -1
  168. package/dest/contract/deployment_info.d.ts +2 -2
  169. package/dest/contract/deployment_info.d.ts.map +1 -1
  170. package/dest/contract/index.d.ts +1 -3
  171. package/dest/contract/index.d.ts.map +1 -1
  172. package/dest/contract/index.js +0 -2
  173. package/dest/contract/interfaces/contract_class.d.ts +19 -14
  174. package/dest/contract/interfaces/contract_class.d.ts.map +1 -1
  175. package/dest/contract/interfaces/contract_class.js +35 -18
  176. package/dest/contract/interfaces/contract_data_source.d.ts +4 -3
  177. package/dest/contract/interfaces/contract_data_source.d.ts.map +1 -1
  178. package/dest/contract/interfaces/contract_instance.d.ts +40 -31
  179. package/dest/contract/interfaces/contract_instance.d.ts.map +1 -1
  180. package/dest/contract/interfaces/contract_instance.js +30 -5
  181. package/dest/contract/interfaces/contract_instance_update.d.ts +7 -8
  182. package/dest/contract/interfaces/contract_instance_update.d.ts.map +1 -1
  183. package/dest/contract/interfaces/contract_instance_update.js +5 -5
  184. package/dest/contract/partial_address.d.ts +2 -2
  185. package/dest/contract/partial_address.d.ts.map +1 -1
  186. package/dest/contract/private_function.d.ts +2 -2
  187. package/dest/contract/private_function.d.ts.map +1 -1
  188. package/dest/contract/private_function.js +4 -4
  189. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  190. package/dest/contract/private_function_membership_proof.js +3 -3
  191. package/dest/contract/utility_function_membership_proof.js +1 -1
  192. package/dest/database-version/database_version.d.ts +58 -0
  193. package/dest/database-version/database_version.d.ts.map +1 -0
  194. package/dest/database-version/database_version.js +69 -0
  195. package/dest/database-version/version_manager.d.ts +3 -49
  196. package/dest/database-version/version_manager.d.ts.map +1 -1
  197. package/dest/database-version/version_manager.js +1 -64
  198. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +3 -3
  199. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  200. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +9 -12
  201. package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts +2 -2
  202. package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts.map +1 -1
  203. package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.js +1 -1
  204. package/dest/delayed_public_mutable/scheduled_value_change.d.ts +2 -2
  205. package/dest/delayed_public_mutable/scheduled_value_change.d.ts.map +1 -1
  206. package/dest/delayed_public_mutable/scheduled_value_change.js +1 -1
  207. package/dest/deserialization/index.d.ts +11 -0
  208. package/dest/deserialization/index.d.ts.map +1 -0
  209. package/dest/deserialization/index.js +10 -0
  210. package/dest/epoch-helpers/index.d.ts +3 -1
  211. package/dest/epoch-helpers/index.d.ts.map +1 -1
  212. package/dest/epoch-helpers/index.js +8 -4
  213. package/dest/errors/proving_error.d.ts +2 -2
  214. package/dest/errors/proving_error.d.ts.map +1 -1
  215. package/dest/errors/simulation_error.d.ts +2 -2
  216. package/dest/errors/simulation_error.d.ts.map +1 -1
  217. package/dest/fees/transaction_fee.d.ts +2 -2
  218. package/dest/fees/transaction_fee.d.ts.map +1 -1
  219. package/dest/gas/gas.d.ts +2 -2
  220. package/dest/gas/gas.d.ts.map +1 -1
  221. package/dest/gas/gas.js +4 -2
  222. package/dest/gas/gas_fees.d.ts +2 -2
  223. package/dest/gas/gas_fees.d.ts.map +1 -1
  224. package/dest/gas/gas_fees.js +3 -1
  225. package/dest/gas/gas_settings.d.ts +2 -2
  226. package/dest/gas/gas_settings.d.ts.map +1 -1
  227. package/dest/gas/gas_settings.js +1 -1
  228. package/dest/hash/hash.d.ts +2 -10
  229. package/dest/hash/hash.d.ts.map +1 -1
  230. package/dest/hash/hash.js +5 -16
  231. package/dest/hash/map_slot.d.ts +2 -2
  232. package/dest/hash/map_slot.d.ts.map +1 -1
  233. package/dest/hash/map_slot.js +4 -3
  234. package/dest/interfaces/allowed_element.d.ts +8 -9
  235. package/dest/interfaces/allowed_element.d.ts.map +1 -1
  236. package/dest/interfaces/allowed_element.js +3 -3
  237. package/dest/interfaces/api_limit.d.ts +3 -1
  238. package/dest/interfaces/api_limit.d.ts.map +1 -1
  239. package/dest/interfaces/api_limit.js +2 -0
  240. package/dest/interfaces/archiver.d.ts +12 -7
  241. package/dest/interfaces/archiver.d.ts.map +1 -1
  242. package/dest/interfaces/archiver.js +35 -21
  243. package/dest/interfaces/aztec-node-admin.d.ts +102 -41
  244. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  245. package/dest/interfaces/aztec-node-admin.js +6 -4
  246. package/dest/interfaces/aztec-node.d.ts +89 -94
  247. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  248. package/dest/interfaces/aztec-node.js +32 -33
  249. package/dest/interfaces/block-builder.d.ts +24 -14
  250. package/dest/interfaces/block-builder.d.ts.map +1 -1
  251. package/dest/interfaces/block-builder.js +16 -1
  252. package/dest/interfaces/configs.d.ts +56 -27
  253. package/dest/interfaces/configs.d.ts.map +1 -1
  254. package/dest/interfaces/configs.js +12 -6
  255. package/dest/interfaces/epoch-prover.d.ts +5 -5
  256. package/dest/interfaces/epoch-prover.d.ts.map +1 -1
  257. package/dest/interfaces/get_logs_response.d.ts +23 -6
  258. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  259. package/dest/interfaces/get_logs_response.js +5 -4
  260. package/dest/interfaces/l2_logs_source.d.ts +21 -15
  261. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  262. package/dest/interfaces/merkle_tree_operations.d.ts +5 -4
  263. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  264. package/dest/interfaces/p2p.d.ts +7 -9
  265. package/dest/interfaces/p2p.d.ts.map +1 -1
  266. package/dest/interfaces/p2p.js +3 -4
  267. package/dest/interfaces/prover-broker.d.ts +16 -1
  268. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  269. package/dest/interfaces/prover-broker.js +4 -1
  270. package/dest/interfaces/prover-client.d.ts +19 -3
  271. package/dest/interfaces/prover-client.d.ts.map +1 -1
  272. package/dest/interfaces/prover-client.js +16 -4
  273. package/dest/interfaces/proving-job.d.ts +226 -222
  274. package/dest/interfaces/proving-job.d.ts.map +1 -1
  275. package/dest/interfaces/proving-job.js +1 -7
  276. package/dest/interfaces/public_state_source.d.ts +2 -2
  277. package/dest/interfaces/public_state_source.d.ts.map +1 -1
  278. package/dest/interfaces/server_circuit_prover.d.ts +4 -3
  279. package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
  280. package/dest/interfaces/slasher.d.ts +1 -1
  281. package/dest/interfaces/slasher.d.ts.map +1 -1
  282. package/dest/interfaces/slasher.js +3 -3
  283. package/dest/interfaces/validator.d.ts +147 -26
  284. package/dest/interfaces/validator.d.ts.map +1 -1
  285. package/dest/interfaces/validator.js +9 -7
  286. package/dest/interfaces/world_state.d.ts +23 -31
  287. package/dest/interfaces/world_state.d.ts.map +1 -1
  288. package/dest/interfaces/world_state.js +4 -3
  289. package/dest/kernel/claimed_length_array.d.ts +2 -2
  290. package/dest/kernel/claimed_length_array.d.ts.map +1 -1
  291. package/dest/kernel/claimed_length_array.js +3 -1
  292. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +6 -5
  293. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  294. package/dest/kernel/hints/build_note_hash_read_request_hints.js +19 -10
  295. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +4 -4
  296. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  297. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
  298. package/dest/kernel/hints/find_private_kernel_reset_dimensions.d.ts +1 -1
  299. package/dest/kernel/hints/find_private_kernel_reset_dimensions.d.ts.map +1 -1
  300. package/dest/kernel/hints/find_private_kernel_reset_dimensions.js +1 -3
  301. package/dest/kernel/hints/key_validation_hint.d.ts +3 -2
  302. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  303. package/dest/kernel/hints/key_validation_hint.js +1 -1
  304. package/dest/kernel/hints/key_validation_request.d.ts +5 -3
  305. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  306. package/dest/kernel/hints/key_validation_request.js +2 -1
  307. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +7 -2
  308. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +1 -1
  309. package/dest/kernel/hints/key_validation_request_and_generator.js +1 -1
  310. package/dest/kernel/hints/note_hash_read_request_hints.d.ts +2 -2
  311. package/dest/kernel/hints/note_hash_read_request_hints.d.ts.map +1 -1
  312. package/dest/kernel/hints/note_hash_read_request_hints.js +1 -1
  313. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  314. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  315. package/dest/kernel/hints/read_request.d.ts +8 -2
  316. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  317. package/dest/kernel/hints/read_request.js +1 -1
  318. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  319. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  320. package/dest/kernel/hints/scoped_key_validation_request_and_generator.d.ts +2 -2
  321. package/dest/kernel/hints/scoped_key_validation_request_and_generator.d.ts.map +1 -1
  322. package/dest/kernel/hints/scoped_value_cache.d.ts +2 -2
  323. package/dest/kernel/hints/scoped_value_cache.d.ts.map +1 -1
  324. package/dest/kernel/hints/transient_data_squashing_hint.d.ts +2 -2
  325. package/dest/kernel/hints/transient_data_squashing_hint.d.ts.map +1 -1
  326. package/dest/kernel/hints/transient_data_squashing_hint.js +4 -2
  327. package/dest/kernel/hints/tree_leaf_read_request.d.ts +2 -2
  328. package/dest/kernel/hints/tree_leaf_read_request.d.ts.map +1 -1
  329. package/dest/kernel/hints/tree_leaf_read_request.js +1 -1
  330. package/dest/kernel/log_hash.d.ts +2 -2
  331. package/dest/kernel/log_hash.d.ts.map +1 -1
  332. package/dest/kernel/log_hash.js +4 -2
  333. package/dest/kernel/note_hash.d.ts +2 -2
  334. package/dest/kernel/note_hash.d.ts.map +1 -1
  335. package/dest/kernel/note_hash.js +1 -1
  336. package/dest/kernel/nullifier.d.ts +2 -2
  337. package/dest/kernel/nullifier.d.ts.map +1 -1
  338. package/dest/kernel/nullifier.js +1 -1
  339. package/dest/kernel/padded_side_effects.d.ts +2 -2
  340. package/dest/kernel/padded_side_effects.d.ts.map +1 -1
  341. package/dest/kernel/padded_side_effects.js +1 -1
  342. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  343. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  344. package/dest/kernel/private_call_data.d.ts +26 -2
  345. package/dest/kernel/private_call_data.d.ts.map +1 -1
  346. package/dest/kernel/private_call_data.js +1 -1
  347. package/dest/kernel/private_call_request.d.ts +17 -2
  348. package/dest/kernel/private_call_request.d.ts.map +1 -1
  349. package/dest/kernel/private_call_request.js +1 -1
  350. package/dest/kernel/private_circuit_public_inputs.d.ts +121 -48
  351. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  352. package/dest/kernel/private_circuit_public_inputs.js +60 -60
  353. package/dest/kernel/private_context_inputs.d.ts +2 -2
  354. package/dest/kernel/private_context_inputs.d.ts.map +1 -1
  355. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +32 -2
  356. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  357. package/dest/kernel/private_kernel_circuit_public_inputs.js +1 -1
  358. package/dest/kernel/private_kernel_data.d.ts +7 -1
  359. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  360. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +23 -2
  361. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  362. package/dest/kernel/private_kernel_init_circuit_private_inputs.js +1 -1
  363. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  364. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  365. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  366. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  367. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +10 -1
  368. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  369. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +24 -2
  370. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  371. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +1 -1
  372. package/dest/kernel/private_log_data.d.ts +2 -2
  373. package/dest/kernel/private_log_data.d.ts.map +1 -1
  374. package/dest/kernel/private_log_data.js +5 -2
  375. package/dest/kernel/private_to_avm_accumulated_data.d.ts +4 -4
  376. package/dest/kernel/private_to_avm_accumulated_data.d.ts.map +1 -1
  377. package/dest/kernel/private_to_avm_accumulated_data.js +6 -3
  378. package/dest/kernel/private_to_public_accumulated_data.d.ts +2 -2
  379. package/dest/kernel/private_to_public_accumulated_data.d.ts.map +1 -1
  380. package/dest/kernel/private_to_public_accumulated_data.js +4 -2
  381. package/dest/kernel/private_to_public_accumulated_data_builder.d.ts +2 -2
  382. package/dest/kernel/private_to_public_accumulated_data_builder.d.ts.map +1 -1
  383. package/dest/kernel/private_to_public_accumulated_data_builder.js +1 -1
  384. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +2 -2
  385. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  386. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +1 -1
  387. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +18 -2
  388. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  389. package/dest/kernel/private_to_rollup_accumulated_data.js +4 -2
  390. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +17 -2
  391. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  392. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +1 -1
  393. package/dest/kernel/private_validation_requests.d.ts +10 -1
  394. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  395. package/dest/kernel/private_validation_requests.js +3 -1
  396. package/dest/kernel/public_call_request.d.ts +23 -2
  397. package/dest/kernel/public_call_request.d.ts.map +1 -1
  398. package/dest/kernel/public_call_request.js +6 -3
  399. package/dest/kernel/utils/optional_number.d.ts +8 -2
  400. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  401. package/dest/keys/derivation.d.ts +7 -6
  402. package/dest/keys/derivation.d.ts.map +1 -1
  403. package/dest/keys/derivation.js +13 -10
  404. package/dest/keys/key_types.d.ts +1 -1
  405. package/dest/keys/public_key.d.ts +2 -2
  406. package/dest/keys/public_key.d.ts.map +1 -1
  407. package/dest/keys/public_keys.d.ts +7 -2
  408. package/dest/keys/public_keys.d.ts.map +1 -1
  409. package/dest/keys/public_keys.js +3 -2
  410. package/dest/keys/utils.d.ts +1 -1
  411. package/dest/keys/utils.d.ts.map +1 -1
  412. package/dest/keys/utils.js +7 -3
  413. package/dest/l1-contracts/slash_factory.d.ts +3 -2
  414. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  415. package/dest/l1-contracts/slash_factory.js +2 -1
  416. package/dest/logs/contract_class_log.d.ts +2 -2
  417. package/dest/logs/contract_class_log.d.ts.map +1 -1
  418. package/dest/logs/contract_class_log.js +5 -3
  419. package/dest/logs/debug_log.d.ts +2 -2
  420. package/dest/logs/debug_log.d.ts.map +1 -1
  421. package/dest/logs/debug_log.js +1 -1
  422. package/dest/logs/directional_app_tagging_secret.d.ts +2 -2
  423. package/dest/logs/directional_app_tagging_secret.d.ts.map +1 -1
  424. package/dest/logs/directional_app_tagging_secret.js +3 -2
  425. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  426. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  427. package/dest/logs/extended_public_log.d.ts +14 -4
  428. package/dest/logs/extended_public_log.d.ts.map +1 -1
  429. package/dest/logs/index.d.ts +3 -2
  430. package/dest/logs/index.d.ts.map +1 -1
  431. package/dest/logs/index.js +2 -1
  432. package/dest/logs/log_id.d.ts +20 -5
  433. package/dest/logs/log_id.d.ts.map +1 -1
  434. package/dest/logs/log_id.js +20 -11
  435. package/dest/logs/message_context.d.ts +2 -2
  436. package/dest/logs/message_context.d.ts.map +1 -1
  437. package/dest/logs/message_context.js +1 -1
  438. package/dest/logs/pending_tagged_log.d.ts +2 -2
  439. package/dest/logs/pending_tagged_log.d.ts.map +1 -1
  440. package/dest/logs/pending_tagged_log.js +1 -1
  441. package/dest/logs/private_log.d.ts +2 -2
  442. package/dest/logs/private_log.d.ts.map +1 -1
  443. package/dest/logs/private_log.js +6 -3
  444. package/dest/logs/public_log.d.ts +3 -2
  445. package/dest/logs/public_log.d.ts.map +1 -1
  446. package/dest/logs/public_log.js +7 -2
  447. package/dest/logs/shared_secret_derivation.d.ts +2 -2
  448. package/dest/logs/shared_secret_derivation.d.ts.map +1 -1
  449. package/dest/logs/shared_secret_derivation.js +1 -1
  450. package/dest/logs/siloed_tag.d.ts +23 -0
  451. package/dest/logs/siloed_tag.d.ts.map +1 -0
  452. package/dest/logs/siloed_tag.js +31 -0
  453. package/dest/logs/tag.d.ts +21 -0
  454. package/dest/logs/tag.d.ts.map +1 -0
  455. package/dest/logs/tag.js +30 -0
  456. package/dest/logs/tx_scoped_l2_log.d.ts +32 -38
  457. package/dest/logs/tx_scoped_l2_log.d.ts.map +1 -1
  458. package/dest/logs/tx_scoped_l2_log.js +40 -45
  459. package/dest/messaging/in_hash.d.ts +5 -3
  460. package/dest/messaging/in_hash.d.ts.map +1 -1
  461. package/dest/messaging/in_hash.js +4 -2
  462. package/dest/messaging/inbox_leaf.d.ts +10 -7
  463. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  464. package/dest/messaging/inbox_leaf.js +10 -9
  465. package/dest/messaging/l1_actor.d.ts +8 -2
  466. package/dest/messaging/l1_actor.d.ts.map +1 -1
  467. package/dest/messaging/l1_actor.js +2 -2
  468. package/dest/messaging/l1_to_l2_message.d.ts +7 -2
  469. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  470. package/dest/messaging/l1_to_l2_message.js +2 -2
  471. package/dest/messaging/l1_to_l2_message_source.d.ts +6 -10
  472. package/dest/messaging/l1_to_l2_message_source.d.ts.map +1 -1
  473. package/dest/messaging/l2_actor.d.ts +8 -2
  474. package/dest/messaging/l2_actor.d.ts.map +1 -1
  475. package/dest/messaging/l2_actor.js +2 -2
  476. package/dest/messaging/l2_to_l1_membership.d.ts +89 -6
  477. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  478. package/dest/messaging/l2_to_l1_membership.js +161 -43
  479. package/dest/messaging/l2_to_l1_message.d.ts +3 -2
  480. package/dest/messaging/l2_to_l1_message.d.ts.map +1 -1
  481. package/dest/messaging/l2_to_l1_message.js +4 -1
  482. package/dest/messaging/out_hash.d.ts +42 -4
  483. package/dest/messaging/out_hash.d.ts.map +1 -1
  484. package/dest/messaging/out_hash.js +55 -20
  485. package/dest/note/note.d.ts +2 -2
  486. package/dest/note/note.d.ts.map +1 -1
  487. package/dest/note/note.js +5 -2
  488. package/dest/note/note_dao.d.ts +48 -9
  489. package/dest/note/note_dao.d.ts.map +1 -1
  490. package/dest/note/note_dao.js +29 -15
  491. package/dest/note/notes_filter.d.ts +4 -2
  492. package/dest/note/notes_filter.d.ts.map +1 -1
  493. package/dest/note/notes_filter.js +1 -0
  494. package/dest/p2p/attestation_utils.d.ts +3 -3
  495. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  496. package/dest/p2p/attestation_utils.js +1 -1
  497. package/dest/p2p/block_proposal.d.ts +103 -24
  498. package/dest/p2p/block_proposal.d.ts.map +1 -1
  499. package/dest/p2p/block_proposal.js +142 -40
  500. package/dest/p2p/checkpoint_attestation.d.ts +81 -0
  501. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
  502. package/dest/p2p/{block_attestation.js → checkpoint_attestation.js} +24 -20
  503. package/dest/p2p/checkpoint_proposal.d.ts +167 -0
  504. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
  505. package/dest/p2p/checkpoint_proposal.js +229 -0
  506. package/dest/p2p/consensus_payload.d.ts +10 -10
  507. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  508. package/dest/p2p/consensus_payload.js +4 -6
  509. package/dest/p2p/constants.d.ts +3 -0
  510. package/dest/p2p/constants.d.ts.map +1 -0
  511. package/dest/p2p/constants.js +2 -0
  512. package/dest/p2p/gossipable.d.ts +4 -3
  513. package/dest/p2p/gossipable.d.ts.map +1 -1
  514. package/dest/p2p/gossipable.js +16 -5
  515. package/dest/p2p/index.d.ts +5 -2
  516. package/dest/p2p/index.d.ts.map +1 -1
  517. package/dest/p2p/index.js +4 -1
  518. package/dest/p2p/message_validator.d.ts +18 -3
  519. package/dest/p2p/message_validator.d.ts.map +1 -1
  520. package/dest/p2p/message_validator.js +2 -1
  521. package/dest/p2p/signature_utils.d.ts +5 -3
  522. package/dest/p2p/signature_utils.d.ts.map +1 -1
  523. package/dest/p2p/signature_utils.js +5 -2
  524. package/dest/p2p/signed_txs.d.ts +42 -0
  525. package/dest/p2p/signed_txs.d.ts.map +1 -0
  526. package/dest/p2p/signed_txs.js +75 -0
  527. package/dest/p2p/topic_type.d.ts +3 -2
  528. package/dest/p2p/topic_type.d.ts.map +1 -1
  529. package/dest/p2p/topic_type.js +10 -3
  530. package/dest/parity/parity_base_private_inputs.d.ts +4 -2
  531. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  532. package/dest/parity/parity_base_private_inputs.js +1 -1
  533. package/dest/parity/parity_public_inputs.d.ts +5 -2
  534. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  535. package/dest/parity/parity_public_inputs.js +1 -1
  536. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  537. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  538. package/dest/proofs/chonk_proof.d.ts +2 -2
  539. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  540. package/dest/proofs/chonk_proof.js +11 -6
  541. package/dest/proofs/proof.d.ts +5 -2
  542. package/dest/proofs/proof.d.ts.map +1 -1
  543. package/dest/proofs/proof.js +1 -1
  544. package/dest/proofs/proof_data.d.ts +13 -1
  545. package/dest/proofs/proof_data.d.ts.map +1 -1
  546. package/dest/proofs/proof_data.js +17 -0
  547. package/dest/proofs/recursive_proof.d.ts +11 -2
  548. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  549. package/dest/proofs/recursive_proof.js +1 -1
  550. package/dest/rollup/avm_proof_data.d.ts +3 -5
  551. package/dest/rollup/avm_proof_data.d.ts.map +1 -1
  552. package/dest/rollup/avm_proof_data.js +1 -9
  553. package/dest/rollup/base_rollup_hints.d.ts +35 -2
  554. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  555. package/dest/rollup/base_rollup_hints.js +1 -1
  556. package/dest/rollup/block_constant_data.d.ts +13 -2
  557. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  558. package/dest/rollup/block_constant_data.js +1 -1
  559. package/dest/rollup/block_headers_hash.d.ts +2 -2
  560. package/dest/rollup/block_headers_hash.d.ts.map +1 -1
  561. package/dest/rollup/block_headers_hash.js +2 -2
  562. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  563. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  564. package/dest/rollup/block_rollup_public_inputs.d.ts +48 -12
  565. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  566. package/dest/rollup/block_rollup_public_inputs.js +9 -13
  567. package/dest/rollup/block_root_rollup_private_inputs.d.ts +65 -2
  568. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  569. package/dest/rollup/block_root_rollup_private_inputs.js +1 -1
  570. package/dest/rollup/checkpoint_constant_data.d.ts +12 -2
  571. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  572. package/dest/rollup/checkpoint_constant_data.js +5 -2
  573. package/dest/rollup/checkpoint_header.d.ts +47 -13
  574. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  575. package/dest/rollup/checkpoint_header.js +55 -22
  576. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  577. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  578. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +42 -2
  579. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  580. package/dest/rollup/checkpoint_rollup_public_inputs.js +11 -3
  581. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +46 -4
  582. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  583. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +15 -3
  584. package/dest/rollup/epoch_constant_data.d.ts +17 -2
  585. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  586. package/dest/rollup/epoch_constant_data.js +1 -1
  587. package/dest/rollup/public_chonk_verifier_private_inputs.d.ts +2 -2
  588. package/dest/rollup/public_chonk_verifier_private_inputs.d.ts.map +1 -1
  589. package/dest/rollup/public_chonk_verifier_private_inputs.js +1 -1
  590. package/dest/rollup/public_chonk_verifier_public_inputs.d.ts +2 -2
  591. package/dest/rollup/public_chonk_verifier_public_inputs.d.ts.map +1 -1
  592. package/dest/rollup/public_chonk_verifier_public_inputs.js +1 -1
  593. package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts +1 -1
  594. package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts.map +1 -1
  595. package/dest/rollup/public_tx_base_rollup_private_inputs.js +2 -2
  596. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  597. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  598. package/dest/rollup/root_rollup_public_inputs.d.ts +19 -4
  599. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  600. package/dest/rollup/root_rollup_public_inputs.js +10 -4
  601. package/dest/rollup/tree_snapshot_diff_hints.d.ts +25 -2
  602. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  603. package/dest/rollup/tree_snapshot_diff_hints.js +1 -1
  604. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  605. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  606. package/dest/rollup/tx_rollup_public_inputs.d.ts +30 -2
  607. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  608. package/dest/rollup/tx_rollup_public_inputs.js +1 -1
  609. package/dest/schemas/schemas.d.ts +7 -4
  610. package/dest/schemas/schemas.d.ts.map +1 -1
  611. package/dest/schemas/schemas.js +2 -1
  612. package/dest/slashing/types.d.ts +4 -5
  613. package/dest/slashing/types.d.ts.map +1 -1
  614. package/dest/slashing/types.js +5 -5
  615. package/dest/snapshots/types.d.ts +1 -1
  616. package/dest/snapshots/types.d.ts.map +1 -1
  617. package/dest/snapshots/types.js +5 -5
  618. package/dest/stats/stats.d.ts +10 -8
  619. package/dest/stats/stats.d.ts.map +1 -1
  620. package/dest/tests/factories.d.ts +42 -12
  621. package/dest/tests/factories.d.ts.map +1 -1
  622. package/dest/tests/factories.js +99 -32
  623. package/dest/tests/jest.js +1 -1
  624. package/dest/tests/mocks.d.ts +87 -19
  625. package/dest/tests/mocks.d.ts.map +1 -1
  626. package/dest/tests/mocks.js +182 -57
  627. package/dest/trees/append_only_tree_snapshot.d.ts +14 -2
  628. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  629. package/dest/trees/append_only_tree_snapshot.js +4 -2
  630. package/dest/trees/database_public_state_source.d.ts +2 -2
  631. package/dest/trees/database_public_state_source.d.ts.map +1 -1
  632. package/dest/trees/database_public_state_source.js +1 -1
  633. package/dest/trees/nullifier_leaf.d.ts +14 -2
  634. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  635. package/dest/trees/nullifier_leaf.js +1 -1
  636. package/dest/trees/nullifier_membership_witness.d.ts +11 -2
  637. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  638. package/dest/trees/nullifier_membership_witness.js +1 -1
  639. package/dest/trees/public_data_leaf.d.ts +17 -2
  640. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  641. package/dest/trees/public_data_leaf.js +1 -1
  642. package/dest/trees/public_data_witness.d.ts +12 -2
  643. package/dest/trees/public_data_witness.d.ts.map +1 -1
  644. package/dest/trees/public_data_witness.js +1 -1
  645. package/dest/tx/block_header.d.ts +25 -12
  646. package/dest/tx/block_header.d.ts.map +1 -1
  647. package/dest/tx/block_header.js +15 -4
  648. package/dest/tx/call_context.d.ts +14 -2
  649. package/dest/tx/call_context.d.ts.map +1 -1
  650. package/dest/tx/call_context.js +3 -1
  651. package/dest/tx/capsule.d.ts +5 -2
  652. package/dest/tx/capsule.d.ts.map +1 -1
  653. package/dest/tx/capsule.js +1 -1
  654. package/dest/tx/execution_payload.d.ts +9 -1
  655. package/dest/tx/execution_payload.d.ts.map +1 -1
  656. package/dest/tx/function_data.d.ts +5 -3
  657. package/dest/tx/function_data.d.ts.map +1 -1
  658. package/dest/tx/function_data.js +1 -1
  659. package/dest/tx/global_variable_builder.d.ts +5 -3
  660. package/dest/tx/global_variable_builder.d.ts.map +1 -1
  661. package/dest/tx/global_variables.d.ts +27 -12
  662. package/dest/tx/global_variables.d.ts.map +1 -1
  663. package/dest/tx/global_variables.js +11 -9
  664. package/dest/tx/hashed_values.d.ts +8 -2
  665. package/dest/tx/hashed_values.d.ts.map +1 -1
  666. package/dest/tx/hashed_values.js +1 -1
  667. package/dest/tx/in_tx.d.ts +26 -0
  668. package/dest/tx/in_tx.d.ts.map +1 -0
  669. package/dest/tx/in_tx.js +14 -0
  670. package/dest/tx/index.d.ts +2 -2
  671. package/dest/tx/index.d.ts.map +1 -1
  672. package/dest/tx/index.js +1 -1
  673. package/dest/tx/indexed_tx_effect.d.ts +14 -10
  674. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  675. package/dest/tx/indexed_tx_effect.js +8 -6
  676. package/dest/tx/offchain_effect.d.ts +2 -2
  677. package/dest/tx/offchain_effect.d.ts.map +1 -1
  678. package/dest/tx/offchain_effect.js +1 -1
  679. package/dest/tx/partial_state_reference.d.ts +5 -2
  680. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  681. package/dest/tx/private_execution_result.d.ts +27 -10
  682. package/dest/tx/private_execution_result.d.ts.map +1 -1
  683. package/dest/tx/private_execution_result.js +6 -23
  684. package/dest/tx/private_tx_constant_data.d.ts +17 -2
  685. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  686. package/dest/tx/private_tx_constant_data.js +1 -1
  687. package/dest/tx/processed_tx.d.ts +5 -4
  688. package/dest/tx/processed_tx.d.ts.map +1 -1
  689. package/dest/tx/processed_tx.js +8 -7
  690. package/dest/tx/profiling.d.ts +150 -27
  691. package/dest/tx/profiling.d.ts.map +1 -1
  692. package/dest/tx/profiling.js +45 -8
  693. package/dest/tx/protocol_contracts.d.ts +3 -3
  694. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  695. package/dest/tx/protocol_contracts.js +1 -1
  696. package/dest/tx/public_call_request_with_calldata.d.ts +8 -2
  697. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  698. package/dest/tx/public_call_request_with_calldata.js +4 -2
  699. package/dest/tx/public_simulation_output.d.ts +2 -2
  700. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  701. package/dest/tx/public_simulation_output.js +1 -1
  702. package/dest/tx/simulated_tx.d.ts +1031 -7
  703. package/dest/tx/simulated_tx.d.ts.map +1 -1
  704. package/dest/tx/state_reference.d.ts +4 -2
  705. package/dest/tx/state_reference.d.ts.map +1 -1
  706. package/dest/tx/state_reference.js +3 -1
  707. package/dest/tx/tree_snapshots.d.ts +2 -2
  708. package/dest/tx/tree_snapshots.d.ts.map +1 -1
  709. package/dest/tx/tree_snapshots.js +3 -1
  710. package/dest/tx/tx.d.ts +35 -5
  711. package/dest/tx/tx.d.ts.map +1 -1
  712. package/dest/tx/tx.js +20 -7
  713. package/dest/tx/tx_constant_data.d.ts +2 -2
  714. package/dest/tx/tx_constant_data.d.ts.map +1 -1
  715. package/dest/tx/tx_constant_data.js +1 -1
  716. package/dest/tx/tx_context.d.ts +3 -2
  717. package/dest/tx/tx_context.d.ts.map +1 -1
  718. package/dest/tx/tx_context.js +1 -1
  719. package/dest/tx/tx_effect.d.ts +33 -7
  720. package/dest/tx/tx_effect.d.ts.map +1 -1
  721. package/dest/tx/tx_effect.js +8 -11
  722. package/dest/tx/tx_execution_request.d.ts +31 -2
  723. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  724. package/dest/tx/tx_execution_request.js +7 -3
  725. package/dest/tx/tx_hash.d.ts +3 -2
  726. package/dest/tx/tx_hash.d.ts.map +1 -1
  727. package/dest/tx/tx_hash.js +1 -1
  728. package/dest/tx/tx_receipt.d.ts +50 -15
  729. package/dest/tx/tx_receipt.d.ts.map +1 -1
  730. package/dest/tx/tx_receipt.js +48 -16
  731. package/dest/tx/tx_request.d.ts +7 -2
  732. package/dest/tx/tx_request.d.ts.map +1 -1
  733. package/dest/tx/tx_request.js +2 -2
  734. package/dest/tx/validator/error_texts.d.ts +2 -1
  735. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  736. package/dest/tx/validator/error_texts.js +2 -0
  737. package/dest/tx/validator/tx_validator.d.ts +1 -4
  738. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  739. package/dest/tx/validator/tx_validator.js +4 -4
  740. package/dest/types/shared.d.ts +4 -1
  741. package/dest/types/shared.d.ts.map +1 -1
  742. package/dest/update-checker/update-checker.d.ts +2 -2
  743. package/dest/update-checker/update-checker.d.ts.map +1 -1
  744. package/dest/update-checker/update-checker.js +1 -1
  745. package/dest/validators/errors.d.ts +2 -2
  746. package/dest/validators/errors.d.ts.map +1 -1
  747. package/dest/validators/schemas.d.ts +9 -9
  748. package/dest/validators/schemas.d.ts.map +1 -1
  749. package/dest/validators/schemas.js +13 -13
  750. package/dest/versioning/versioning.d.ts +2 -2
  751. package/dest/versioning/versioning.d.ts.map +1 -1
  752. package/dest/vks/verification_key.d.ts +23 -2
  753. package/dest/vks/verification_key.d.ts.map +1 -1
  754. package/dest/vks/verification_key.js +1 -1
  755. package/dest/vks/vk_data.d.ts +8 -2
  756. package/dest/vks/vk_data.d.ts.map +1 -1
  757. package/dest/vks/vk_data.js +1 -1
  758. package/dest/zkpassport/index.d.ts +4 -5
  759. package/dest/zkpassport/index.d.ts.map +1 -1
  760. package/dest/zkpassport/index.js +11 -11
  761. package/package.json +20 -12
  762. package/src/abi/abi.ts +40 -34
  763. package/src/abi/authorization_selector.ts +3 -2
  764. package/src/abi/buffer.ts +1 -1
  765. package/src/abi/contract_artifact.ts +10 -10
  766. package/src/abi/decoder.ts +1 -1
  767. package/src/abi/encoder.ts +1 -1
  768. package/src/abi/event_selector.ts +3 -2
  769. package/src/abi/function_call.ts +1 -1
  770. package/src/abi/function_selector.ts +11 -2
  771. package/src/abi/note_selector.ts +2 -2
  772. package/src/abi/selector.ts +1 -1
  773. package/src/abi/utils.ts +17 -0
  774. package/src/auth_witness/auth_witness.ts +2 -2
  775. package/src/avm/avm.ts +338 -20
  776. package/src/avm/avm_accumulated_data.ts +1 -1
  777. package/src/avm/avm_circuit_public_inputs.ts +1 -1
  778. package/src/avm/contract_storage_read.ts +1 -1
  779. package/src/avm/contract_storage_update_request.ts +1 -1
  780. package/src/avm/message_pack.ts +2 -1
  781. package/src/avm/public_call_stack_item_compressed.ts +1 -1
  782. package/src/avm/public_data_read.ts +1 -1
  783. package/src/avm/public_data_update_request.ts +1 -1
  784. package/src/avm/public_data_write.ts +1 -1
  785. package/src/avm/public_inner_call_request.ts +1 -1
  786. package/src/avm/revert_code.ts +1 -1
  787. package/src/aztec-address/index.ts +2 -1
  788. package/src/block/attestation_info.ts +10 -7
  789. package/src/block/block_hash.ts +27 -26
  790. package/src/block/block_parameter.ts +10 -0
  791. package/src/block/body.ts +2 -1
  792. package/src/block/checkpointed_l2_block.ts +70 -0
  793. package/src/block/in_block.ts +28 -15
  794. package/src/block/index.ts +2 -4
  795. package/src/block/l2_block.ts +107 -141
  796. package/src/block/l2_block_info.ts +11 -10
  797. package/src/block/l2_block_source.ts +196 -71
  798. package/src/block/l2_block_stream/index.ts +1 -0
  799. package/src/block/l2_block_stream/interfaces.ts +15 -4
  800. package/src/block/l2_block_stream/l2_block_stream.ts +142 -37
  801. package/src/block/l2_block_stream/l2_tips_memory_store.ts +63 -54
  802. package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
  803. package/src/block/proposal/attestations_and_signers.ts +1 -1
  804. package/src/block/proposal/committee_attestation.ts +1 -1
  805. package/src/block/test/l2_tips_store_test_suite.ts +486 -36
  806. package/src/block/validate_block_result.ts +40 -35
  807. package/src/checkpoint/checkpoint.ts +88 -18
  808. package/src/checkpoint/checkpoint_info.ts +52 -0
  809. package/src/checkpoint/index.ts +1 -0
  810. package/src/checkpoint/published_checkpoint.ts +23 -8
  811. package/src/config/node-rpc-config.ts +1 -1
  812. package/src/contract/artifact_hash.ts +2 -2
  813. package/src/contract/complete_address.ts +1 -1
  814. package/src/contract/contract_address.ts +3 -3
  815. package/src/contract/contract_class.ts +2 -2
  816. package/src/contract/contract_class_id.ts +4 -4
  817. package/src/contract/contract_instance.ts +1 -1
  818. package/src/contract/contract_instance_update.ts +1 -1
  819. package/src/contract/deployment_info.ts +1 -1
  820. package/src/contract/index.ts +0 -2
  821. package/src/contract/interfaces/contract_class.ts +78 -47
  822. package/src/contract/interfaces/contract_data_source.ts +3 -2
  823. package/src/contract/interfaces/contract_instance.ts +48 -16
  824. package/src/contract/interfaces/contract_instance_update.ts +12 -10
  825. package/src/contract/partial_address.ts +1 -1
  826. package/src/contract/private_function.ts +4 -4
  827. package/src/contract/private_function_membership_proof.ts +3 -3
  828. package/src/contract/utility_function_membership_proof.ts +1 -1
  829. package/src/database-version/database_version.ts +87 -0
  830. package/src/database-version/version_manager.ts +1 -77
  831. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +11 -12
  832. package/src/delayed_public_mutable/delayed_public_mutable_values_with_hash.ts +1 -1
  833. package/src/delayed_public_mutable/scheduled_value_change.ts +1 -1
  834. package/src/deserialization/index.ts +21 -0
  835. package/src/epoch-helpers/index.ts +21 -10
  836. package/src/errors/simulation_error.ts +1 -1
  837. package/src/fees/transaction_fee.ts +1 -1
  838. package/src/gas/gas.ts +1 -1
  839. package/src/gas/gas_fees.ts +1 -1
  840. package/src/gas/gas_settings.ts +1 -1
  841. package/src/hash/hash.ts +5 -15
  842. package/src/hash/map_slot.ts +4 -3
  843. package/src/interfaces/allowed_element.ts +10 -8
  844. package/src/interfaces/api_limit.ts +2 -0
  845. package/src/interfaces/archiver.ts +49 -29
  846. package/src/interfaces/aztec-node-admin.ts +10 -6
  847. package/src/interfaces/aztec-node.ts +158 -173
  848. package/src/interfaces/block-builder.ts +51 -23
  849. package/src/interfaces/configs.ts +67 -33
  850. package/src/interfaces/epoch-prover.ts +4 -4
  851. package/src/interfaces/get_logs_response.ts +13 -9
  852. package/src/interfaces/l2_logs_source.ts +24 -14
  853. package/src/interfaces/merkle_tree_operations.ts +7 -3
  854. package/src/interfaces/p2p.ts +8 -12
  855. package/src/interfaces/prover-broker.ts +22 -0
  856. package/src/interfaces/prover-client.ts +35 -10
  857. package/src/interfaces/proving-job.ts +2 -11
  858. package/src/interfaces/public_state_source.ts +1 -1
  859. package/src/interfaces/server_circuit_prover.ts +3 -3
  860. package/src/interfaces/slasher.ts +24 -22
  861. package/src/interfaces/validator.ts +83 -31
  862. package/src/interfaces/world_state.ts +26 -18
  863. package/src/kernel/claimed_length_array.ts +1 -1
  864. package/src/kernel/hints/build_note_hash_read_request_hints.ts +20 -12
  865. package/src/kernel/hints/build_nullifier_read_request_hints.ts +18 -15
  866. package/src/kernel/hints/find_private_kernel_reset_dimensions.ts +2 -4
  867. package/src/kernel/hints/key_validation_hint.ts +1 -1
  868. package/src/kernel/hints/key_validation_request.ts +2 -1
  869. package/src/kernel/hints/key_validation_request_and_generator.ts +1 -1
  870. package/src/kernel/hints/note_hash_read_request_hints.ts +1 -1
  871. package/src/kernel/hints/read_request.ts +1 -1
  872. package/src/kernel/hints/scoped_key_validation_request_and_generator.ts +1 -1
  873. package/src/kernel/hints/scoped_value_cache.ts +1 -1
  874. package/src/kernel/hints/transient_data_squashing_hint.ts +1 -1
  875. package/src/kernel/hints/tree_leaf_read_request.ts +1 -1
  876. package/src/kernel/log_hash.ts +1 -1
  877. package/src/kernel/note_hash.ts +1 -1
  878. package/src/kernel/nullifier.ts +1 -1
  879. package/src/kernel/padded_side_effects.ts +1 -1
  880. package/src/kernel/private_call_data.ts +1 -1
  881. package/src/kernel/private_call_request.ts +1 -1
  882. package/src/kernel/private_circuit_public_inputs.ts +86 -86
  883. package/src/kernel/private_context_inputs.ts +1 -1
  884. package/src/kernel/private_kernel_circuit_public_inputs.ts +1 -1
  885. package/src/kernel/private_kernel_init_circuit_private_inputs.ts +1 -1
  886. package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +1 -1
  887. package/src/kernel/private_log_data.ts +1 -1
  888. package/src/kernel/private_to_avm_accumulated_data.ts +1 -1
  889. package/src/kernel/private_to_public_accumulated_data.ts +1 -1
  890. package/src/kernel/private_to_public_accumulated_data_builder.ts +1 -1
  891. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +2 -2
  892. package/src/kernel/private_to_rollup_accumulated_data.ts +1 -1
  893. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +2 -2
  894. package/src/kernel/public_call_request.ts +1 -1
  895. package/src/kernel/utils/optional_number.ts +1 -1
  896. package/src/keys/derivation.ts +13 -10
  897. package/src/keys/key_types.ts +1 -1
  898. package/src/keys/public_key.ts +1 -1
  899. package/src/keys/public_keys.ts +3 -2
  900. package/src/keys/utils.ts +7 -3
  901. package/src/l1-contracts/slash_factory.ts +4 -1
  902. package/src/logs/contract_class_log.ts +2 -2
  903. package/src/logs/debug_log.ts +1 -1
  904. package/src/logs/directional_app_tagging_secret.ts +4 -2
  905. package/src/logs/index.ts +2 -1
  906. package/src/logs/log_id.ts +23 -11
  907. package/src/logs/message_context.ts +1 -1
  908. package/src/logs/pending_tagged_log.ts +1 -1
  909. package/src/logs/private_log.ts +3 -2
  910. package/src/logs/public_log.ts +8 -1
  911. package/src/logs/shared_secret_derivation.ts +2 -2
  912. package/src/logs/siloed_tag.ts +45 -0
  913. package/src/logs/tag.ts +42 -0
  914. package/src/logs/tx_scoped_l2_log.ts +48 -45
  915. package/src/messaging/in_hash.ts +4 -2
  916. package/src/messaging/inbox_leaf.ts +11 -10
  917. package/src/messaging/l1_actor.ts +2 -2
  918. package/src/messaging/l1_to_l2_message.ts +3 -2
  919. package/src/messaging/l1_to_l2_message_source.ts +5 -10
  920. package/src/messaging/l2_actor.ts +2 -2
  921. package/src/messaging/l2_to_l1_membership.ts +179 -52
  922. package/src/messaging/l2_to_l1_message.ts +5 -1
  923. package/src/messaging/out_hash.ts +63 -22
  924. package/src/note/note.ts +5 -2
  925. package/src/note/note_dao.ts +51 -15
  926. package/src/note/notes_filter.ts +4 -1
  927. package/src/p2p/attestation_utils.ts +3 -3
  928. package/src/p2p/block_proposal.ts +216 -48
  929. package/src/p2p/{block_attestation.ts → checkpoint_attestation.ts} +33 -26
  930. package/src/p2p/checkpoint_proposal.ts +355 -0
  931. package/src/p2p/consensus_payload.ts +6 -8
  932. package/src/p2p/constants.ts +3 -0
  933. package/src/p2p/gossipable.ts +14 -4
  934. package/src/p2p/index.ts +4 -1
  935. package/src/p2p/message_validator.ts +14 -2
  936. package/src/p2p/signature_utils.ts +5 -2
  937. package/src/p2p/signed_txs.ts +88 -0
  938. package/src/p2p/topic_type.ts +4 -3
  939. package/src/parity/parity_base_private_inputs.ts +1 -1
  940. package/src/parity/parity_public_inputs.ts +1 -1
  941. package/src/proofs/chonk_proof.ts +11 -7
  942. package/src/proofs/proof.ts +1 -1
  943. package/src/proofs/proof_data.ts +24 -0
  944. package/src/proofs/recursive_proof.ts +1 -1
  945. package/src/rollup/avm_proof_data.ts +2 -9
  946. package/src/rollup/base_rollup_hints.ts +1 -1
  947. package/src/rollup/block_constant_data.ts +1 -1
  948. package/src/rollup/block_headers_hash.ts +2 -2
  949. package/src/rollup/block_rollup_public_inputs.ts +6 -12
  950. package/src/rollup/block_root_rollup_private_inputs.ts +1 -1
  951. package/src/rollup/checkpoint_constant_data.ts +2 -1
  952. package/src/rollup/checkpoint_header.ts +69 -20
  953. package/src/rollup/checkpoint_rollup_public_inputs.ts +13 -1
  954. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +16 -2
  955. package/src/rollup/epoch_constant_data.ts +1 -1
  956. package/src/rollup/public_chonk_verifier_private_inputs.ts +1 -1
  957. package/src/rollup/public_chonk_verifier_public_inputs.ts +1 -1
  958. package/src/rollup/public_tx_base_rollup_private_inputs.ts +2 -2
  959. package/src/rollup/root_rollup_public_inputs.ts +10 -1
  960. package/src/rollup/tree_snapshot_diff_hints.ts +1 -1
  961. package/src/rollup/tx_rollup_public_inputs.ts +1 -1
  962. package/src/schemas/schemas.ts +6 -1
  963. package/src/slashing/types.ts +24 -20
  964. package/src/snapshots/types.ts +33 -29
  965. package/src/stats/stats.ts +10 -7
  966. package/src/tests/factories.ts +129 -47
  967. package/src/tests/jest.ts +1 -1
  968. package/src/tests/mocks.ts +280 -82
  969. package/src/trees/append_only_tree_snapshot.ts +1 -1
  970. package/src/trees/database_public_state_source.ts +1 -1
  971. package/src/trees/nullifier_leaf.ts +1 -1
  972. package/src/trees/nullifier_membership_witness.ts +1 -1
  973. package/src/trees/public_data_leaf.ts +1 -1
  974. package/src/trees/public_data_witness.ts +1 -1
  975. package/src/tx/block_header.ts +26 -12
  976. package/src/tx/call_context.ts +1 -1
  977. package/src/tx/capsule.ts +1 -1
  978. package/src/tx/function_data.ts +1 -1
  979. package/src/tx/global_variable_builder.ts +9 -2
  980. package/src/tx/global_variables.ts +16 -10
  981. package/src/tx/hashed_values.ts +1 -1
  982. package/src/tx/in_tx.ts +24 -0
  983. package/src/tx/index.ts +1 -1
  984. package/src/tx/indexed_tx_effect.ts +9 -7
  985. package/src/tx/offchain_effect.ts +1 -1
  986. package/src/tx/partial_state_reference.ts +1 -1
  987. package/src/tx/private_execution_result.ts +6 -21
  988. package/src/tx/private_tx_constant_data.ts +1 -1
  989. package/src/tx/processed_tx.ts +19 -16
  990. package/src/tx/profiling.ts +47 -5
  991. package/src/tx/protocol_contracts.ts +2 -2
  992. package/src/tx/public_call_request_with_calldata.ts +1 -1
  993. package/src/tx/public_simulation_output.ts +1 -1
  994. package/src/tx/state_reference.ts +1 -1
  995. package/src/tx/tree_snapshots.ts +1 -1
  996. package/src/tx/tx.ts +22 -13
  997. package/src/tx/tx_constant_data.ts +1 -1
  998. package/src/tx/tx_context.ts +1 -1
  999. package/src/tx/tx_effect.ts +5 -12
  1000. package/src/tx/tx_execution_request.ts +3 -1
  1001. package/src/tx/tx_hash.ts +1 -1
  1002. package/src/tx/tx_receipt.ts +78 -20
  1003. package/src/tx/tx_request.ts +2 -2
  1004. package/src/tx/validator/error_texts.ts +3 -0
  1005. package/src/tx/validator/tx_validator.ts +8 -6
  1006. package/src/update-checker/update-checker.ts +2 -1
  1007. package/src/validators/errors.ts +1 -1
  1008. package/src/validators/schemas.ts +54 -48
  1009. package/src/versioning/versioning.ts +1 -1
  1010. package/src/vks/verification_key.ts +1 -1
  1011. package/src/vks/vk_data.ts +1 -1
  1012. package/src/zkpassport/index.ts +13 -14
  1013. package/dest/block/l2_block_code_to_purge.d.ts +0 -12
  1014. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  1015. package/dest/block/l2_block_code_to_purge.js +0 -61
  1016. package/dest/block/l2_block_header.d.ts +0 -98
  1017. package/dest/block/l2_block_header.d.ts.map +0 -1
  1018. package/dest/block/l2_block_header.js +0 -153
  1019. package/dest/block/l2_block_new.d.ts +0 -108
  1020. package/dest/block/l2_block_new.d.ts.map +0 -1
  1021. package/dest/block/l2_block_new.js +0 -135
  1022. package/dest/block/l2_block_number.d.ts +0 -5
  1023. package/dest/block/l2_block_number.d.ts.map +0 -1
  1024. package/dest/block/l2_block_number.js +0 -6
  1025. package/dest/block/published_l2_block.d.ts +0 -130
  1026. package/dest/block/published_l2_block.d.ts.map +0 -1
  1027. package/dest/block/published_l2_block.js +0 -48
  1028. package/dest/contract/contract_class_metadata.d.ts +0 -8
  1029. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  1030. package/dest/contract/contract_class_metadata.js +0 -1
  1031. package/dest/contract/contract_metadata.d.ts +0 -7
  1032. package/dest/contract/contract_metadata.d.ts.map +0 -1
  1033. package/dest/contract/contract_metadata.js +0 -1
  1034. package/dest/database-version/index.d.ts +0 -2
  1035. package/dest/database-version/index.d.ts.map +0 -1
  1036. package/dest/database-version/index.js +0 -1
  1037. package/dest/logs/log_with_tx_data.d.ts +0 -19
  1038. package/dest/logs/log_with_tx_data.d.ts.map +0 -1
  1039. package/dest/logs/log_with_tx_data.js +0 -49
  1040. package/dest/p2p/block_attestation.d.ts +0 -80
  1041. package/dest/p2p/block_attestation.d.ts.map +0 -1
  1042. package/dest/tx/content_commitment.d.ts +0 -48
  1043. package/dest/tx/content_commitment.d.ts.map +0 -1
  1044. package/dest/tx/content_commitment.js +0 -82
  1045. package/src/block/l2_block_code_to_purge.ts +0 -88
  1046. package/src/block/l2_block_header.ts +0 -246
  1047. package/src/block/l2_block_new.ts +0 -171
  1048. package/src/block/l2_block_number.ts +0 -8
  1049. package/src/block/published_l2_block.ts +0 -65
  1050. package/src/contract/contract_class_metadata.ts +0 -8
  1051. package/src/contract/contract_metadata.ts +0 -7
  1052. package/src/database-version/index.ts +0 -1
  1053. package/src/logs/log_with_tx_data.ts +0 -46
  1054. package/src/tx/content_commitment.ts +0 -104
@@ -6,22 +6,25 @@ import {
6
6
  MAX_NULLIFIERS_PER_TX,
7
7
  MAX_TOTAL_PUBLIC_DATA_UPDATE_REQUESTS_PER_TX,
8
8
  } from '@aztec/constants';
9
- import { makeTuple } from '@aztec/foundation/array';
9
+ import { type FieldsOf, makeTuple } from '@aztec/foundation/array';
10
+ import { BlockNumber, CheckpointNumber, IndexWithinCheckpoint, SlotNumber } from '@aztec/foundation/branded-types';
10
11
  import { Buffer32 } from '@aztec/foundation/buffer';
11
12
  import { padArrayEnd, times } from '@aztec/foundation/collection';
12
- import { Secp256k1Signer, randomBytes } from '@aztec/foundation/crypto';
13
- import { Fr } from '@aztec/foundation/fields';
13
+ import { randomBytes } from '@aztec/foundation/crypto/random';
14
+ import { Secp256k1Signer } from '@aztec/foundation/crypto/secp256k1-signer';
15
+ import { Fr } from '@aztec/foundation/curves/bn254';
16
+ import { Signature } from '@aztec/foundation/eth-signature';
14
17
 
15
18
  import type { ContractArtifact } from '../abi/abi.js';
19
+ import { PublicTxEffect } from '../avm/avm.js';
20
+ import type { AvmAccumulatedData } from '../avm/avm_accumulated_data.js';
16
21
  import { AvmCircuitPublicInputs } from '../avm/avm_circuit_public_inputs.js';
17
22
  import { PublicDataWrite } from '../avm/public_data_write.js';
18
23
  import { RevertCode } from '../avm/revert_code.js';
19
24
  import { AztecAddress } from '../aztec-address/index.js';
20
- import { CommitteeAttestation, L2BlockHeader } from '../block/index.js';
21
- import { L2Block } from '../block/l2_block.js';
25
+ import { CheckpointedL2Block, CommitteeAttestation, L2Block } from '../block/index.js';
22
26
  import type { CommitteeAttestationsAndSigners } from '../block/proposal/attestations_and_signers.js';
23
- import { PublishedL2Block } from '../block/published_l2_block.js';
24
- import type { Checkpoint } from '../checkpoint/checkpoint.js';
27
+ import { Checkpoint } from '../checkpoint/checkpoint.js';
25
28
  import { L1PublishedData } from '../checkpoint/published_checkpoint.js';
26
29
  import { computeContractAddressFromInstance } from '../contract/contract_address.js';
27
30
  import { getContractClassFromArtifact } from '../contract/contract_class.js';
@@ -42,12 +45,15 @@ import {
42
45
  import { PrivateToAvmAccumulatedData } from '../kernel/private_to_avm_accumulated_data.js';
43
46
  import { PrivateToPublicAccumulatedDataBuilder } from '../kernel/private_to_public_accumulated_data_builder.js';
44
47
  import { PublicCallRequestArrayLengths } from '../kernel/public_call_request.js';
45
- import { BlockAttestation } from '../p2p/block_attestation.js';
48
+ import { computeInHashFromL1ToL2Messages } from '../messaging/in_hash.js';
46
49
  import { BlockProposal } from '../p2p/block_proposal.js';
50
+ import { CheckpointAttestation } from '../p2p/checkpoint_attestation.js';
51
+ import { CheckpointProposal } from '../p2p/checkpoint_proposal.js';
47
52
  import { ConsensusPayload } from '../p2p/consensus_payload.js';
48
53
  import { SignatureDomainSeparator, getHashedSignaturePayloadEthSignedMessage } from '../p2p/signature_utils.js';
49
54
  import { ChonkProof } from '../proofs/chonk_proof.js';
50
55
  import { ProvingRequestType } from '../proofs/proving_request_type.js';
56
+ import { CheckpointHeader } from '../rollup/checkpoint_header.js';
51
57
  import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
52
58
  import {
53
59
  BlockHeader,
@@ -69,9 +75,9 @@ import {
69
75
  makeAvmCircuitInputs,
70
76
  makeAztecAddress,
71
77
  makeBlockHeader,
78
+ makeCheckpointHeader,
72
79
  makeGas,
73
80
  makeGlobalVariables,
74
- makeL2BlockHeader,
75
81
  makePrivateToPublicAccumulatedData,
76
82
  makePrivateToRollupAccumulatedData,
77
83
  makeProtocolContracts,
@@ -91,12 +97,14 @@ export const mockTx = async (
91
97
  publicCalldataSize = 2,
92
98
  feePayer,
93
99
  chonkProof = ChonkProof.random(),
100
+ maxFeesPerGas = new GasFees(10, 10),
94
101
  maxPriorityFeesPerGas,
95
102
  gasUsed = Gas.empty(),
96
103
  chainId = Fr.ZERO,
97
104
  version = Fr.ZERO,
98
105
  vkTreeRoot = Fr.ZERO,
99
106
  protocolContractsHash = Fr.ZERO,
107
+ anchorBlockHeader = BlockHeader.empty(),
100
108
  }: {
101
109
  numberOfNonRevertiblePublicCallRequests?: number;
102
110
  numberOfRevertiblePublicCallRequests?: number;
@@ -105,12 +113,14 @@ export const mockTx = async (
105
113
  publicCalldataSize?: number;
106
114
  feePayer?: AztecAddress;
107
115
  chonkProof?: ChonkProof;
116
+ maxFeesPerGas?: GasFees;
108
117
  maxPriorityFeesPerGas?: GasFees;
109
118
  gasUsed?: Gas;
110
119
  chainId?: Fr;
111
120
  version?: Fr;
112
121
  vkTreeRoot?: Fr;
113
122
  protocolContractsHash?: Fr;
123
+ anchorBlockHeader?: BlockHeader;
114
124
  } = {},
115
125
  ) => {
116
126
  const totalPublicCallRequests =
@@ -120,10 +130,8 @@ export const mockTx = async (
120
130
  const isForPublic = totalPublicCallRequests > 0;
121
131
  const data = PrivateKernelTailCircuitPublicInputs.empty();
122
132
  const firstNullifier = new Nullifier(new Fr(seed + 1), Fr.ZERO, 0);
123
- data.constants.txContext.gasSettings = GasSettings.default({
124
- maxFeesPerGas: new GasFees(10, 10),
125
- maxPriorityFeesPerGas,
126
- });
133
+ data.constants.anchorBlockHeader = anchorBlockHeader;
134
+ data.constants.txContext.gasSettings = GasSettings.default({ maxFeesPerGas, maxPriorityFeesPerGas });
127
135
  data.feePayer = feePayer ?? (await AztecAddress.random());
128
136
  data.gasUsed = gasUsed;
129
137
  data.constants.txContext.chainId = chainId;
@@ -199,6 +207,7 @@ export async function mockProcessedTx({
199
207
  // The default gasUsed is the tx overhead.
200
208
  gasUsed = Gas.from({ daGas: FIXED_DA_GAS, l2Gas: FIXED_L2_GAS }),
201
209
  privateOnly = false,
210
+ avmAccumulatedData,
202
211
  ...mockTxOpts
203
212
  }: {
204
213
  seed?: number;
@@ -210,6 +219,7 @@ export async function mockProcessedTx({
210
219
  protocolContracts?: ProtocolContracts;
211
220
  feePaymentPublicDataWrite?: PublicDataWrite;
212
221
  privateOnly?: boolean;
222
+ avmAccumulatedData?: Partial<FieldsOf<AvmAccumulatedData>>;
213
223
  } & Parameters<typeof mockTx>[1] = {}) {
214
224
  seed *= 0x1000; // Avoid clashing with the previous mock values if seed only increases by 1.
215
225
  anchorBlockHeader ??= db?.getInitialHeader() ?? makeBlockHeader(seed);
@@ -289,19 +299,22 @@ export async function mockProcessedTx({
289
299
  avmOutput.previousRevertibleAccumulatedDataArrayLengths =
290
300
  avmOutput.previousRevertibleAccumulatedData.getArrayLengths();
291
301
  // Assign final data emitted from avm.
292
- avmOutput.accumulatedData.noteHashes = revertibleData.noteHashes;
293
- avmOutput.accumulatedData.nullifiers = padArrayEnd(
294
- nonRevertibleData.nullifiers.concat(revertibleData.nullifiers).filter(n => !n.isEmpty()),
295
- Fr.ZERO,
296
- MAX_NULLIFIERS_PER_TX,
297
- );
298
- avmOutput.accumulatedData.l2ToL1Msgs = revertibleData.l2ToL1Msgs;
299
- avmOutput.accumulatedData.publicDataWrites = makeTuple(
300
- MAX_TOTAL_PUBLIC_DATA_UPDATE_REQUESTS_PER_TX,
301
- i => new PublicDataWrite(new Fr(i), new Fr(i + 10)),
302
- seed + 0x2000,
303
- );
304
- avmOutput.accumulatedData.publicDataWrites[0] = feePaymentPublicDataWrite;
302
+ avmOutput.accumulatedData.noteHashes = avmAccumulatedData?.noteHashes ?? revertibleData.noteHashes;
303
+ avmOutput.accumulatedData.nullifiers =
304
+ avmAccumulatedData?.nullifiers ??
305
+ padArrayEnd(
306
+ nonRevertibleData.nullifiers.concat(revertibleData.nullifiers).filter(n => !n.isEmpty()),
307
+ Fr.ZERO,
308
+ MAX_NULLIFIERS_PER_TX,
309
+ );
310
+ avmOutput.accumulatedData.l2ToL1Msgs = avmAccumulatedData?.l2ToL1Msgs ?? revertibleData.l2ToL1Msgs;
311
+ avmOutput.accumulatedData.publicDataWrites =
312
+ avmAccumulatedData?.publicDataWrites ??
313
+ makeTuple(
314
+ MAX_TOTAL_PUBLIC_DATA_UPDATE_REQUESTS_PER_TX,
315
+ i => (i === 0 ? feePaymentPublicDataWrite : new PublicDataWrite(new Fr(i), new Fr(i + 10))),
316
+ seed + 0x2000,
317
+ );
305
318
  avmOutput.accumulatedDataArrayLengths = avmOutput.accumulatedData.getArrayLengths();
306
319
  avmOutput.gasSettings = gasSettings;
307
320
  // Note: The fee is computed from the tx's gas used, which only includes the gas used in private. But this shouldn't
@@ -319,12 +332,24 @@ export async function mockProcessedTx({
319
332
  } satisfies GasUsed;
320
333
 
321
334
  await tx.recomputeHash();
335
+
336
+ const publicTxEffect = new PublicTxEffect(
337
+ avmOutput.transactionFee,
338
+ avmOutput.accumulatedData.noteHashes.filter(h => !h.isZero()),
339
+ avmOutput.accumulatedData.nullifiers.filter(h => !h.isZero()),
340
+ avmOutput.accumulatedData.l2ToL1Msgs.filter(h => !h.isEmpty()),
341
+ avmOutput.accumulatedData.publicLogs.toLogs(),
342
+ avmOutput.accumulatedData.publicDataWrites.filter(h => !h.isEmpty()),
343
+ );
344
+
322
345
  return makeProcessedTxFromTxWithPublicCalls(
323
346
  tx,
347
+ globalVariables,
324
348
  {
325
349
  type: ProvingRequestType.PUBLIC_VM,
326
350
  inputs: avmCircuitInputs,
327
351
  },
352
+ publicTxEffect,
328
353
  gasUsed,
329
354
  RevertCode.OK,
330
355
  undefined /* revertReason */,
@@ -338,7 +363,6 @@ const emptyPrivateCallExecutionResult = () =>
338
363
  Buffer.from(''),
339
364
  new Map(),
340
365
  PrivateCircuitPublicInputs.empty(),
341
- new Map(),
342
366
  [],
343
367
  new Map(),
344
368
  [],
@@ -368,6 +392,76 @@ export const mockSimulatedTx = async (seed = 1) => {
368
392
  return new TxSimulationResult(privateExecutionResult, tx.data, output);
369
393
  };
370
394
 
395
+ export function mockL1ToL2Messages(numL1ToL2Messages: number): Fr[] {
396
+ return Array.from({ length: numL1ToL2Messages }, () => Fr.random());
397
+ }
398
+
399
+ export async function mockCheckpointAndMessages(
400
+ checkpointNumber: CheckpointNumber,
401
+ {
402
+ startBlockNumber = BlockNumber(1),
403
+ numBlocks = 1,
404
+ blocks,
405
+ numTxsPerBlock = 1,
406
+ numL1ToL2Messages = 1,
407
+ makeBlockOptions = () => ({}),
408
+ previousArchive,
409
+ maxEffects,
410
+ ...options
411
+ }: {
412
+ startBlockNumber?: BlockNumber;
413
+ numBlocks?: number;
414
+ numTxsPerBlock?: number;
415
+ numL1ToL2Messages?: number;
416
+ makeBlockOptions?: (blockNumber: BlockNumber) => Partial<Parameters<typeof L2Block.random>[1]>;
417
+ previousArchive?: AppendOnlyTreeSnapshot;
418
+ blocks?: L2Block[];
419
+ maxEffects?: number;
420
+ } & Partial<Parameters<typeof Checkpoint.random>[1]> &
421
+ Partial<Parameters<typeof L2Block.random>[1]> = {},
422
+ ) {
423
+ const slotNumber = options.slotNumber ?? SlotNumber(Number(checkpointNumber) * 10);
424
+ const blocksAndMessages = [];
425
+ // Track the previous block's archive to ensure consecutive blocks have consistent archive roots.
426
+ // The current block's header.lastArchive must equal the previous block's archive.
427
+ let lastArchive: AppendOnlyTreeSnapshot | undefined = previousArchive;
428
+ // Pass maxEffects via txOptions so it reaches TxEffect.random
429
+ const txOptions = maxEffects !== undefined ? { maxEffects } : {};
430
+ for (let i = 0; i < (blocks?.length ?? numBlocks); i++) {
431
+ const blockNumber = BlockNumber(startBlockNumber + i);
432
+ const { block, messages } = {
433
+ block:
434
+ blocks?.[i] ??
435
+ (await L2Block.random(blockNumber, {
436
+ checkpointNumber,
437
+ indexWithinCheckpoint: IndexWithinCheckpoint(i),
438
+ txsPerBlock: numTxsPerBlock,
439
+ txOptions,
440
+ slotNumber,
441
+ ...options,
442
+ ...makeBlockOptions(blockNumber),
443
+ ...(lastArchive ? { lastArchive } : {}),
444
+ })),
445
+ messages: mockL1ToL2Messages(numL1ToL2Messages),
446
+ };
447
+ // Update lastArchive for the next block
448
+ lastArchive = block.archive;
449
+ blocksAndMessages.push({ block, messages });
450
+ }
451
+
452
+ const messages = blocksAndMessages[0].messages;
453
+ const inHash = computeInHashFromL1ToL2Messages(messages);
454
+ const checkpoint = await Checkpoint.random(checkpointNumber, { numBlocks: 0, slotNumber, inHash, ...options });
455
+ checkpoint.blocks = blocksAndMessages.map(({ block }) => block);
456
+ // Set the checkpoint's archive to match the last block's archive for proper chaining.
457
+ // When the archiver reconstructs checkpoints from L1, it uses the checkpoint's archive root
458
+ // from the L1 event to set the last block's archive. Without this, the archive chain breaks.
459
+ checkpoint.archive = lastArchive!;
460
+
461
+ // Return lastArchive so callers can chain it across multiple checkpoints
462
+ return { checkpoint, messages, lastArchive };
463
+ }
464
+
371
465
  export const randomContractArtifact = (): ContractArtifact => ({
372
466
  name: randomBytes(4).toString('hex'),
373
467
  functions: [],
@@ -405,28 +499,52 @@ export interface MakeConsensusPayloadOptions {
405
499
  signer?: Secp256k1Signer;
406
500
  attesterSigner?: Secp256k1Signer;
407
501
  proposerSigner?: Secp256k1Signer;
408
- header?: L2BlockHeader;
502
+ header?: CheckpointHeader;
409
503
  archive?: Fr;
410
504
  txHashes?: TxHash[];
411
505
  txs?: Tx[];
412
506
  }
413
507
 
508
+ export interface MakeBlockProposalOptions {
509
+ signer?: Secp256k1Signer;
510
+ blockHeader?: BlockHeader;
511
+ indexWithinCheckpoint?: IndexWithinCheckpoint;
512
+ inHash?: Fr;
513
+ archiveRoot?: Fr;
514
+ txHashes?: TxHash[];
515
+ txs?: Tx[];
516
+ }
517
+
518
+ export interface MakeCheckpointProposalOptions {
519
+ signer?: Secp256k1Signer;
520
+ checkpointHeader?: CheckpointHeader;
521
+ archiveRoot?: Fr;
522
+ /** Options for the lastBlock - if undefined, no lastBlock is included */
523
+ lastBlock?: {
524
+ blockHeader?: BlockHeader;
525
+ indexWithinCheckpoint?: IndexWithinCheckpoint;
526
+ txHashes?: TxHash[];
527
+ txs?: Tx[];
528
+ };
529
+ }
530
+
531
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
414
532
  const makeAndSignConsensusPayload = (
415
533
  domainSeparator: SignatureDomainSeparator,
416
534
  options?: MakeConsensusPayloadOptions,
417
535
  ) => {
418
- const header = options?.header ?? makeL2BlockHeader(1);
536
+ const header = options?.header ?? makeCheckpointHeader(1);
419
537
  const { signer = Secp256k1Signer.random(), archive = Fr.random() } = options ?? {};
420
538
 
421
539
  const payload = ConsensusPayload.fromFields({
422
- header: header.toCheckpointHeader(),
540
+ header,
423
541
  archive,
424
542
  });
425
543
 
426
544
  const hash = getHashedSignaturePayloadEthSignedMessage(payload, domainSeparator);
427
545
  const signature = signer.sign(hash);
428
546
 
429
- return { blockNumber: header.globalVariables.blockNumber, payload, signature };
547
+ return { blockNumber: header.slotNumber, payload, signature };
430
548
  };
431
549
 
432
550
  export const makeAndSignCommitteeAttestationsAndSigners = (
@@ -440,80 +558,150 @@ export const makeAndSignCommitteeAttestationsAndSigners = (
440
558
  return signer.sign(hash);
441
559
  };
442
560
 
443
- export const makeBlockProposal = (options?: MakeConsensusPayloadOptions): BlockProposal => {
444
- const { payload, signature } = makeAndSignConsensusPayload(SignatureDomainSeparator.blockProposal, options);
561
+ export const makeBlockProposal = (options?: MakeBlockProposalOptions): Promise<BlockProposal> => {
562
+ const blockHeader = options?.blockHeader ?? makeBlockHeader(1);
563
+ const indexWithinCheckpoint = options?.indexWithinCheckpoint ?? IndexWithinCheckpoint(0);
564
+ const inHash = options?.inHash ?? Fr.random();
565
+ const archiveRoot = options?.archiveRoot ?? Fr.random();
445
566
  const txHashes = options?.txHashes ?? [0, 1, 2, 3, 4, 5].map(() => TxHash.random());
446
- return new BlockProposal(payload, signature, txHashes, options?.txs ?? []);
567
+ const txs = options?.txs;
568
+ const signer = options?.signer ?? Secp256k1Signer.random();
569
+
570
+ return BlockProposal.createProposalFromSigner(
571
+ blockHeader,
572
+ indexWithinCheckpoint,
573
+ inHash,
574
+ archiveRoot,
575
+ txHashes,
576
+ txs,
577
+ (_payload, _context) => Promise.resolve(signer.signMessage(_payload)),
578
+ );
447
579
  };
448
580
 
449
- // TODO(https://github.com/AztecProtocol/aztec-packages/issues/8028)
450
- export const makeBlockAttestation = (options: MakeConsensusPayloadOptions = {}): BlockAttestation => {
451
- const header = options.header ?? makeL2BlockHeader(1);
452
- const { signer, attesterSigner = signer, proposerSigner = signer, archive = Fr.random() } = options;
581
+ export const makeCheckpointProposal = (options?: MakeCheckpointProposalOptions): Promise<CheckpointProposal> => {
582
+ const blockHeader = options?.lastBlock?.blockHeader ?? makeBlockHeader(1);
583
+ const checkpointHeader = options?.checkpointHeader ?? makeCheckpointHeader(1);
584
+ const archiveRoot = options?.archiveRoot ?? Fr.random();
585
+ const signer = options?.signer ?? Secp256k1Signer.random();
586
+
587
+ // Build lastBlock info if provided
588
+ const lastBlockInfo = options?.lastBlock
589
+ ? {
590
+ blockHeader,
591
+ indexWithinCheckpoint: options.lastBlock.indexWithinCheckpoint ?? IndexWithinCheckpoint(4), // Last block in a 5-block checkpoint
592
+ txHashes: options.lastBlock.txHashes ?? [0, 1, 2, 3, 4, 5].map(() => TxHash.random()),
593
+ txs: options.lastBlock.txs,
594
+ }
595
+ : undefined;
596
+
597
+ return CheckpointProposal.createProposalFromSigner(checkpointHeader, archiveRoot, lastBlockInfo, payload =>
598
+ Promise.resolve(signer.signMessage(payload)),
599
+ );
600
+ };
453
601
 
454
- const payload = ConsensusPayload.fromFields({
455
- header: header.toCheckpointHeader(),
456
- archive,
457
- });
602
+ /**
603
+ * Options for creating a checkpoint attestation
604
+ */
605
+ export type MakeCheckpointAttestationOptions = {
606
+ header?: CheckpointHeader;
607
+ archive?: Fr;
608
+ attesterSigner?: Secp256k1Signer;
609
+ proposerSigner?: Secp256k1Signer;
610
+ signer?: Secp256k1Signer;
611
+ };
612
+
613
+ /**
614
+ * Create a checkpoint attestation for testing
615
+ */
616
+ export const makeCheckpointAttestation = (options: MakeCheckpointAttestationOptions = {}): CheckpointAttestation => {
617
+ const header = options.header ?? makeCheckpointHeader(1);
618
+ const archive = options.archive ?? Fr.random();
619
+ const { signer, attesterSigner = signer, proposerSigner = signer } = options;
620
+
621
+ const payload = new ConsensusPayload(header, archive);
458
622
 
459
- return makeBlockAttestationFromPayload(payload, attesterSigner, proposerSigner);
623
+ // Sign as attester
624
+ const attestationHash = getHashedSignaturePayloadEthSignedMessage(
625
+ payload,
626
+ SignatureDomainSeparator.checkpointAttestation,
627
+ );
628
+ const attestationSigner = attesterSigner ?? Secp256k1Signer.random();
629
+ const attestationSignature = attestationSigner.sign(attestationHash);
630
+
631
+ // Sign as proposer - use CheckpointProposal's payload format (serializeToBuffer)
632
+ // This is different from ConsensusPayload's format (ABI encoding)
633
+ const proposalSignerToUse = proposerSigner ?? Secp256k1Signer.random();
634
+ const tempProposal = new CheckpointProposal(header, archive, Signature.empty());
635
+ const proposalHash = getHashedSignaturePayloadEthSignedMessage(
636
+ tempProposal,
637
+ SignatureDomainSeparator.checkpointProposal,
638
+ );
639
+ const proposerSignature = proposalSignerToUse.sign(proposalHash);
640
+
641
+ return new CheckpointAttestation(payload, attestationSignature, proposerSignature);
460
642
  };
461
643
 
462
- export const makeAttestationFromCheckpoint = (
463
- checkpoint: Checkpoint,
644
+ /**
645
+ * Create a checkpoint attestation from a checkpoint proposal
646
+ */
647
+ export const makeCheckpointAttestationFromProposal = (
648
+ proposal: CheckpointProposal,
464
649
  attesterSigner?: Secp256k1Signer,
465
- proposerSigner?: Secp256k1Signer,
466
- ): BlockAttestation => {
467
- const header = checkpoint.header;
468
- const archive = checkpoint.archive.root;
650
+ ): CheckpointAttestation => {
651
+ const payload = new ConsensusPayload(proposal.checkpointHeader, proposal.archive);
469
652
 
470
- const payload = ConsensusPayload.fromFields({
471
- header,
472
- archive,
473
- });
653
+ // Sign as attester
654
+ const attestationHash = getHashedSignaturePayloadEthSignedMessage(
655
+ payload,
656
+ SignatureDomainSeparator.checkpointAttestation,
657
+ );
658
+ const attestationSigner = attesterSigner ?? Secp256k1Signer.random();
659
+ const attestationSignature = attestationSigner.sign(attestationHash);
474
660
 
475
- return makeBlockAttestationFromPayload(payload, attesterSigner, proposerSigner);
661
+ // Use the proposal's signature as the proposer signature
662
+ return new CheckpointAttestation(payload, attestationSignature, proposal.signature);
476
663
  };
477
664
 
478
- export const makeBlockAttestationFromBlock = (
479
- block: L2Block,
665
+ /**
666
+ * Create a checkpoint attestation from a checkpoint
667
+ */
668
+ export const makeCheckpointAttestationFromCheckpoint = (
669
+ checkpoint: Checkpoint,
480
670
  attesterSigner?: Secp256k1Signer,
481
671
  proposerSigner?: Secp256k1Signer,
482
- ): BlockAttestation => {
483
- const header = block.header;
484
- const archive = block.archive.root;
485
-
486
- const payload = ConsensusPayload.fromFields({
487
- header: header.toCheckpointHeader(),
488
- archive,
489
- });
672
+ ): CheckpointAttestation => {
673
+ const header = checkpoint.header;
674
+ const archive = checkpoint.archive.root;
490
675
 
491
- return makeBlockAttestationFromPayload(payload, attesterSigner, proposerSigner);
676
+ return makeCheckpointAttestation({ header, archive, attesterSigner, proposerSigner });
492
677
  };
493
678
 
494
- export const makeBlockAttestationFromPayload = (
495
- payload: ConsensusPayload,
679
+ /**
680
+ * Create a checkpoint attestation from an L2Block
681
+ * Note: This is a compatibility function for tests. L2Block doesn't have a checkpoint header directly.
682
+ */
683
+ export const makeCheckpointAttestationFromBlock = (
684
+ block: L2Block,
496
685
  attesterSigner?: Secp256k1Signer,
497
686
  proposerSigner?: Secp256k1Signer,
498
- ): BlockAttestation => {
499
- // Sign as attester
500
- const attestationHash = getHashedSignaturePayloadEthSignedMessage(payload, SignatureDomainSeparator.blockAttestation);
501
- const attestationSigner = attesterSigner ?? Secp256k1Signer.random();
502
- const attestationSignature = attestationSigner.sign(attestationHash);
503
-
504
- // Sign as proposer
505
- const proposalHash = getHashedSignaturePayloadEthSignedMessage(payload, SignatureDomainSeparator.blockProposal);
506
- const proposalSignerToUse = proposerSigner ?? Secp256k1Signer.random();
507
- const proposerSignature = proposalSignerToUse.sign(proposalHash);
687
+ ): CheckpointAttestation => {
688
+ // For L2Block, we create a minimal checkpoint header for testing purposes
689
+ const header = CheckpointHeader.empty({
690
+ lastArchiveRoot: block.header.lastArchive.root,
691
+ slotNumber: block.slot,
692
+ timestamp: block.timestamp,
693
+ blockHeadersHash: Fr.ZERO, // Would need to compute from block header hash
694
+ });
695
+ const archive = block.archive.root;
508
696
 
509
- return new BlockAttestation(payload, attestationSignature, proposerSignature);
697
+ return makeCheckpointAttestation({ header, archive, attesterSigner, proposerSigner });
510
698
  };
511
699
 
512
700
  export async function randomPublishedL2Block(
513
701
  l2BlockNumber: number,
514
702
  opts: { signers?: Secp256k1Signer[] } = {},
515
- ): Promise<PublishedL2Block> {
516
- const block = await L2Block.random(l2BlockNumber);
703
+ ): Promise<CheckpointedL2Block> {
704
+ const block = await L2Block.random(BlockNumber(l2BlockNumber));
517
705
  const l1 = L1PublishedData.fromFields({
518
706
  blockNumber: BigInt(block.number),
519
707
  timestamp: block.header.globalVariables.timestamp,
@@ -521,9 +709,19 @@ export async function randomPublishedL2Block(
521
709
  });
522
710
 
523
711
  const signers = opts.signers ?? times(3, () => Secp256k1Signer.random());
524
- const atts = await Promise.all(signers.map(signer => makeBlockAttestationFromBlock(block, signer)));
712
+ const checkpoint = await Checkpoint.random(CheckpointNumber.fromBlockNumber(BlockNumber(l2BlockNumber)), {
713
+ numBlocks: 0,
714
+ });
715
+ checkpoint.blocks = [block];
716
+ const atts = signers.map(signer =>
717
+ makeCheckpointAttestation({
718
+ signer,
719
+ archive: block.archive.root,
720
+ header: checkpoint.header,
721
+ }),
722
+ );
525
723
  const attestations = atts.map(
526
724
  (attestation, i) => new CommitteeAttestation(signers[i].address, attestation.signature),
527
725
  );
528
- return new PublishedL2Block(block, l1, attestations);
726
+ return new CheckpointedL2Block(CheckpointNumber.fromBlockNumber(BlockNumber(l2BlockNumber)), block, l1, attestations);
529
727
  }
@@ -1,4 +1,4 @@
1
- import { Fr } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { schemas } from '@aztec/foundation/schemas';
3
3
  import { BufferReader, FieldReader, serializeToBuffer } from '@aztec/foundation/serialize';
4
4
  import { bufferToHex, hexToBuffer } from '@aztec/foundation/string';
@@ -1,4 +1,4 @@
1
- import { Fr } from '@aztec/foundation/fields';
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
2
 
3
3
  import type { AztecAddress } from '../aztec-address/index.js';
4
4
  import { computePublicDataTreeLeafSlot } from '../hash/hash.js';
@@ -1,5 +1,5 @@
1
1
  import { toBigIntBE, toBufferBE } from '@aztec/foundation/bigint-buffer';
2
- import { Fr } from '@aztec/foundation/fields';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { schemas } from '@aztec/foundation/schemas';
4
4
  import { BufferReader } from '@aztec/foundation/serialize';
5
5
  import type { IndexedTreeLeaf, IndexedTreeLeafPreimage } from '@aztec/foundation/trees';
@@ -1,5 +1,5 @@
1
1
  import { NULLIFIER_TREE_HEIGHT } from '@aztec/constants';
2
- import { Fr } from '@aztec/foundation/fields';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { MembershipWitness, SiblingPath } from '@aztec/foundation/trees';
4
4
 
5
5
  import { z } from 'zod';
@@ -1,5 +1,5 @@
1
1
  import { toBigIntBE, toBufferBE } from '@aztec/foundation/bigint-buffer';
2
- import { Fr } from '@aztec/foundation/fields';
2
+ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { schemas } from '@aztec/foundation/schemas';
4
4
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
5
5
  import type { IndexedTreeLeaf, IndexedTreeLeafPreimage } from '@aztec/foundation/trees';
@@ -1,6 +1,6 @@
1
1
  import { PUBLIC_DATA_TREE_HEIGHT } from '@aztec/constants';
2
2
  import { toBigIntBE } from '@aztec/foundation/bigint-buffer';
3
- import { Fr } from '@aztec/foundation/fields';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
5
5
  import { bufferToHex, hexToBuffer } from '@aztec/foundation/string';
6
6
  import { MembershipWitness, SiblingPath } from '@aztec/foundation/trees';
@@ -1,7 +1,8 @@
1
1
  import { BLOCK_HEADER_LENGTH, GeneratorIndex } from '@aztec/constants';
2
- import { SlotNumber } from '@aztec/foundation/branded-types';
3
- import { poseidon2HashWithSeparator, randomInt } from '@aztec/foundation/crypto';
4
- import { Fr } from '@aztec/foundation/fields';
2
+ import { BlockNumber, SlotNumber } from '@aztec/foundation/branded-types';
3
+ import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
4
+ import { randomInt } from '@aztec/foundation/crypto/random';
5
+ import { Fr } from '@aztec/foundation/curves/bn254';
5
6
  import { type ZodFor, schemas } from '@aztec/foundation/schemas';
6
7
  import { BufferReader, FieldReader, serializeToBuffer, serializeToFields } from '@aztec/foundation/serialize';
7
8
  import { bufferToHex, hexToBuffer } from '@aztec/foundation/string';
@@ -10,28 +11,31 @@ import type { FieldsOf } from '@aztec/foundation/types';
10
11
  import { inspect } from 'util';
11
12
  import { z } from 'zod';
12
13
 
14
+ import { BlockHash } from '../block/block_hash.js';
13
15
  import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
14
16
  import { GlobalVariables } from './global_variables.js';
15
17
  import { StateReference } from './state_reference.js';
16
18
 
17
19
  /** A header of an L2 block. */
18
20
  export class BlockHeader {
21
+ private _cachedHash?: Promise<BlockHash>;
22
+
19
23
  constructor(
20
24
  /** Snapshot of archive before the block is applied. */
21
- public lastArchive: AppendOnlyTreeSnapshot,
25
+ public readonly lastArchive: AppendOnlyTreeSnapshot,
22
26
  /** State reference. */
23
- public state: StateReference,
27
+ public readonly state: StateReference,
24
28
  /**
25
29
  * Hash of the sponge blob after the tx effects of this block has been applied.
26
30
  * May contain tx effects from the previous blocks in the same checkpoint.
27
31
  */
28
- public spongeBlobHash: Fr,
32
+ public readonly spongeBlobHash: Fr,
29
33
  /** Global variables of an L2 block. */
30
- public globalVariables: GlobalVariables,
34
+ public readonly globalVariables: GlobalVariables,
31
35
  /** Total fees in the block, computed by the root rollup circuit */
32
- public totalFees: Fr,
36
+ public readonly totalFees: Fr,
33
37
  /** Total mana used in the block, computed by the root rollup circuit */
34
- public totalManaUsed: Fr,
38
+ public readonly totalManaUsed: Fr,
35
39
  ) {}
36
40
 
37
41
  static get schema(): ZodFor<BlockHeader> {
@@ -66,7 +70,7 @@ export class BlockHeader {
66
70
  return this.globalVariables.slotNumber;
67
71
  }
68
72
 
69
- getBlockNumber() {
73
+ getBlockNumber(): BlockNumber {
70
74
  return this.globalVariables.blockNumber;
71
75
  }
72
76
 
@@ -158,8 +162,18 @@ export class BlockHeader {
158
162
  return BlockHeader.fromBuffer(hexToBuffer(str));
159
163
  }
160
164
 
161
- hash(): Promise<Fr> {
162
- return poseidon2HashWithSeparator(this.toFields(), GeneratorIndex.BLOCK_HASH);
165
+ hash(): Promise<BlockHash> {
166
+ if (!this._cachedHash) {
167
+ this._cachedHash = poseidon2HashWithSeparator(this.toFields(), GeneratorIndex.BLOCK_HEADER_HASH).then(
168
+ fr => new BlockHash(fr),
169
+ );
170
+ }
171
+ return this._cachedHash;
172
+ }
173
+
174
+ /** Manually set the hash for this block header if already computed */
175
+ setHash(hashed: Fr) {
176
+ this._cachedHash = Promise.resolve(new BlockHash(hashed));
163
177
  }
164
178
 
165
179
  static random(overrides: Partial<FieldsOf<BlockHeader>> & Partial<FieldsOf<GlobalVariables>> = {}): BlockHeader {