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

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 (732) hide show
  1. package/dest/abi/contract_artifact.d.ts +2 -2
  2. package/dest/abi/contract_artifact.d.ts.map +1 -1
  3. package/dest/abi/contract_artifact.js +1 -1
  4. package/dest/abi/function_call.d.ts +47 -9
  5. package/dest/abi/function_call.d.ts.map +1 -1
  6. package/dest/abi/function_call.js +20 -3
  7. package/dest/abi/selector.js +3 -1
  8. package/dest/abi/utils.d.ts +7 -1
  9. package/dest/abi/utils.d.ts.map +1 -1
  10. package/dest/abi/utils.js +7 -0
  11. package/dest/auth_witness/auth_witness.d.ts +2 -1
  12. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  13. package/dest/auth_witness/auth_witness.js +3 -3
  14. package/dest/avm/avm.d.ts +62 -62
  15. package/dest/avm/avm_accumulated_data.d.ts +30 -3
  16. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  17. package/dest/avm/avm_accumulated_data.js +5 -2
  18. package/dest/avm/avm_circuit_public_inputs.d.ts +9 -9
  19. package/dest/avm/avm_circuit_public_inputs.js +3 -1
  20. package/dest/avm/avm_proving_request.d.ts +299 -299
  21. package/dest/avm/contract_storage_read.d.ts +13 -1
  22. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  23. package/dest/avm/contract_storage_update_request.d.ts +13 -1
  24. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  25. package/dest/avm/public_call_stack_item_compressed.d.ts +3 -1
  26. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  27. package/dest/avm/public_data_read.d.ts +10 -1
  28. package/dest/avm/public_data_read.d.ts.map +1 -1
  29. package/dest/avm/public_data_update_request.d.ts +10 -1
  30. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  31. package/dest/avm/public_data_update_request.js +3 -1
  32. package/dest/avm/public_data_write.d.ts +7 -1
  33. package/dest/avm/public_data_write.d.ts.map +1 -1
  34. package/dest/avm/public_inner_call_request.d.ts +4 -1
  35. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  36. package/dest/avm/public_inner_call_request.js +3 -1
  37. package/dest/avm/revert_code.d.ts +4 -4
  38. package/dest/avm/revert_code.d.ts.map +1 -1
  39. package/dest/avm/revert_code.js +3 -1
  40. package/dest/aztec-address/index.js +4 -2
  41. package/dest/block/attestation_info.d.ts +5 -5
  42. package/dest/block/attestation_info.d.ts.map +1 -1
  43. package/dest/block/attestation_info.js +4 -4
  44. package/dest/block/block_data.d.ts +52 -0
  45. package/dest/block/block_data.d.ts.map +1 -0
  46. package/dest/block/block_data.js +12 -0
  47. package/dest/block/block_hash.d.ts +18 -14
  48. package/dest/block/block_hash.d.ts.map +1 -1
  49. package/dest/block/block_hash.js +22 -20
  50. package/dest/block/block_parameter.d.ts +4 -3
  51. package/dest/block/block_parameter.d.ts.map +1 -1
  52. package/dest/block/block_parameter.js +2 -0
  53. package/dest/block/body.d.ts +1 -1
  54. package/dest/block/body.d.ts.map +1 -1
  55. package/dest/block/body.js +5 -2
  56. package/dest/block/checkpointed_l2_block.d.ts +20 -137
  57. package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
  58. package/dest/block/checkpointed_l2_block.js +7 -45
  59. package/dest/block/in_block.d.ts +9 -9
  60. package/dest/block/in_block.d.ts.map +1 -1
  61. package/dest/block/in_block.js +5 -5
  62. package/dest/block/index.d.ts +2 -3
  63. package/dest/block/index.d.ts.map +1 -1
  64. package/dest/block/index.js +1 -2
  65. package/dest/block/l2_block.d.ts +57 -57
  66. package/dest/block/l2_block.d.ts.map +1 -1
  67. package/dest/block/l2_block.js +64 -108
  68. package/dest/block/l2_block_source.d.ts +317 -68
  69. package/dest/block/l2_block_source.d.ts.map +1 -1
  70. package/dest/block/l2_block_source.js +25 -6
  71. package/dest/block/l2_block_stream/index.d.ts +2 -1
  72. package/dest/block/l2_block_stream/index.d.ts.map +1 -1
  73. package/dest/block/l2_block_stream/index.js +1 -0
  74. package/dest/block/l2_block_stream/interfaces.d.ts +15 -5
  75. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  76. package/dest/block/l2_block_stream/l2_block_stream.d.ts +8 -3
  77. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  78. package/dest/block/l2_block_stream/l2_block_stream.js +106 -31
  79. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +24 -16
  80. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
  81. package/dest/block/l2_block_stream/l2_tips_memory_store.js +55 -61
  82. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
  83. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
  84. package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
  85. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  86. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  87. package/dest/block/test/l2_tips_store_test_suite.js +478 -38
  88. package/dest/block/validate_block_result.d.ts +24 -24
  89. package/dest/block/validate_block_result.d.ts.map +1 -1
  90. package/dest/block/validate_block_result.js +18 -17
  91. package/dest/checkpoint/checkpoint.d.ts +43 -19
  92. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  93. package/dest/checkpoint/checkpoint.js +38 -14
  94. package/dest/checkpoint/checkpoint_data.d.ts +120 -0
  95. package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
  96. package/dest/checkpoint/checkpoint_data.js +26 -0
  97. package/dest/checkpoint/checkpoint_info.d.ts +32 -3
  98. package/dest/checkpoint/checkpoint_info.d.ts.map +1 -1
  99. package/dest/checkpoint/checkpoint_info.js +34 -1
  100. package/dest/checkpoint/index.d.ts +3 -1
  101. package/dest/checkpoint/index.d.ts.map +1 -1
  102. package/dest/checkpoint/index.js +2 -0
  103. package/dest/checkpoint/published_checkpoint.d.ts +33 -16
  104. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  105. package/dest/checkpoint/published_checkpoint.js +5 -5
  106. package/dest/config/index.d.ts +2 -1
  107. package/dest/config/index.d.ts.map +1 -1
  108. package/dest/config/index.js +1 -0
  109. package/dest/config/node-rpc-config.js +1 -1
  110. package/dest/config/sequencer-config.d.ts +10 -0
  111. package/dest/config/sequencer-config.d.ts.map +1 -0
  112. package/dest/config/sequencer-config.js +18 -0
  113. package/dest/contract/complete_address.d.ts +4 -1
  114. package/dest/contract/complete_address.d.ts.map +1 -1
  115. package/dest/contract/contract_address.js +4 -4
  116. package/dest/contract/contract_class.d.ts +2 -3
  117. package/dest/contract/contract_class.d.ts.map +1 -1
  118. package/dest/contract/contract_class_id.d.ts +2 -2
  119. package/dest/contract/contract_class_id.d.ts.map +1 -1
  120. package/dest/contract/contract_class_id.js +6 -5
  121. package/dest/contract/contract_deployment_data.d.ts +5 -5
  122. package/dest/contract/index.d.ts +1 -3
  123. package/dest/contract/index.d.ts.map +1 -1
  124. package/dest/contract/index.js +0 -2
  125. package/dest/contract/interfaces/contract_instance.d.ts +16 -16
  126. package/dest/contract/interfaces/node-info.d.ts +3 -1
  127. package/dest/contract/interfaces/node-info.d.ts.map +1 -1
  128. package/dest/contract/interfaces/node-info.js +2 -1
  129. package/dest/contract/private_function.d.ts +1 -1
  130. package/dest/contract/private_function.d.ts.map +1 -1
  131. package/dest/contract/private_function.js +3 -4
  132. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  133. package/dest/contract/private_function_membership_proof.js +1 -1
  134. package/dest/database-version/database_version.d.ts +58 -0
  135. package/dest/database-version/database_version.d.ts.map +1 -0
  136. package/dest/database-version/database_version.js +69 -0
  137. package/dest/database-version/version_manager.d.ts +3 -49
  138. package/dest/database-version/version_manager.d.ts.map +1 -1
  139. package/dest/database-version/version_manager.js +1 -64
  140. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  141. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  142. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  143. package/dest/deserialization/index.d.ts +11 -0
  144. package/dest/deserialization/index.d.ts.map +1 -0
  145. package/dest/deserialization/index.js +10 -0
  146. package/dest/epoch-helpers/index.d.ts +7 -1
  147. package/dest/epoch-helpers/index.d.ts.map +1 -1
  148. package/dest/epoch-helpers/index.js +9 -3
  149. package/dest/errors/proving_error.d.ts +2 -2
  150. package/dest/errors/proving_error.d.ts.map +1 -1
  151. package/dest/file-store/local.d.ts +3 -3
  152. package/dest/file-store/local.d.ts.map +1 -1
  153. package/dest/file-store/local.js +13 -4
  154. package/dest/file-store/s3.d.ts +1 -1
  155. package/dest/file-store/s3.d.ts.map +1 -1
  156. package/dest/file-store/s3.js +11 -3
  157. package/dest/gas/gas.js +3 -1
  158. package/dest/gas/gas_fees.js +3 -1
  159. package/dest/ha-signing/config.d.ts +101 -0
  160. package/dest/ha-signing/config.d.ts.map +1 -0
  161. package/dest/ha-signing/config.js +92 -0
  162. package/dest/ha-signing/index.d.ts +3 -0
  163. package/dest/ha-signing/index.d.ts.map +1 -0
  164. package/dest/ha-signing/index.js +2 -0
  165. package/dest/ha-signing/types.d.ts +85 -0
  166. package/dest/ha-signing/types.d.ts.map +1 -0
  167. package/dest/ha-signing/types.js +32 -0
  168. package/dest/hash/hash.d.ts +2 -1
  169. package/dest/hash/hash.d.ts.map +1 -1
  170. package/dest/hash/hash.js +16 -10
  171. package/dest/hash/map_slot.d.ts +1 -1
  172. package/dest/hash/map_slot.d.ts.map +1 -1
  173. package/dest/hash/map_slot.js +4 -3
  174. package/dest/interfaces/api_limit.d.ts +3 -1
  175. package/dest/interfaces/api_limit.d.ts.map +1 -1
  176. package/dest/interfaces/api_limit.js +2 -0
  177. package/dest/interfaces/archiver.d.ts +6 -6
  178. package/dest/interfaces/archiver.d.ts.map +1 -1
  179. package/dest/interfaces/archiver.js +27 -17
  180. package/dest/interfaces/aztec-node-admin.d.ts +111 -32
  181. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  182. package/dest/interfaces/aztec-node-admin.js +14 -6
  183. package/dest/interfaces/aztec-node.d.ts +75 -77
  184. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  185. package/dest/interfaces/aztec-node.js +15 -16
  186. package/dest/interfaces/block-builder.d.ts +22 -14
  187. package/dest/interfaces/block-builder.d.ts.map +1 -1
  188. package/dest/interfaces/block-builder.js +7 -0
  189. package/dest/interfaces/configs.d.ts +28 -8
  190. package/dest/interfaces/configs.d.ts.map +1 -1
  191. package/dest/interfaces/configs.js +5 -1
  192. package/dest/interfaces/get_logs_response.d.ts +16 -9
  193. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  194. package/dest/interfaces/l2_logs_source.d.ts +14 -5
  195. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  196. package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
  197. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  198. package/dest/interfaces/p2p.d.ts +7 -9
  199. package/dest/interfaces/p2p.d.ts.map +1 -1
  200. package/dest/interfaces/p2p.js +3 -4
  201. package/dest/interfaces/prover-broker.d.ts +16 -1
  202. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  203. package/dest/interfaces/prover-broker.js +4 -1
  204. package/dest/interfaces/prover-client.d.ts +15 -1
  205. package/dest/interfaces/prover-client.d.ts.map +1 -1
  206. package/dest/interfaces/prover-client.js +12 -1
  207. package/dest/interfaces/proving-job.d.ts +52 -52
  208. package/dest/interfaces/proving-job.d.ts.map +1 -1
  209. package/dest/interfaces/proving-job.js +1 -7
  210. package/dest/interfaces/server_circuit_prover.d.ts +4 -3
  211. package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
  212. package/dest/interfaces/slasher.d.ts +9 -1
  213. package/dest/interfaces/slasher.d.ts.map +1 -1
  214. package/dest/interfaces/slasher.js +2 -0
  215. package/dest/interfaces/tx_provider.d.ts +3 -3
  216. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  217. package/dest/interfaces/validator.d.ts +155 -19
  218. package/dest/interfaces/validator.d.ts.map +1 -1
  219. package/dest/interfaces/validator.js +8 -3
  220. package/dest/kernel/claimed_length_array.js +3 -1
  221. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +6 -5
  222. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  223. package/dest/kernel/hints/build_note_hash_read_request_hints.js +19 -10
  224. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
  225. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  226. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
  227. package/dest/kernel/hints/index.d.ts +2 -2
  228. package/dest/kernel/hints/index.js +2 -2
  229. package/dest/kernel/hints/key_validation_hint.d.ts +2 -1
  230. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  231. package/dest/kernel/hints/key_validation_request.d.ts +2 -1
  232. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  233. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  234. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  235. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
  236. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  237. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  238. package/dest/kernel/hints/read_request.d.ts +7 -1
  239. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  240. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  241. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  242. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
  243. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  244. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  245. package/dest/kernel/hints/transient_data_squashing_hint.js +3 -1
  246. package/dest/kernel/log_hash.js +3 -1
  247. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  248. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  249. package/dest/kernel/private_call_data.d.ts +25 -1
  250. package/dest/kernel/private_call_data.d.ts.map +1 -1
  251. package/dest/kernel/private_call_request.d.ts +16 -1
  252. package/dest/kernel/private_call_request.d.ts.map +1 -1
  253. package/dest/kernel/private_circuit_public_inputs.d.ts +81 -8
  254. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  255. package/dest/kernel/private_circuit_public_inputs.js +16 -16
  256. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +33 -3
  257. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  258. package/dest/kernel/private_kernel_circuit_public_inputs.js +4 -4
  259. package/dest/kernel/private_kernel_data.d.ts +7 -1
  260. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  261. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
  262. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  263. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  264. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  265. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  266. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  267. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +12 -3
  268. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  269. package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
  270. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +25 -3
  271. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  272. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +7 -7
  273. package/dest/kernel/private_log_data.js +5 -2
  274. package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
  275. package/dest/kernel/private_to_avm_accumulated_data.js +5 -2
  276. package/dest/kernel/private_to_public_accumulated_data.js +3 -1
  277. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +3 -3
  278. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  279. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +7 -7
  280. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
  281. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  282. package/dest/kernel/private_to_rollup_accumulated_data.js +3 -1
  283. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +18 -3
  284. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  285. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +7 -7
  286. package/dest/kernel/private_validation_requests.d.ts +13 -4
  287. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  288. package/dest/kernel/private_validation_requests.js +12 -10
  289. package/dest/kernel/public_call_request.d.ts +22 -1
  290. package/dest/kernel/public_call_request.d.ts.map +1 -1
  291. package/dest/kernel/public_call_request.js +5 -2
  292. package/dest/kernel/utils/optional_number.d.ts +7 -1
  293. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  294. package/dest/keys/derivation.d.ts +3 -3
  295. package/dest/keys/derivation.js +15 -15
  296. package/dest/keys/key_types.d.ts +3 -3
  297. package/dest/keys/key_types.d.ts.map +1 -1
  298. package/dest/keys/public_keys.d.ts +5 -1
  299. package/dest/keys/public_keys.d.ts.map +1 -1
  300. package/dest/keys/public_keys.js +2 -2
  301. package/dest/keys/utils.d.ts +1 -1
  302. package/dest/keys/utils.d.ts.map +1 -1
  303. package/dest/keys/utils.js +8 -4
  304. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  305. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  306. package/dest/l1-contracts/slash_factory.js +1 -0
  307. package/dest/logs/contract_class_log.js +3 -1
  308. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  309. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  310. package/dest/logs/extended_public_log.d.ts +17 -9
  311. package/dest/logs/extended_public_log.d.ts.map +1 -1
  312. package/dest/logs/log_id.d.ts +21 -14
  313. package/dest/logs/log_id.d.ts.map +1 -1
  314. package/dest/logs/log_id.js +20 -17
  315. package/dest/logs/private_log.d.ts +2 -2
  316. package/dest/logs/private_log.d.ts.map +1 -1
  317. package/dest/logs/private_log.js +3 -1
  318. package/dest/logs/public_log.js +3 -1
  319. package/dest/logs/siloed_tag.d.ts +1 -1
  320. package/dest/logs/siloed_tag.d.ts.map +1 -1
  321. package/dest/logs/siloed_tag.js +2 -5
  322. package/dest/messaging/in_hash.d.ts +4 -2
  323. package/dest/messaging/in_hash.d.ts.map +1 -1
  324. package/dest/messaging/in_hash.js +3 -1
  325. package/dest/messaging/inbox_leaf.d.ts +3 -1
  326. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  327. package/dest/messaging/l1_actor.d.ts +7 -1
  328. package/dest/messaging/l1_actor.d.ts.map +1 -1
  329. package/dest/messaging/l1_to_l2_message.d.ts +6 -1
  330. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  331. package/dest/messaging/l2_actor.d.ts +7 -1
  332. package/dest/messaging/l2_actor.d.ts.map +1 -1
  333. package/dest/messaging/l2_to_l1_membership.d.ts +88 -6
  334. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  335. package/dest/messaging/l2_to_l1_membership.js +160 -42
  336. package/dest/messaging/out_hash.d.ts +41 -3
  337. package/dest/messaging/out_hash.d.ts.map +1 -1
  338. package/dest/messaging/out_hash.js +54 -19
  339. package/dest/note/index.d.ts +1 -2
  340. package/dest/note/index.d.ts.map +1 -1
  341. package/dest/note/index.js +0 -1
  342. package/dest/note/note_dao.d.ts +36 -5
  343. package/dest/note/note_dao.d.ts.map +1 -1
  344. package/dest/note/note_dao.js +15 -12
  345. package/dest/p2p/attestation_utils.d.ts +3 -3
  346. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  347. package/dest/p2p/attestation_utils.js +1 -1
  348. package/dest/p2p/block_proposal.d.ts +102 -23
  349. package/dest/p2p/block_proposal.d.ts.map +1 -1
  350. package/dest/p2p/block_proposal.js +138 -39
  351. package/dest/p2p/checkpoint_attestation.d.ts +82 -0
  352. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
  353. package/dest/p2p/{block_attestation.js → checkpoint_attestation.js} +22 -19
  354. package/dest/p2p/checkpoint_proposal.d.ts +179 -0
  355. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
  356. package/dest/p2p/checkpoint_proposal.js +243 -0
  357. package/dest/p2p/consensus_payload.d.ts +20 -11
  358. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  359. package/dest/p2p/consensus_payload.js +24 -19
  360. package/dest/p2p/constants.d.ts +5 -0
  361. package/dest/p2p/constants.d.ts.map +1 -0
  362. package/dest/p2p/constants.js +3 -0
  363. package/dest/p2p/gossipable.d.ts +4 -3
  364. package/dest/p2p/gossipable.d.ts.map +1 -1
  365. package/dest/p2p/gossipable.js +16 -5
  366. package/dest/p2p/index.d.ts +5 -2
  367. package/dest/p2p/index.d.ts.map +1 -1
  368. package/dest/p2p/index.js +4 -1
  369. package/dest/p2p/message_validator.d.ts +18 -3
  370. package/dest/p2p/message_validator.d.ts.map +1 -1
  371. package/dest/p2p/message_validator.js +2 -1
  372. package/dest/p2p/signature_utils.d.ts +5 -3
  373. package/dest/p2p/signature_utils.d.ts.map +1 -1
  374. package/dest/p2p/signature_utils.js +3 -1
  375. package/dest/p2p/signed_txs.d.ts +42 -0
  376. package/dest/p2p/signed_txs.d.ts.map +1 -0
  377. package/dest/p2p/signed_txs.js +75 -0
  378. package/dest/p2p/topic_type.d.ts +3 -2
  379. package/dest/p2p/topic_type.d.ts.map +1 -1
  380. package/dest/p2p/topic_type.js +10 -3
  381. package/dest/parity/parity_base_private_inputs.d.ts +3 -1
  382. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  383. package/dest/parity/parity_public_inputs.d.ts +4 -1
  384. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  385. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  386. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  387. package/dest/proofs/chonk_proof.d.ts +1 -1
  388. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  389. package/dest/proofs/chonk_proof.js +9 -4
  390. package/dest/proofs/proof.d.ts +4 -1
  391. package/dest/proofs/proof.d.ts.map +1 -1
  392. package/dest/proofs/recursive_proof.d.ts +10 -1
  393. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  394. package/dest/rollup/base_rollup_hints.d.ts +34 -1
  395. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  396. package/dest/rollup/block_constant_data.d.ts +12 -1
  397. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  398. package/dest/rollup/block_headers_hash.js +1 -1
  399. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  400. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  401. package/dest/rollup/block_rollup_public_inputs.d.ts +47 -11
  402. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  403. package/dest/rollup/block_rollup_public_inputs.js +8 -12
  404. package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
  405. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  406. package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
  407. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  408. package/dest/rollup/checkpoint_constant_data.js +3 -1
  409. package/dest/rollup/checkpoint_header.d.ts +43 -13
  410. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  411. package/dest/rollup/checkpoint_header.js +50 -20
  412. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  413. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  414. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +46 -6
  415. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  416. package/dest/rollup/checkpoint_rollup_public_inputs.js +11 -3
  417. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
  418. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  419. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
  420. package/dest/rollup/epoch_constant_data.d.ts +16 -1
  421. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  422. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  423. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  424. package/dest/rollup/root_rollup_public_inputs.d.ts +21 -6
  425. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  426. package/dest/rollup/root_rollup_public_inputs.js +10 -4
  427. package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
  428. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  429. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  430. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  431. package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
  432. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  433. package/dest/schemas/schemas.d.ts +1 -1
  434. package/dest/slashing/empire.d.ts +1 -1
  435. package/dest/slashing/empire.d.ts.map +1 -1
  436. package/dest/slashing/empire.js +2 -0
  437. package/dest/slashing/helpers.d.ts +2 -2
  438. package/dest/slashing/helpers.d.ts.map +1 -1
  439. package/dest/slashing/helpers.js +6 -0
  440. package/dest/slashing/tally.d.ts +2 -1
  441. package/dest/slashing/tally.d.ts.map +1 -1
  442. package/dest/slashing/tally.js +6 -2
  443. package/dest/slashing/types.d.ts +7 -3
  444. package/dest/slashing/types.d.ts.map +1 -1
  445. package/dest/slashing/types.js +13 -1
  446. package/dest/stats/stats.d.ts +1 -3
  447. package/dest/stats/stats.d.ts.map +1 -1
  448. package/dest/tests/factories.d.ts +16 -10
  449. package/dest/tests/factories.d.ts.map +1 -1
  450. package/dest/tests/factories.js +71 -36
  451. package/dest/tests/jest.js +1 -1
  452. package/dest/tests/mocks.d.ts +77 -19
  453. package/dest/tests/mocks.d.ts.map +1 -1
  454. package/dest/tests/mocks.js +133 -62
  455. package/dest/timetable/index.d.ts +37 -0
  456. package/dest/timetable/index.d.ts.map +1 -0
  457. package/dest/timetable/index.js +39 -0
  458. package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
  459. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  460. package/dest/trees/append_only_tree_snapshot.js +3 -1
  461. package/dest/trees/nullifier_leaf.d.ts +13 -1
  462. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  463. package/dest/trees/nullifier_membership_witness.d.ts +10 -1
  464. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  465. package/dest/trees/public_data_leaf.d.ts +17 -1
  466. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  467. package/dest/trees/public_data_leaf.js +7 -6
  468. package/dest/trees/public_data_witness.d.ts +11 -1
  469. package/dest/trees/public_data_witness.d.ts.map +1 -1
  470. package/dest/tx/block_header.d.ts +14 -2
  471. package/dest/tx/block_header.d.ts.map +1 -1
  472. package/dest/tx/block_header.js +9 -3
  473. package/dest/tx/call_context.d.ts +13 -1
  474. package/dest/tx/call_context.d.ts.map +1 -1
  475. package/dest/tx/call_context.js +3 -1
  476. package/dest/tx/capsule.d.ts +4 -1
  477. package/dest/tx/capsule.d.ts.map +1 -1
  478. package/dest/tx/execution_payload.d.ts +9 -1
  479. package/dest/tx/execution_payload.d.ts.map +1 -1
  480. package/dest/tx/function_data.d.ts +4 -2
  481. package/dest/tx/function_data.d.ts.map +1 -1
  482. package/dest/tx/global_variable_builder.d.ts +2 -2
  483. package/dest/tx/global_variable_builder.d.ts.map +1 -1
  484. package/dest/tx/global_variables.d.ts +12 -4
  485. package/dest/tx/global_variables.d.ts.map +1 -1
  486. package/dest/tx/global_variables.js +3 -1
  487. package/dest/tx/hashed_values.d.ts +7 -1
  488. package/dest/tx/hashed_values.d.ts.map +1 -1
  489. package/dest/tx/in_tx.d.ts +4 -4
  490. package/dest/tx/index.d.ts +1 -2
  491. package/dest/tx/index.d.ts.map +1 -1
  492. package/dest/tx/index.js +0 -1
  493. package/dest/tx/indexed_tx_effect.d.ts +5 -5
  494. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  495. package/dest/tx/indexed_tx_effect.js +3 -2
  496. package/dest/tx/partial_state_reference.d.ts +4 -1
  497. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  498. package/dest/tx/private_execution_result.d.ts +23 -6
  499. package/dest/tx/private_execution_result.d.ts.map +1 -1
  500. package/dest/tx/private_execution_result.js +4 -21
  501. package/dest/tx/private_tx_constant_data.d.ts +16 -1
  502. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  503. package/dest/tx/profiling.d.ts +152 -29
  504. package/dest/tx/profiling.d.ts.map +1 -1
  505. package/dest/tx/profiling.js +47 -10
  506. package/dest/tx/protocol_contracts.d.ts +2 -2
  507. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  508. package/dest/tx/protocol_contracts.js +2 -2
  509. package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
  510. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  511. package/dest/tx/public_call_request_with_calldata.js +3 -1
  512. package/dest/tx/public_simulation_output.d.ts +4 -2
  513. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  514. package/dest/tx/public_simulation_output.js +7 -3
  515. package/dest/tx/state_reference.d.ts +3 -1
  516. package/dest/tx/state_reference.d.ts.map +1 -1
  517. package/dest/tx/state_reference.js +3 -1
  518. package/dest/tx/tree_snapshots.js +3 -1
  519. package/dest/tx/tx.d.ts +24 -1
  520. package/dest/tx/tx.d.ts.map +1 -1
  521. package/dest/tx/tx.js +9 -4
  522. package/dest/tx/tx_context.d.ts +2 -1
  523. package/dest/tx/tx_context.d.ts.map +1 -1
  524. package/dest/tx/tx_effect.d.ts +32 -6
  525. package/dest/tx/tx_effect.d.ts.map +1 -1
  526. package/dest/tx/tx_effect.js +3 -8
  527. package/dest/tx/tx_execution_request.d.ts +30 -1
  528. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  529. package/dest/tx/tx_execution_request.js +6 -2
  530. package/dest/tx/tx_hash.d.ts +2 -1
  531. package/dest/tx/tx_hash.d.ts.map +1 -1
  532. package/dest/tx/tx_receipt.d.ts +47 -13
  533. package/dest/tx/tx_receipt.d.ts.map +1 -1
  534. package/dest/tx/tx_receipt.js +46 -15
  535. package/dest/tx/tx_request.d.ts +6 -1
  536. package/dest/tx/tx_request.d.ts.map +1 -1
  537. package/dest/tx/tx_request.js +2 -2
  538. package/dest/tx/validator/empty_validator.d.ts +2 -2
  539. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  540. package/dest/tx/validator/error_texts.d.ts +3 -2
  541. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  542. package/dest/tx/validator/error_texts.js +3 -1
  543. package/dest/tx/validator/tx_validator.d.ts +2 -2
  544. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  545. package/dest/types/shared.d.ts +4 -1
  546. package/dest/types/shared.d.ts.map +1 -1
  547. package/dest/validators/schemas.d.ts +38 -38
  548. package/dest/validators/schemas.d.ts.map +1 -1
  549. package/dest/validators/schemas.js +4 -3
  550. package/dest/validators/types.d.ts +3 -3
  551. package/dest/validators/types.d.ts.map +1 -1
  552. package/dest/vks/verification_key.d.ts +22 -1
  553. package/dest/vks/verification_key.d.ts.map +1 -1
  554. package/dest/vks/vk_data.d.ts +7 -1
  555. package/dest/vks/vk_data.d.ts.map +1 -1
  556. package/dest/zkpassport/index.d.ts +3 -4
  557. package/dest/zkpassport/index.d.ts.map +1 -1
  558. package/dest/zkpassport/index.js +9 -9
  559. package/package.json +27 -13
  560. package/src/abi/contract_artifact.ts +10 -10
  561. package/src/abi/function_call.ts +25 -3
  562. package/src/abi/utils.ts +17 -0
  563. package/src/auth_witness/auth_witness.ts +3 -3
  564. package/src/block/attestation_info.ts +9 -6
  565. package/src/block/block_data.ts +26 -0
  566. package/src/block/block_hash.ts +26 -25
  567. package/src/block/block_parameter.ts +4 -2
  568. package/src/block/body.ts +2 -1
  569. package/src/block/checkpointed_l2_block.ts +8 -58
  570. package/src/block/in_block.ts +6 -6
  571. package/src/block/index.ts +1 -2
  572. package/src/block/l2_block.ts +102 -149
  573. package/src/block/l2_block_source.ts +145 -44
  574. package/src/block/l2_block_stream/index.ts +1 -0
  575. package/src/block/l2_block_stream/interfaces.ts +15 -4
  576. package/src/block/l2_block_stream/l2_block_stream.ts +130 -39
  577. package/src/block/l2_block_stream/l2_tips_memory_store.ts +62 -56
  578. package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
  579. package/src/block/test/l2_tips_store_test_suite.ts +480 -36
  580. package/src/block/validate_block_result.ts +40 -35
  581. package/src/checkpoint/checkpoint.ts +62 -21
  582. package/src/checkpoint/checkpoint_data.ts +51 -0
  583. package/src/checkpoint/checkpoint_info.ts +45 -2
  584. package/src/checkpoint/index.ts +2 -0
  585. package/src/checkpoint/published_checkpoint.ts +7 -4
  586. package/src/config/index.ts +1 -0
  587. package/src/config/node-rpc-config.ts +1 -1
  588. package/src/config/sequencer-config.ts +29 -0
  589. package/src/contract/contract_address.ts +4 -4
  590. package/src/contract/contract_class.ts +3 -3
  591. package/src/contract/contract_class_id.ts +6 -5
  592. package/src/contract/index.ts +0 -2
  593. package/src/contract/interfaces/node-info.ts +3 -0
  594. package/src/contract/private_function.ts +3 -4
  595. package/src/contract/private_function_membership_proof.ts +1 -1
  596. package/src/database-version/database_version.ts +87 -0
  597. package/src/database-version/version_manager.ts +1 -77
  598. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  599. package/src/deserialization/index.ts +21 -0
  600. package/src/epoch-helpers/index.ts +13 -1
  601. package/src/file-store/local.ts +15 -5
  602. package/src/file-store/s3.ts +12 -3
  603. package/src/ha-signing/config.ts +149 -0
  604. package/src/ha-signing/index.ts +18 -0
  605. package/src/ha-signing/types.ts +112 -0
  606. package/src/hash/hash.ts +14 -10
  607. package/src/hash/map_slot.ts +3 -2
  608. package/src/interfaces/api_limit.ts +2 -0
  609. package/src/interfaces/archiver.ts +31 -24
  610. package/src/interfaces/aztec-node-admin.ts +31 -4
  611. package/src/interfaces/aztec-node.ts +110 -129
  612. package/src/interfaces/block-builder.ts +41 -23
  613. package/src/interfaces/configs.ts +15 -1
  614. package/src/interfaces/l2_logs_source.ts +17 -4
  615. package/src/interfaces/merkle_tree_operations.ts +1 -1
  616. package/src/interfaces/p2p.ts +8 -12
  617. package/src/interfaces/prover-broker.ts +22 -0
  618. package/src/interfaces/prover-client.ts +22 -0
  619. package/src/interfaces/proving-job.ts +2 -11
  620. package/src/interfaces/server_circuit_prover.ts +3 -2
  621. package/src/interfaces/slasher.ts +4 -0
  622. package/src/interfaces/tx_provider.ts +2 -2
  623. package/src/interfaces/validator.ts +73 -15
  624. package/src/kernel/hints/build_note_hash_read_request_hints.ts +20 -12
  625. package/src/kernel/hints/build_nullifier_read_request_hints.ts +17 -14
  626. package/src/kernel/hints/index.ts +2 -2
  627. package/src/kernel/hints/{key_validation_request_and_generator.ts → key_validation_request_and_separator.ts} +12 -15
  628. package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +10 -10
  629. package/src/kernel/private_circuit_public_inputs.ts +14 -14
  630. package/src/kernel/private_kernel_circuit_public_inputs.ts +2 -2
  631. package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +2 -2
  632. package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +5 -5
  633. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +5 -5
  634. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +5 -5
  635. package/src/kernel/private_validation_requests.ts +8 -8
  636. package/src/keys/derivation.ts +15 -15
  637. package/src/keys/key_types.ts +6 -2
  638. package/src/keys/public_keys.ts +2 -2
  639. package/src/keys/utils.ts +8 -4
  640. package/src/l1-contracts/slash_factory.ts +1 -0
  641. package/src/logs/log_id.ts +22 -18
  642. package/src/logs/siloed_tag.ts +2 -2
  643. package/src/messaging/in_hash.ts +3 -1
  644. package/src/messaging/l2_to_l1_membership.ts +178 -52
  645. package/src/messaging/out_hash.ts +62 -21
  646. package/src/note/index.ts +0 -1
  647. package/src/note/note_dao.ts +18 -13
  648. package/src/p2p/attestation_utils.ts +3 -3
  649. package/src/p2p/block_proposal.ts +211 -46
  650. package/src/p2p/{block_attestation.ts → checkpoint_attestation.ts} +36 -25
  651. package/src/p2p/checkpoint_proposal.ts +387 -0
  652. package/src/p2p/consensus_payload.ts +29 -18
  653. package/src/p2p/constants.ts +6 -0
  654. package/src/p2p/gossipable.ts +14 -4
  655. package/src/p2p/index.ts +4 -1
  656. package/src/p2p/message_validator.ts +14 -2
  657. package/src/p2p/signature_utils.ts +3 -1
  658. package/src/p2p/signed_txs.ts +88 -0
  659. package/src/p2p/topic_type.ts +4 -3
  660. package/src/proofs/chonk_proof.ts +9 -5
  661. package/src/rollup/block_headers_hash.ts +1 -1
  662. package/src/rollup/block_rollup_public_inputs.ts +5 -11
  663. package/src/rollup/checkpoint_header.ts +64 -21
  664. package/src/rollup/checkpoint_rollup_public_inputs.ts +17 -5
  665. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
  666. package/src/rollup/root_rollup_public_inputs.ts +16 -7
  667. package/src/slashing/empire.ts +3 -1
  668. package/src/slashing/helpers.ts +8 -0
  669. package/src/slashing/tally.ts +8 -2
  670. package/src/slashing/types.ts +14 -0
  671. package/src/stats/stats.ts +0 -2
  672. package/src/tests/factories.ts +70 -54
  673. package/src/tests/jest.ts +1 -1
  674. package/src/tests/mocks.ts +228 -95
  675. package/src/timetable/index.ts +66 -0
  676. package/src/trees/public_data_leaf.ts +11 -5
  677. package/src/tx/block_header.ts +12 -4
  678. package/src/tx/global_variable_builder.ts +1 -1
  679. package/src/tx/global_variables.ts +3 -3
  680. package/src/tx/index.ts +0 -1
  681. package/src/tx/indexed_tx_effect.ts +3 -2
  682. package/src/tx/private_execution_result.ts +1 -16
  683. package/src/tx/profiling.ts +51 -9
  684. package/src/tx/protocol_contracts.ts +2 -2
  685. package/src/tx/public_simulation_output.ts +4 -0
  686. package/src/tx/tx.ts +10 -9
  687. package/src/tx/tx_effect.ts +0 -9
  688. package/src/tx/tx_execution_request.ts +2 -0
  689. package/src/tx/tx_receipt.ts +75 -18
  690. package/src/tx/tx_request.ts +2 -2
  691. package/src/tx/validator/empty_validator.ts +1 -1
  692. package/src/tx/validator/error_texts.ts +4 -1
  693. package/src/tx/validator/tx_validator.ts +1 -1
  694. package/src/validators/schemas.ts +8 -1
  695. package/src/validators/types.ts +5 -4
  696. package/src/zkpassport/index.ts +11 -12
  697. package/dest/block/l2_block_code_to_purge.d.ts +0 -12
  698. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  699. package/dest/block/l2_block_code_to_purge.js +0 -61
  700. package/dest/block/l2_block_header.d.ts +0 -98
  701. package/dest/block/l2_block_header.d.ts.map +0 -1
  702. package/dest/block/l2_block_header.js +0 -153
  703. package/dest/block/l2_block_new.d.ts +0 -135
  704. package/dest/block/l2_block_new.d.ts.map +0 -1
  705. package/dest/block/l2_block_new.js +0 -152
  706. package/dest/contract/contract_class_metadata.d.ts +0 -8
  707. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  708. package/dest/contract/contract_class_metadata.js +0 -1
  709. package/dest/contract/contract_metadata.d.ts +0 -7
  710. package/dest/contract/contract_metadata.d.ts.map +0 -1
  711. package/dest/contract/contract_metadata.js +0 -1
  712. package/dest/database-version/index.d.ts +0 -2
  713. package/dest/database-version/index.d.ts.map +0 -1
  714. package/dest/database-version/index.js +0 -1
  715. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -25
  716. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  717. package/dest/note/notes_filter.d.ts +0 -27
  718. package/dest/note/notes_filter.d.ts.map +0 -1
  719. package/dest/note/notes_filter.js +0 -11
  720. package/dest/p2p/block_attestation.d.ts +0 -80
  721. package/dest/p2p/block_attestation.d.ts.map +0 -1
  722. package/dest/tx/content_commitment.d.ts +0 -49
  723. package/dest/tx/content_commitment.d.ts.map +0 -1
  724. package/dest/tx/content_commitment.js +0 -90
  725. package/src/block/l2_block_code_to_purge.ts +0 -88
  726. package/src/block/l2_block_header.ts +0 -246
  727. package/src/block/l2_block_new.ts +0 -207
  728. package/src/contract/contract_class_metadata.ts +0 -8
  729. package/src/contract/contract_metadata.ts +0 -7
  730. package/src/database-version/index.ts +0 -1
  731. package/src/note/notes_filter.ts +0 -38
  732. package/src/tx/content_commitment.ts +0 -113
@@ -0,0 +1,179 @@
1
+ import { BlockNumber, IndexWithinCheckpoint, SlotNumber } from '@aztec/foundation/branded-types';
2
+ import { Buffer32 } from '@aztec/foundation/buffer';
3
+ import { Fr } from '@aztec/foundation/curves/bn254';
4
+ import type { EthAddress } from '@aztec/foundation/eth-address';
5
+ import { Signature } from '@aztec/foundation/eth-signature';
6
+ import { BufferReader } from '@aztec/foundation/serialize';
7
+ import type { L2BlockInfo } from '../block/l2_block_info.js';
8
+ import { type SigningContext } from '../ha-signing/index.js';
9
+ import { CheckpointHeader } from '../rollup/checkpoint_header.js';
10
+ import { BlockHeader } from '../tx/block_header.js';
11
+ import { TxHash } from '../tx/index.js';
12
+ import type { Tx } from '../tx/tx.js';
13
+ import { BlockProposal } from './block_proposal.js';
14
+ import { Gossipable } from './gossipable.js';
15
+ import { SignatureDomainSeparator } from './signature_utils.js';
16
+ import { SignedTxs } from './signed_txs.js';
17
+ import { TopicType } from './topic_type.js';
18
+ export declare class CheckpointProposalHash extends Buffer32 {
19
+ constructor(hash: Buffer);
20
+ }
21
+ export type CheckpointProposalOptions = {
22
+ /**
23
+ * Whether to include the tx objects along with the block proposal.
24
+ * Dramatically increases size of the payload but eliminates failed reexecutions due to missing txs.
25
+ */
26
+ publishFullTxs?: boolean;
27
+ /**
28
+ * Whether to generate an invalid checkpoint proposal for broadcasting.
29
+ * Use only for testing.
30
+ */
31
+ broadcastInvalidCheckpointProposal?: boolean;
32
+ };
33
+ /** Data for the last block included in a checkpoint proposal */
34
+ export type CheckpointLastBlockData = {
35
+ /** The per-block header for the last block in the checkpoint */
36
+ blockHeader: BlockHeader;
37
+ /** Index of this block within the checkpoint (should be the last index, e.g., numBlocks - 1) */
38
+ indexWithinCheckpoint: IndexWithinCheckpoint;
39
+ /** The sequence of transactions in the last block */
40
+ txHashes: TxHash[];
41
+ /** The tx in the last block (optional, for DA guarantees) */
42
+ txs?: Tx[];
43
+ };
44
+ /** Last block included in a checkpoint proposal */
45
+ export type CheckpointLastBlock = Omit<CheckpointLastBlockData, 'txs'> & {
46
+ /** The proposer's signature over the block data (separate from checkpoint signature) */
47
+ signature: Signature;
48
+ /** The signed transactions in the last block (optional, for DA guarantees) */
49
+ signedTxs?: SignedTxs;
50
+ };
51
+ /**
52
+ * A checkpoint proposal is created by the leader of the chain for the last block in a checkpoint.
53
+ * It includes the aggregated checkpoint header that validators will attest to, plus optionally
54
+ * the last block's info for nodes to re-execute. This marks the completion of a slot's worth of blocks.
55
+ */
56
+ export declare class CheckpointProposal extends Gossipable {
57
+ /** The aggregated checkpoint header for consensus */
58
+ readonly checkpointHeader: CheckpointHeader;
59
+ /** Archive root after this checkpoint is applied */
60
+ readonly archive: Fr;
61
+ /** The fee asset price modifier in basis points (from oracle) */
62
+ readonly feeAssetPriceModifier: bigint;
63
+ /** The proposer's signature over the checkpoint payload (checkpointHeader + archive + feeAssetPriceModifier) */
64
+ readonly signature: Signature;
65
+ /** Optional last block info, including its own signature for BlockProposal extraction */
66
+ readonly lastBlock?: CheckpointLastBlock | undefined;
67
+ static p2pTopic: TopicType;
68
+ private sender;
69
+ constructor(
70
+ /** The aggregated checkpoint header for consensus */
71
+ checkpointHeader: CheckpointHeader,
72
+ /** Archive root after this checkpoint is applied */
73
+ archive: Fr,
74
+ /** The fee asset price modifier in basis points (from oracle) */
75
+ feeAssetPriceModifier: bigint,
76
+ /** The proposer's signature over the checkpoint payload (checkpointHeader + archive + feeAssetPriceModifier) */
77
+ signature: Signature,
78
+ /** Optional last block info, including its own signature for BlockProposal extraction */
79
+ lastBlock?: CheckpointLastBlock | undefined);
80
+ generateP2PMessageIdentifier(): Promise<Buffer32>;
81
+ get slotNumber(): SlotNumber;
82
+ get blockNumber(): BlockNumber;
83
+ /** Convenience getter for txHashes from lastBlock */
84
+ get txHashes(): TxHash[];
85
+ /** Convenience getter for txs from lastBlock */
86
+ get txs(): Tx[] | undefined;
87
+ /**
88
+ * Extract a BlockProposal from the last block info.
89
+ * Uses inHash from checkpointHeader.contentCommitment.inHash
90
+ */
91
+ getBlockProposal(): BlockProposal | undefined;
92
+ toBlockInfo(): Omit<L2BlockInfo, 'blockNumber'>;
93
+ toCheckpointInfo(): {
94
+ slotNumber: SlotNumber;
95
+ archive: Fr;
96
+ lastBlockNumber: BlockNumber | undefined;
97
+ lastBlockIndex: IndexWithinCheckpoint | undefined;
98
+ blockHeadersHash: Fr;
99
+ };
100
+ /**
101
+ * Get the payload to sign for this checkpoint proposal.
102
+ * The signature is over the checkpoint header + archive root + feeAssetPriceModifier (for consensus).
103
+ */
104
+ getPayloadToSign(domainSeparator: SignatureDomainSeparator): Buffer;
105
+ static createProposalFromSigner(checkpointHeader: CheckpointHeader, archiveRoot: Fr, feeAssetPriceModifier: bigint, lastBlockInfo: CheckpointLastBlockData | undefined, payloadSigner: (payload: Buffer32, context: SigningContext) => Promise<Signature>): Promise<CheckpointProposal>;
106
+ /**
107
+ * Lazily evaluate the sender of the proposal; result is cached.
108
+ * If there's a lastBlock, also verifies the block proposal sender matches the checkpoint sender.
109
+ * @returns The sender address, or undefined if signature recovery fails or senders don't match
110
+ */
111
+ getSender(): EthAddress | undefined;
112
+ getPayload(): Buffer<ArrayBufferLike>;
113
+ toBuffer(): Buffer;
114
+ static fromBuffer(buf: Buffer | BufferReader): CheckpointProposal;
115
+ getSize(): number;
116
+ static empty(): CheckpointProposal;
117
+ static random(): CheckpointProposal;
118
+ toInspect(): {
119
+ checkpointHeader: {
120
+ lastArchive: `0x${string}`;
121
+ blockHeadersHash: `0x${string}`;
122
+ blobsHash: `0x${string}`;
123
+ inHash: `0x${string}`;
124
+ epochOutHash: `0x${string}`;
125
+ slotNumber: SlotNumber;
126
+ timestamp: bigint;
127
+ coinbase: `0x${string}`;
128
+ feeRecipient: `0x${string}`;
129
+ gasFees: {
130
+ feePerDaGas: bigint;
131
+ feePerL2Gas: bigint;
132
+ };
133
+ totalManaUsed: bigint;
134
+ };
135
+ archive: `0x${string}`;
136
+ signature: `0x${string}`;
137
+ feeAssetPriceModifier: string;
138
+ lastBlock: {
139
+ blockHeader: {
140
+ lastArchive: `0x${string}`;
141
+ state: {
142
+ l1ToL2MessageTree: `0x${string}`;
143
+ noteHashTree: `0x${string}`;
144
+ nullifierTree: `0x${string}`;
145
+ publicDataTree: `0x${string}`;
146
+ };
147
+ spongeBlobHash: bigint;
148
+ globalVariables: {
149
+ chainId: number;
150
+ version: number;
151
+ blockNumber: BlockNumber;
152
+ slotNumber: SlotNumber;
153
+ timestamp: bigint;
154
+ coinbase: `0x${string}`;
155
+ feeRecipient: `0x${string}`;
156
+ feePerDaGas: number;
157
+ feePerL2Gas: number;
158
+ };
159
+ totalFees: bigint;
160
+ totalManaUsed: bigint;
161
+ };
162
+ indexWithinCheckpoint: IndexWithinCheckpoint;
163
+ txHashes: `0x${string}`[];
164
+ signature: `0x${string}`;
165
+ } | undefined;
166
+ };
167
+ /**
168
+ * Returns a copy of this proposal without lastBlock info, as a CheckpointProposalCore.
169
+ * Used when the lastBlock has been extracted and stored separately.
170
+ */
171
+ toCore(): CheckpointProposalCore;
172
+ }
173
+ /**
174
+ * A checkpoint proposal without the lastBlock info.
175
+ * Used when the lastBlock has been extracted and handled separately as a BlockProposal.
176
+ * This type makes it clear that lastBlock and getBlockProposal() are not available.
177
+ */
178
+ export type CheckpointProposalCore = Omit<CheckpointProposal, 'lastBlock' | 'getBlockProposal' | 'toCore'>;
179
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2twb2ludF9wcm9wb3NhbC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3AycC9jaGVja3BvaW50X3Byb3Bvc2FsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUscUJBQXFCLEVBQUUsVUFBVSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDakcsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBR3BELE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRCxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNoRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDNUQsT0FBTyxFQUFFLFlBQVksRUFBNEMsTUFBTSw2QkFBNkIsQ0FBQztBQUVyRyxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUU3RCxPQUFPLEVBQVksS0FBSyxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNsRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDcEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3hDLE9BQU8sS0FBSyxFQUFFLEVBQUUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN0QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFDTCx3QkFBd0IsRUFHekIsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDNUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFN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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"checkpoint_proposal.d.ts","sourceRoot":"","sources":["../../src/p2p/checkpoint_proposal.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,243 @@
1
+ import { BlockNumber, IndexWithinCheckpoint } from '@aztec/foundation/branded-types';
2
+ import { Buffer32 } from '@aztec/foundation/buffer';
3
+ import { keccak256 } from '@aztec/foundation/crypto/keccak';
4
+ import { tryRecoverAddress } from '@aztec/foundation/crypto/secp256k1-signer';
5
+ import { Fr } from '@aztec/foundation/curves/bn254';
6
+ import { Signature } from '@aztec/foundation/eth-signature';
7
+ import { BufferReader, serializeSignedBigInt, serializeToBuffer } from '@aztec/foundation/serialize';
8
+ import { MAX_TXS_PER_BLOCK } from '../deserialization/index.js';
9
+ import { DutyType } from '../ha-signing/index.js';
10
+ import { CheckpointHeader } from '../rollup/checkpoint_header.js';
11
+ import { BlockHeader } from '../tx/block_header.js';
12
+ import { TxHash } from '../tx/index.js';
13
+ import { BlockProposal } from './block_proposal.js';
14
+ import { Gossipable } from './gossipable.js';
15
+ import { SignatureDomainSeparator, getHashedSignaturePayload, getHashedSignaturePayloadEthSignedMessage } from './signature_utils.js';
16
+ import { SignedTxs } from './signed_txs.js';
17
+ import { TopicType } from './topic_type.js';
18
+ // REFACTOR(palla): Use a branded type instead of a subclass of Buffer32
19
+ export class CheckpointProposalHash extends Buffer32 {
20
+ constructor(hash){
21
+ super(hash);
22
+ }
23
+ }
24
+ /**
25
+ * A checkpoint proposal is created by the leader of the chain for the last block in a checkpoint.
26
+ * It includes the aggregated checkpoint header that validators will attest to, plus optionally
27
+ * the last block's info for nodes to re-execute. This marks the completion of a slot's worth of blocks.
28
+ */ export class CheckpointProposal extends Gossipable {
29
+ checkpointHeader;
30
+ archive;
31
+ feeAssetPriceModifier;
32
+ signature;
33
+ lastBlock;
34
+ static p2pTopic = TopicType.checkpoint_proposal;
35
+ sender;
36
+ constructor(/** The aggregated checkpoint header for consensus */ checkpointHeader, /** Archive root after this checkpoint is applied */ archive, /** The fee asset price modifier in basis points (from oracle) */ feeAssetPriceModifier, /** The proposer's signature over the checkpoint payload (checkpointHeader + archive + feeAssetPriceModifier) */ signature, /** Optional last block info, including its own signature for BlockProposal extraction */ lastBlock){
37
+ super(), this.checkpointHeader = checkpointHeader, this.archive = archive, this.feeAssetPriceModifier = feeAssetPriceModifier, this.signature = signature, this.lastBlock = lastBlock;
38
+ }
39
+ generateP2PMessageIdentifier() {
40
+ return Promise.resolve(new CheckpointProposalHash(keccak256(this.signature.toBuffer())));
41
+ }
42
+ get slotNumber() {
43
+ return this.checkpointHeader.slotNumber;
44
+ }
45
+ get blockNumber() {
46
+ if (!this.lastBlock) {
47
+ throw new Error('Cannot get blockNumber without lastBlock');
48
+ }
49
+ return this.lastBlock.blockHeader.getBlockNumber();
50
+ }
51
+ /** Convenience getter for txHashes from lastBlock */ get txHashes() {
52
+ return this.lastBlock?.txHashes ?? [];
53
+ }
54
+ /** Convenience getter for txs from lastBlock */ get txs() {
55
+ return this.lastBlock?.signedTxs?.txs;
56
+ }
57
+ /**
58
+ * Extract a BlockProposal from the last block info.
59
+ * Uses inHash from checkpointHeader.contentCommitment.inHash
60
+ */ getBlockProposal() {
61
+ if (!this.lastBlock) {
62
+ return undefined;
63
+ }
64
+ return new BlockProposal(this.lastBlock.blockHeader, this.lastBlock.indexWithinCheckpoint, this.checkpointHeader.inHash, this.archive, this.lastBlock.txHashes, this.lastBlock.signature, this.lastBlock.signedTxs);
65
+ }
66
+ toBlockInfo() {
67
+ if (!this.lastBlock) {
68
+ throw new Error('Cannot get blockInfo without lastBlock');
69
+ }
70
+ return {
71
+ slotNumber: this.slotNumber,
72
+ lastArchive: this.lastBlock.blockHeader.lastArchive.root,
73
+ timestamp: this.lastBlock.blockHeader.globalVariables.timestamp,
74
+ archive: this.archive,
75
+ txCount: this.lastBlock.txHashes.length
76
+ };
77
+ }
78
+ toCheckpointInfo() {
79
+ return {
80
+ slotNumber: this.slotNumber,
81
+ archive: this.archive,
82
+ lastBlockNumber: this.lastBlock?.blockHeader.getBlockNumber(),
83
+ lastBlockIndex: this.lastBlock?.indexWithinCheckpoint,
84
+ blockHeadersHash: this.checkpointHeader.blockHeadersHash
85
+ };
86
+ }
87
+ /**
88
+ * Get the payload to sign for this checkpoint proposal.
89
+ * The signature is over the checkpoint header + archive root + feeAssetPriceModifier (for consensus).
90
+ */ getPayloadToSign(domainSeparator) {
91
+ return serializeToBuffer([
92
+ domainSeparator,
93
+ this.checkpointHeader,
94
+ this.archive,
95
+ serializeSignedBigInt(this.feeAssetPriceModifier)
96
+ ]);
97
+ }
98
+ static async createProposalFromSigner(checkpointHeader, archiveRoot, feeAssetPriceModifier, lastBlockInfo, payloadSigner) {
99
+ // Sign the checkpoint payload with CHECKPOINT_PROPOSAL duty type
100
+ const tempProposal = new CheckpointProposal(checkpointHeader, archiveRoot, feeAssetPriceModifier, Signature.empty());
101
+ const checkpointHash = getHashedSignaturePayload(tempProposal, SignatureDomainSeparator.checkpointProposal);
102
+ const checkpointContext = {
103
+ slot: checkpointHeader.slotNumber,
104
+ blockNumber: lastBlockInfo?.blockHeader?.globalVariables.blockNumber ?? BlockNumber(0),
105
+ dutyType: DutyType.CHECKPOINT_PROPOSAL
106
+ };
107
+ const checkpointSignature = await payloadSigner(checkpointHash, checkpointContext);
108
+ if (!lastBlockInfo) {
109
+ return new CheckpointProposal(checkpointHeader, archiveRoot, feeAssetPriceModifier, checkpointSignature);
110
+ }
111
+ const lastBlockProposal = await BlockProposal.createProposalFromSigner(lastBlockInfo.blockHeader, lastBlockInfo.indexWithinCheckpoint, checkpointHeader.inHash, archiveRoot, lastBlockInfo.txHashes, lastBlockInfo.txs, payloadSigner);
112
+ return new CheckpointProposal(checkpointHeader, archiveRoot, feeAssetPriceModifier, checkpointSignature, {
113
+ blockHeader: lastBlockInfo.blockHeader,
114
+ indexWithinCheckpoint: lastBlockInfo.indexWithinCheckpoint,
115
+ txHashes: lastBlockInfo.txHashes,
116
+ signature: lastBlockProposal.signature,
117
+ signedTxs: lastBlockProposal.signedTxs
118
+ });
119
+ }
120
+ /**
121
+ * Lazily evaluate the sender of the proposal; result is cached.
122
+ * If there's a lastBlock, also verifies the block proposal sender matches the checkpoint sender.
123
+ * @returns The sender address, or undefined if signature recovery fails or senders don't match
124
+ */ getSender() {
125
+ if (!this.sender) {
126
+ const hashed = getHashedSignaturePayloadEthSignedMessage(this, SignatureDomainSeparator.checkpointProposal);
127
+ const checkpointSender = tryRecoverAddress(hashed, this.signature);
128
+ // If there's a lastBlock, verify the block proposal sender matches
129
+ if (checkpointSender && this.lastBlock) {
130
+ const blockProposal = this.getBlockProposal();
131
+ const blockSender = blockProposal?.getSender();
132
+ if (!blockSender || !blockSender.equals(checkpointSender)) {
133
+ return undefined; // Sender mismatch - fail
134
+ }
135
+ }
136
+ // Cache the sender for later use
137
+ this.sender = checkpointSender;
138
+ }
139
+ return this.sender;
140
+ }
141
+ getPayload() {
142
+ return this.getPayloadToSign(SignatureDomainSeparator.checkpointProposal);
143
+ }
144
+ toBuffer() {
145
+ const buffer = [
146
+ this.checkpointHeader,
147
+ this.archive,
148
+ serializeSignedBigInt(this.feeAssetPriceModifier),
149
+ this.signature
150
+ ];
151
+ if (this.lastBlock) {
152
+ buffer.push(1); // hasLastBlock = true
153
+ buffer.push(this.lastBlock.blockHeader);
154
+ buffer.push(this.lastBlock.indexWithinCheckpoint);
155
+ buffer.push(this.lastBlock.signature);
156
+ buffer.push(this.lastBlock.txHashes.length);
157
+ buffer.push(this.lastBlock.txHashes);
158
+ if (this.lastBlock.signedTxs) {
159
+ buffer.push(1); // hasSignedTxs = true
160
+ buffer.push(this.lastBlock.signedTxs.toBuffer());
161
+ } else {
162
+ buffer.push(0); // hasSignedTxs = false
163
+ }
164
+ } else {
165
+ buffer.push(0); // hasLastBlock = false
166
+ }
167
+ return serializeToBuffer(buffer);
168
+ }
169
+ static fromBuffer(buf) {
170
+ const reader = BufferReader.asReader(buf);
171
+ const checkpointHeader = reader.readObject(CheckpointHeader);
172
+ const archive = reader.readObject(Fr);
173
+ const feeAssetPriceModifier = reader.readInt256();
174
+ const signature = reader.readObject(Signature);
175
+ const hasLastBlock = reader.readNumber();
176
+ if (hasLastBlock) {
177
+ const blockHeader = reader.readObject(BlockHeader);
178
+ const indexWithinCheckpoint = IndexWithinCheckpoint(reader.readNumber());
179
+ const blockSignature = reader.readObject(Signature);
180
+ const txHashCount = reader.readNumber();
181
+ if (txHashCount > MAX_TXS_PER_BLOCK) {
182
+ throw new Error(`txHashes count ${txHashCount} exceeds maximum ${MAX_TXS_PER_BLOCK}`);
183
+ }
184
+ const txHashes = reader.readArray(txHashCount, TxHash);
185
+ let signedTxs;
186
+ if (!reader.isEmpty()) {
187
+ const hasSignedTxs = reader.readNumber();
188
+ if (hasSignedTxs) {
189
+ signedTxs = SignedTxs.fromBuffer(reader);
190
+ }
191
+ }
192
+ return new CheckpointProposal(checkpointHeader, archive, feeAssetPriceModifier, signature, {
193
+ blockHeader,
194
+ indexWithinCheckpoint,
195
+ txHashes,
196
+ signature: blockSignature,
197
+ signedTxs
198
+ });
199
+ }
200
+ return new CheckpointProposal(checkpointHeader, archive, feeAssetPriceModifier, signature);
201
+ }
202
+ getSize() {
203
+ let size = this.checkpointHeader.toBuffer().length + this.archive.size + this.signature.getSize() + 8 /* feeAssetPriceModifier */ + 4; /* hasLastBlock flag */
204
+ if (this.lastBlock) {
205
+ size += this.lastBlock.blockHeader.getSize() + 4 /* indexWithinCheckpoint */ + this.lastBlock.signature.getSize() + 4 /* txHashes.length */ + this.lastBlock.txHashes.length * TxHash.SIZE + 4 /* hasSignedTxs flag */ + (this.lastBlock.signedTxs ? this.lastBlock.signedTxs.getSize() : 0);
206
+ }
207
+ return size;
208
+ }
209
+ static empty() {
210
+ return new CheckpointProposal(CheckpointHeader.empty(), Fr.ZERO, 0n, Signature.empty());
211
+ }
212
+ static random() {
213
+ return new CheckpointProposal(CheckpointHeader.random(), Fr.random(), 0n, Signature.random(), {
214
+ blockHeader: BlockHeader.random(),
215
+ indexWithinCheckpoint: IndexWithinCheckpoint(Math.floor(Math.random() * 5)),
216
+ txHashes: [
217
+ TxHash.random(),
218
+ TxHash.random()
219
+ ],
220
+ signature: Signature.random()
221
+ });
222
+ }
223
+ toInspect() {
224
+ return {
225
+ checkpointHeader: this.checkpointHeader.toInspect(),
226
+ archive: this.archive.toString(),
227
+ signature: this.signature.toString(),
228
+ feeAssetPriceModifier: this.feeAssetPriceModifier.toString(),
229
+ lastBlock: this.lastBlock ? {
230
+ blockHeader: this.lastBlock.blockHeader.toInspect(),
231
+ indexWithinCheckpoint: this.lastBlock.indexWithinCheckpoint,
232
+ txHashes: this.lastBlock.txHashes.map((h)=>h.toString()),
233
+ signature: this.lastBlock.signature.toString()
234
+ } : undefined
235
+ };
236
+ }
237
+ /**
238
+ * Returns a copy of this proposal without lastBlock info, as a CheckpointProposalCore.
239
+ * Used when the lastBlock has been extracted and stored separately.
240
+ */ toCore() {
241
+ return new CheckpointProposal(this.checkpointHeader, this.archive, this.feeAssetPriceModifier, this.signature);
242
+ }
243
+ }
@@ -2,39 +2,49 @@ import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { BufferReader } from '@aztec/foundation/serialize';
3
3
  import type { FieldsOf } from '@aztec/foundation/types';
4
4
  import { z } from 'zod';
5
- import type { L2Block } from '../block/l2_block.js';
6
5
  import type { Checkpoint } from '../checkpoint/checkpoint.js';
7
6
  import { CheckpointHeader } from '../rollup/checkpoint_header.js';
7
+ import type { CheckpointProposal, CheckpointProposalCore } from './checkpoint_proposal.js';
8
8
  import type { Signable, SignatureDomainSeparator } from './signature_utils.js';
9
+ /** Checkpoint consensus payload as signed by validators and verified on L1. */
9
10
  export declare class ConsensusPayload implements Signable {
11
+ /** The proposed block header the attestation is made over */
10
12
  readonly header: CheckpointHeader;
13
+ /** The archive root after the block is added */
11
14
  readonly archive: Fr;
15
+ /** The fee asset price modifier in basis points (from oracle) */
16
+ readonly feeAssetPriceModifier: bigint;
12
17
  private size;
13
18
  constructor(
14
19
  /** The proposed block header the attestation is made over */
15
20
  header: CheckpointHeader,
16
21
  /** The archive root after the block is added */
17
- archive: Fr);
22
+ archive: Fr,
23
+ /** The fee asset price modifier in basis points (from oracle) */
24
+ feeAssetPriceModifier?: bigint);
18
25
  static get schema(): z.ZodEffects<z.ZodObject<{
19
26
  header: import("@aztec/foundation/schemas").ZodFor<CheckpointHeader>;
20
27
  archive: z.ZodType<Fr, any, string>;
28
+ feeAssetPriceModifier: z.ZodPipeline<z.ZodUnion<[z.ZodBigInt, z.ZodNumber, z.ZodString]>, z.ZodBigInt>;
21
29
  }, "strip", z.ZodTypeAny, {
22
30
  header: CheckpointHeader;
23
31
  archive: Fr;
32
+ feeAssetPriceModifier: bigint;
24
33
  }, {
25
34
  header?: any;
26
35
  archive: string;
36
+ feeAssetPriceModifier: string | number | bigint;
27
37
  }>, ConsensusPayload, {
28
38
  header?: any;
29
39
  archive: string;
40
+ feeAssetPriceModifier: string | number | bigint;
30
41
  }>;
31
- static getFields(fields: FieldsOf<ConsensusPayload>): readonly [CheckpointHeader, Fr];
42
+ static getFields(fields: FieldsOf<ConsensusPayload>): readonly [CheckpointHeader, Fr, bigint];
32
43
  getPayloadToSign(domainSeparator: SignatureDomainSeparator): Buffer;
33
44
  toBuffer(): Buffer;
34
- equals(other: ConsensusPayload): boolean;
45
+ equals(other: ConsensusPayload | CheckpointProposal | CheckpointProposalCore): boolean;
35
46
  static fromBuffer(buf: Buffer | BufferReader): ConsensusPayload;
36
47
  static fromFields(fields: FieldsOf<ConsensusPayload>): ConsensusPayload;
37
- static fromBlock(block: L2Block): ConsensusPayload;
38
48
  static fromCheckpoint(checkpoint: Checkpoint): ConsensusPayload;
39
49
  static empty(): ConsensusPayload;
40
50
  static random(): ConsensusPayload;
@@ -47,11 +57,9 @@ export declare class ConsensusPayload implements Signable {
47
57
  header: {
48
58
  lastArchive: `0x${string}`;
49
59
  blockHeadersHash: `0x${string}`;
50
- contentCommitment: {
51
- blobsHash: `0x${string}`;
52
- inHash: `0x${string}`;
53
- outHash: `0x${string}`;
54
- };
60
+ blobsHash: `0x${string}`;
61
+ inHash: `0x${string}`;
62
+ epochOutHash: `0x${string}`;
55
63
  slotNumber: import("@aztec/foundation/schemas").SlotNumber;
56
64
  timestamp: bigint;
57
65
  coinbase: `0x${string}`;
@@ -63,7 +71,8 @@ export declare class ConsensusPayload implements Signable {
63
71
  totalManaUsed: bigint;
64
72
  };
65
73
  archive: `0x${string}`;
74
+ feeAssetPriceModifier: string;
66
75
  };
67
76
  toString(): string;
68
77
  }
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc2Vuc3VzX3BheWxvYWQuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wMnAvY29uc2Vuc3VzX3BheWxvYWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRXBELE9BQU8sRUFBRSxZQUFZLEVBQXFCLE1BQU0sNkJBQTZCLENBQUM7QUFFOUUsT0FBTyxLQUFLLEVBQUUsUUFBUSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHeEQsT0FBTyxFQUFFLENBQUMsRUFBRSxNQUFNLEtBQUssQ0FBQztBQUV4QixPQUFPLEtBQUssRUFBRSxPQUFPLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNwRCxPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNsRSxPQUFPLEtBQUssRUFBRSxRQUFRLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUUvRSxxQkFBYSxnQkFBaUIsWUFBVyxRQUFRO2FBSzdCLE1BQU0sRUFBRSxnQkFBZ0I7YUFFeEIsT0FBTyxFQUFFLEVBQUU7SUFON0IsT0FBTyxDQUFDLElBQUksQ0FBcUI7SUFFakM7SUFDRSw2REFBNkQ7SUFDN0MsTUFBTSxFQUFFLGdCQUFnQjtJQUN4QyxnREFBZ0Q7SUFDaEMsT0FBTyxFQUFFLEVBQUUsRUFDekI7SUFFSixNQUFNLEtBQUssTUFBTTs7Ozs7Ozs7Ozs7O09BT2hCO0lBRUQsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLG1DQUVsRDtJQUVELGdCQUFnQixDQUFDLGVBQWUsRUFBRSx3QkFBd0IsR0FBRyxNQUFNLENBa0JsRTtJQUVELFFBQVEsSUFBSSxNQUFNLENBRWpCO0lBRU0sTUFBTSxDQUFDLEtBQUssRUFBRSxnQkFBZ0IsR0FBRyxPQUFPLENBRTlDO0lBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsTUFBTSxHQUFHLFlBQVksR0FBRyxnQkFBZ0IsQ0FJOUQ7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxnQkFBZ0IsQ0FFdEU7SUFFRCxNQUFNLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxPQUFPLEdBQUcsZ0JBQWdCLENBRWpEO0lBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxVQUFVLEVBQUUsVUFBVSxHQUFHLGdCQUFnQixDQUU5RDtJQUVELE1BQU0sQ0FBQyxLQUFLLElBQUksZ0JBQWdCLENBRS9CO0lBRUQsTUFBTSxDQUFDLE1BQU0sSUFBSSxnQkFBZ0IsQ0FFaEM7SUFFRDs7O09BR0c7SUFDSCxPQUFPLElBQUksTUFBTSxDQU9oQjtJQUVELFNBQVM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O01BS1I7SUFFRCxRQUFRLFdBRVA7Q0FDRiJ9
78
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc2Vuc3VzX3BheWxvYWQuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wMnAvY29uc2Vuc3VzX3BheWxvYWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEVBQUUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRXBELE9BQU8sRUFBRSxZQUFZLEVBQTRDLE1BQU0sNkJBQTZCLENBQUM7QUFFckcsT0FBTyxLQUFLLEVBQUUsUUFBUSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFHeEQsT0FBTyxFQUFFLENBQUMsRUFBRSxNQUFNLEtBQUssQ0FBQztBQUV4QixPQUFPLEtBQUssRUFBRSxVQUFVLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNsRSxPQUFPLEtBQUssRUFBRSxrQkFBa0IsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNGLE9BQU8sS0FBSyxFQUFFLFFBQVEsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRS9FLCtFQUErRTtBQUMvRSxxQkFBYSxnQkFBaUIsWUFBVyxRQUFRO0lBSTdDLDZEQUE2RDthQUM3QyxNQUFNLEVBQUUsZ0JBQWdCO0lBQ3hDLGdEQUFnRDthQUNoQyxPQUFPLEVBQUUsRUFBRTtJQUMzQixpRUFBaUU7YUFDakQscUJBQXFCLEVBQUUsTUFBTTtJQVIvQyxPQUFPLENBQUMsSUFBSSxDQUFxQjtJQUVqQztJQUNFLDZEQUE2RDtJQUM3QyxNQUFNLEVBQUUsZ0JBQWdCO0lBQ3hDLGdEQUFnRDtJQUNoQyxPQUFPLEVBQUUsRUFBRTtJQUMzQixpRUFBaUU7SUFDakQscUJBQXFCLEdBQUUsTUFBVyxFQUNoRDtJQUVKLE1BQU0sS0FBSyxNQUFNOzs7Ozs7Ozs7Ozs7Ozs7O09BUWhCO0lBRUQsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLGdCQUFnQixDQUFDLDJDQUVsRDtJQUVELGdCQUFnQixDQUFDLGVBQWUsRUFBRSx3QkFBd0IsR0FBRyxNQUFNLENBa0JsRTtJQUVELFFBQVEsSUFBSSxNQUFNLENBRWpCO0lBRU0sTUFBTSxDQUFDLEtBQUssRUFBRSxnQkFBZ0IsR0FBRyxrQkFBa0IsR0FBRyxzQkFBc0IsR0FBRyxPQUFPLENBUTVGO0lBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsTUFBTSxHQUFHLFlBQVksR0FBRyxnQkFBZ0IsQ0FROUQ7SUFFRCxNQUFNLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxnQkFBZ0IsQ0FFdEU7SUFFRCxNQUFNLENBQUMsY0FBYyxDQUFDLFVBQVUsRUFBRSxVQUFVLEdBQUcsZ0JBQWdCLENBRTlEO0lBRUQsTUFBTSxDQUFDLEtBQUssSUFBSSxnQkFBZ0IsQ0FFL0I7SUFFRCxNQUFNLENBQUMsTUFBTSxJQUFJLGdCQUFnQixDQUVoQztJQUVEOzs7T0FHRztJQUNILE9BQU8sSUFBSSxNQUFNLENBT2hCO0lBRUQsU0FBUzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztNQU1SO0lBRUQsUUFBUSxXQUVQO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"consensus_payload.d.ts","sourceRoot":"","sources":["../../src/p2p/consensus_payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAEpD,OAAO,EAAE,YAAY,EAAqB,MAAM,6BAA6B,CAAC;AAE9E,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AAGxD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,KAAK,EAAE,QAAQ,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAE/E,qBAAa,gBAAiB,YAAW,QAAQ;aAK7B,MAAM,EAAE,gBAAgB;aAExB,OAAO,EAAE,EAAE;IAN7B,OAAO,CAAC,IAAI,CAAqB;IAEjC;IACE,6DAA6D;IAC7C,MAAM,EAAE,gBAAgB;IACxC,gDAAgD;IAChC,OAAO,EAAE,EAAE,EACzB;IAEJ,MAAM,KAAK,MAAM;;;;;;;;;;;;OAOhB;IAED,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,gBAAgB,CAAC,mCAElD;IAED,gBAAgB,CAAC,eAAe,EAAE,wBAAwB,GAAG,MAAM,CAkBlE;IAED,QAAQ,IAAI,MAAM,CAEjB;IAEM,MAAM,CAAC,KAAK,EAAE,gBAAgB,GAAG,OAAO,CAE9C;IAED,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,GAAG,gBAAgB,CAI9D;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,QAAQ,CAAC,gBAAgB,CAAC,GAAG,gBAAgB,CAEtE;IAED,MAAM,CAAC,SAAS,CAAC,KAAK,EAAE,OAAO,GAAG,gBAAgB,CAEjD;IAED,MAAM,CAAC,cAAc,CAAC,UAAU,EAAE,UAAU,GAAG,gBAAgB,CAE9D;IAED,MAAM,CAAC,KAAK,IAAI,gBAAgB,CAE/B;IAED,MAAM,CAAC,MAAM,IAAI,gBAAgB,CAEhC;IAED;;;OAGG;IACH,OAAO,IAAI,MAAM,CAOhB;IAED,SAAS;;;;;;;;;;;;;;;;;;;;MAKR;IAED,QAAQ,WAEP;CACF"}
1
+ {"version":3,"file":"consensus_payload.d.ts","sourceRoot":"","sources":["../../src/p2p/consensus_payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAE,MAAM,gCAAgC,CAAC;AAEpD,OAAO,EAAE,YAAY,EAA4C,MAAM,6BAA6B,CAAC;AAErG,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AAGxD,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,KAAK,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAC3F,OAAO,KAAK,EAAE,QAAQ,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAE/E,+EAA+E;AAC/E,qBAAa,gBAAiB,YAAW,QAAQ;IAI7C,6DAA6D;aAC7C,MAAM,EAAE,gBAAgB;IACxC,gDAAgD;aAChC,OAAO,EAAE,EAAE;IAC3B,iEAAiE;aACjD,qBAAqB,EAAE,MAAM;IAR/C,OAAO,CAAC,IAAI,CAAqB;IAEjC;IACE,6DAA6D;IAC7C,MAAM,EAAE,gBAAgB;IACxC,gDAAgD;IAChC,OAAO,EAAE,EAAE;IAC3B,iEAAiE;IACjD,qBAAqB,GAAE,MAAW,EAChD;IAEJ,MAAM,KAAK,MAAM;;;;;;;;;;;;;;;;OAQhB;IAED,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,gBAAgB,CAAC,2CAElD;IAED,gBAAgB,CAAC,eAAe,EAAE,wBAAwB,GAAG,MAAM,CAkBlE;IAED,QAAQ,IAAI,MAAM,CAEjB;IAEM,MAAM,CAAC,KAAK,EAAE,gBAAgB,GAAG,kBAAkB,GAAG,sBAAsB,GAAG,OAAO,CAQ5F;IAED,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,GAAG,gBAAgB,CAQ9D;IAED,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,QAAQ,CAAC,gBAAgB,CAAC,GAAG,gBAAgB,CAEtE;IAED,MAAM,CAAC,cAAc,CAAC,UAAU,EAAE,UAAU,GAAG,gBAAgB,CAE9D;IAED,MAAM,CAAC,KAAK,IAAI,gBAAgB,CAE/B;IAED,MAAM,CAAC,MAAM,IAAI,gBAAgB,CAEhC;IAED;;;OAGG;IACH,OAAO,IAAI,MAAM,CAOhB;IAED,SAAS;;;;;;;;;;;;;;;;;;;MAMR;IAED,QAAQ,WAEP;CACF"}
@@ -1,28 +1,32 @@
1
1
  import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { schemas } from '@aztec/foundation/schemas';
3
- import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
3
+ import { BufferReader, serializeSignedBigInt, serializeToBuffer } from '@aztec/foundation/serialize';
4
4
  import { hexToBuffer } from '@aztec/foundation/string';
5
5
  import { encodeAbiParameters, parseAbiParameters } from 'viem';
6
6
  import { z } from 'zod';
7
7
  import { CheckpointHeader } from '../rollup/checkpoint_header.js';
8
- export class ConsensusPayload {
8
+ /** Checkpoint consensus payload as signed by validators and verified on L1. */ export class ConsensusPayload {
9
9
  header;
10
10
  archive;
11
+ feeAssetPriceModifier;
11
12
  size;
12
- constructor(/** The proposed block header the attestation is made over */ header, /** The archive root after the block is added */ archive){
13
+ constructor(/** The proposed block header the attestation is made over */ header, /** The archive root after the block is added */ archive, /** The fee asset price modifier in basis points (from oracle) */ feeAssetPriceModifier = 0n){
13
14
  this.header = header;
14
15
  this.archive = archive;
16
+ this.feeAssetPriceModifier = feeAssetPriceModifier;
15
17
  }
16
18
  static get schema() {
17
19
  return z.object({
18
20
  header: CheckpointHeader.schema,
19
- archive: schemas.Fr
20
- }).transform((obj)=>new ConsensusPayload(obj.header, obj.archive));
21
+ archive: schemas.Fr,
22
+ feeAssetPriceModifier: schemas.BigInt
23
+ }).transform((obj)=>new ConsensusPayload(obj.header, obj.archive, obj.feeAssetPriceModifier));
21
24
  }
22
25
  static getFields(fields) {
23
26
  return [
24
27
  fields.header,
25
- fields.archive
28
+ fields.archive,
29
+ fields.feeAssetPriceModifier
26
30
  ];
27
31
  }
28
32
  getPayloadToSign(domainSeparator) {
@@ -38,7 +42,7 @@ export class ConsensusPayload {
38
42
  [
39
43
  archiveRoot,
40
44
  [
41
- 0n
45
+ this.feeAssetPriceModifier
42
46
  ],
43
47
  headerHash
44
48
  ]
@@ -48,31 +52,31 @@ export class ConsensusPayload {
48
52
  toBuffer() {
49
53
  return serializeToBuffer([
50
54
  this.header,
51
- this.archive
55
+ this.archive,
56
+ serializeSignedBigInt(this.feeAssetPriceModifier)
52
57
  ]);
53
58
  }
54
59
  equals(other) {
55
- return this.header.equals(other.header) && this.archive.equals(other.archive);
60
+ const otherHeader = 'checkpointHeader' in other ? other.checkpointHeader : other.header;
61
+ const otherModifier = 'feeAssetPriceModifier' in other ? other.feeAssetPriceModifier : 0n;
62
+ return this.header.equals(otherHeader) && this.archive.equals(other.archive) && this.feeAssetPriceModifier === otherModifier;
56
63
  }
57
64
  static fromBuffer(buf) {
58
65
  const reader = BufferReader.asReader(buf);
59
- const payload = new ConsensusPayload(reader.readObject(CheckpointHeader), reader.readObject(Fr));
66
+ const payload = new ConsensusPayload(reader.readObject(CheckpointHeader), reader.readObject(Fr), reader.readInt256());
60
67
  return payload;
61
68
  }
62
69
  static fromFields(fields) {
63
- return new ConsensusPayload(fields.header, fields.archive);
64
- }
65
- static fromBlock(block) {
66
- return new ConsensusPayload(block.header.toCheckpointHeader(), block.archive.root);
70
+ return new ConsensusPayload(fields.header, fields.archive, fields.feeAssetPriceModifier);
67
71
  }
68
72
  static fromCheckpoint(checkpoint) {
69
- return new ConsensusPayload(checkpoint.header, checkpoint.archive.root);
73
+ return new ConsensusPayload(checkpoint.header, checkpoint.archive.root, checkpoint.feeAssetPriceModifier);
70
74
  }
71
75
  static empty() {
72
- return new ConsensusPayload(CheckpointHeader.empty(), Fr.ZERO);
76
+ return new ConsensusPayload(CheckpointHeader.empty(), Fr.ZERO, 0n);
73
77
  }
74
78
  static random() {
75
- return new ConsensusPayload(CheckpointHeader.random(), Fr.random());
79
+ return new ConsensusPayload(CheckpointHeader.random(), Fr.random(), 0n);
76
80
  }
77
81
  /**
78
82
  * Get the size of the consensus payload in bytes.
@@ -88,10 +92,11 @@ export class ConsensusPayload {
88
92
  toInspect() {
89
93
  return {
90
94
  header: this.header.toInspect(),
91
- archive: this.archive.toString()
95
+ archive: this.archive.toString(),
96
+ feeAssetPriceModifier: this.feeAssetPriceModifier.toString()
92
97
  };
93
98
  }
94
99
  toString() {
95
- return `header: ${this.header.toString()}, archive: ${this.archive.toString()}}`;
100
+ return `header: ${this.header.toString()}, archive: ${this.archive.toString()}, feeAssetPriceModifier: ${this.feeAssetPriceModifier}}`;
96
101
  }
97
102
  }
@@ -0,0 +1,5 @@
1
+ export declare const MAX_TX_SIZE_KB: number;
2
+ export declare const MAX_MESSAGE_SIZE_KB: number;
3
+ /** Maximum size for L2Block response (contains TxEffects, not full Txs with proofs) */
4
+ export declare const MAX_L2_BLOCK_SIZE_KB: number;
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvcDJwL2NvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxlQUFPLE1BQU0sY0FBYyxFQUFFLE1BQVksQ0FBQztBQUUxQyxlQUFPLE1BQU0sbUJBQW1CLEVBQUUsTUFBa0IsQ0FBQztBQUVyRCx1RkFBdUY7QUFDdkYsZUFBTyxNQUFNLG9CQUFvQixFQUFFLE1BQWlCLENBQUMifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../src/p2p/constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,cAAc,EAAE,MAAY,CAAC;AAE1C,eAAO,MAAM,mBAAmB,EAAE,MAAkB,CAAC;AAErD,uFAAuF;AACvF,eAAO,MAAM,oBAAoB,EAAE,MAAiB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export const MAX_TX_SIZE_KB = 512;
2
+ export const MAX_MESSAGE_SIZE_KB = 10 * 1024;
3
+ /** Maximum size for L2Block response (contains TxEffects, not full Txs with proofs) */ export const MAX_L2_BLOCK_SIZE_KB = 3 * 1024; // 3 MB