@aztec/stdlib 0.0.1-commit.fce3e4f → 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 (1132) hide show
  1. package/dest/abi/abi.d.ts +603 -5
  2. package/dest/abi/abi.d.ts.map +1 -1
  3. package/dest/abi/abi.js +7 -7
  4. package/dest/abi/authorization_selector.d.ts +2 -2
  5. package/dest/abi/authorization_selector.d.ts.map +1 -1
  6. package/dest/abi/authorization_selector.js +2 -1
  7. package/dest/abi/buffer.d.ts +2 -2
  8. package/dest/abi/buffer.d.ts.map +1 -1
  9. package/dest/abi/buffer.js +1 -1
  10. package/dest/abi/contract_artifact.d.ts +2 -2
  11. package/dest/abi/contract_artifact.d.ts.map +1 -1
  12. package/dest/abi/contract_artifact.js +1 -1
  13. package/dest/abi/decoder.d.ts +2 -2
  14. package/dest/abi/decoder.d.ts.map +1 -1
  15. package/dest/abi/encoder.d.ts +2 -2
  16. package/dest/abi/encoder.d.ts.map +1 -1
  17. package/dest/abi/encoder.js +1 -1
  18. package/dest/abi/event_selector.d.ts +2 -2
  19. package/dest/abi/event_selector.d.ts.map +1 -1
  20. package/dest/abi/event_selector.js +2 -1
  21. package/dest/abi/function_call.d.ts +48 -10
  22. package/dest/abi/function_call.d.ts.map +1 -1
  23. package/dest/abi/function_call.js +20 -3
  24. package/dest/abi/function_selector.d.ts +3 -2
  25. package/dest/abi/function_selector.d.ts.map +1 -1
  26. package/dest/abi/function_selector.js +9 -1
  27. package/dest/abi/note_selector.d.ts +2 -2
  28. package/dest/abi/note_selector.d.ts.map +1 -1
  29. package/dest/abi/note_selector.js +2 -2
  30. package/dest/abi/selector.d.ts +2 -2
  31. package/dest/abi/selector.d.ts.map +1 -1
  32. package/dest/abi/selector.js +4 -2
  33. package/dest/abi/utils.d.ts +7 -1
  34. package/dest/abi/utils.d.ts.map +1 -1
  35. package/dest/abi/utils.js +7 -0
  36. package/dest/auth_witness/auth_witness.d.ts +3 -2
  37. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  38. package/dest/auth_witness/auth_witness.js +5 -5
  39. package/dest/avm/avm.d.ts +598 -386
  40. package/dest/avm/avm.d.ts.map +1 -1
  41. package/dest/avm/avm.js +238 -22
  42. package/dest/avm/avm_accumulated_data.d.ts +31 -4
  43. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  44. package/dest/avm/avm_accumulated_data.js +6 -3
  45. package/dest/avm/avm_circuit_public_inputs.d.ts +14 -12
  46. package/dest/avm/avm_circuit_public_inputs.d.ts.map +1 -1
  47. package/dest/avm/avm_circuit_public_inputs.js +4 -2
  48. package/dest/avm/avm_proving_request.d.ts +306 -302
  49. package/dest/avm/avm_proving_request.d.ts.map +1 -1
  50. package/dest/avm/contract_storage_read.d.ts +14 -2
  51. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  52. package/dest/avm/contract_storage_read.js +1 -1
  53. package/dest/avm/contract_storage_update_request.d.ts +14 -2
  54. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  55. package/dest/avm/contract_storage_update_request.js +1 -1
  56. package/dest/avm/message_pack.d.ts +1 -1
  57. package/dest/avm/message_pack.d.ts.map +1 -1
  58. package/dest/avm/message_pack.js +2 -1
  59. package/dest/avm/public_call_stack_item_compressed.d.ts +4 -2
  60. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  61. package/dest/avm/public_call_stack_item_compressed.js +1 -1
  62. package/dest/avm/public_data_read.d.ts +11 -2
  63. package/dest/avm/public_data_read.d.ts.map +1 -1
  64. package/dest/avm/public_data_read.js +1 -1
  65. package/dest/avm/public_data_update_request.d.ts +11 -2
  66. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  67. package/dest/avm/public_data_update_request.js +4 -2
  68. package/dest/avm/public_data_write.d.ts +8 -2
  69. package/dest/avm/public_data_write.d.ts.map +1 -1
  70. package/dest/avm/public_data_write.js +1 -1
  71. package/dest/avm/public_inner_call_request.d.ts +5 -2
  72. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  73. package/dest/avm/public_inner_call_request.js +3 -1
  74. package/dest/avm/revert_code.d.ts +5 -5
  75. package/dest/avm/revert_code.d.ts.map +1 -1
  76. package/dest/avm/revert_code.js +4 -2
  77. package/dest/aztec-address/index.d.ts +3 -2
  78. package/dest/aztec-address/index.d.ts.map +1 -1
  79. package/dest/aztec-address/index.js +5 -2
  80. package/dest/block/attestation_info.d.ts +5 -5
  81. package/dest/block/attestation_info.d.ts.map +1 -1
  82. package/dest/block/attestation_info.js +5 -5
  83. package/dest/block/block_data.d.ts +52 -0
  84. package/dest/block/block_data.d.ts.map +1 -0
  85. package/dest/block/block_data.js +12 -0
  86. package/dest/block/block_hash.d.ts +19 -15
  87. package/dest/block/block_hash.d.ts.map +1 -1
  88. package/dest/block/block_hash.js +23 -21
  89. package/dest/block/block_parameter.d.ts +6 -0
  90. package/dest/block/block_parameter.d.ts.map +1 -0
  91. package/dest/block/block_parameter.js +8 -0
  92. package/dest/block/body.d.ts +1 -1
  93. package/dest/block/body.d.ts.map +1 -1
  94. package/dest/block/body.js +5 -2
  95. package/dest/block/checkpointed_l2_block.d.ts +150 -0
  96. package/dest/block/checkpointed_l2_block.d.ts.map +1 -0
  97. package/dest/block/checkpointed_l2_block.js +46 -0
  98. package/dest/block/in_block.d.ts +34 -15
  99. package/dest/block/in_block.d.ts.map +1 -1
  100. package/dest/block/in_block.js +21 -12
  101. package/dest/block/index.d.ts +4 -5
  102. package/dest/block/index.d.ts.map +1 -1
  103. package/dest/block/index.js +3 -4
  104. package/dest/block/l2_block.d.ts +59 -59
  105. package/dest/block/l2_block.d.ts.map +1 -1
  106. package/dest/block/l2_block.js +69 -110
  107. package/dest/block/l2_block_info.d.ts +16 -11
  108. package/dest/block/l2_block_info.d.ts.map +1 -1
  109. package/dest/block/l2_block_info.js +8 -7
  110. package/dest/block/l2_block_source.d.ts +390 -151
  111. package/dest/block/l2_block_source.d.ts.map +1 -1
  112. package/dest/block/l2_block_source.js +29 -16
  113. package/dest/block/l2_block_stream/index.d.ts +2 -1
  114. package/dest/block/l2_block_stream/index.d.ts.map +1 -1
  115. package/dest/block/l2_block_stream/index.js +1 -0
  116. package/dest/block/l2_block_stream/interfaces.d.ts +15 -5
  117. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  118. package/dest/block/l2_block_stream/l2_block_stream.d.ts +13 -3
  119. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  120. package/dest/block/l2_block_stream/l2_block_stream.js +116 -32
  121. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +24 -15
  122. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
  123. package/dest/block/l2_block_stream/l2_tips_memory_store.js +55 -59
  124. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
  125. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
  126. package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
  127. package/dest/block/proposal/attestations_and_signers.d.ts +2 -2
  128. package/dest/block/proposal/attestations_and_signers.d.ts.map +1 -1
  129. package/dest/block/proposal/committee_attestation.d.ts +2 -2
  130. package/dest/block/proposal/committee_attestation.d.ts.map +1 -1
  131. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  132. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  133. package/dest/block/test/l2_tips_store_test_suite.js +482 -43
  134. package/dest/block/validate_block_result.d.ts +24 -24
  135. package/dest/block/validate_block_result.d.ts.map +1 -1
  136. package/dest/block/validate_block_result.js +18 -17
  137. package/dest/checkpoint/checkpoint.d.ts +74 -18
  138. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  139. package/dest/checkpoint/checkpoint.js +78 -16
  140. package/dest/checkpoint/checkpoint_data.d.ts +120 -0
  141. package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
  142. package/dest/checkpoint/checkpoint_data.js +26 -0
  143. package/dest/checkpoint/checkpoint_info.d.ts +38 -0
  144. package/dest/checkpoint/checkpoint_info.d.ts.map +1 -0
  145. package/dest/checkpoint/checkpoint_info.js +34 -0
  146. package/dest/checkpoint/index.d.ts +3 -1
  147. package/dest/checkpoint/index.d.ts.map +1 -1
  148. package/dest/checkpoint/index.js +2 -0
  149. package/dest/checkpoint/published_checkpoint.d.ts +58 -15
  150. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  151. package/dest/checkpoint/published_checkpoint.js +16 -6
  152. package/dest/config/index.d.ts +2 -1
  153. package/dest/config/index.d.ts.map +1 -1
  154. package/dest/config/index.js +1 -0
  155. package/dest/config/node-rpc-config.js +1 -1
  156. package/dest/config/sequencer-config.d.ts +10 -0
  157. package/dest/config/sequencer-config.d.ts.map +1 -0
  158. package/dest/config/sequencer-config.js +18 -0
  159. package/dest/contract/artifact_hash.d.ts +2 -2
  160. package/dest/contract/artifact_hash.d.ts.map +1 -1
  161. package/dest/contract/artifact_hash.js +2 -2
  162. package/dest/contract/complete_address.d.ts +5 -2
  163. package/dest/contract/complete_address.d.ts.map +1 -1
  164. package/dest/contract/complete_address.js +1 -1
  165. package/dest/contract/contract_address.d.ts +2 -2
  166. package/dest/contract/contract_address.d.ts.map +1 -1
  167. package/dest/contract/contract_address.js +6 -6
  168. package/dest/contract/contract_class.d.ts +3 -4
  169. package/dest/contract/contract_class.d.ts.map +1 -1
  170. package/dest/contract/contract_class.js +1 -1
  171. package/dest/contract/contract_class_id.d.ts +3 -3
  172. package/dest/contract/contract_class_id.d.ts.map +1 -1
  173. package/dest/contract/contract_class_id.js +8 -7
  174. package/dest/contract/contract_deployment_data.d.ts +5 -5
  175. package/dest/contract/contract_instance.d.ts +2 -2
  176. package/dest/contract/contract_instance.d.ts.map +1 -1
  177. package/dest/contract/contract_instance.js +1 -1
  178. package/dest/contract/contract_instance_update.d.ts +2 -2
  179. package/dest/contract/contract_instance_update.d.ts.map +1 -1
  180. package/dest/contract/contract_instance_update.js +1 -1
  181. package/dest/contract/deployment_info.d.ts +2 -2
  182. package/dest/contract/deployment_info.d.ts.map +1 -1
  183. package/dest/contract/index.d.ts +1 -3
  184. package/dest/contract/index.d.ts.map +1 -1
  185. package/dest/contract/index.js +0 -2
  186. package/dest/contract/interfaces/contract_class.d.ts +19 -14
  187. package/dest/contract/interfaces/contract_class.d.ts.map +1 -1
  188. package/dest/contract/interfaces/contract_class.js +35 -18
  189. package/dest/contract/interfaces/contract_data_source.d.ts +4 -3
  190. package/dest/contract/interfaces/contract_data_source.d.ts.map +1 -1
  191. package/dest/contract/interfaces/contract_instance.d.ts +40 -31
  192. package/dest/contract/interfaces/contract_instance.d.ts.map +1 -1
  193. package/dest/contract/interfaces/contract_instance.js +30 -5
  194. package/dest/contract/interfaces/contract_instance_update.d.ts +7 -8
  195. package/dest/contract/interfaces/contract_instance_update.d.ts.map +1 -1
  196. package/dest/contract/interfaces/contract_instance_update.js +5 -5
  197. package/dest/contract/interfaces/node-info.d.ts +3 -1
  198. package/dest/contract/interfaces/node-info.d.ts.map +1 -1
  199. package/dest/contract/interfaces/node-info.js +2 -1
  200. package/dest/contract/partial_address.d.ts +2 -2
  201. package/dest/contract/partial_address.d.ts.map +1 -1
  202. package/dest/contract/private_function.d.ts +2 -2
  203. package/dest/contract/private_function.d.ts.map +1 -1
  204. package/dest/contract/private_function.js +5 -5
  205. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  206. package/dest/contract/private_function_membership_proof.js +3 -3
  207. package/dest/contract/utility_function_membership_proof.js +1 -1
  208. package/dest/database-version/database_version.d.ts +58 -0
  209. package/dest/database-version/database_version.d.ts.map +1 -0
  210. package/dest/database-version/database_version.js +69 -0
  211. package/dest/database-version/version_manager.d.ts +3 -49
  212. package/dest/database-version/version_manager.d.ts.map +1 -1
  213. package/dest/database-version/version_manager.js +1 -64
  214. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +3 -3
  215. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  216. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +9 -12
  217. package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts +2 -2
  218. package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.d.ts.map +1 -1
  219. package/dest/delayed_public_mutable/delayed_public_mutable_values_with_hash.js +1 -1
  220. package/dest/delayed_public_mutable/scheduled_value_change.d.ts +2 -2
  221. package/dest/delayed_public_mutable/scheduled_value_change.d.ts.map +1 -1
  222. package/dest/delayed_public_mutable/scheduled_value_change.js +1 -1
  223. package/dest/deserialization/index.d.ts +11 -0
  224. package/dest/deserialization/index.d.ts.map +1 -0
  225. package/dest/deserialization/index.js +10 -0
  226. package/dest/epoch-helpers/index.d.ts +7 -1
  227. package/dest/epoch-helpers/index.d.ts.map +1 -1
  228. package/dest/epoch-helpers/index.js +12 -6
  229. package/dest/errors/proving_error.d.ts +2 -2
  230. package/dest/errors/proving_error.d.ts.map +1 -1
  231. package/dest/errors/simulation_error.d.ts +2 -2
  232. package/dest/errors/simulation_error.d.ts.map +1 -1
  233. package/dest/fees/transaction_fee.d.ts +2 -2
  234. package/dest/fees/transaction_fee.d.ts.map +1 -1
  235. package/dest/file-store/local.d.ts +3 -3
  236. package/dest/file-store/local.d.ts.map +1 -1
  237. package/dest/file-store/local.js +13 -4
  238. package/dest/file-store/s3.d.ts +1 -1
  239. package/dest/file-store/s3.d.ts.map +1 -1
  240. package/dest/file-store/s3.js +11 -3
  241. package/dest/gas/gas.d.ts +2 -2
  242. package/dest/gas/gas.d.ts.map +1 -1
  243. package/dest/gas/gas.js +4 -2
  244. package/dest/gas/gas_fees.d.ts +2 -2
  245. package/dest/gas/gas_fees.d.ts.map +1 -1
  246. package/dest/gas/gas_fees.js +3 -1
  247. package/dest/gas/gas_settings.d.ts +2 -2
  248. package/dest/gas/gas_settings.d.ts.map +1 -1
  249. package/dest/gas/gas_settings.js +1 -1
  250. package/dest/ha-signing/config.d.ts +101 -0
  251. package/dest/ha-signing/config.d.ts.map +1 -0
  252. package/dest/ha-signing/config.js +92 -0
  253. package/dest/ha-signing/index.d.ts +3 -0
  254. package/dest/ha-signing/index.d.ts.map +1 -0
  255. package/dest/ha-signing/index.js +2 -0
  256. package/dest/ha-signing/types.d.ts +85 -0
  257. package/dest/ha-signing/types.d.ts.map +1 -0
  258. package/dest/ha-signing/types.js +32 -0
  259. package/dest/hash/hash.d.ts +3 -10
  260. package/dest/hash/hash.d.ts.map +1 -1
  261. package/dest/hash/hash.js +17 -22
  262. package/dest/hash/map_slot.d.ts +2 -2
  263. package/dest/hash/map_slot.d.ts.map +1 -1
  264. package/dest/hash/map_slot.js +4 -3
  265. package/dest/interfaces/allowed_element.d.ts +8 -9
  266. package/dest/interfaces/allowed_element.d.ts.map +1 -1
  267. package/dest/interfaces/allowed_element.js +3 -3
  268. package/dest/interfaces/api_limit.d.ts +3 -1
  269. package/dest/interfaces/api_limit.d.ts.map +1 -1
  270. package/dest/interfaces/api_limit.js +2 -0
  271. package/dest/interfaces/archiver.d.ts +12 -7
  272. package/dest/interfaces/archiver.d.ts.map +1 -1
  273. package/dest/interfaces/archiver.js +40 -21
  274. package/dest/interfaces/aztec-node-admin.d.ts +140 -42
  275. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  276. package/dest/interfaces/aztec-node-admin.js +15 -7
  277. package/dest/interfaces/aztec-node.d.ts +90 -95
  278. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  279. package/dest/interfaces/aztec-node.js +32 -33
  280. package/dest/interfaces/block-builder.d.ts +24 -14
  281. package/dest/interfaces/block-builder.d.ts.map +1 -1
  282. package/dest/interfaces/block-builder.js +16 -1
  283. package/dest/interfaces/configs.d.ts +71 -27
  284. package/dest/interfaces/configs.d.ts.map +1 -1
  285. package/dest/interfaces/configs.js +15 -6
  286. package/dest/interfaces/epoch-prover.d.ts +5 -5
  287. package/dest/interfaces/epoch-prover.d.ts.map +1 -1
  288. package/dest/interfaces/get_logs_response.d.ts +30 -6
  289. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  290. package/dest/interfaces/get_logs_response.js +5 -4
  291. package/dest/interfaces/l2_logs_source.d.ts +21 -15
  292. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  293. package/dest/interfaces/merkle_tree_operations.d.ts +5 -4
  294. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  295. package/dest/interfaces/p2p.d.ts +7 -9
  296. package/dest/interfaces/p2p.d.ts.map +1 -1
  297. package/dest/interfaces/p2p.js +3 -4
  298. package/dest/interfaces/prover-broker.d.ts +16 -1
  299. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  300. package/dest/interfaces/prover-broker.js +4 -1
  301. package/dest/interfaces/prover-client.d.ts +19 -3
  302. package/dest/interfaces/prover-client.d.ts.map +1 -1
  303. package/dest/interfaces/prover-client.js +16 -4
  304. package/dest/interfaces/proving-job.d.ts +60 -56
  305. package/dest/interfaces/proving-job.d.ts.map +1 -1
  306. package/dest/interfaces/proving-job.js +1 -7
  307. package/dest/interfaces/public_state_source.d.ts +2 -2
  308. package/dest/interfaces/public_state_source.d.ts.map +1 -1
  309. package/dest/interfaces/server_circuit_prover.d.ts +4 -3
  310. package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
  311. package/dest/interfaces/slasher.d.ts +9 -1
  312. package/dest/interfaces/slasher.d.ts.map +1 -1
  313. package/dest/interfaces/slasher.js +5 -3
  314. package/dest/interfaces/validator.d.ts +162 -27
  315. package/dest/interfaces/validator.d.ts.map +1 -1
  316. package/dest/interfaces/validator.js +12 -7
  317. package/dest/interfaces/world_state.d.ts +23 -31
  318. package/dest/interfaces/world_state.d.ts.map +1 -1
  319. package/dest/interfaces/world_state.js +4 -3
  320. package/dest/kernel/claimed_length_array.d.ts +2 -2
  321. package/dest/kernel/claimed_length_array.d.ts.map +1 -1
  322. package/dest/kernel/claimed_length_array.js +3 -1
  323. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +6 -5
  324. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  325. package/dest/kernel/hints/build_note_hash_read_request_hints.js +19 -10
  326. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +4 -4
  327. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  328. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
  329. package/dest/kernel/hints/find_private_kernel_reset_dimensions.d.ts +1 -1
  330. package/dest/kernel/hints/find_private_kernel_reset_dimensions.d.ts.map +1 -1
  331. package/dest/kernel/hints/find_private_kernel_reset_dimensions.js +1 -3
  332. package/dest/kernel/hints/index.d.ts +2 -2
  333. package/dest/kernel/hints/index.js +2 -2
  334. package/dest/kernel/hints/key_validation_hint.d.ts +3 -2
  335. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  336. package/dest/kernel/hints/key_validation_hint.js +1 -1
  337. package/dest/kernel/hints/key_validation_request.d.ts +5 -3
  338. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  339. package/dest/kernel/hints/key_validation_request.js +2 -1
  340. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  341. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  342. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +13 -16
  343. package/dest/kernel/hints/note_hash_read_request_hints.d.ts +2 -2
  344. package/dest/kernel/hints/note_hash_read_request_hints.d.ts.map +1 -1
  345. package/dest/kernel/hints/note_hash_read_request_hints.js +1 -1
  346. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  347. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  348. package/dest/kernel/hints/read_request.d.ts +8 -2
  349. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  350. package/dest/kernel/hints/read_request.js +1 -1
  351. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  352. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  353. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +9 -9
  354. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  355. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  356. package/dest/kernel/hints/scoped_value_cache.d.ts +2 -2
  357. package/dest/kernel/hints/scoped_value_cache.d.ts.map +1 -1
  358. package/dest/kernel/hints/transient_data_squashing_hint.d.ts +2 -2
  359. package/dest/kernel/hints/transient_data_squashing_hint.d.ts.map +1 -1
  360. package/dest/kernel/hints/transient_data_squashing_hint.js +4 -2
  361. package/dest/kernel/hints/tree_leaf_read_request.d.ts +2 -2
  362. package/dest/kernel/hints/tree_leaf_read_request.d.ts.map +1 -1
  363. package/dest/kernel/hints/tree_leaf_read_request.js +1 -1
  364. package/dest/kernel/log_hash.d.ts +2 -2
  365. package/dest/kernel/log_hash.d.ts.map +1 -1
  366. package/dest/kernel/log_hash.js +4 -2
  367. package/dest/kernel/note_hash.d.ts +2 -2
  368. package/dest/kernel/note_hash.d.ts.map +1 -1
  369. package/dest/kernel/note_hash.js +1 -1
  370. package/dest/kernel/nullifier.d.ts +2 -2
  371. package/dest/kernel/nullifier.d.ts.map +1 -1
  372. package/dest/kernel/nullifier.js +1 -1
  373. package/dest/kernel/padded_side_effects.d.ts +2 -2
  374. package/dest/kernel/padded_side_effects.d.ts.map +1 -1
  375. package/dest/kernel/padded_side_effects.js +1 -1
  376. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  377. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  378. package/dest/kernel/private_call_data.d.ts +26 -2
  379. package/dest/kernel/private_call_data.d.ts.map +1 -1
  380. package/dest/kernel/private_call_data.js +1 -1
  381. package/dest/kernel/private_call_request.d.ts +17 -2
  382. package/dest/kernel/private_call_request.d.ts.map +1 -1
  383. package/dest/kernel/private_call_request.js +1 -1
  384. package/dest/kernel/private_circuit_public_inputs.d.ts +127 -54
  385. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  386. package/dest/kernel/private_circuit_public_inputs.js +72 -72
  387. package/dest/kernel/private_context_inputs.d.ts +2 -2
  388. package/dest/kernel/private_context_inputs.d.ts.map +1 -1
  389. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +34 -4
  390. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  391. package/dest/kernel/private_kernel_circuit_public_inputs.js +5 -5
  392. package/dest/kernel/private_kernel_data.d.ts +7 -1
  393. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  394. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +23 -2
  395. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  396. package/dest/kernel/private_kernel_init_circuit_private_inputs.js +1 -1
  397. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  398. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  399. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  400. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  401. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +12 -3
  402. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  403. package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
  404. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +26 -4
  405. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  406. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +8 -8
  407. package/dest/kernel/private_log_data.d.ts +2 -2
  408. package/dest/kernel/private_log_data.d.ts.map +1 -1
  409. package/dest/kernel/private_log_data.js +5 -2
  410. package/dest/kernel/private_to_avm_accumulated_data.d.ts +4 -4
  411. package/dest/kernel/private_to_avm_accumulated_data.d.ts.map +1 -1
  412. package/dest/kernel/private_to_avm_accumulated_data.js +6 -3
  413. package/dest/kernel/private_to_public_accumulated_data.d.ts +2 -2
  414. package/dest/kernel/private_to_public_accumulated_data.d.ts.map +1 -1
  415. package/dest/kernel/private_to_public_accumulated_data.js +4 -2
  416. package/dest/kernel/private_to_public_accumulated_data_builder.d.ts +2 -2
  417. package/dest/kernel/private_to_public_accumulated_data_builder.d.ts.map +1 -1
  418. package/dest/kernel/private_to_public_accumulated_data_builder.js +1 -1
  419. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +4 -4
  420. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  421. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +8 -8
  422. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +18 -2
  423. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  424. package/dest/kernel/private_to_rollup_accumulated_data.js +4 -2
  425. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +19 -4
  426. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  427. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +8 -8
  428. package/dest/kernel/private_validation_requests.d.ts +13 -4
  429. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  430. package/dest/kernel/private_validation_requests.js +12 -10
  431. package/dest/kernel/public_call_request.d.ts +23 -2
  432. package/dest/kernel/public_call_request.d.ts.map +1 -1
  433. package/dest/kernel/public_call_request.js +6 -3
  434. package/dest/kernel/utils/optional_number.d.ts +8 -2
  435. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  436. package/dest/keys/derivation.d.ts +7 -6
  437. package/dest/keys/derivation.d.ts.map +1 -1
  438. package/dest/keys/derivation.js +20 -17
  439. package/dest/keys/key_types.d.ts +3 -3
  440. package/dest/keys/key_types.d.ts.map +1 -1
  441. package/dest/keys/public_key.d.ts +2 -2
  442. package/dest/keys/public_key.d.ts.map +1 -1
  443. package/dest/keys/public_keys.d.ts +7 -2
  444. package/dest/keys/public_keys.d.ts.map +1 -1
  445. package/dest/keys/public_keys.js +5 -4
  446. package/dest/keys/utils.d.ts +1 -1
  447. package/dest/keys/utils.d.ts.map +1 -1
  448. package/dest/keys/utils.js +8 -4
  449. package/dest/l1-contracts/slash_factory.d.ts +3 -2
  450. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  451. package/dest/l1-contracts/slash_factory.js +2 -1
  452. package/dest/logs/contract_class_log.d.ts +2 -2
  453. package/dest/logs/contract_class_log.d.ts.map +1 -1
  454. package/dest/logs/contract_class_log.js +5 -3
  455. package/dest/logs/debug_log.d.ts +2 -2
  456. package/dest/logs/debug_log.d.ts.map +1 -1
  457. package/dest/logs/debug_log.js +1 -1
  458. package/dest/logs/directional_app_tagging_secret.d.ts +2 -2
  459. package/dest/logs/directional_app_tagging_secret.d.ts.map +1 -1
  460. package/dest/logs/directional_app_tagging_secret.js +3 -2
  461. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  462. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  463. package/dest/logs/extended_public_log.d.ts +20 -4
  464. package/dest/logs/extended_public_log.d.ts.map +1 -1
  465. package/dest/logs/index.d.ts +3 -2
  466. package/dest/logs/index.d.ts.map +1 -1
  467. package/dest/logs/index.js +2 -1
  468. package/dest/logs/log_id.d.ts +29 -11
  469. package/dest/logs/log_id.d.ts.map +1 -1
  470. package/dest/logs/log_id.js +27 -16
  471. package/dest/logs/message_context.d.ts +2 -2
  472. package/dest/logs/message_context.d.ts.map +1 -1
  473. package/dest/logs/message_context.js +1 -1
  474. package/dest/logs/pending_tagged_log.d.ts +2 -2
  475. package/dest/logs/pending_tagged_log.d.ts.map +1 -1
  476. package/dest/logs/pending_tagged_log.js +1 -1
  477. package/dest/logs/private_log.d.ts +3 -3
  478. package/dest/logs/private_log.d.ts.map +1 -1
  479. package/dest/logs/private_log.js +6 -3
  480. package/dest/logs/public_log.d.ts +3 -2
  481. package/dest/logs/public_log.d.ts.map +1 -1
  482. package/dest/logs/public_log.js +7 -2
  483. package/dest/logs/shared_secret_derivation.d.ts +2 -2
  484. package/dest/logs/shared_secret_derivation.d.ts.map +1 -1
  485. package/dest/logs/shared_secret_derivation.js +1 -1
  486. package/dest/logs/siloed_tag.d.ts +23 -0
  487. package/dest/logs/siloed_tag.d.ts.map +1 -0
  488. package/dest/logs/siloed_tag.js +27 -0
  489. package/dest/logs/tag.d.ts +21 -0
  490. package/dest/logs/tag.d.ts.map +1 -0
  491. package/dest/logs/tag.js +30 -0
  492. package/dest/logs/tx_scoped_l2_log.d.ts +32 -38
  493. package/dest/logs/tx_scoped_l2_log.d.ts.map +1 -1
  494. package/dest/logs/tx_scoped_l2_log.js +40 -45
  495. package/dest/messaging/in_hash.d.ts +5 -3
  496. package/dest/messaging/in_hash.d.ts.map +1 -1
  497. package/dest/messaging/in_hash.js +4 -2
  498. package/dest/messaging/inbox_leaf.d.ts +10 -7
  499. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  500. package/dest/messaging/inbox_leaf.js +10 -9
  501. package/dest/messaging/l1_actor.d.ts +8 -2
  502. package/dest/messaging/l1_actor.d.ts.map +1 -1
  503. package/dest/messaging/l1_actor.js +2 -2
  504. package/dest/messaging/l1_to_l2_message.d.ts +7 -2
  505. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  506. package/dest/messaging/l1_to_l2_message.js +2 -2
  507. package/dest/messaging/l1_to_l2_message_source.d.ts +6 -10
  508. package/dest/messaging/l1_to_l2_message_source.d.ts.map +1 -1
  509. package/dest/messaging/l2_actor.d.ts +8 -2
  510. package/dest/messaging/l2_actor.d.ts.map +1 -1
  511. package/dest/messaging/l2_actor.js +2 -2
  512. package/dest/messaging/l2_to_l1_membership.d.ts +89 -6
  513. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  514. package/dest/messaging/l2_to_l1_membership.js +161 -43
  515. package/dest/messaging/l2_to_l1_message.d.ts +3 -2
  516. package/dest/messaging/l2_to_l1_message.d.ts.map +1 -1
  517. package/dest/messaging/l2_to_l1_message.js +4 -1
  518. package/dest/messaging/out_hash.d.ts +42 -4
  519. package/dest/messaging/out_hash.d.ts.map +1 -1
  520. package/dest/messaging/out_hash.js +55 -20
  521. package/dest/note/index.d.ts +1 -2
  522. package/dest/note/index.d.ts.map +1 -1
  523. package/dest/note/index.js +0 -1
  524. package/dest/note/note.d.ts +2 -2
  525. package/dest/note/note.d.ts.map +1 -1
  526. package/dest/note/note.js +5 -2
  527. package/dest/note/note_dao.d.ts +48 -9
  528. package/dest/note/note_dao.d.ts.map +1 -1
  529. package/dest/note/note_dao.js +29 -15
  530. package/dest/p2p/attestation_utils.d.ts +3 -3
  531. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  532. package/dest/p2p/attestation_utils.js +1 -1
  533. package/dest/p2p/block_proposal.d.ts +103 -24
  534. package/dest/p2p/block_proposal.d.ts.map +1 -1
  535. package/dest/p2p/block_proposal.js +140 -40
  536. package/dest/p2p/checkpoint_attestation.d.ts +82 -0
  537. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
  538. package/dest/p2p/{block_attestation.js → checkpoint_attestation.js} +24 -20
  539. package/dest/p2p/checkpoint_proposal.d.ts +179 -0
  540. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
  541. package/dest/p2p/checkpoint_proposal.js +243 -0
  542. package/dest/p2p/consensus_payload.d.ts +21 -12
  543. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  544. package/dest/p2p/consensus_payload.js +25 -20
  545. package/dest/p2p/constants.d.ts +5 -0
  546. package/dest/p2p/constants.d.ts.map +1 -0
  547. package/dest/p2p/constants.js +3 -0
  548. package/dest/p2p/gossipable.d.ts +4 -3
  549. package/dest/p2p/gossipable.d.ts.map +1 -1
  550. package/dest/p2p/gossipable.js +16 -5
  551. package/dest/p2p/index.d.ts +5 -2
  552. package/dest/p2p/index.d.ts.map +1 -1
  553. package/dest/p2p/index.js +4 -1
  554. package/dest/p2p/message_validator.d.ts +18 -3
  555. package/dest/p2p/message_validator.d.ts.map +1 -1
  556. package/dest/p2p/message_validator.js +2 -1
  557. package/dest/p2p/signature_utils.d.ts +5 -3
  558. package/dest/p2p/signature_utils.d.ts.map +1 -1
  559. package/dest/p2p/signature_utils.js +5 -2
  560. package/dest/p2p/signed_txs.d.ts +42 -0
  561. package/dest/p2p/signed_txs.d.ts.map +1 -0
  562. package/dest/p2p/signed_txs.js +75 -0
  563. package/dest/p2p/topic_type.d.ts +3 -2
  564. package/dest/p2p/topic_type.d.ts.map +1 -1
  565. package/dest/p2p/topic_type.js +10 -3
  566. package/dest/parity/parity_base_private_inputs.d.ts +4 -2
  567. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  568. package/dest/parity/parity_base_private_inputs.js +1 -1
  569. package/dest/parity/parity_public_inputs.d.ts +5 -2
  570. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  571. package/dest/parity/parity_public_inputs.js +1 -1
  572. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  573. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  574. package/dest/proofs/chonk_proof.d.ts +2 -2
  575. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  576. package/dest/proofs/chonk_proof.js +11 -6
  577. package/dest/proofs/proof.d.ts +5 -2
  578. package/dest/proofs/proof.d.ts.map +1 -1
  579. package/dest/proofs/proof.js +1 -1
  580. package/dest/proofs/proof_data.d.ts +13 -1
  581. package/dest/proofs/proof_data.d.ts.map +1 -1
  582. package/dest/proofs/proof_data.js +17 -0
  583. package/dest/proofs/recursive_proof.d.ts +11 -2
  584. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  585. package/dest/proofs/recursive_proof.js +1 -1
  586. package/dest/rollup/avm_proof_data.d.ts +3 -5
  587. package/dest/rollup/avm_proof_data.d.ts.map +1 -1
  588. package/dest/rollup/avm_proof_data.js +1 -9
  589. package/dest/rollup/base_rollup_hints.d.ts +35 -2
  590. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  591. package/dest/rollup/base_rollup_hints.js +1 -1
  592. package/dest/rollup/block_constant_data.d.ts +13 -2
  593. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  594. package/dest/rollup/block_constant_data.js +1 -1
  595. package/dest/rollup/block_headers_hash.d.ts +2 -2
  596. package/dest/rollup/block_headers_hash.d.ts.map +1 -1
  597. package/dest/rollup/block_headers_hash.js +2 -2
  598. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  599. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  600. package/dest/rollup/block_rollup_public_inputs.d.ts +48 -12
  601. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  602. package/dest/rollup/block_rollup_public_inputs.js +9 -13
  603. package/dest/rollup/block_root_rollup_private_inputs.d.ts +65 -2
  604. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  605. package/dest/rollup/block_root_rollup_private_inputs.js +1 -1
  606. package/dest/rollup/checkpoint_constant_data.d.ts +12 -2
  607. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  608. package/dest/rollup/checkpoint_constant_data.js +5 -2
  609. package/dest/rollup/checkpoint_header.d.ts +47 -13
  610. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  611. package/dest/rollup/checkpoint_header.js +55 -22
  612. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  613. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  614. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +47 -7
  615. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  616. package/dest/rollup/checkpoint_rollup_public_inputs.js +12 -4
  617. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +46 -4
  618. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  619. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +15 -3
  620. package/dest/rollup/epoch_constant_data.d.ts +17 -2
  621. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  622. package/dest/rollup/epoch_constant_data.js +1 -1
  623. package/dest/rollup/public_chonk_verifier_private_inputs.d.ts +2 -2
  624. package/dest/rollup/public_chonk_verifier_private_inputs.d.ts.map +1 -1
  625. package/dest/rollup/public_chonk_verifier_private_inputs.js +1 -1
  626. package/dest/rollup/public_chonk_verifier_public_inputs.d.ts +2 -2
  627. package/dest/rollup/public_chonk_verifier_public_inputs.d.ts.map +1 -1
  628. package/dest/rollup/public_chonk_verifier_public_inputs.js +1 -1
  629. package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts +1 -1
  630. package/dest/rollup/public_tx_base_rollup_private_inputs.d.ts.map +1 -1
  631. package/dest/rollup/public_tx_base_rollup_private_inputs.js +2 -2
  632. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  633. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  634. package/dest/rollup/root_rollup_public_inputs.d.ts +22 -7
  635. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  636. package/dest/rollup/root_rollup_public_inputs.js +11 -5
  637. package/dest/rollup/tree_snapshot_diff_hints.d.ts +25 -2
  638. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  639. package/dest/rollup/tree_snapshot_diff_hints.js +1 -1
  640. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  641. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  642. package/dest/rollup/tx_rollup_public_inputs.d.ts +30 -2
  643. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  644. package/dest/rollup/tx_rollup_public_inputs.js +1 -1
  645. package/dest/schemas/schemas.d.ts +7 -4
  646. package/dest/schemas/schemas.d.ts.map +1 -1
  647. package/dest/schemas/schemas.js +2 -1
  648. package/dest/slashing/empire.d.ts +1 -1
  649. package/dest/slashing/empire.d.ts.map +1 -1
  650. package/dest/slashing/empire.js +2 -0
  651. package/dest/slashing/helpers.d.ts +2 -2
  652. package/dest/slashing/helpers.d.ts.map +1 -1
  653. package/dest/slashing/helpers.js +6 -0
  654. package/dest/slashing/tally.d.ts +2 -1
  655. package/dest/slashing/tally.d.ts.map +1 -1
  656. package/dest/slashing/tally.js +6 -2
  657. package/dest/slashing/types.d.ts +10 -7
  658. package/dest/slashing/types.d.ts.map +1 -1
  659. package/dest/slashing/types.js +18 -6
  660. package/dest/snapshots/types.d.ts +1 -1
  661. package/dest/snapshots/types.d.ts.map +1 -1
  662. package/dest/snapshots/types.js +5 -5
  663. package/dest/stats/stats.d.ts +10 -8
  664. package/dest/stats/stats.d.ts.map +1 -1
  665. package/dest/tests/factories.d.ts +42 -12
  666. package/dest/tests/factories.d.ts.map +1 -1
  667. package/dest/tests/factories.js +110 -43
  668. package/dest/tests/jest.js +1 -1
  669. package/dest/tests/mocks.d.ts +90 -19
  670. package/dest/tests/mocks.d.ts.map +1 -1
  671. package/dest/tests/mocks.js +192 -62
  672. package/dest/timetable/index.d.ts +37 -0
  673. package/dest/timetable/index.d.ts.map +1 -0
  674. package/dest/timetable/index.js +39 -0
  675. package/dest/trees/append_only_tree_snapshot.d.ts +14 -2
  676. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  677. package/dest/trees/append_only_tree_snapshot.js +4 -2
  678. package/dest/trees/database_public_state_source.d.ts +2 -2
  679. package/dest/trees/database_public_state_source.d.ts.map +1 -1
  680. package/dest/trees/database_public_state_source.js +1 -1
  681. package/dest/trees/nullifier_leaf.d.ts +14 -2
  682. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  683. package/dest/trees/nullifier_leaf.js +1 -1
  684. package/dest/trees/nullifier_membership_witness.d.ts +11 -2
  685. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  686. package/dest/trees/nullifier_membership_witness.js +1 -1
  687. package/dest/trees/public_data_leaf.d.ts +18 -2
  688. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  689. package/dest/trees/public_data_leaf.js +8 -7
  690. package/dest/trees/public_data_witness.d.ts +12 -2
  691. package/dest/trees/public_data_witness.d.ts.map +1 -1
  692. package/dest/trees/public_data_witness.js +1 -1
  693. package/dest/tx/block_header.d.ts +25 -12
  694. package/dest/tx/block_header.d.ts.map +1 -1
  695. package/dest/tx/block_header.js +16 -5
  696. package/dest/tx/call_context.d.ts +14 -2
  697. package/dest/tx/call_context.d.ts.map +1 -1
  698. package/dest/tx/call_context.js +3 -1
  699. package/dest/tx/capsule.d.ts +5 -2
  700. package/dest/tx/capsule.d.ts.map +1 -1
  701. package/dest/tx/capsule.js +1 -1
  702. package/dest/tx/execution_payload.d.ts +9 -1
  703. package/dest/tx/execution_payload.d.ts.map +1 -1
  704. package/dest/tx/function_data.d.ts +5 -3
  705. package/dest/tx/function_data.d.ts.map +1 -1
  706. package/dest/tx/function_data.js +1 -1
  707. package/dest/tx/global_variable_builder.d.ts +5 -3
  708. package/dest/tx/global_variable_builder.d.ts.map +1 -1
  709. package/dest/tx/global_variables.d.ts +27 -12
  710. package/dest/tx/global_variables.d.ts.map +1 -1
  711. package/dest/tx/global_variables.js +11 -9
  712. package/dest/tx/hashed_values.d.ts +8 -2
  713. package/dest/tx/hashed_values.d.ts.map +1 -1
  714. package/dest/tx/hashed_values.js +1 -1
  715. package/dest/tx/in_tx.d.ts +26 -0
  716. package/dest/tx/in_tx.d.ts.map +1 -0
  717. package/dest/tx/in_tx.js +14 -0
  718. package/dest/tx/index.d.ts +2 -2
  719. package/dest/tx/index.d.ts.map +1 -1
  720. package/dest/tx/index.js +1 -1
  721. package/dest/tx/indexed_tx_effect.d.ts +14 -10
  722. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  723. package/dest/tx/indexed_tx_effect.js +8 -6
  724. package/dest/tx/offchain_effect.d.ts +2 -2
  725. package/dest/tx/offchain_effect.d.ts.map +1 -1
  726. package/dest/tx/offchain_effect.js +1 -1
  727. package/dest/tx/partial_state_reference.d.ts +5 -2
  728. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  729. package/dest/tx/private_execution_result.d.ts +27 -10
  730. package/dest/tx/private_execution_result.d.ts.map +1 -1
  731. package/dest/tx/private_execution_result.js +6 -23
  732. package/dest/tx/private_tx_constant_data.d.ts +17 -2
  733. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  734. package/dest/tx/private_tx_constant_data.js +1 -1
  735. package/dest/tx/processed_tx.d.ts +5 -4
  736. package/dest/tx/processed_tx.d.ts.map +1 -1
  737. package/dest/tx/processed_tx.js +8 -7
  738. package/dest/tx/profiling.d.ts +153 -30
  739. package/dest/tx/profiling.d.ts.map +1 -1
  740. package/dest/tx/profiling.js +48 -11
  741. package/dest/tx/protocol_contracts.d.ts +3 -3
  742. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  743. package/dest/tx/protocol_contracts.js +3 -3
  744. package/dest/tx/public_call_request_with_calldata.d.ts +8 -2
  745. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  746. package/dest/tx/public_call_request_with_calldata.js +4 -2
  747. package/dest/tx/public_simulation_output.d.ts +5 -3
  748. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  749. package/dest/tx/public_simulation_output.js +8 -4
  750. package/dest/tx/simulated_tx.d.ts +1031 -7
  751. package/dest/tx/simulated_tx.d.ts.map +1 -1
  752. package/dest/tx/state_reference.d.ts +4 -2
  753. package/dest/tx/state_reference.d.ts.map +1 -1
  754. package/dest/tx/state_reference.js +3 -1
  755. package/dest/tx/tree_snapshots.d.ts +2 -2
  756. package/dest/tx/tree_snapshots.d.ts.map +1 -1
  757. package/dest/tx/tree_snapshots.js +3 -1
  758. package/dest/tx/tx.d.ts +35 -5
  759. package/dest/tx/tx.d.ts.map +1 -1
  760. package/dest/tx/tx.js +20 -7
  761. package/dest/tx/tx_constant_data.d.ts +2 -2
  762. package/dest/tx/tx_constant_data.d.ts.map +1 -1
  763. package/dest/tx/tx_constant_data.js +1 -1
  764. package/dest/tx/tx_context.d.ts +3 -2
  765. package/dest/tx/tx_context.d.ts.map +1 -1
  766. package/dest/tx/tx_context.js +1 -1
  767. package/dest/tx/tx_effect.d.ts +33 -7
  768. package/dest/tx/tx_effect.d.ts.map +1 -1
  769. package/dest/tx/tx_effect.js +8 -11
  770. package/dest/tx/tx_execution_request.d.ts +31 -2
  771. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  772. package/dest/tx/tx_execution_request.js +7 -3
  773. package/dest/tx/tx_hash.d.ts +3 -2
  774. package/dest/tx/tx_hash.d.ts.map +1 -1
  775. package/dest/tx/tx_hash.js +1 -1
  776. package/dest/tx/tx_receipt.d.ts +50 -15
  777. package/dest/tx/tx_receipt.d.ts.map +1 -1
  778. package/dest/tx/tx_receipt.js +48 -16
  779. package/dest/tx/tx_request.d.ts +7 -2
  780. package/dest/tx/tx_request.d.ts.map +1 -1
  781. package/dest/tx/tx_request.js +4 -4
  782. package/dest/tx/validator/empty_validator.d.ts +2 -2
  783. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  784. package/dest/tx/validator/error_texts.d.ts +3 -2
  785. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  786. package/dest/tx/validator/error_texts.js +3 -1
  787. package/dest/tx/validator/tx_validator.d.ts +2 -5
  788. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  789. package/dest/tx/validator/tx_validator.js +4 -4
  790. package/dest/types/shared.d.ts +4 -1
  791. package/dest/types/shared.d.ts.map +1 -1
  792. package/dest/update-checker/update-checker.d.ts +2 -2
  793. package/dest/update-checker/update-checker.d.ts.map +1 -1
  794. package/dest/update-checker/update-checker.js +1 -1
  795. package/dest/validators/errors.d.ts +2 -2
  796. package/dest/validators/errors.d.ts.map +1 -1
  797. package/dest/validators/schemas.d.ts +38 -38
  798. package/dest/validators/schemas.d.ts.map +1 -1
  799. package/dest/validators/schemas.js +17 -16
  800. package/dest/validators/types.d.ts +3 -3
  801. package/dest/validators/types.d.ts.map +1 -1
  802. package/dest/versioning/versioning.d.ts +2 -2
  803. package/dest/versioning/versioning.d.ts.map +1 -1
  804. package/dest/vks/verification_key.d.ts +23 -2
  805. package/dest/vks/verification_key.d.ts.map +1 -1
  806. package/dest/vks/verification_key.js +1 -1
  807. package/dest/vks/vk_data.d.ts +8 -2
  808. package/dest/vks/vk_data.d.ts.map +1 -1
  809. package/dest/vks/vk_data.js +1 -1
  810. package/dest/zkpassport/index.d.ts +4 -5
  811. package/dest/zkpassport/index.d.ts.map +1 -1
  812. package/dest/zkpassport/index.js +11 -11
  813. package/package.json +33 -14
  814. package/src/abi/abi.ts +40 -34
  815. package/src/abi/authorization_selector.ts +3 -2
  816. package/src/abi/buffer.ts +1 -1
  817. package/src/abi/contract_artifact.ts +10 -10
  818. package/src/abi/decoder.ts +1 -1
  819. package/src/abi/encoder.ts +1 -1
  820. package/src/abi/event_selector.ts +3 -2
  821. package/src/abi/function_call.ts +26 -4
  822. package/src/abi/function_selector.ts +11 -2
  823. package/src/abi/note_selector.ts +2 -2
  824. package/src/abi/selector.ts +1 -1
  825. package/src/abi/utils.ts +17 -0
  826. package/src/auth_witness/auth_witness.ts +5 -5
  827. package/src/avm/avm.ts +338 -20
  828. package/src/avm/avm_accumulated_data.ts +1 -1
  829. package/src/avm/avm_circuit_public_inputs.ts +1 -1
  830. package/src/avm/contract_storage_read.ts +1 -1
  831. package/src/avm/contract_storage_update_request.ts +1 -1
  832. package/src/avm/message_pack.ts +2 -1
  833. package/src/avm/public_call_stack_item_compressed.ts +1 -1
  834. package/src/avm/public_data_read.ts +1 -1
  835. package/src/avm/public_data_update_request.ts +1 -1
  836. package/src/avm/public_data_write.ts +1 -1
  837. package/src/avm/public_inner_call_request.ts +1 -1
  838. package/src/avm/revert_code.ts +1 -1
  839. package/src/aztec-address/index.ts +2 -1
  840. package/src/block/attestation_info.ts +10 -7
  841. package/src/block/block_data.ts +26 -0
  842. package/src/block/block_hash.ts +27 -26
  843. package/src/block/block_parameter.ts +10 -0
  844. package/src/block/body.ts +2 -1
  845. package/src/block/checkpointed_l2_block.ts +70 -0
  846. package/src/block/in_block.ts +28 -15
  847. package/src/block/index.ts +3 -4
  848. package/src/block/l2_block.ts +107 -141
  849. package/src/block/l2_block_info.ts +11 -10
  850. package/src/block/l2_block_source.ts +218 -71
  851. package/src/block/l2_block_stream/index.ts +1 -0
  852. package/src/block/l2_block_stream/interfaces.ts +15 -4
  853. package/src/block/l2_block_stream/l2_block_stream.ts +142 -37
  854. package/src/block/l2_block_stream/l2_tips_memory_store.ts +63 -54
  855. package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
  856. package/src/block/proposal/attestations_and_signers.ts +1 -1
  857. package/src/block/proposal/committee_attestation.ts +1 -1
  858. package/src/block/test/l2_tips_store_test_suite.ts +486 -36
  859. package/src/block/validate_block_result.ts +40 -35
  860. package/src/checkpoint/checkpoint.ts +115 -27
  861. package/src/checkpoint/checkpoint_data.ts +51 -0
  862. package/src/checkpoint/checkpoint_info.ts +52 -0
  863. package/src/checkpoint/index.ts +2 -0
  864. package/src/checkpoint/published_checkpoint.ts +26 -9
  865. package/src/config/index.ts +1 -0
  866. package/src/config/node-rpc-config.ts +1 -1
  867. package/src/config/sequencer-config.ts +29 -0
  868. package/src/contract/artifact_hash.ts +2 -2
  869. package/src/contract/complete_address.ts +1 -1
  870. package/src/contract/contract_address.ts +6 -6
  871. package/src/contract/contract_class.ts +5 -5
  872. package/src/contract/contract_class_id.ts +8 -7
  873. package/src/contract/contract_instance.ts +1 -1
  874. package/src/contract/contract_instance_update.ts +1 -1
  875. package/src/contract/deployment_info.ts +1 -1
  876. package/src/contract/index.ts +0 -2
  877. package/src/contract/interfaces/contract_class.ts +78 -47
  878. package/src/contract/interfaces/contract_data_source.ts +3 -2
  879. package/src/contract/interfaces/contract_instance.ts +48 -16
  880. package/src/contract/interfaces/contract_instance_update.ts +12 -10
  881. package/src/contract/interfaces/node-info.ts +3 -0
  882. package/src/contract/partial_address.ts +1 -1
  883. package/src/contract/private_function.ts +5 -5
  884. package/src/contract/private_function_membership_proof.ts +3 -3
  885. package/src/contract/utility_function_membership_proof.ts +1 -1
  886. package/src/database-version/database_version.ts +87 -0
  887. package/src/database-version/version_manager.ts +1 -77
  888. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +11 -12
  889. package/src/delayed_public_mutable/delayed_public_mutable_values_with_hash.ts +1 -1
  890. package/src/delayed_public_mutable/scheduled_value_change.ts +1 -1
  891. package/src/deserialization/index.ts +21 -0
  892. package/src/epoch-helpers/index.ts +24 -10
  893. package/src/errors/simulation_error.ts +1 -1
  894. package/src/fees/transaction_fee.ts +1 -1
  895. package/src/file-store/local.ts +15 -5
  896. package/src/file-store/s3.ts +12 -3
  897. package/src/gas/gas.ts +1 -1
  898. package/src/gas/gas_fees.ts +1 -1
  899. package/src/gas/gas_settings.ts +1 -1
  900. package/src/ha-signing/config.ts +149 -0
  901. package/src/ha-signing/index.ts +18 -0
  902. package/src/ha-signing/types.ts +112 -0
  903. package/src/hash/hash.ts +15 -21
  904. package/src/hash/map_slot.ts +4 -3
  905. package/src/interfaces/allowed_element.ts +10 -8
  906. package/src/interfaces/api_limit.ts +2 -0
  907. package/src/interfaces/archiver.ts +54 -29
  908. package/src/interfaces/aztec-node-admin.ts +33 -6
  909. package/src/interfaces/aztec-node.ts +159 -174
  910. package/src/interfaces/block-builder.ts +52 -23
  911. package/src/interfaces/configs.ts +78 -33
  912. package/src/interfaces/epoch-prover.ts +4 -4
  913. package/src/interfaces/get_logs_response.ts +13 -9
  914. package/src/interfaces/l2_logs_source.ts +24 -14
  915. package/src/interfaces/merkle_tree_operations.ts +7 -3
  916. package/src/interfaces/p2p.ts +8 -12
  917. package/src/interfaces/prover-broker.ts +22 -0
  918. package/src/interfaces/prover-client.ts +35 -10
  919. package/src/interfaces/proving-job.ts +2 -11
  920. package/src/interfaces/public_state_source.ts +1 -1
  921. package/src/interfaces/server_circuit_prover.ts +3 -3
  922. package/src/interfaces/slasher.ts +28 -22
  923. package/src/interfaces/validator.ts +94 -32
  924. package/src/interfaces/world_state.ts +26 -18
  925. package/src/kernel/claimed_length_array.ts +1 -1
  926. package/src/kernel/hints/build_note_hash_read_request_hints.ts +20 -12
  927. package/src/kernel/hints/build_nullifier_read_request_hints.ts +18 -15
  928. package/src/kernel/hints/find_private_kernel_reset_dimensions.ts +2 -4
  929. package/src/kernel/hints/index.ts +2 -2
  930. package/src/kernel/hints/key_validation_hint.ts +1 -1
  931. package/src/kernel/hints/key_validation_request.ts +2 -1
  932. package/src/kernel/hints/key_validation_request_and_separator.ts +49 -0
  933. package/src/kernel/hints/note_hash_read_request_hints.ts +1 -1
  934. package/src/kernel/hints/read_request.ts +1 -1
  935. package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +11 -11
  936. package/src/kernel/hints/scoped_value_cache.ts +1 -1
  937. package/src/kernel/hints/transient_data_squashing_hint.ts +1 -1
  938. package/src/kernel/hints/tree_leaf_read_request.ts +1 -1
  939. package/src/kernel/log_hash.ts +1 -1
  940. package/src/kernel/note_hash.ts +1 -1
  941. package/src/kernel/nullifier.ts +1 -1
  942. package/src/kernel/padded_side_effects.ts +1 -1
  943. package/src/kernel/private_call_data.ts +1 -1
  944. package/src/kernel/private_call_request.ts +1 -1
  945. package/src/kernel/private_circuit_public_inputs.ts +100 -100
  946. package/src/kernel/private_context_inputs.ts +1 -1
  947. package/src/kernel/private_kernel_circuit_public_inputs.ts +3 -3
  948. package/src/kernel/private_kernel_init_circuit_private_inputs.ts +1 -1
  949. package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +2 -2
  950. package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +6 -6
  951. package/src/kernel/private_log_data.ts +1 -1
  952. package/src/kernel/private_to_avm_accumulated_data.ts +1 -1
  953. package/src/kernel/private_to_public_accumulated_data.ts +1 -1
  954. package/src/kernel/private_to_public_accumulated_data_builder.ts +1 -1
  955. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +7 -7
  956. package/src/kernel/private_to_rollup_accumulated_data.ts +1 -1
  957. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +7 -7
  958. package/src/kernel/private_validation_requests.ts +8 -8
  959. package/src/kernel/public_call_request.ts +1 -1
  960. package/src/kernel/utils/optional_number.ts +1 -1
  961. package/src/keys/derivation.ts +20 -17
  962. package/src/keys/key_types.ts +6 -2
  963. package/src/keys/public_key.ts +1 -1
  964. package/src/keys/public_keys.ts +5 -4
  965. package/src/keys/utils.ts +8 -4
  966. package/src/l1-contracts/slash_factory.ts +4 -1
  967. package/src/logs/contract_class_log.ts +2 -2
  968. package/src/logs/debug_log.ts +1 -1
  969. package/src/logs/directional_app_tagging_secret.ts +4 -2
  970. package/src/logs/index.ts +2 -1
  971. package/src/logs/log_id.ts +32 -17
  972. package/src/logs/message_context.ts +1 -1
  973. package/src/logs/pending_tagged_log.ts +1 -1
  974. package/src/logs/private_log.ts +3 -2
  975. package/src/logs/public_log.ts +8 -1
  976. package/src/logs/shared_secret_derivation.ts +2 -2
  977. package/src/logs/siloed_tag.ts +44 -0
  978. package/src/logs/tag.ts +42 -0
  979. package/src/logs/tx_scoped_l2_log.ts +48 -45
  980. package/src/messaging/in_hash.ts +4 -2
  981. package/src/messaging/inbox_leaf.ts +11 -10
  982. package/src/messaging/l1_actor.ts +2 -2
  983. package/src/messaging/l1_to_l2_message.ts +3 -2
  984. package/src/messaging/l1_to_l2_message_source.ts +5 -10
  985. package/src/messaging/l2_actor.ts +2 -2
  986. package/src/messaging/l2_to_l1_membership.ts +179 -52
  987. package/src/messaging/l2_to_l1_message.ts +5 -1
  988. package/src/messaging/out_hash.ts +63 -22
  989. package/src/note/index.ts +0 -1
  990. package/src/note/note.ts +5 -2
  991. package/src/note/note_dao.ts +51 -15
  992. package/src/p2p/attestation_utils.ts +3 -3
  993. package/src/p2p/block_proposal.ts +214 -48
  994. package/src/p2p/{block_attestation.ts → checkpoint_attestation.ts} +38 -26
  995. package/src/p2p/checkpoint_proposal.ts +387 -0
  996. package/src/p2p/consensus_payload.ts +30 -19
  997. package/src/p2p/constants.ts +6 -0
  998. package/src/p2p/gossipable.ts +14 -4
  999. package/src/p2p/index.ts +4 -1
  1000. package/src/p2p/message_validator.ts +14 -2
  1001. package/src/p2p/signature_utils.ts +5 -2
  1002. package/src/p2p/signed_txs.ts +88 -0
  1003. package/src/p2p/topic_type.ts +4 -3
  1004. package/src/parity/parity_base_private_inputs.ts +1 -1
  1005. package/src/parity/parity_public_inputs.ts +1 -1
  1006. package/src/proofs/chonk_proof.ts +11 -7
  1007. package/src/proofs/proof.ts +1 -1
  1008. package/src/proofs/proof_data.ts +24 -0
  1009. package/src/proofs/recursive_proof.ts +1 -1
  1010. package/src/rollup/avm_proof_data.ts +2 -9
  1011. package/src/rollup/base_rollup_hints.ts +1 -1
  1012. package/src/rollup/block_constant_data.ts +1 -1
  1013. package/src/rollup/block_headers_hash.ts +2 -2
  1014. package/src/rollup/block_rollup_public_inputs.ts +6 -12
  1015. package/src/rollup/block_root_rollup_private_inputs.ts +1 -1
  1016. package/src/rollup/checkpoint_constant_data.ts +2 -1
  1017. package/src/rollup/checkpoint_header.ts +69 -20
  1018. package/src/rollup/checkpoint_rollup_public_inputs.ts +18 -6
  1019. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +16 -2
  1020. package/src/rollup/epoch_constant_data.ts +1 -1
  1021. package/src/rollup/public_chonk_verifier_private_inputs.ts +1 -1
  1022. package/src/rollup/public_chonk_verifier_public_inputs.ts +1 -1
  1023. package/src/rollup/public_tx_base_rollup_private_inputs.ts +2 -2
  1024. package/src/rollup/root_rollup_public_inputs.ts +17 -8
  1025. package/src/rollup/tree_snapshot_diff_hints.ts +1 -1
  1026. package/src/rollup/tx_rollup_public_inputs.ts +1 -1
  1027. package/src/schemas/schemas.ts +6 -1
  1028. package/src/slashing/empire.ts +3 -1
  1029. package/src/slashing/helpers.ts +8 -0
  1030. package/src/slashing/tally.ts +8 -2
  1031. package/src/slashing/types.ts +38 -20
  1032. package/src/snapshots/types.ts +33 -29
  1033. package/src/stats/stats.ts +10 -7
  1034. package/src/tests/factories.ts +143 -61
  1035. package/src/tests/jest.ts +1 -1
  1036. package/src/tests/mocks.ts +295 -86
  1037. package/src/timetable/index.ts +66 -0
  1038. package/src/trees/append_only_tree_snapshot.ts +1 -1
  1039. package/src/trees/database_public_state_source.ts +1 -1
  1040. package/src/trees/nullifier_leaf.ts +1 -1
  1041. package/src/trees/nullifier_membership_witness.ts +1 -1
  1042. package/src/trees/public_data_leaf.ts +12 -6
  1043. package/src/trees/public_data_witness.ts +1 -1
  1044. package/src/tx/block_header.ts +27 -13
  1045. package/src/tx/call_context.ts +1 -1
  1046. package/src/tx/capsule.ts +1 -1
  1047. package/src/tx/function_data.ts +1 -1
  1048. package/src/tx/global_variable_builder.ts +9 -2
  1049. package/src/tx/global_variables.ts +16 -10
  1050. package/src/tx/hashed_values.ts +1 -1
  1051. package/src/tx/in_tx.ts +24 -0
  1052. package/src/tx/index.ts +1 -1
  1053. package/src/tx/indexed_tx_effect.ts +9 -7
  1054. package/src/tx/offchain_effect.ts +1 -1
  1055. package/src/tx/partial_state_reference.ts +1 -1
  1056. package/src/tx/private_execution_result.ts +6 -21
  1057. package/src/tx/private_tx_constant_data.ts +1 -1
  1058. package/src/tx/processed_tx.ts +19 -16
  1059. package/src/tx/profiling.ts +52 -10
  1060. package/src/tx/protocol_contracts.ts +4 -4
  1061. package/src/tx/public_call_request_with_calldata.ts +1 -1
  1062. package/src/tx/public_simulation_output.ts +5 -1
  1063. package/src/tx/state_reference.ts +1 -1
  1064. package/src/tx/tree_snapshots.ts +1 -1
  1065. package/src/tx/tx.ts +22 -13
  1066. package/src/tx/tx_constant_data.ts +1 -1
  1067. package/src/tx/tx_context.ts +1 -1
  1068. package/src/tx/tx_effect.ts +5 -12
  1069. package/src/tx/tx_execution_request.ts +3 -1
  1070. package/src/tx/tx_hash.ts +1 -1
  1071. package/src/tx/tx_receipt.ts +78 -20
  1072. package/src/tx/tx_request.ts +4 -4
  1073. package/src/tx/validator/empty_validator.ts +1 -1
  1074. package/src/tx/validator/error_texts.ts +4 -1
  1075. package/src/tx/validator/tx_validator.ts +9 -7
  1076. package/src/update-checker/update-checker.ts +2 -1
  1077. package/src/validators/errors.ts +1 -1
  1078. package/src/validators/schemas.ts +61 -48
  1079. package/src/validators/types.ts +5 -4
  1080. package/src/versioning/versioning.ts +1 -1
  1081. package/src/vks/verification_key.ts +1 -1
  1082. package/src/vks/vk_data.ts +1 -1
  1083. package/src/zkpassport/index.ts +13 -14
  1084. package/dest/block/l2_block_code_to_purge.d.ts +0 -12
  1085. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  1086. package/dest/block/l2_block_code_to_purge.js +0 -61
  1087. package/dest/block/l2_block_header.d.ts +0 -98
  1088. package/dest/block/l2_block_header.d.ts.map +0 -1
  1089. package/dest/block/l2_block_header.js +0 -153
  1090. package/dest/block/l2_block_new.d.ts +0 -108
  1091. package/dest/block/l2_block_new.d.ts.map +0 -1
  1092. package/dest/block/l2_block_new.js +0 -135
  1093. package/dest/block/l2_block_number.d.ts +0 -5
  1094. package/dest/block/l2_block_number.d.ts.map +0 -1
  1095. package/dest/block/l2_block_number.js +0 -6
  1096. package/dest/block/published_l2_block.d.ts +0 -130
  1097. package/dest/block/published_l2_block.d.ts.map +0 -1
  1098. package/dest/block/published_l2_block.js +0 -48
  1099. package/dest/contract/contract_class_metadata.d.ts +0 -8
  1100. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  1101. package/dest/contract/contract_class_metadata.js +0 -1
  1102. package/dest/contract/contract_metadata.d.ts +0 -7
  1103. package/dest/contract/contract_metadata.d.ts.map +0 -1
  1104. package/dest/contract/contract_metadata.js +0 -1
  1105. package/dest/database-version/index.d.ts +0 -2
  1106. package/dest/database-version/index.d.ts.map +0 -1
  1107. package/dest/database-version/index.js +0 -1
  1108. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -25
  1109. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  1110. package/dest/logs/log_with_tx_data.d.ts +0 -19
  1111. package/dest/logs/log_with_tx_data.d.ts.map +0 -1
  1112. package/dest/logs/log_with_tx_data.js +0 -49
  1113. package/dest/note/notes_filter.d.ts +0 -25
  1114. package/dest/note/notes_filter.d.ts.map +0 -1
  1115. package/dest/note/notes_filter.js +0 -10
  1116. package/dest/p2p/block_attestation.d.ts +0 -80
  1117. package/dest/p2p/block_attestation.d.ts.map +0 -1
  1118. package/dest/tx/content_commitment.d.ts +0 -48
  1119. package/dest/tx/content_commitment.d.ts.map +0 -1
  1120. package/dest/tx/content_commitment.js +0 -82
  1121. package/src/block/l2_block_code_to_purge.ts +0 -88
  1122. package/src/block/l2_block_header.ts +0 -246
  1123. package/src/block/l2_block_new.ts +0 -171
  1124. package/src/block/l2_block_number.ts +0 -8
  1125. package/src/block/published_l2_block.ts +0 -65
  1126. package/src/contract/contract_class_metadata.ts +0 -8
  1127. package/src/contract/contract_metadata.ts +0 -7
  1128. package/src/database-version/index.ts +0 -1
  1129. package/src/kernel/hints/key_validation_request_and_generator.ts +0 -52
  1130. package/src/logs/log_with_tx_data.ts +0 -46
  1131. package/src/note/notes_filter.ts +0 -35
  1132. package/src/tx/content_commitment.ts +0 -104
@@ -1,6 +1,15 @@
1
+ import { GENESIS_BLOCK_HEADER_HASH } from '@aztec/constants';
2
+ import { BlockNumber, CheckpointNumber } from '@aztec/foundation/branded-types';
1
3
  import { times } from '@aztec/foundation/collection';
2
- import { Fr } from '@aztec/foundation/fields';
3
- import { type L2Block, type L2BlockId, PublishedL2Block } from '@aztec/stdlib/block';
4
+ import { Fr } from '@aztec/foundation/curves/bn254';
5
+ import {
6
+ type CheckpointId,
7
+ GENESIS_CHECKPOINT_HEADER_HASH,
8
+ L2Block,
9
+ type L2BlockId,
10
+ type L2TipId,
11
+ } from '@aztec/stdlib/block';
12
+ import { Checkpoint, L1PublishedData, PublishedCheckpoint } from '@aztec/stdlib/checkpoint';
4
13
 
5
14
  import { jestExpect as expect } from '@jest/expect';
6
15
 
@@ -8,80 +17,521 @@ import type { L2TipsStore } from '../l2_block_stream/index.js';
8
17
 
9
18
  export function testL2TipsStore(makeTipsStore: () => Promise<L2TipsStore>) {
10
19
  let tipsStore: L2TipsStore;
20
+ // Track blocks and their hashes for test assertions
21
+ const blockHashes: Map<number, string> = new Map();
22
+ // Track checkpoints and their hashes
23
+ const checkpointHashes: Map<number, string> = new Map();
24
+ // Track which blocks belong to which checkpoint
25
+ const blockToCheckpoint: Map<number, number> = new Map();
11
26
 
12
27
  beforeEach(async () => {
13
28
  tipsStore = await makeTipsStore();
29
+ blockHashes.clear();
30
+ checkpointHashes.clear();
31
+ blockToCheckpoint.clear();
14
32
  });
15
33
 
16
- const makeBlock = (number: number): PublishedL2Block =>
17
- PublishedL2Block.fromFields({
18
- block: { number, hash: () => Promise.resolve(new Fr(number)) } as L2Block,
19
- l1: { blockNumber: BigInt(number), blockHash: `0x${number}`, timestamp: BigInt(number) },
20
- attestations: [],
21
- });
34
+ const makeBlock = async (number: number): Promise<L2Block> => {
35
+ const block = await L2Block.random(BlockNumber(number));
36
+ blockHashes.set(number, (await block.hash()).toString());
37
+ return block;
38
+ };
22
39
 
23
40
  const makeBlockId = (number: number): L2BlockId => ({
24
- number,
25
- hash: new Fr(number).toString(),
41
+ number: BlockNumber(number),
42
+ hash: blockHashes.get(number) ?? new Fr(number).toString(),
43
+ });
44
+
45
+ const makeTip = (number: number): L2BlockId => ({
46
+ number: BlockNumber(number),
47
+ hash: number === 0 ? GENESIS_BLOCK_HEADER_HASH.toString() : (blockHashes.get(number) ?? new Fr(number).toString()),
26
48
  });
27
49
 
28
- const makeTip = (number: number) => ({ number, hash: number === 0 ? undefined : new Fr(number).toString() });
50
+ const makeCheckpointIdForBlock = (blockNumber: number): CheckpointId => {
51
+ if (blockNumber === 0) {
52
+ return { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() };
53
+ }
54
+ const checkpointNum = blockToCheckpoint.get(blockNumber);
55
+ if (checkpointNum === undefined) {
56
+ return { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() };
57
+ }
58
+ const hash = checkpointHashes.get(checkpointNum);
59
+ if (!hash) {
60
+ return { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() };
61
+ }
62
+ return { number: CheckpointNumber(checkpointNum), hash };
63
+ };
29
64
 
30
- const makeTips = (latest: number, proven: number, finalized: number) => ({
31
- latest: makeTip(latest),
32
- proven: makeTip(proven),
33
- finalized: makeTip(finalized),
65
+ const makeTipId = (blockNumber: number): L2TipId => ({
66
+ block: makeTip(blockNumber),
67
+ checkpoint: makeCheckpointIdForBlock(blockNumber),
34
68
  });
35
69
 
70
+ const makeTips = (proposed: number, proven: number, finalized: number, checkpointed: number = 0) => ({
71
+ proposed: makeTip(proposed),
72
+ proven: makeTipId(proven),
73
+ finalized: makeTipId(finalized),
74
+ checkpointed: makeTipId(checkpointed),
75
+ });
76
+
77
+ const makeCheckpoint = async (checkpointNumber: number, blocks: L2Block[]): Promise<PublishedCheckpoint> => {
78
+ const checkpoint = await Checkpoint.random(CheckpointNumber(checkpointNumber), {
79
+ numBlocks: blocks.length,
80
+ startBlockNumber: blocks[0].number,
81
+ });
82
+ // Override the blocks with our actual blocks (to keep hashes consistent)
83
+ (checkpoint as any).blocks = blocks;
84
+
85
+ const checkpointHash = checkpoint.hash().toString();
86
+ checkpointHashes.set(checkpointNumber, checkpointHash);
87
+
88
+ // Track which blocks belong to this checkpoint
89
+ for (const block of blocks) {
90
+ blockToCheckpoint.set(block.number, checkpointNumber);
91
+ }
92
+
93
+ return new PublishedCheckpoint(checkpoint, L1PublishedData.random(), []);
94
+ };
95
+
96
+ /** Creates a chain-checkpointed event with the required block field */
97
+ const makeCheckpointedEvent = async (checkpoint: PublishedCheckpoint) => {
98
+ const lastBlock = checkpoint.checkpoint.blocks.at(-1)!;
99
+ const blockId: L2BlockId = {
100
+ number: lastBlock.number,
101
+ hash: (await lastBlock.hash()).toString(),
102
+ };
103
+ return { type: 'chain-checkpointed' as const, checkpoint, block: blockId };
104
+ };
105
+
36
106
  it('returns zero if no tips are stored', async () => {
37
107
  const tips = await tipsStore.getL2Tips();
38
108
  expect(tips).toEqual(makeTips(0, 0, 0));
39
109
  });
40
110
 
41
- it('stores chain tips', async () => {
42
- await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: times(20, i => makeBlock(i + 1)) });
111
+ it('sets proposed tip from blocks added', async () => {
112
+ await tipsStore.handleBlockStreamEvent({
113
+ type: 'blocks-added',
114
+ blocks: await Promise.all(times(3, i => makeBlock(i + 1))),
115
+ });
43
116
 
44
- await tipsStore.handleBlockStreamEvent({ type: 'chain-finalized', block: makeBlockId(5) });
45
- await tipsStore.handleBlockStreamEvent({ type: 'chain-proven', block: makeBlockId(8) });
46
- await tipsStore.handleBlockStreamEvent({ type: 'chain-pruned', block: makeBlockId(10) });
117
+ const tips = await tipsStore.getL2Tips();
118
+ expect(tips).toEqual(makeTips(3, 0, 0));
119
+
120
+ expect(await tipsStore.getL2BlockHash(1)).toEqual(blockHashes.get(1));
121
+ expect(await tipsStore.getL2BlockHash(2)).toEqual(blockHashes.get(2));
122
+ expect(await tipsStore.getL2BlockHash(3)).toEqual(blockHashes.get(3));
123
+ });
124
+
125
+ it('checkpoints all proposed blocks', async () => {
126
+ // Propose blocks 1-5
127
+ const blocks = await Promise.all(times(5, i => makeBlock(i + 1)));
128
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks });
129
+
130
+ // Checkpoint all proposed blocks (1-5)
131
+ const checkpoint1 = await makeCheckpoint(1, blocks);
132
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
47
133
 
48
134
  const tips = await tipsStore.getL2Tips();
49
- expect(tips).toEqual(makeTips(10, 8, 5));
135
+ // Proposed and checkpointed should be the same
136
+ expect(tips.proposed).toEqual(makeTip(5));
137
+ expect(tips.checkpointed.block).toEqual(makeTip(5));
138
+ expect(tips.checkpointed.checkpoint.number).toEqual(CheckpointNumber(1));
50
139
  });
51
140
 
52
- it('sets latest tip from blocks added', async () => {
53
- await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: times(3, i => makeBlock(i + 1)) });
141
+ it('advances proven chain with checkpoint info', async () => {
142
+ // Propose and checkpoint blocks 1-5
143
+ const blocks = await Promise.all(times(5, i => makeBlock(i + 1)));
144
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks });
145
+ const checkpoint1 = await makeCheckpoint(1, blocks);
146
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
147
+
148
+ // Prove up to block 5
149
+ await tipsStore.handleBlockStreamEvent({ type: 'chain-proven', block: makeBlockId(5) });
54
150
 
55
151
  const tips = await tipsStore.getL2Tips();
56
- expect(tips).toEqual(makeTips(3, 0, 0));
152
+ expect(tips.proposed).toEqual(makeTip(5));
153
+ expect(tips.checkpointed.block).toEqual(makeTip(5));
154
+ expect(tips.proven.block).toEqual(makeTip(5));
155
+
156
+ // Proven tip should have the checkpoint info
157
+ expect(tips.proven.checkpoint.number).toEqual(CheckpointNumber(1));
158
+ expect(tips.proven.checkpoint.hash).toEqual(checkpointHashes.get(1));
159
+ });
160
+
161
+ it('advances finalized chain with checkpoint info', async () => {
162
+ // Propose and checkpoint blocks 1-5
163
+ const blocks = await Promise.all(times(5, i => makeBlock(i + 1)));
164
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks });
165
+ const checkpoint1 = await makeCheckpoint(1, blocks);
166
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
167
+
168
+ // Prove and finalize
169
+ await tipsStore.handleBlockStreamEvent({ type: 'chain-proven', block: makeBlockId(5) });
170
+ await tipsStore.handleBlockStreamEvent({ type: 'chain-finalized', block: makeBlockId(5) });
171
+
172
+ const tips = await tipsStore.getL2Tips();
173
+ expect(tips.proposed).toEqual(makeTip(5));
174
+ expect(tips.checkpointed.block).toEqual(makeTip(5));
175
+ expect(tips.proven.block).toEqual(makeTip(5));
176
+ expect(tips.finalized.block).toEqual(makeTip(5));
57
177
 
58
- expect(await tipsStore.getL2BlockHash(1)).toEqual(new Fr(1).toString());
59
- expect(await tipsStore.getL2BlockHash(2)).toEqual(new Fr(2).toString());
60
- expect(await tipsStore.getL2BlockHash(3)).toEqual(new Fr(3).toString());
178
+ // Finalized tip should have checkpoint info
179
+ expect(tips.finalized.checkpoint.number).toEqual(CheckpointNumber(1));
180
+ expect(tips.finalized.checkpoint.hash).toEqual(checkpointHashes.get(1));
181
+ });
182
+
183
+ it('handles multiple checkpoints advancing the chain', async () => {
184
+ // Propose blocks 1-5
185
+ const blocks1 = await Promise.all(times(5, i => makeBlock(i + 1)));
186
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: blocks1 });
187
+
188
+ // Checkpoint 1: all proposed blocks 1-5
189
+ const checkpoint1 = await makeCheckpoint(1, blocks1);
190
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
191
+
192
+ // Propose more blocks 6-10
193
+ const blocks2 = await Promise.all(times(5, i => makeBlock(i + 6)));
194
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: blocks2 });
195
+
196
+ // Checkpoint 2: all remaining proposed blocks 6-10
197
+ const checkpoint2 = await makeCheckpoint(2, blocks2);
198
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint2));
199
+
200
+ const tips = await tipsStore.getL2Tips();
201
+ expect(tips.proposed).toEqual(makeTip(10));
202
+ expect(tips.checkpointed.block).toEqual(makeTip(10));
203
+ expect(tips.checkpointed.checkpoint.number).toEqual(CheckpointNumber(2));
204
+ expect(tips.checkpointed.checkpoint.hash).toEqual(checkpointHashes.get(2));
61
205
  });
62
206
 
63
207
  it('clears block hashes when setting finalized chain', async () => {
64
- await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: times(5, i => makeBlock(i + 1)) });
208
+ // Propose blocks 1-3
209
+ const blocks1to3 = await Promise.all(times(3, i => makeBlock(i + 1)));
210
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: blocks1to3 });
211
+
212
+ // Checkpoint all proposed blocks (1-3)
213
+ const checkpoint1 = await makeCheckpoint(1, blocks1to3);
214
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
215
+
216
+ // Propose more blocks 4-5
217
+ const blocks4to5 = await Promise.all(times(2, i => makeBlock(i + 4)));
218
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: blocks4to5 });
219
+
220
+ // Checkpoint all remaining proposed blocks (4-5)
221
+ const checkpoint2 = await makeCheckpoint(2, blocks4to5);
222
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint2));
223
+
224
+ // Prove and finalize up to block 3 (checkpoint 1)
65
225
  await tipsStore.handleBlockStreamEvent({ type: 'chain-proven', block: makeBlockId(3) });
66
226
  await tipsStore.handleBlockStreamEvent({ type: 'chain-finalized', block: makeBlockId(3) });
67
227
 
68
- const tips = await tipsStore.getL2Tips();
69
- expect(tips).toEqual(makeTips(5, 3, 3));
70
-
228
+ // Blocks before finalized should be cleared
71
229
  expect(await tipsStore.getL2BlockHash(1)).toBeUndefined();
72
230
  expect(await tipsStore.getL2BlockHash(2)).toBeUndefined();
73
231
 
74
- expect(await tipsStore.getL2BlockHash(3)).toEqual(new Fr(3).toString());
75
- expect(await tipsStore.getL2BlockHash(4)).toEqual(new Fr(4).toString());
76
- expect(await tipsStore.getL2BlockHash(5)).toEqual(new Fr(5).toString());
232
+ // Finalized and later blocks should remain
233
+ expect(await tipsStore.getL2BlockHash(3)).toEqual(blockHashes.get(3));
234
+ expect(await tipsStore.getL2BlockHash(4)).toEqual(blockHashes.get(4));
235
+ expect(await tipsStore.getL2BlockHash(5)).toEqual(blockHashes.get(5));
236
+ });
237
+
238
+ it('handles chain pruning by updating proposed tip', async () => {
239
+ const blocks = await Promise.all(times(10, i => makeBlock(i + 1)));
240
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks });
241
+
242
+ // Prune to block 5
243
+ await tipsStore.handleBlockStreamEvent({
244
+ type: 'chain-pruned',
245
+ block: makeBlockId(5),
246
+ checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
247
+ });
248
+
249
+ const tips = await tipsStore.getL2Tips();
250
+ expect(tips.proposed).toEqual(makeTip(5));
251
+ });
252
+
253
+ it('handles pruning proposed chain to genesis, re-proposing, and checkpointing', async () => {
254
+ // Propose blocks 1-3
255
+ const firstBlocks = await Promise.all(times(3, i => makeBlock(i + 1)));
256
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: firstBlocks });
257
+
258
+ let tips = await tipsStore.getL2Tips();
259
+ expect(tips.proposed).toEqual(makeTip(3));
260
+
261
+ // Store original hashes
262
+ const originalHash1 = blockHashes.get(1);
263
+ const originalHash2 = blockHashes.get(2);
264
+ const originalHash3 = blockHashes.get(3);
265
+
266
+ // Prune back to genesis (block 0)
267
+ await tipsStore.handleBlockStreamEvent({
268
+ type: 'chain-pruned',
269
+ block: makeTip(0),
270
+ checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
271
+ });
272
+
273
+ tips = await tipsStore.getL2Tips();
274
+ expect(tips.proposed).toEqual(makeTip(0));
275
+ expect(tips.checkpointed.block).toEqual(makeTip(0));
276
+
277
+ // Clear hashes and propose new blocks 1-3 (different from original)
278
+ blockHashes.delete(1);
279
+ blockHashes.delete(2);
280
+ blockHashes.delete(3);
281
+ const newBlocks = await Promise.all(times(3, i => makeBlock(i + 1)));
282
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: newBlocks });
283
+
284
+ // Verify new blocks have different hashes
285
+ expect(blockHashes.get(1)).not.toEqual(originalHash1);
286
+ expect(blockHashes.get(2)).not.toEqual(originalHash2);
287
+ expect(blockHashes.get(3)).not.toEqual(originalHash3);
288
+
289
+ tips = await tipsStore.getL2Tips();
290
+ expect(tips.proposed).toEqual(makeTip(3));
291
+ expect(tips.checkpointed.block).toEqual(makeTip(0)); // Not yet checkpointed
292
+
293
+ // Checkpoint all the new proposed blocks (1-3)
294
+ const checkpoint1 = await makeCheckpoint(1, newBlocks);
295
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
296
+
297
+ tips = await tipsStore.getL2Tips();
298
+ expect(tips.proposed).toEqual(makeTip(3));
299
+ expect(tips.checkpointed.block).toEqual(makeTip(3));
300
+ expect(tips.checkpointed.checkpoint.number).toEqual(CheckpointNumber(1));
301
+
302
+ // Verify block hashes in store are the new ones
303
+ expect(await tipsStore.getL2BlockHash(1)).toEqual(blockHashes.get(1));
304
+ expect(await tipsStore.getL2BlockHash(2)).toEqual(blockHashes.get(2));
305
+ expect(await tipsStore.getL2BlockHash(3)).toEqual(blockHashes.get(3));
306
+ });
307
+
308
+ it('handles reorg: prune proposed blocks back to checkpoint, then re-propose with different blocks', async () => {
309
+ // Propose blocks 1-5
310
+ const firstBlocks = await Promise.all(times(5, i => makeBlock(i + 1)));
311
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: firstBlocks });
312
+
313
+ // Checkpoint all proposed blocks (1-5) - these are now committed
314
+ const checkpoint1 = await makeCheckpoint(1, firstBlocks);
315
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
316
+
317
+ // Propose more blocks 6-10 (not yet checkpointed, can be pruned)
318
+ const originalBlocks6to10 = await Promise.all(times(5, i => makeBlock(i + 6)));
319
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: originalBlocks6to10 });
320
+
321
+ let tips = await tipsStore.getL2Tips();
322
+ expect(tips.proposed).toEqual(makeTip(10));
323
+ expect(tips.checkpointed.block).toEqual(makeTip(5)); // Only blocks 1-5 are checkpointed
324
+
325
+ // Store original hashes for proposed (non-checkpointed) blocks 6-8
326
+ const originalHash6 = blockHashes.get(6);
327
+ const originalHash7 = blockHashes.get(7);
328
+ const originalHash8 = blockHashes.get(8);
329
+
330
+ // Prune proposed blocks back to checkpoint (block 5)
331
+ // This removes proposed blocks 6-10, but checkpoint remains at 5
332
+ await tipsStore.handleBlockStreamEvent({
333
+ type: 'chain-pruned',
334
+ block: makeBlockId(5),
335
+ checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
336
+ });
337
+
338
+ tips = await tipsStore.getL2Tips();
339
+ expect(tips.proposed).toEqual(makeTip(5));
340
+ expect(tips.checkpointed.block).toEqual(makeTip(5)); // Checkpoint unchanged
341
+
342
+ // Propose new blocks 6-8 (different from original 6-10)
343
+ blockHashes.delete(6);
344
+ blockHashes.delete(7);
345
+ blockHashes.delete(8);
346
+ const newBlocks = await Promise.all(times(3, i => makeBlock(i + 6)));
347
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: newBlocks });
348
+
349
+ // Verify the new blocks have different hashes than the original ones
350
+ expect(blockHashes.get(6)).not.toEqual(originalHash6);
351
+ expect(blockHashes.get(7)).not.toEqual(originalHash7);
352
+ expect(blockHashes.get(8)).not.toEqual(originalHash8);
353
+
354
+ tips = await tipsStore.getL2Tips();
355
+ expect(tips.proposed).toEqual(makeTip(8));
356
+ expect(tips.checkpointed.block).toEqual(makeTip(5)); // Still at checkpoint 1
357
+
358
+ // Checkpoint all the new proposed blocks (6-8)
359
+ const checkpoint2 = await makeCheckpoint(2, newBlocks);
360
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint2));
361
+
362
+ tips = await tipsStore.getL2Tips();
363
+ expect(tips.proposed).toEqual(makeTip(8));
364
+ expect(tips.checkpointed.block).toEqual(makeTip(8));
365
+ expect(tips.checkpointed.checkpoint.number).toEqual(CheckpointNumber(2));
366
+
367
+ // Block hashes in the store should reflect the new blocks
368
+ expect(await tipsStore.getL2BlockHash(6)).toEqual(blockHashes.get(6));
369
+ expect(await tipsStore.getL2BlockHash(7)).toEqual(blockHashes.get(7));
370
+ expect(await tipsStore.getL2BlockHash(8)).toEqual(blockHashes.get(8));
371
+
372
+ // And should NOT equal the original hashes
373
+ expect(await tipsStore.getL2BlockHash(6)).not.toEqual(originalHash6);
374
+ expect(await tipsStore.getL2BlockHash(7)).not.toEqual(originalHash7);
375
+ expect(await tipsStore.getL2BlockHash(8)).not.toEqual(originalHash8);
376
+ });
377
+
378
+ it('handles reorg with different chain length after prune', async () => {
379
+ // Propose blocks 1-3
380
+ const firstBlocks = await Promise.all(times(3, i => makeBlock(i + 1)));
381
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: firstBlocks });
382
+
383
+ // Checkpoint all proposed blocks (1-3) - these are now committed
384
+ const checkpoint1 = await makeCheckpoint(1, firstBlocks);
385
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
386
+
387
+ // Propose more blocks 4-10 (not yet checkpointed, can be pruned)
388
+ const originalBlocks4to10 = await Promise.all(times(7, i => makeBlock(i + 4)));
389
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: originalBlocks4to10 });
390
+
391
+ let tips = await tipsStore.getL2Tips();
392
+ expect(tips.proposed).toEqual(makeTip(10));
393
+ expect(tips.checkpointed.block).toEqual(makeTip(3)); // Only blocks 1-3 are checkpointed
394
+
395
+ // Prune proposed blocks back to checkpoint (block 3)
396
+ await tipsStore.handleBlockStreamEvent({
397
+ type: 'chain-pruned',
398
+ block: makeBlockId(3),
399
+ checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
400
+ });
401
+
402
+ tips = await tipsStore.getL2Tips();
403
+ expect(tips.proposed).toEqual(makeTip(3));
404
+ expect(tips.checkpointed.block).toEqual(makeTip(3)); // Checkpoint unchanged
405
+
406
+ // Now propose only 2 new blocks (4-5) instead of the original 7 blocks (4-10)
407
+ blockHashes.delete(4);
408
+ blockHashes.delete(5);
409
+ const newBlocks = await Promise.all(times(2, i => makeBlock(i + 4)));
410
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: newBlocks });
411
+
412
+ tips = await tipsStore.getL2Tips();
413
+ expect(tips.proposed).toEqual(makeTip(5));
414
+ expect(tips.checkpointed.block).toEqual(makeTip(3)); // Still at checkpoint 1
415
+
416
+ // Checkpoint all the new proposed blocks (4-5)
417
+ const checkpoint2 = await makeCheckpoint(2, newBlocks);
418
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint2));
419
+
420
+ tips = await tipsStore.getL2Tips();
421
+ expect(tips.proposed).toEqual(makeTip(5));
422
+ expect(tips.checkpointed.block).toEqual(makeTip(5));
423
+ expect(tips.checkpointed.checkpoint.number).toEqual(CheckpointNumber(2));
424
+ });
425
+
426
+ it('handles reorg: prune back to proven tip (including checkpointed blocks), then re-propose and checkpoint', async () => {
427
+ // Propose blocks 1-3
428
+ const firstBlocks = await Promise.all(times(3, i => makeBlock(i + 1)));
429
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: firstBlocks });
430
+
431
+ // Checkpoint all proposed blocks (1-3)
432
+ const checkpoint1 = await makeCheckpoint(1, firstBlocks);
433
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint1));
434
+
435
+ // Prove up to block 3
436
+ await tipsStore.handleBlockStreamEvent({ type: 'chain-proven', block: makeBlockId(3) });
437
+
438
+ let tips = await tipsStore.getL2Tips();
439
+ expect(tips.proposed).toEqual(makeTip(3));
440
+ expect(tips.checkpointed.block).toEqual(makeTip(3));
441
+ expect(tips.proven.block).toEqual(makeTip(3));
442
+
443
+ // Propose more blocks 4-6
444
+ const blocks4to6 = await Promise.all(times(3, i => makeBlock(i + 4)));
445
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: blocks4to6 });
446
+
447
+ // Checkpoint blocks 4-6 (now checkpointed is ahead of proven)
448
+ const checkpoint2 = await makeCheckpoint(2, blocks4to6);
449
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint2));
450
+
451
+ tips = await tipsStore.getL2Tips();
452
+ expect(tips.proposed).toEqual(makeTip(6));
453
+ expect(tips.checkpointed.block).toEqual(makeTip(6));
454
+ expect(tips.proven.block).toEqual(makeTip(3)); // Proven is behind checkpointed
455
+
456
+ // Propose even more blocks 7-10 (proposed is now ahead of checkpointed)
457
+ const originalBlocks7to10 = await Promise.all(times(4, i => makeBlock(i + 7)));
458
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: originalBlocks7to10 });
459
+
460
+ tips = await tipsStore.getL2Tips();
461
+ // Now all three tips are different: proposed=10, checkpointed=6, proven=3
462
+ expect(tips.proposed).toEqual(makeTip(10));
463
+ expect(tips.checkpointed.block).toEqual(makeTip(6));
464
+ expect(tips.proven.block).toEqual(makeTip(3));
465
+
466
+ // Store original hashes for blocks 4-7
467
+ const originalHash4 = blockHashes.get(4);
468
+ const originalHash5 = blockHashes.get(5);
469
+ const originalHash6 = blockHashes.get(6);
470
+ const originalHash7 = blockHashes.get(7);
471
+
472
+ // Prune all the way back to proven tip (block 3)
473
+ // This prunes both proposed blocks (7-10) AND checkpointed blocks (4-6)
474
+ await tipsStore.handleBlockStreamEvent({
475
+ type: 'chain-pruned',
476
+ block: makeBlockId(3),
477
+ checkpoint: { number: CheckpointNumber.ZERO, hash: GENESIS_CHECKPOINT_HEADER_HASH.toString() },
478
+ });
479
+
480
+ tips = await tipsStore.getL2Tips();
481
+ expect(tips.proposed).toEqual(makeTip(3));
482
+ expect(tips.checkpointed.block).toEqual(makeTip(3)); // Checkpointed also pruned back
483
+ expect(tips.proven.block).toEqual(makeTip(3));
484
+
485
+ // Propose new blocks 4-7 (different from original)
486
+ blockHashes.delete(4);
487
+ blockHashes.delete(5);
488
+ blockHashes.delete(6);
489
+ blockHashes.delete(7);
490
+ const newBlocks = await Promise.all(times(4, i => makeBlock(i + 4)));
491
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: newBlocks });
492
+
493
+ // Verify the new blocks have different hashes than the original ones
494
+ expect(blockHashes.get(4)).not.toEqual(originalHash4);
495
+ expect(blockHashes.get(5)).not.toEqual(originalHash5);
496
+ expect(blockHashes.get(6)).not.toEqual(originalHash6);
497
+ expect(blockHashes.get(7)).not.toEqual(originalHash7);
498
+
499
+ tips = await tipsStore.getL2Tips();
500
+ expect(tips.proposed).toEqual(makeTip(7));
501
+ expect(tips.proven.block).toEqual(makeTip(3));
502
+
503
+ // Checkpoint all the new proposed blocks (4-7)
504
+ const checkpoint3 = await makeCheckpoint(3, newBlocks);
505
+ await tipsStore.handleBlockStreamEvent(await makeCheckpointedEvent(checkpoint3));
506
+
507
+ tips = await tipsStore.getL2Tips();
508
+ expect(tips.proposed).toEqual(makeTip(7));
509
+ expect(tips.checkpointed.block).toEqual(makeTip(7));
510
+ expect(tips.checkpointed.checkpoint.number).toEqual(CheckpointNumber(3));
511
+ expect(tips.proven.block).toEqual(makeTip(3)); // Proven hasn't moved yet
512
+
513
+ // Block hashes in the store should reflect the new blocks
514
+ expect(await tipsStore.getL2BlockHash(4)).toEqual(blockHashes.get(4));
515
+ expect(await tipsStore.getL2BlockHash(5)).toEqual(blockHashes.get(5));
516
+ expect(await tipsStore.getL2BlockHash(6)).toEqual(blockHashes.get(6));
517
+ expect(await tipsStore.getL2BlockHash(7)).toEqual(blockHashes.get(7));
518
+
519
+ // And should NOT equal the original hashes
520
+ expect(await tipsStore.getL2BlockHash(4)).not.toEqual(originalHash4);
521
+ expect(await tipsStore.getL2BlockHash(5)).not.toEqual(originalHash5);
522
+ expect(await tipsStore.getL2BlockHash(6)).not.toEqual(originalHash6);
523
+ expect(await tipsStore.getL2BlockHash(7)).not.toEqual(originalHash7);
77
524
  });
78
525
 
79
526
  // Regression test for #13142
80
527
  it('does not blow up when setting proven chain on an unseen block number', async () => {
81
- await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: [makeBlock(5)] });
528
+ await tipsStore.handleBlockStreamEvent({ type: 'blocks-added', blocks: [await makeBlock(5)] });
82
529
  await tipsStore.handleBlockStreamEvent({ type: 'chain-proven', block: makeBlockId(3) });
83
530
 
84
531
  const tips = await tipsStore.getL2Tips();
85
- expect(tips).toEqual(makeTips(5, 3, 0));
532
+ expect(tips.proposed).toEqual(makeTip(5));
533
+ expect(tips.proven.block).toEqual(makeTip(3));
534
+ // No checkpoint for block 3 since it wasn't checkpointed
535
+ expect(tips.proven.checkpoint.number).toEqual(CheckpointNumber.ZERO);
86
536
  });
87
537
  }