@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,88 @@
1
+ import { Buffer32 } from '@aztec/foundation/buffer';
2
+ import { tryRecoverAddress } from '@aztec/foundation/crypto/secp256k1-signer';
3
+ import type { EthAddress } from '@aztec/foundation/eth-address';
4
+ import { Signature } from '@aztec/foundation/eth-signature';
5
+ import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
6
+
7
+ import { MAX_TXS_PER_BLOCK } from '../deserialization/index.js';
8
+ import { Tx } from '../tx/tx.js';
9
+ import {
10
+ SignatureDomainSeparator,
11
+ getHashedSignaturePayload,
12
+ getHashedSignaturePayloadEthSignedMessage,
13
+ } from './signature_utils.js';
14
+
15
+ /**
16
+ * A signed collection of transactions.
17
+ * The signature is over the transaction objects themselves, providing
18
+ * data availability guarantees beyond just the transaction hashes.
19
+ */
20
+ export class SignedTxs {
21
+ private sender: EthAddress | undefined;
22
+
23
+ constructor(
24
+ /** The transactions */
25
+ public readonly txs: Tx[],
26
+ /** The proposer's signature over the transactions */
27
+ public readonly signature: Signature,
28
+ ) {}
29
+
30
+ /**
31
+ * Get the payload to sign for this signed txs.
32
+ */
33
+ getPayloadToSign(domainSeparator: SignatureDomainSeparator): Buffer {
34
+ return serializeToBuffer([domainSeparator, this.txs.length, this.txs]);
35
+ }
36
+
37
+ /**
38
+ * Lazily evaluate the sender of the signed txs; result is cached
39
+ * @returns The sender address, or undefined if signature recovery fails
40
+ */
41
+ getSender(): EthAddress | undefined {
42
+ if (!this.sender) {
43
+ const hashed = getHashedSignaturePayloadEthSignedMessage(this, SignatureDomainSeparator.signedTxs);
44
+ this.sender = tryRecoverAddress(hashed, this.signature);
45
+ }
46
+ return this.sender;
47
+ }
48
+
49
+ /**
50
+ * Create SignedTxs from a signer function
51
+ */
52
+ static async createFromSigner(
53
+ txs: Tx[],
54
+ payloadSigner: (payload: Buffer32) => Promise<Signature>,
55
+ ): Promise<SignedTxs> {
56
+ const tempSignedTxs = new SignedTxs(txs, Signature.empty());
57
+ const hashed = getHashedSignaturePayload(tempSignedTxs, SignatureDomainSeparator.signedTxs);
58
+ const signature = await payloadSigner(hashed);
59
+ return new SignedTxs(txs, signature);
60
+ }
61
+
62
+ toBuffer(): Buffer {
63
+ return serializeToBuffer([this.txs.length, this.txs, this.signature]);
64
+ }
65
+
66
+ static fromBuffer(buf: Buffer | BufferReader): SignedTxs {
67
+ const reader = BufferReader.asReader(buf);
68
+ const txCount = reader.readNumber();
69
+ if (txCount > MAX_TXS_PER_BLOCK) {
70
+ throw new Error(`txs count ${txCount} exceeds maximum ${MAX_TXS_PER_BLOCK}`);
71
+ }
72
+ const txs = reader.readArray(txCount, Tx);
73
+ const signature = reader.readObject(Signature);
74
+ return new SignedTxs(txs, signature);
75
+ }
76
+
77
+ getSize(): number {
78
+ return 4 /* txs.length */ + this.txs.reduce((acc, tx) => acc + tx.getSize(), 0) + this.signature.getSize();
79
+ }
80
+
81
+ static empty(): SignedTxs {
82
+ return new SignedTxs([], Signature.empty());
83
+ }
84
+
85
+ static random(): SignedTxs {
86
+ return new SignedTxs([Tx.random(), Tx.random()], Signature.random());
87
+ }
88
+ }
@@ -23,14 +23,15 @@ export function getTopicFromString(topicStr: string): TopicType | undefined {
23
23
  export enum TopicType {
24
24
  tx = 'tx',
25
25
  block_proposal = 'block_proposal',
26
- block_attestation = 'block_attestation',
26
+ checkpoint_proposal = 'checkpoint_proposal',
27
+ checkpoint_attestation = 'checkpoint_attestation',
27
28
  }
28
29
 
29
30
  export function getTopicTypeForClientType(clientType: P2PClientType) {
30
31
  if (clientType === P2PClientType.Full) {
31
- return Object.values(TopicType);
32
+ return [TopicType.tx, TopicType.block_proposal, TopicType.checkpoint_proposal, TopicType.checkpoint_attestation];
32
33
  } else if (clientType === P2PClientType.Prover) {
33
- return [TopicType.tx, TopicType.block_proposal];
34
+ return [TopicType.tx, TopicType.block_proposal, TopicType.checkpoint_proposal];
34
35
  } else {
35
36
  const _: never = clientType;
36
37
  return [TopicType.tx];
@@ -1,4 +1,5 @@
1
1
  import { CHONK_PROOF_LENGTH } from '@aztec/constants';
2
+ import { times } from '@aztec/foundation/collection';
2
3
  import { randomBytes } from '@aztec/foundation/crypto/random';
3
4
  import { Fr } from '@aztec/foundation/curves/bn254';
4
5
  import { bufferSchemaFor } from '@aztec/foundation/schemas';
@@ -31,12 +32,15 @@ export class ChonkProof {
31
32
 
32
33
  static random() {
33
34
  // NB: Not using Fr.random here because it slows down some tests that require a large number of txs significantly.
35
+ // NB2: generate one fewer random bytes to not have to deal with buffers representing numbers greater than the field modulus
36
+ // NB3: a chonk proof can be compressed. Simulate this by filling 1/4 of the proof with zero data
34
37
  const reducedFrSize = Fr.SIZE_IN_BYTES - 1;
35
- const randomFields = randomBytes(CHONK_PROOF_LENGTH * reducedFrSize);
36
- const proof = Array.from(
37
- { length: CHONK_PROOF_LENGTH },
38
- (_, i) => new Fr(randomFields.subarray(i * reducedFrSize, (i + 1) * reducedFrSize)),
39
- );
38
+ const nonZeroFields = Math.floor((3 * CHONK_PROOF_LENGTH) / 4);
39
+ const randomFields = randomBytes(nonZeroFields * Fr.SIZE_IN_BYTES);
40
+ const proof = [
41
+ ...times(nonZeroFields, i => new Fr(randomFields.subarray(i * reducedFrSize, (i + 1) * reducedFrSize))),
42
+ ...times(CHONK_PROOF_LENGTH - nonZeroFields, () => Fr.ZERO),
43
+ ];
40
44
  return new ChonkProof(proof);
41
45
  }
42
46
 
@@ -5,7 +5,7 @@ import type { BlockHeader } from '../tx/block_header.js';
5
5
 
6
6
  export async function computeBlockHeadersHash(blockHeaders: BlockHeader[]): Promise<Fr> {
7
7
  const blockHeaderHashes = await Promise.all(blockHeaders.map(header => header.hash()));
8
- // Must match the implementation in merge_block_rollups.nr, with the **wonky** rollup structure
8
+ // Must match the implementation in merge_block_rollups.nr, with the **unbalanced** rollup structure
9
9
  // (see validate_consecutive_block_rollups.nr > assert_rollups_filled_greedily.nr).
10
10
  const blockHeadersHash = await computeUnbalancedPoseidonRoot(blockHeaderHashes.map(hash => hash.toBuffer()));
11
11
  return Fr.fromBuffer(blockHeadersHash);
@@ -43,17 +43,13 @@ export class BlockRollupPublicInputs {
43
43
  */
44
44
  public endSpongeBlob: SpongeBlob,
45
45
  /**
46
- * Timestamp of the first block in this block range.
46
+ * Timestamp of the blocks in this block range.
47
47
  */
48
- public startTimestamp: UInt64,
49
- /**
50
- * Timestamp of the last block in this block range.
51
- */
52
- public endTimestamp: UInt64,
48
+ public timestamp: UInt64,
53
49
  /**
54
50
  * Hash of the headers of all blocks in this block range. It will be combined with the `blockHeadersHash` from
55
- * other blocks in the same checkpoint to form a wonky tree. The root of that tree becomes the final hash stored in
56
- * the checkpoint header, enabling validation of the blocks included in a checkpoint given their headers.
51
+ * other blocks in the same checkpoint to form an unbalanced tree. The root of that tree becomes the final hash
52
+ * stored in the checkpoint header, enabling validation of the blocks included in a checkpoint given their headers.
57
53
  */
58
54
  public blockHeadersHash: Fr,
59
55
  /**
@@ -85,7 +81,6 @@ export class BlockRollupPublicInputs {
85
81
  reader.readObject(SpongeBlob),
86
82
  reader.readObject(SpongeBlob),
87
83
  reader.readUInt64(),
88
- reader.readUInt64(),
89
84
  Fr.fromBuffer(reader),
90
85
  Fr.fromBuffer(reader),
91
86
  Fr.fromBuffer(reader),
@@ -103,8 +98,7 @@ export class BlockRollupPublicInputs {
103
98
  this.endState,
104
99
  this.startSpongeBlob,
105
100
  this.endSpongeBlob,
106
- bigintToUInt64BE(this.startTimestamp),
107
- bigintToUInt64BE(this.endTimestamp),
101
+ bigintToUInt64BE(this.timestamp),
108
102
  this.blockHeadersHash,
109
103
  this.inHash,
110
104
  this.outHash,
@@ -14,12 +14,13 @@ import { z } from 'zod';
14
14
  import { AztecAddress } from '../aztec-address/index.js';
15
15
  import { GasFees } from '../gas/index.js';
16
16
  import { schemas } from '../schemas/index.js';
17
- import { ContentCommitment } from '../tx/content_commitment.js';
17
+ import type { GlobalVariables } from '../tx/global_variables.js';
18
18
  import type { UInt64 } from '../types/shared.js';
19
19
 
20
20
  /**
21
21
  * Header of a checkpoint. A checkpoint is a collection of blocks submitted to L1 all within the same slot.
22
- * TODO(palla/mbps): Should this include chainId and version as well? Is this used just in circuits?
22
+ * This header is verified as-is in the rollup circuits, posted to the L1 rollup contract, stored in the archiver,
23
+ * and exposed via the Aztec Node API. See `CheckpointData` for a struct that includes the header plus extra metadata.
23
24
  */
24
25
  export class CheckpointHeader {
25
26
  constructor(
@@ -27,8 +28,18 @@ export class CheckpointHeader {
27
28
  public lastArchiveRoot: Fr,
28
29
  /** Hash of the headers of all blocks in this checkpoint. */
29
30
  public blockHeadersHash: Fr,
30
- /** Content commitment of the L2 block. */
31
- public contentCommitment: ContentCommitment,
31
+ /** Hash of the blobs in the checkpoint. */
32
+ public blobsHash: Fr,
33
+ /** Root of the l1 to l2 messages subtree. */
34
+ public inHash: Fr,
35
+ /**
36
+ * The root of the epoch out hash balanced tree. The out hash of the first checkpoint in the epoch is inserted at
37
+ * index 0, the second at index 1, and so on.
38
+ * Note: This is not necessarily the final epoch out hash. It includes only the out hashes of checkpoints up to and
39
+ * including the current checkpoint. Any subsequent checkpoints added to the same epoch are not reflected in this
40
+ * value.
41
+ */
42
+ public epochOutHash: Fr,
32
43
  /** Slot number of the L2 block */
33
44
  public slotNumber: SlotNumber,
34
45
  /** Timestamp of the L2 block. */
@@ -48,7 +59,9 @@ export class CheckpointHeader {
48
59
  .object({
49
60
  lastArchiveRoot: schemas.Fr,
50
61
  blockHeadersHash: schemas.Fr,
51
- contentCommitment: ContentCommitment.schema,
62
+ blobsHash: schemas.Fr,
63
+ inHash: schemas.Fr,
64
+ epochOutHash: schemas.Fr,
52
65
  slotNumber: schemas.SlotNumber,
53
66
  timestamp: schemas.BigInt,
54
67
  coinbase: schemas.EthAddress,
@@ -63,7 +76,9 @@ export class CheckpointHeader {
63
76
  return [
64
77
  fields.lastArchiveRoot,
65
78
  fields.blockHeadersHash,
66
- fields.contentCommitment,
79
+ fields.blobsHash,
80
+ fields.inHash,
81
+ fields.epochOutHash,
67
82
  fields.slotNumber,
68
83
  fields.timestamp,
69
84
  fields.coinbase,
@@ -83,7 +98,9 @@ export class CheckpointHeader {
83
98
  return new CheckpointHeader(
84
99
  reader.readObject(Fr),
85
100
  reader.readObject(Fr),
86
- reader.readObject(ContentCommitment),
101
+ reader.readObject(Fr),
102
+ reader.readObject(Fr),
103
+ reader.readObject(Fr),
87
104
  SlotNumber(Fr.fromBuffer(reader).toNumber()),
88
105
  reader.readUInt64(),
89
106
  reader.readObject(EthAddress),
@@ -97,7 +114,9 @@ export class CheckpointHeader {
97
114
  return (
98
115
  this.lastArchiveRoot.equals(other.lastArchiveRoot) &&
99
116
  this.blockHeadersHash.equals(other.blockHeadersHash) &&
100
- this.contentCommitment.equals(other.contentCommitment) &&
117
+ this.blobsHash.equals(other.blobsHash) &&
118
+ this.inHash.equals(other.inHash) &&
119
+ this.epochOutHash.equals(other.epochOutHash) &&
101
120
  this.slotNumber === other.slotNumber &&
102
121
  this.timestamp === other.timestamp &&
103
122
  this.coinbase.equals(other.coinbase) &&
@@ -107,12 +126,25 @@ export class CheckpointHeader {
107
126
  );
108
127
  }
109
128
 
129
+ /** Returns true if the global variables match those in the checkpoint header. */
130
+ matchesGlobalVariables(other: GlobalVariables) {
131
+ return (
132
+ this.coinbase.equals(other.coinbase) &&
133
+ this.feeRecipient.equals(other.feeRecipient) &&
134
+ this.gasFees.equals(other.gasFees) &&
135
+ this.slotNumber === other.slotNumber &&
136
+ this.timestamp === other.timestamp
137
+ );
138
+ }
139
+
110
140
  toBuffer() {
111
141
  // Note: The order here must match the order in the ProposedHeaderLib solidity library.
112
142
  return serializeToBuffer([
113
143
  this.lastArchiveRoot,
114
144
  this.blockHeadersHash,
115
- this.contentCommitment,
145
+ this.blobsHash,
146
+ this.inHash,
147
+ this.epochOutHash,
116
148
  new Fr(this.slotNumber),
117
149
  bigintToUInt64BE(this.timestamp),
118
150
  this.coinbase,
@@ -130,7 +162,9 @@ export class CheckpointHeader {
130
162
  return CheckpointHeader.from({
131
163
  lastArchiveRoot: Fr.ZERO,
132
164
  blockHeadersHash: Fr.ZERO,
133
- contentCommitment: ContentCommitment.empty(),
165
+ blobsHash: Fr.ZERO,
166
+ inHash: Fr.ZERO,
167
+ epochOutHash: Fr.ZERO,
134
168
  slotNumber: SlotNumber.ZERO,
135
169
  timestamp: 0n,
136
170
  coinbase: EthAddress.ZERO,
@@ -141,13 +175,13 @@ export class CheckpointHeader {
141
175
  });
142
176
  }
143
177
 
144
- static random(
145
- overrides: Partial<FieldsOf<CheckpointHeader>> & Partial<FieldsOf<ContentCommitment>> = {},
146
- ): CheckpointHeader {
178
+ static random(overrides: Partial<FieldsOf<CheckpointHeader>> = {}): CheckpointHeader {
147
179
  return CheckpointHeader.from({
148
180
  lastArchiveRoot: Fr.random(),
149
181
  blockHeadersHash: Fr.random(),
150
- contentCommitment: ContentCommitment.random(overrides),
182
+ blobsHash: Fr.random(),
183
+ inHash: Fr.random(),
184
+ epochOutHash: Fr.random(),
151
185
  slotNumber: SlotNumber(Math.floor(Math.random() * 1000) + 1),
152
186
  timestamp: BigInt(Math.floor(Date.now() / 1000)),
153
187
  coinbase: EthAddress.random(),
@@ -162,7 +196,9 @@ export class CheckpointHeader {
162
196
  return (
163
197
  this.lastArchiveRoot.isZero() &&
164
198
  this.blockHeadersHash.isZero() &&
165
- this.contentCommitment.isEmpty() &&
199
+ this.blobsHash.isZero() &&
200
+ this.inHash.isZero() &&
201
+ this.epochOutHash.isZero() &&
166
202
  this.slotNumber === 0 &&
167
203
  this.timestamp === 0n &&
168
204
  this.coinbase.isZero() &&
@@ -188,7 +224,9 @@ export class CheckpointHeader {
188
224
  return new CheckpointHeader(
189
225
  Fr.fromString(header.lastArchiveRoot),
190
226
  Fr.fromString(header.blockHeadersHash),
191
- ContentCommitment.fromViem(header.contentCommitment),
227
+ Fr.fromString(header.blobsHash),
228
+ Fr.fromString(header.inHash),
229
+ Fr.fromString(header.outHash),
192
230
  SlotNumber.fromBigInt(header.slotNumber),
193
231
  header.timestamp,
194
232
  new EthAddress(hexToBuffer(header.coinbase)),
@@ -210,7 +248,9 @@ export class CheckpointHeader {
210
248
  return {
211
249
  lastArchiveRoot: this.lastArchiveRoot.toString(),
212
250
  blockHeadersHash: this.blockHeadersHash.toString(),
213
- contentCommitment: this.contentCommitment.toViem(),
251
+ blobsHash: this.blobsHash.toString(),
252
+ inHash: this.inHash.toString(),
253
+ outHash: this.epochOutHash.toString(),
214
254
  slotNumber: BigInt(this.slotNumber),
215
255
  timestamp: this.timestamp,
216
256
  coinbase: this.coinbase.toString(),
@@ -227,7 +267,9 @@ export class CheckpointHeader {
227
267
  return {
228
268
  lastArchive: this.lastArchiveRoot.toString(),
229
269
  blockHeadersHash: this.blockHeadersHash.toString(),
230
- contentCommitment: this.contentCommitment.toInspect(),
270
+ blobsHash: this.blobsHash.toString(),
271
+ inHash: this.inHash.toString(),
272
+ epochOutHash: this.epochOutHash.toString(),
231
273
  slotNumber: this.slotNumber,
232
274
  timestamp: this.timestamp,
233
275
  coinbase: this.coinbase.toString(),
@@ -238,16 +280,17 @@ export class CheckpointHeader {
238
280
  }
239
281
 
240
282
  [inspect.custom]() {
241
- const gasfees = `da:${this.gasFees.feePerDaGas}, l2:${this.gasFees.feePerL2Gas}`;
242
283
  return `Header {
243
284
  lastArchiveRoot: ${this.lastArchiveRoot.toString()},
244
285
  blockHeadersHash: ${this.blockHeadersHash.toString()},
245
- contentCommitment: ${inspect(this.contentCommitment)},
286
+ blobsHash: ${inspect(this.blobsHash)},
287
+ inHash: ${inspect(this.inHash)},
288
+ epochOutHash: ${inspect(this.epochOutHash)},
246
289
  slotNumber: ${this.slotNumber},
247
290
  timestamp: ${this.timestamp},
248
291
  coinbase: ${this.coinbase.toString()},
249
292
  feeRecipient: ${this.feeRecipient.toString()},
250
- gasFees: ${gasfees},
293
+ gasFees: { da:${this.gasFees.feePerDaGas}, l2:${this.gasFees.feePerL2Gas} },
251
294
  totalManaUsed: ${this.totalManaUsed.toBigInt()},
252
295
  }`;
253
296
  }
@@ -1,5 +1,5 @@
1
1
  import { BlobAccumulator, FinalBlobBatchingChallenges } from '@aztec/blob-lib/types';
2
- import { AZTEC_MAX_EPOCH_DURATION } from '@aztec/constants';
2
+ import { MAX_CHECKPOINTS_PER_EPOCH } from '@aztec/constants';
3
3
  import { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { EthAddress } from '@aztec/foundation/eth-address';
5
5
  import { bufferSchemaFor } from '@aztec/foundation/schemas';
@@ -27,14 +27,22 @@ export class CheckpointRollupPublicInputs {
27
27
  * Archive tree after adding this checkpoint range.
28
28
  */
29
29
  public newArchive: AppendOnlyTreeSnapshot,
30
+ /**
31
+ * The out hash tree snapshot immediately before this checkpoint range.
32
+ */
33
+ public previousOutHash: AppendOnlyTreeSnapshot,
34
+ /**
35
+ * The out hash tree snapshot after applying this checkpoint range.
36
+ */
37
+ public newOutHash: AppendOnlyTreeSnapshot,
30
38
  /**
31
39
  * The hashes of the headers of the constituent checkpoints.
32
40
  */
33
- public checkpointHeaderHashes: Tuple<Fr, typeof AZTEC_MAX_EPOCH_DURATION>,
41
+ public checkpointHeaderHashes: Tuple<Fr, typeof MAX_CHECKPOINTS_PER_EPOCH>,
34
42
  /**
35
43
  * The summed transaction fees and recipients of the constituent checkpoints.
36
44
  */
37
- public fees: Tuple<FeeRecipient, typeof AZTEC_MAX_EPOCH_DURATION>,
45
+ public fees: Tuple<FeeRecipient, typeof MAX_CHECKPOINTS_PER_EPOCH>,
38
46
  /**
39
47
  * Accumulated opening proofs for all blobs before this checkpoint range.
40
48
  */
@@ -55,8 +63,10 @@ export class CheckpointRollupPublicInputs {
55
63
  reader.readObject(EpochConstantData),
56
64
  reader.readObject(AppendOnlyTreeSnapshot),
57
65
  reader.readObject(AppendOnlyTreeSnapshot),
58
- reader.readArray(AZTEC_MAX_EPOCH_DURATION, Fr),
59
- reader.readArray(AZTEC_MAX_EPOCH_DURATION, FeeRecipient),
66
+ reader.readObject(AppendOnlyTreeSnapshot),
67
+ reader.readObject(AppendOnlyTreeSnapshot),
68
+ reader.readArray(MAX_CHECKPOINTS_PER_EPOCH, Fr),
69
+ reader.readArray(MAX_CHECKPOINTS_PER_EPOCH, FeeRecipient),
60
70
  reader.readObject(BlobAccumulator),
61
71
  reader.readObject(BlobAccumulator),
62
72
  reader.readObject(FinalBlobBatchingChallenges),
@@ -68,6 +78,8 @@ export class CheckpointRollupPublicInputs {
68
78
  this.constants,
69
79
  this.previousArchive,
70
80
  this.newArchive,
81
+ this.previousOutHash,
82
+ this.newOutHash,
71
83
  this.checkpointHeaderHashes,
72
84
  this.fees,
73
85
  this.startBlobAccumulator,
@@ -1,5 +1,5 @@
1
1
  import { BlobAccumulator, FinalBlobBatchingChallenges } from '@aztec/blob-lib/types';
2
- import { ARCHIVE_HEIGHT, BLOBS_PER_CHECKPOINT, FIELDS_PER_BLOB } from '@aztec/constants';
2
+ import { ARCHIVE_HEIGHT, BLOBS_PER_CHECKPOINT, FIELDS_PER_BLOB, OUT_HASH_TREE_HEIGHT } from '@aztec/constants';
3
3
  import { BLS12Point } from '@aztec/foundation/curves/bls12';
4
4
  import { Fr } from '@aztec/foundation/curves/bn254';
5
5
  import { bufferSchemaFor } from '@aztec/foundation/schemas';
@@ -8,6 +8,7 @@ import { bufferToHex, hexToBuffer } from '@aztec/foundation/string';
8
8
  import type { FieldsOf } from '@aztec/foundation/types';
9
9
 
10
10
  import { ProofData, type RollupHonkProofData } from '../proofs/proof_data.js';
11
+ import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
11
12
  import { BlockHeader } from '../tx/block_header.js';
12
13
  import { BlockRollupPublicInputs } from './block_rollup_public_inputs.js';
13
14
 
@@ -21,6 +22,14 @@ export class CheckpointRootRollupHints {
21
22
  * Hint for checking the hash of previous_block_header is the last leaf of the previous archive.
22
23
  */
23
24
  public previousArchiveSiblingPath: Tuple<Fr, typeof ARCHIVE_HEIGHT>,
25
+ /**
26
+ * The out hash tree snapshot immediately before this checkpoint.
27
+ */
28
+ public previousOutHash: AppendOnlyTreeSnapshot,
29
+ /**
30
+ * Hint for inserting the new out hash into the out hash tree.
31
+ */
32
+ public newOutHashSiblingPath: Tuple<Fr, typeof OUT_HASH_TREE_HEIGHT>,
24
33
  /**
25
34
  * The current blob accumulation state across the epoch.
26
35
  */
@@ -54,6 +63,8 @@ export class CheckpointRootRollupHints {
54
63
  return [
55
64
  fields.previousBlockHeader,
56
65
  fields.previousArchiveSiblingPath,
66
+ fields.previousOutHash,
67
+ fields.newOutHashSiblingPath,
57
68
  fields.startBlobAccumulator,
58
69
  fields.finalBlobChallenges,
59
70
  fields.blobFields,
@@ -71,6 +82,8 @@ export class CheckpointRootRollupHints {
71
82
  return new CheckpointRootRollupHints(
72
83
  BlockHeader.fromBuffer(reader),
73
84
  reader.readArray(ARCHIVE_HEIGHT, Fr),
85
+ reader.readObject(AppendOnlyTreeSnapshot),
86
+ reader.readArray(OUT_HASH_TREE_HEIGHT, Fr),
74
87
  reader.readObject(BlobAccumulator),
75
88
  reader.readObject(FinalBlobBatchingChallenges),
76
89
  // Below line gives error 'Type instantiation is excessively deep and possibly infinite. ts(2589)'
@@ -1,5 +1,5 @@
1
1
  import { FinalBlobAccumulator } from '@aztec/blob-lib/types';
2
- import { AZTEC_MAX_EPOCH_DURATION } from '@aztec/constants';
2
+ import { MAX_CHECKPOINTS_PER_EPOCH } from '@aztec/constants';
3
3
  import { makeTuple } from '@aztec/foundation/array';
4
4
  import { Fr } from '@aztec/foundation/curves/bn254';
5
5
  import { bufferSchemaFor } from '@aztec/foundation/schemas';
@@ -21,8 +21,14 @@ export class RootRollupPublicInputs {
21
21
  public previousArchiveRoot: Fr,
22
22
  /** Root of the archive tree after this rollup is processed */
23
23
  public endArchiveRoot: Fr,
24
- public checkpointHeaderHashes: Tuple<Fr, typeof AZTEC_MAX_EPOCH_DURATION>,
25
- public fees: Tuple<FeeRecipient, typeof AZTEC_MAX_EPOCH_DURATION>,
24
+ /**
25
+ * Root of the balanced merkle tree consisting of the out hashes of all checkpoints in this epoch.
26
+ * The out hash of the first checkpoint in the epoch is inserted at index 0, the second at index 1, and so on.
27
+ */
28
+ public outHash: Fr,
29
+ /** Hashes of checkpoint headers for this rollup. */
30
+ public checkpointHeaderHashes: Tuple<Fr, typeof MAX_CHECKPOINTS_PER_EPOCH>,
31
+ public fees: Tuple<FeeRecipient, typeof MAX_CHECKPOINTS_PER_EPOCH>,
26
32
  public constants: EpochConstantData,
27
33
  public blobPublicInputs: FinalBlobAccumulator,
28
34
  ) {}
@@ -31,6 +37,7 @@ export class RootRollupPublicInputs {
31
37
  return [
32
38
  fields.previousArchiveRoot,
33
39
  fields.endArchiveRoot,
40
+ fields.outHash,
34
41
  fields.checkpointHeaderHashes,
35
42
  fields.fees,
36
43
  fields.constants,
@@ -60,8 +67,9 @@ export class RootRollupPublicInputs {
60
67
  return new RootRollupPublicInputs(
61
68
  Fr.fromBuffer(reader),
62
69
  Fr.fromBuffer(reader),
63
- reader.readArray(AZTEC_MAX_EPOCH_DURATION, Fr),
64
- reader.readArray(AZTEC_MAX_EPOCH_DURATION, FeeRecipient),
70
+ Fr.fromBuffer(reader),
71
+ reader.readArray(MAX_CHECKPOINTS_PER_EPOCH, Fr),
72
+ reader.readArray(MAX_CHECKPOINTS_PER_EPOCH, FeeRecipient),
65
73
  EpochConstantData.fromBuffer(reader),
66
74
  reader.readObject(FinalBlobAccumulator),
67
75
  );
@@ -90,8 +98,9 @@ export class RootRollupPublicInputs {
90
98
  return new RootRollupPublicInputs(
91
99
  Fr.random(),
92
100
  Fr.random(),
93
- makeTuple(AZTEC_MAX_EPOCH_DURATION, Fr.random),
94
- makeTuple(AZTEC_MAX_EPOCH_DURATION, FeeRecipient.random),
101
+ Fr.random(),
102
+ makeTuple(MAX_CHECKPOINTS_PER_EPOCH, Fr.random),
103
+ makeTuple(MAX_CHECKPOINTS_PER_EPOCH, FeeRecipient.random),
95
104
  new EpochConstantData(Fr.random(), Fr.random(), Fr.random(), Fr.random(), Fr.random()),
96
105
  FinalBlobAccumulator.random(),
97
106
  );
@@ -83,7 +83,9 @@ export function getFirstEligibleRoundForOffense(
83
83
  case OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS:
84
84
  case OffenseType.PROPOSED_INCORRECT_ATTESTATIONS:
85
85
  case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
86
- case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL: {
86
+ case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
87
+ case OffenseType.DUPLICATE_PROPOSAL:
88
+ case OffenseType.DUPLICATE_ATTESTATION: {
87
89
  const slot = offense.epochOrSlot;
88
90
  const detectedSlot = SlotNumber.fromBigInt(slot + 1n);
89
91
  return getRoundForSlot(detectedSlot, constants).round + 1n;
@@ -50,6 +50,8 @@ export function getPenaltyForOffense(
50
50
  SlasherConfig,
51
51
  | 'slashAttestDescendantOfInvalidPenalty'
52
52
  | 'slashBroadcastedInvalidBlockPenalty'
53
+ | 'slashDuplicateProposalPenalty'
54
+ | 'slashDuplicateAttestationPenalty'
53
55
  | 'slashPrunePenalty'
54
56
  | 'slashDataWithholdingPenalty'
55
57
  | 'slashUnknownPenalty'
@@ -71,6 +73,10 @@ export function getPenaltyForOffense(
71
73
  return config.slashAttestDescendantOfInvalidPenalty;
72
74
  case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
73
75
  return config.slashBroadcastedInvalidBlockPenalty;
76
+ case OffenseType.DUPLICATE_PROPOSAL:
77
+ return config.slashDuplicateProposalPenalty;
78
+ case OffenseType.DUPLICATE_ATTESTATION:
79
+ return config.slashDuplicateAttestationPenalty;
74
80
  case OffenseType.UNKNOWN:
75
81
  return config.slashUnknownPenalty;
76
82
  default: {
@@ -85,6 +91,8 @@ export function getTimeUnitForOffense(offense: OffenseType): 'epoch' | 'slot' {
85
91
  switch (offense) {
86
92
  case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
87
93
  case OffenseType.BROADCASTED_INVALID_BLOCK_PROPOSAL:
94
+ case OffenseType.DUPLICATE_PROPOSAL:
95
+ case OffenseType.DUPLICATE_ATTESTATION:
88
96
  case OffenseType.PROPOSED_INCORRECT_ATTESTATIONS:
89
97
  case OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS:
90
98
  return 'slot';
@@ -1,4 +1,5 @@
1
1
  import { sumBigint } from '@aztec/foundation/bigint';
2
+ import { padArrayEnd } from '@aztec/foundation/collection';
2
3
  import { EthAddress } from '@aztec/foundation/eth-address';
3
4
  import type { PartialBy } from '@aztec/foundation/types';
4
5
 
@@ -20,9 +21,10 @@ export function getSlashConsensusVotesFromOffenses(
20
21
  settings: {
21
22
  slashingAmounts: [bigint, bigint, bigint];
22
23
  epochDuration: number;
24
+ targetCommitteeSize: number;
23
25
  },
24
26
  ): ValidatorSlashVote[] {
25
- const { slashingAmounts } = settings;
27
+ const { slashingAmounts, targetCommitteeSize } = settings;
26
28
 
27
29
  if (committees.length !== epochsForCommittees.length) {
28
30
  throw new Error('committees and epochsForCommittees must have the same length');
@@ -31,7 +33,9 @@ export function getSlashConsensusVotesFromOffenses(
31
33
  const votes = committees.flatMap((committee, committeeIndex) => {
32
34
  const committeeEpoch = epochsForCommittees[committeeIndex];
33
35
 
34
- return committee.map(validator => {
36
+ // Map over actual committee members, then pad to targetCommitteeSize.
37
+ // Padding handles cases where committees may be empty (e.g., when there aren't enough validators to fill the committee size during network startup).
38
+ const votes = committee.map(validator => {
35
39
  // Find offenses for this validator in this specific epoch.
36
40
  // If an offense has no epoch, it is considered for all epochs due to a slashAlways setting.
37
41
  const validatorOffenses = offenses.filter(
@@ -45,6 +49,8 @@ export function getSlashConsensusVotesFromOffenses(
45
49
  const slashUnits = getSlashUnitsForAmount(slashAmount, slashingAmounts);
46
50
  return Number(slashUnits);
47
51
  });
52
+
53
+ return padArrayEnd(votes, 0, targetCommitteeSize);
48
54
  });
49
55
 
50
56
  return votes;
@@ -20,6 +20,10 @@ export enum OffenseType {
20
20
  PROPOSED_INCORRECT_ATTESTATIONS = 6,
21
21
  /** A committee member attested to a block that was built as a descendent of an invalid block (as in a block with invalid attestations) */
22
22
  ATTESTED_DESCENDANT_OF_INVALID = 7,
23
+ /** A proposer sent duplicate proposals for the same position (slot, indexWithinCheckpoint for blocks or slot for checkpoints) */
24
+ DUPLICATE_PROPOSAL = 8,
25
+ /** A validator signed attestations for different proposals at the same slot (equivocation) */
26
+ DUPLICATE_ATTESTATION = 9,
23
27
  }
24
28
 
25
29
  export function getOffenseTypeName(offense: OffenseType) {
@@ -40,6 +44,10 @@ export function getOffenseTypeName(offense: OffenseType) {
40
44
  return 'proposed_incorrect_attestations';
41
45
  case OffenseType.ATTESTED_DESCENDANT_OF_INVALID:
42
46
  return 'attested_descendant_of_invalid';
47
+ case OffenseType.DUPLICATE_PROPOSAL:
48
+ return 'duplicate_proposal';
49
+ case OffenseType.DUPLICATE_ATTESTATION:
50
+ return 'duplicate_attestation';
43
51
  default:
44
52
  throw new Error(`Unknown offense type: ${offense}`);
45
53
  }
@@ -56,6 +64,8 @@ export const OffenseToBigInt: Record<OffenseType, bigint> = {
56
64
  [OffenseType.PROPOSED_INSUFFICIENT_ATTESTATIONS]: 5n,
57
65
  [OffenseType.PROPOSED_INCORRECT_ATTESTATIONS]: 6n,
58
66
  [OffenseType.ATTESTED_DESCENDANT_OF_INVALID]: 7n,
67
+ [OffenseType.DUPLICATE_PROPOSAL]: 8n,
68
+ [OffenseType.DUPLICATE_ATTESTATION]: 9n,
59
69
  };
60
70
 
61
71
  export function bigIntToOffense(offense: bigint): OffenseType {
@@ -76,6 +86,10 @@ export function bigIntToOffense(offense: bigint): OffenseType {
76
86
  return OffenseType.PROPOSED_INCORRECT_ATTESTATIONS;
77
87
  case 7n:
78
88
  return OffenseType.ATTESTED_DESCENDANT_OF_INVALID;
89
+ case 8n:
90
+ return OffenseType.DUPLICATE_PROPOSAL;
91
+ case 9n:
92
+ return OffenseType.DUPLICATE_ATTESTATION;
79
93
  default:
80
94
  throw new Error(`Unknown offense: ${offense}`);
81
95
  }