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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (732) hide show
  1. package/dest/abi/contract_artifact.d.ts +2 -2
  2. package/dest/abi/contract_artifact.d.ts.map +1 -1
  3. package/dest/abi/contract_artifact.js +1 -1
  4. package/dest/abi/function_call.d.ts +47 -9
  5. package/dest/abi/function_call.d.ts.map +1 -1
  6. package/dest/abi/function_call.js +20 -3
  7. package/dest/abi/selector.js +3 -1
  8. package/dest/abi/utils.d.ts +7 -1
  9. package/dest/abi/utils.d.ts.map +1 -1
  10. package/dest/abi/utils.js +7 -0
  11. package/dest/auth_witness/auth_witness.d.ts +2 -1
  12. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  13. package/dest/auth_witness/auth_witness.js +3 -3
  14. package/dest/avm/avm.d.ts +62 -62
  15. package/dest/avm/avm_accumulated_data.d.ts +30 -3
  16. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  17. package/dest/avm/avm_accumulated_data.js +5 -2
  18. package/dest/avm/avm_circuit_public_inputs.d.ts +9 -9
  19. package/dest/avm/avm_circuit_public_inputs.js +3 -1
  20. package/dest/avm/avm_proving_request.d.ts +299 -299
  21. package/dest/avm/contract_storage_read.d.ts +13 -1
  22. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  23. package/dest/avm/contract_storage_update_request.d.ts +13 -1
  24. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  25. package/dest/avm/public_call_stack_item_compressed.d.ts +3 -1
  26. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  27. package/dest/avm/public_data_read.d.ts +10 -1
  28. package/dest/avm/public_data_read.d.ts.map +1 -1
  29. package/dest/avm/public_data_update_request.d.ts +10 -1
  30. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  31. package/dest/avm/public_data_update_request.js +3 -1
  32. package/dest/avm/public_data_write.d.ts +7 -1
  33. package/dest/avm/public_data_write.d.ts.map +1 -1
  34. package/dest/avm/public_inner_call_request.d.ts +4 -1
  35. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  36. package/dest/avm/public_inner_call_request.js +3 -1
  37. package/dest/avm/revert_code.d.ts +4 -4
  38. package/dest/avm/revert_code.d.ts.map +1 -1
  39. package/dest/avm/revert_code.js +3 -1
  40. package/dest/aztec-address/index.js +4 -2
  41. package/dest/block/attestation_info.d.ts +5 -5
  42. package/dest/block/attestation_info.d.ts.map +1 -1
  43. package/dest/block/attestation_info.js +4 -4
  44. package/dest/block/block_data.d.ts +52 -0
  45. package/dest/block/block_data.d.ts.map +1 -0
  46. package/dest/block/block_data.js +12 -0
  47. package/dest/block/block_hash.d.ts +18 -14
  48. package/dest/block/block_hash.d.ts.map +1 -1
  49. package/dest/block/block_hash.js +22 -20
  50. package/dest/block/block_parameter.d.ts +4 -3
  51. package/dest/block/block_parameter.d.ts.map +1 -1
  52. package/dest/block/block_parameter.js +2 -0
  53. package/dest/block/body.d.ts +1 -1
  54. package/dest/block/body.d.ts.map +1 -1
  55. package/dest/block/body.js +5 -2
  56. package/dest/block/checkpointed_l2_block.d.ts +20 -137
  57. package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
  58. package/dest/block/checkpointed_l2_block.js +7 -45
  59. package/dest/block/in_block.d.ts +9 -9
  60. package/dest/block/in_block.d.ts.map +1 -1
  61. package/dest/block/in_block.js +5 -5
  62. package/dest/block/index.d.ts +2 -3
  63. package/dest/block/index.d.ts.map +1 -1
  64. package/dest/block/index.js +1 -2
  65. package/dest/block/l2_block.d.ts +57 -57
  66. package/dest/block/l2_block.d.ts.map +1 -1
  67. package/dest/block/l2_block.js +64 -108
  68. package/dest/block/l2_block_source.d.ts +317 -68
  69. package/dest/block/l2_block_source.d.ts.map +1 -1
  70. package/dest/block/l2_block_source.js +25 -6
  71. package/dest/block/l2_block_stream/index.d.ts +2 -1
  72. package/dest/block/l2_block_stream/index.d.ts.map +1 -1
  73. package/dest/block/l2_block_stream/index.js +1 -0
  74. package/dest/block/l2_block_stream/interfaces.d.ts +15 -5
  75. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  76. package/dest/block/l2_block_stream/l2_block_stream.d.ts +8 -3
  77. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  78. package/dest/block/l2_block_stream/l2_block_stream.js +106 -31
  79. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts +24 -16
  80. package/dest/block/l2_block_stream/l2_tips_memory_store.d.ts.map +1 -1
  81. package/dest/block/l2_block_stream/l2_tips_memory_store.js +55 -61
  82. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +49 -0
  83. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -0
  84. package/dest/block/l2_block_stream/l2_tips_store_base.js +179 -0
  85. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  86. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  87. package/dest/block/test/l2_tips_store_test_suite.js +478 -38
  88. package/dest/block/validate_block_result.d.ts +24 -24
  89. package/dest/block/validate_block_result.d.ts.map +1 -1
  90. package/dest/block/validate_block_result.js +18 -17
  91. package/dest/checkpoint/checkpoint.d.ts +43 -19
  92. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  93. package/dest/checkpoint/checkpoint.js +38 -14
  94. package/dest/checkpoint/checkpoint_data.d.ts +120 -0
  95. package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
  96. package/dest/checkpoint/checkpoint_data.js +26 -0
  97. package/dest/checkpoint/checkpoint_info.d.ts +32 -3
  98. package/dest/checkpoint/checkpoint_info.d.ts.map +1 -1
  99. package/dest/checkpoint/checkpoint_info.js +34 -1
  100. package/dest/checkpoint/index.d.ts +3 -1
  101. package/dest/checkpoint/index.d.ts.map +1 -1
  102. package/dest/checkpoint/index.js +2 -0
  103. package/dest/checkpoint/published_checkpoint.d.ts +33 -16
  104. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  105. package/dest/checkpoint/published_checkpoint.js +5 -5
  106. package/dest/config/index.d.ts +2 -1
  107. package/dest/config/index.d.ts.map +1 -1
  108. package/dest/config/index.js +1 -0
  109. package/dest/config/node-rpc-config.js +1 -1
  110. package/dest/config/sequencer-config.d.ts +10 -0
  111. package/dest/config/sequencer-config.d.ts.map +1 -0
  112. package/dest/config/sequencer-config.js +18 -0
  113. package/dest/contract/complete_address.d.ts +4 -1
  114. package/dest/contract/complete_address.d.ts.map +1 -1
  115. package/dest/contract/contract_address.js +4 -4
  116. package/dest/contract/contract_class.d.ts +2 -3
  117. package/dest/contract/contract_class.d.ts.map +1 -1
  118. package/dest/contract/contract_class_id.d.ts +2 -2
  119. package/dest/contract/contract_class_id.d.ts.map +1 -1
  120. package/dest/contract/contract_class_id.js +6 -5
  121. package/dest/contract/contract_deployment_data.d.ts +5 -5
  122. package/dest/contract/index.d.ts +1 -3
  123. package/dest/contract/index.d.ts.map +1 -1
  124. package/dest/contract/index.js +0 -2
  125. package/dest/contract/interfaces/contract_instance.d.ts +16 -16
  126. package/dest/contract/interfaces/node-info.d.ts +3 -1
  127. package/dest/contract/interfaces/node-info.d.ts.map +1 -1
  128. package/dest/contract/interfaces/node-info.js +2 -1
  129. package/dest/contract/private_function.d.ts +1 -1
  130. package/dest/contract/private_function.d.ts.map +1 -1
  131. package/dest/contract/private_function.js +3 -4
  132. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  133. package/dest/contract/private_function_membership_proof.js +1 -1
  134. package/dest/database-version/database_version.d.ts +58 -0
  135. package/dest/database-version/database_version.d.ts.map +1 -0
  136. package/dest/database-version/database_version.js +69 -0
  137. package/dest/database-version/version_manager.d.ts +3 -49
  138. package/dest/database-version/version_manager.d.ts.map +1 -1
  139. package/dest/database-version/version_manager.js +1 -64
  140. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  141. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  142. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  143. package/dest/deserialization/index.d.ts +11 -0
  144. package/dest/deserialization/index.d.ts.map +1 -0
  145. package/dest/deserialization/index.js +10 -0
  146. package/dest/epoch-helpers/index.d.ts +7 -1
  147. package/dest/epoch-helpers/index.d.ts.map +1 -1
  148. package/dest/epoch-helpers/index.js +9 -3
  149. package/dest/errors/proving_error.d.ts +2 -2
  150. package/dest/errors/proving_error.d.ts.map +1 -1
  151. package/dest/file-store/local.d.ts +3 -3
  152. package/dest/file-store/local.d.ts.map +1 -1
  153. package/dest/file-store/local.js +13 -4
  154. package/dest/file-store/s3.d.ts +1 -1
  155. package/dest/file-store/s3.d.ts.map +1 -1
  156. package/dest/file-store/s3.js +11 -3
  157. package/dest/gas/gas.js +3 -1
  158. package/dest/gas/gas_fees.js +3 -1
  159. package/dest/ha-signing/config.d.ts +101 -0
  160. package/dest/ha-signing/config.d.ts.map +1 -0
  161. package/dest/ha-signing/config.js +92 -0
  162. package/dest/ha-signing/index.d.ts +3 -0
  163. package/dest/ha-signing/index.d.ts.map +1 -0
  164. package/dest/ha-signing/index.js +2 -0
  165. package/dest/ha-signing/types.d.ts +85 -0
  166. package/dest/ha-signing/types.d.ts.map +1 -0
  167. package/dest/ha-signing/types.js +32 -0
  168. package/dest/hash/hash.d.ts +2 -1
  169. package/dest/hash/hash.d.ts.map +1 -1
  170. package/dest/hash/hash.js +16 -10
  171. package/dest/hash/map_slot.d.ts +1 -1
  172. package/dest/hash/map_slot.d.ts.map +1 -1
  173. package/dest/hash/map_slot.js +4 -3
  174. package/dest/interfaces/api_limit.d.ts +3 -1
  175. package/dest/interfaces/api_limit.d.ts.map +1 -1
  176. package/dest/interfaces/api_limit.js +2 -0
  177. package/dest/interfaces/archiver.d.ts +6 -6
  178. package/dest/interfaces/archiver.d.ts.map +1 -1
  179. package/dest/interfaces/archiver.js +27 -17
  180. package/dest/interfaces/aztec-node-admin.d.ts +111 -32
  181. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  182. package/dest/interfaces/aztec-node-admin.js +14 -6
  183. package/dest/interfaces/aztec-node.d.ts +75 -77
  184. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  185. package/dest/interfaces/aztec-node.js +15 -16
  186. package/dest/interfaces/block-builder.d.ts +22 -14
  187. package/dest/interfaces/block-builder.d.ts.map +1 -1
  188. package/dest/interfaces/block-builder.js +7 -0
  189. package/dest/interfaces/configs.d.ts +28 -8
  190. package/dest/interfaces/configs.d.ts.map +1 -1
  191. package/dest/interfaces/configs.js +5 -1
  192. package/dest/interfaces/get_logs_response.d.ts +16 -9
  193. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  194. package/dest/interfaces/l2_logs_source.d.ts +14 -5
  195. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  196. package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
  197. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  198. package/dest/interfaces/p2p.d.ts +7 -9
  199. package/dest/interfaces/p2p.d.ts.map +1 -1
  200. package/dest/interfaces/p2p.js +3 -4
  201. package/dest/interfaces/prover-broker.d.ts +16 -1
  202. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  203. package/dest/interfaces/prover-broker.js +4 -1
  204. package/dest/interfaces/prover-client.d.ts +15 -1
  205. package/dest/interfaces/prover-client.d.ts.map +1 -1
  206. package/dest/interfaces/prover-client.js +12 -1
  207. package/dest/interfaces/proving-job.d.ts +52 -52
  208. package/dest/interfaces/proving-job.d.ts.map +1 -1
  209. package/dest/interfaces/proving-job.js +1 -7
  210. package/dest/interfaces/server_circuit_prover.d.ts +4 -3
  211. package/dest/interfaces/server_circuit_prover.d.ts.map +1 -1
  212. package/dest/interfaces/slasher.d.ts +9 -1
  213. package/dest/interfaces/slasher.d.ts.map +1 -1
  214. package/dest/interfaces/slasher.js +2 -0
  215. package/dest/interfaces/tx_provider.d.ts +3 -3
  216. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  217. package/dest/interfaces/validator.d.ts +155 -19
  218. package/dest/interfaces/validator.d.ts.map +1 -1
  219. package/dest/interfaces/validator.js +8 -3
  220. package/dest/kernel/claimed_length_array.js +3 -1
  221. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +6 -5
  222. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  223. package/dest/kernel/hints/build_note_hash_read_request_hints.js +19 -10
  224. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
  225. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  226. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -8
  227. package/dest/kernel/hints/index.d.ts +2 -2
  228. package/dest/kernel/hints/index.js +2 -2
  229. package/dest/kernel/hints/key_validation_hint.d.ts +2 -1
  230. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  231. package/dest/kernel/hints/key_validation_request.d.ts +2 -1
  232. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  233. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  234. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  235. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
  236. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  237. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  238. package/dest/kernel/hints/read_request.d.ts +7 -1
  239. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  240. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  241. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  242. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
  243. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  244. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  245. package/dest/kernel/hints/transient_data_squashing_hint.js +3 -1
  246. package/dest/kernel/log_hash.js +3 -1
  247. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  248. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  249. package/dest/kernel/private_call_data.d.ts +25 -1
  250. package/dest/kernel/private_call_data.d.ts.map +1 -1
  251. package/dest/kernel/private_call_request.d.ts +16 -1
  252. package/dest/kernel/private_call_request.d.ts.map +1 -1
  253. package/dest/kernel/private_circuit_public_inputs.d.ts +81 -8
  254. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  255. package/dest/kernel/private_circuit_public_inputs.js +16 -16
  256. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +33 -3
  257. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  258. package/dest/kernel/private_kernel_circuit_public_inputs.js +4 -4
  259. package/dest/kernel/private_kernel_data.d.ts +7 -1
  260. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  261. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
  262. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  263. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  264. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  265. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  266. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  267. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +12 -3
  268. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  269. package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
  270. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +25 -3
  271. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  272. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +7 -7
  273. package/dest/kernel/private_log_data.js +5 -2
  274. package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
  275. package/dest/kernel/private_to_avm_accumulated_data.js +5 -2
  276. package/dest/kernel/private_to_public_accumulated_data.js +3 -1
  277. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +3 -3
  278. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  279. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +7 -7
  280. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
  281. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  282. package/dest/kernel/private_to_rollup_accumulated_data.js +3 -1
  283. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +18 -3
  284. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  285. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +7 -7
  286. package/dest/kernel/private_validation_requests.d.ts +13 -4
  287. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  288. package/dest/kernel/private_validation_requests.js +12 -10
  289. package/dest/kernel/public_call_request.d.ts +22 -1
  290. package/dest/kernel/public_call_request.d.ts.map +1 -1
  291. package/dest/kernel/public_call_request.js +5 -2
  292. package/dest/kernel/utils/optional_number.d.ts +7 -1
  293. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  294. package/dest/keys/derivation.d.ts +3 -3
  295. package/dest/keys/derivation.js +15 -15
  296. package/dest/keys/key_types.d.ts +3 -3
  297. package/dest/keys/key_types.d.ts.map +1 -1
  298. package/dest/keys/public_keys.d.ts +5 -1
  299. package/dest/keys/public_keys.d.ts.map +1 -1
  300. package/dest/keys/public_keys.js +2 -2
  301. package/dest/keys/utils.d.ts +1 -1
  302. package/dest/keys/utils.d.ts.map +1 -1
  303. package/dest/keys/utils.js +8 -4
  304. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  305. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  306. package/dest/l1-contracts/slash_factory.js +1 -0
  307. package/dest/logs/contract_class_log.js +3 -1
  308. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  309. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  310. package/dest/logs/extended_public_log.d.ts +17 -9
  311. package/dest/logs/extended_public_log.d.ts.map +1 -1
  312. package/dest/logs/log_id.d.ts +21 -14
  313. package/dest/logs/log_id.d.ts.map +1 -1
  314. package/dest/logs/log_id.js +20 -17
  315. package/dest/logs/private_log.d.ts +2 -2
  316. package/dest/logs/private_log.d.ts.map +1 -1
  317. package/dest/logs/private_log.js +3 -1
  318. package/dest/logs/public_log.js +3 -1
  319. package/dest/logs/siloed_tag.d.ts +1 -1
  320. package/dest/logs/siloed_tag.d.ts.map +1 -1
  321. package/dest/logs/siloed_tag.js +2 -5
  322. package/dest/messaging/in_hash.d.ts +4 -2
  323. package/dest/messaging/in_hash.d.ts.map +1 -1
  324. package/dest/messaging/in_hash.js +3 -1
  325. package/dest/messaging/inbox_leaf.d.ts +3 -1
  326. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  327. package/dest/messaging/l1_actor.d.ts +7 -1
  328. package/dest/messaging/l1_actor.d.ts.map +1 -1
  329. package/dest/messaging/l1_to_l2_message.d.ts +6 -1
  330. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  331. package/dest/messaging/l2_actor.d.ts +7 -1
  332. package/dest/messaging/l2_actor.d.ts.map +1 -1
  333. package/dest/messaging/l2_to_l1_membership.d.ts +88 -6
  334. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  335. package/dest/messaging/l2_to_l1_membership.js +160 -42
  336. package/dest/messaging/out_hash.d.ts +41 -3
  337. package/dest/messaging/out_hash.d.ts.map +1 -1
  338. package/dest/messaging/out_hash.js +54 -19
  339. package/dest/note/index.d.ts +1 -2
  340. package/dest/note/index.d.ts.map +1 -1
  341. package/dest/note/index.js +0 -1
  342. package/dest/note/note_dao.d.ts +36 -5
  343. package/dest/note/note_dao.d.ts.map +1 -1
  344. package/dest/note/note_dao.js +15 -12
  345. package/dest/p2p/attestation_utils.d.ts +3 -3
  346. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  347. package/dest/p2p/attestation_utils.js +1 -1
  348. package/dest/p2p/block_proposal.d.ts +102 -23
  349. package/dest/p2p/block_proposal.d.ts.map +1 -1
  350. package/dest/p2p/block_proposal.js +138 -39
  351. package/dest/p2p/checkpoint_attestation.d.ts +82 -0
  352. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -0
  353. package/dest/p2p/{block_attestation.js → checkpoint_attestation.js} +22 -19
  354. package/dest/p2p/checkpoint_proposal.d.ts +179 -0
  355. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -0
  356. package/dest/p2p/checkpoint_proposal.js +243 -0
  357. package/dest/p2p/consensus_payload.d.ts +20 -11
  358. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  359. package/dest/p2p/consensus_payload.js +24 -19
  360. package/dest/p2p/constants.d.ts +5 -0
  361. package/dest/p2p/constants.d.ts.map +1 -0
  362. package/dest/p2p/constants.js +3 -0
  363. package/dest/p2p/gossipable.d.ts +4 -3
  364. package/dest/p2p/gossipable.d.ts.map +1 -1
  365. package/dest/p2p/gossipable.js +16 -5
  366. package/dest/p2p/index.d.ts +5 -2
  367. package/dest/p2p/index.d.ts.map +1 -1
  368. package/dest/p2p/index.js +4 -1
  369. package/dest/p2p/message_validator.d.ts +18 -3
  370. package/dest/p2p/message_validator.d.ts.map +1 -1
  371. package/dest/p2p/message_validator.js +2 -1
  372. package/dest/p2p/signature_utils.d.ts +5 -3
  373. package/dest/p2p/signature_utils.d.ts.map +1 -1
  374. package/dest/p2p/signature_utils.js +3 -1
  375. package/dest/p2p/signed_txs.d.ts +42 -0
  376. package/dest/p2p/signed_txs.d.ts.map +1 -0
  377. package/dest/p2p/signed_txs.js +75 -0
  378. package/dest/p2p/topic_type.d.ts +3 -2
  379. package/dest/p2p/topic_type.d.ts.map +1 -1
  380. package/dest/p2p/topic_type.js +10 -3
  381. package/dest/parity/parity_base_private_inputs.d.ts +3 -1
  382. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  383. package/dest/parity/parity_public_inputs.d.ts +4 -1
  384. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  385. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  386. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  387. package/dest/proofs/chonk_proof.d.ts +1 -1
  388. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  389. package/dest/proofs/chonk_proof.js +9 -4
  390. package/dest/proofs/proof.d.ts +4 -1
  391. package/dest/proofs/proof.d.ts.map +1 -1
  392. package/dest/proofs/recursive_proof.d.ts +10 -1
  393. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  394. package/dest/rollup/base_rollup_hints.d.ts +34 -1
  395. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  396. package/dest/rollup/block_constant_data.d.ts +12 -1
  397. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  398. package/dest/rollup/block_headers_hash.js +1 -1
  399. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  400. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  401. package/dest/rollup/block_rollup_public_inputs.d.ts +47 -11
  402. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  403. package/dest/rollup/block_rollup_public_inputs.js +8 -12
  404. package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
  405. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  406. package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
  407. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  408. package/dest/rollup/checkpoint_constant_data.js +3 -1
  409. package/dest/rollup/checkpoint_header.d.ts +43 -13
  410. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  411. package/dest/rollup/checkpoint_header.js +50 -20
  412. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  413. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  414. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +46 -6
  415. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  416. package/dest/rollup/checkpoint_rollup_public_inputs.js +11 -3
  417. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
  418. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  419. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
  420. package/dest/rollup/epoch_constant_data.d.ts +16 -1
  421. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  422. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  423. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  424. package/dest/rollup/root_rollup_public_inputs.d.ts +21 -6
  425. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  426. package/dest/rollup/root_rollup_public_inputs.js +10 -4
  427. package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
  428. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  429. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  430. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  431. package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
  432. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  433. package/dest/schemas/schemas.d.ts +1 -1
  434. package/dest/slashing/empire.d.ts +1 -1
  435. package/dest/slashing/empire.d.ts.map +1 -1
  436. package/dest/slashing/empire.js +2 -0
  437. package/dest/slashing/helpers.d.ts +2 -2
  438. package/dest/slashing/helpers.d.ts.map +1 -1
  439. package/dest/slashing/helpers.js +6 -0
  440. package/dest/slashing/tally.d.ts +2 -1
  441. package/dest/slashing/tally.d.ts.map +1 -1
  442. package/dest/slashing/tally.js +6 -2
  443. package/dest/slashing/types.d.ts +7 -3
  444. package/dest/slashing/types.d.ts.map +1 -1
  445. package/dest/slashing/types.js +13 -1
  446. package/dest/stats/stats.d.ts +1 -3
  447. package/dest/stats/stats.d.ts.map +1 -1
  448. package/dest/tests/factories.d.ts +16 -10
  449. package/dest/tests/factories.d.ts.map +1 -1
  450. package/dest/tests/factories.js +71 -36
  451. package/dest/tests/jest.js +1 -1
  452. package/dest/tests/mocks.d.ts +77 -19
  453. package/dest/tests/mocks.d.ts.map +1 -1
  454. package/dest/tests/mocks.js +133 -62
  455. package/dest/timetable/index.d.ts +37 -0
  456. package/dest/timetable/index.d.ts.map +1 -0
  457. package/dest/timetable/index.js +39 -0
  458. package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
  459. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  460. package/dest/trees/append_only_tree_snapshot.js +3 -1
  461. package/dest/trees/nullifier_leaf.d.ts +13 -1
  462. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  463. package/dest/trees/nullifier_membership_witness.d.ts +10 -1
  464. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  465. package/dest/trees/public_data_leaf.d.ts +17 -1
  466. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  467. package/dest/trees/public_data_leaf.js +7 -6
  468. package/dest/trees/public_data_witness.d.ts +11 -1
  469. package/dest/trees/public_data_witness.d.ts.map +1 -1
  470. package/dest/tx/block_header.d.ts +14 -2
  471. package/dest/tx/block_header.d.ts.map +1 -1
  472. package/dest/tx/block_header.js +9 -3
  473. package/dest/tx/call_context.d.ts +13 -1
  474. package/dest/tx/call_context.d.ts.map +1 -1
  475. package/dest/tx/call_context.js +3 -1
  476. package/dest/tx/capsule.d.ts +4 -1
  477. package/dest/tx/capsule.d.ts.map +1 -1
  478. package/dest/tx/execution_payload.d.ts +9 -1
  479. package/dest/tx/execution_payload.d.ts.map +1 -1
  480. package/dest/tx/function_data.d.ts +4 -2
  481. package/dest/tx/function_data.d.ts.map +1 -1
  482. package/dest/tx/global_variable_builder.d.ts +2 -2
  483. package/dest/tx/global_variable_builder.d.ts.map +1 -1
  484. package/dest/tx/global_variables.d.ts +12 -4
  485. package/dest/tx/global_variables.d.ts.map +1 -1
  486. package/dest/tx/global_variables.js +3 -1
  487. package/dest/tx/hashed_values.d.ts +7 -1
  488. package/dest/tx/hashed_values.d.ts.map +1 -1
  489. package/dest/tx/in_tx.d.ts +4 -4
  490. package/dest/tx/index.d.ts +1 -2
  491. package/dest/tx/index.d.ts.map +1 -1
  492. package/dest/tx/index.js +0 -1
  493. package/dest/tx/indexed_tx_effect.d.ts +5 -5
  494. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  495. package/dest/tx/indexed_tx_effect.js +3 -2
  496. package/dest/tx/partial_state_reference.d.ts +4 -1
  497. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  498. package/dest/tx/private_execution_result.d.ts +23 -6
  499. package/dest/tx/private_execution_result.d.ts.map +1 -1
  500. package/dest/tx/private_execution_result.js +4 -21
  501. package/dest/tx/private_tx_constant_data.d.ts +16 -1
  502. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  503. package/dest/tx/profiling.d.ts +152 -29
  504. package/dest/tx/profiling.d.ts.map +1 -1
  505. package/dest/tx/profiling.js +47 -10
  506. package/dest/tx/protocol_contracts.d.ts +2 -2
  507. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  508. package/dest/tx/protocol_contracts.js +2 -2
  509. package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
  510. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  511. package/dest/tx/public_call_request_with_calldata.js +3 -1
  512. package/dest/tx/public_simulation_output.d.ts +4 -2
  513. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  514. package/dest/tx/public_simulation_output.js +7 -3
  515. package/dest/tx/state_reference.d.ts +3 -1
  516. package/dest/tx/state_reference.d.ts.map +1 -1
  517. package/dest/tx/state_reference.js +3 -1
  518. package/dest/tx/tree_snapshots.js +3 -1
  519. package/dest/tx/tx.d.ts +24 -1
  520. package/dest/tx/tx.d.ts.map +1 -1
  521. package/dest/tx/tx.js +9 -4
  522. package/dest/tx/tx_context.d.ts +2 -1
  523. package/dest/tx/tx_context.d.ts.map +1 -1
  524. package/dest/tx/tx_effect.d.ts +32 -6
  525. package/dest/tx/tx_effect.d.ts.map +1 -1
  526. package/dest/tx/tx_effect.js +3 -8
  527. package/dest/tx/tx_execution_request.d.ts +30 -1
  528. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  529. package/dest/tx/tx_execution_request.js +6 -2
  530. package/dest/tx/tx_hash.d.ts +2 -1
  531. package/dest/tx/tx_hash.d.ts.map +1 -1
  532. package/dest/tx/tx_receipt.d.ts +47 -13
  533. package/dest/tx/tx_receipt.d.ts.map +1 -1
  534. package/dest/tx/tx_receipt.js +46 -15
  535. package/dest/tx/tx_request.d.ts +6 -1
  536. package/dest/tx/tx_request.d.ts.map +1 -1
  537. package/dest/tx/tx_request.js +2 -2
  538. package/dest/tx/validator/empty_validator.d.ts +2 -2
  539. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  540. package/dest/tx/validator/error_texts.d.ts +3 -2
  541. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  542. package/dest/tx/validator/error_texts.js +3 -1
  543. package/dest/tx/validator/tx_validator.d.ts +2 -2
  544. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  545. package/dest/types/shared.d.ts +4 -1
  546. package/dest/types/shared.d.ts.map +1 -1
  547. package/dest/validators/schemas.d.ts +38 -38
  548. package/dest/validators/schemas.d.ts.map +1 -1
  549. package/dest/validators/schemas.js +4 -3
  550. package/dest/validators/types.d.ts +3 -3
  551. package/dest/validators/types.d.ts.map +1 -1
  552. package/dest/vks/verification_key.d.ts +22 -1
  553. package/dest/vks/verification_key.d.ts.map +1 -1
  554. package/dest/vks/vk_data.d.ts +7 -1
  555. package/dest/vks/vk_data.d.ts.map +1 -1
  556. package/dest/zkpassport/index.d.ts +3 -4
  557. package/dest/zkpassport/index.d.ts.map +1 -1
  558. package/dest/zkpassport/index.js +9 -9
  559. package/package.json +27 -13
  560. package/src/abi/contract_artifact.ts +10 -10
  561. package/src/abi/function_call.ts +25 -3
  562. package/src/abi/utils.ts +17 -0
  563. package/src/auth_witness/auth_witness.ts +3 -3
  564. package/src/block/attestation_info.ts +9 -6
  565. package/src/block/block_data.ts +26 -0
  566. package/src/block/block_hash.ts +26 -25
  567. package/src/block/block_parameter.ts +4 -2
  568. package/src/block/body.ts +2 -1
  569. package/src/block/checkpointed_l2_block.ts +8 -58
  570. package/src/block/in_block.ts +6 -6
  571. package/src/block/index.ts +1 -2
  572. package/src/block/l2_block.ts +102 -149
  573. package/src/block/l2_block_source.ts +145 -44
  574. package/src/block/l2_block_stream/index.ts +1 -0
  575. package/src/block/l2_block_stream/interfaces.ts +15 -4
  576. package/src/block/l2_block_stream/l2_block_stream.ts +130 -39
  577. package/src/block/l2_block_stream/l2_tips_memory_store.ts +62 -56
  578. package/src/block/l2_block_stream/l2_tips_store_base.ts +226 -0
  579. package/src/block/test/l2_tips_store_test_suite.ts +480 -36
  580. package/src/block/validate_block_result.ts +40 -35
  581. package/src/checkpoint/checkpoint.ts +62 -21
  582. package/src/checkpoint/checkpoint_data.ts +51 -0
  583. package/src/checkpoint/checkpoint_info.ts +45 -2
  584. package/src/checkpoint/index.ts +2 -0
  585. package/src/checkpoint/published_checkpoint.ts +7 -4
  586. package/src/config/index.ts +1 -0
  587. package/src/config/node-rpc-config.ts +1 -1
  588. package/src/config/sequencer-config.ts +29 -0
  589. package/src/contract/contract_address.ts +4 -4
  590. package/src/contract/contract_class.ts +3 -3
  591. package/src/contract/contract_class_id.ts +6 -5
  592. package/src/contract/index.ts +0 -2
  593. package/src/contract/interfaces/node-info.ts +3 -0
  594. package/src/contract/private_function.ts +3 -4
  595. package/src/contract/private_function_membership_proof.ts +1 -1
  596. package/src/database-version/database_version.ts +87 -0
  597. package/src/database-version/version_manager.ts +1 -77
  598. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  599. package/src/deserialization/index.ts +21 -0
  600. package/src/epoch-helpers/index.ts +13 -1
  601. package/src/file-store/local.ts +15 -5
  602. package/src/file-store/s3.ts +12 -3
  603. package/src/ha-signing/config.ts +149 -0
  604. package/src/ha-signing/index.ts +18 -0
  605. package/src/ha-signing/types.ts +112 -0
  606. package/src/hash/hash.ts +14 -10
  607. package/src/hash/map_slot.ts +3 -2
  608. package/src/interfaces/api_limit.ts +2 -0
  609. package/src/interfaces/archiver.ts +31 -24
  610. package/src/interfaces/aztec-node-admin.ts +31 -4
  611. package/src/interfaces/aztec-node.ts +110 -129
  612. package/src/interfaces/block-builder.ts +41 -23
  613. package/src/interfaces/configs.ts +15 -1
  614. package/src/interfaces/l2_logs_source.ts +17 -4
  615. package/src/interfaces/merkle_tree_operations.ts +1 -1
  616. package/src/interfaces/p2p.ts +8 -12
  617. package/src/interfaces/prover-broker.ts +22 -0
  618. package/src/interfaces/prover-client.ts +22 -0
  619. package/src/interfaces/proving-job.ts +2 -11
  620. package/src/interfaces/server_circuit_prover.ts +3 -2
  621. package/src/interfaces/slasher.ts +4 -0
  622. package/src/interfaces/tx_provider.ts +2 -2
  623. package/src/interfaces/validator.ts +73 -15
  624. package/src/kernel/hints/build_note_hash_read_request_hints.ts +20 -12
  625. package/src/kernel/hints/build_nullifier_read_request_hints.ts +17 -14
  626. package/src/kernel/hints/index.ts +2 -2
  627. package/src/kernel/hints/{key_validation_request_and_generator.ts → key_validation_request_and_separator.ts} +12 -15
  628. package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +10 -10
  629. package/src/kernel/private_circuit_public_inputs.ts +14 -14
  630. package/src/kernel/private_kernel_circuit_public_inputs.ts +2 -2
  631. package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +2 -2
  632. package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +5 -5
  633. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +5 -5
  634. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +5 -5
  635. package/src/kernel/private_validation_requests.ts +8 -8
  636. package/src/keys/derivation.ts +15 -15
  637. package/src/keys/key_types.ts +6 -2
  638. package/src/keys/public_keys.ts +2 -2
  639. package/src/keys/utils.ts +8 -4
  640. package/src/l1-contracts/slash_factory.ts +1 -0
  641. package/src/logs/log_id.ts +22 -18
  642. package/src/logs/siloed_tag.ts +2 -2
  643. package/src/messaging/in_hash.ts +3 -1
  644. package/src/messaging/l2_to_l1_membership.ts +178 -52
  645. package/src/messaging/out_hash.ts +62 -21
  646. package/src/note/index.ts +0 -1
  647. package/src/note/note_dao.ts +18 -13
  648. package/src/p2p/attestation_utils.ts +3 -3
  649. package/src/p2p/block_proposal.ts +211 -46
  650. package/src/p2p/{block_attestation.ts → checkpoint_attestation.ts} +36 -25
  651. package/src/p2p/checkpoint_proposal.ts +387 -0
  652. package/src/p2p/consensus_payload.ts +29 -18
  653. package/src/p2p/constants.ts +6 -0
  654. package/src/p2p/gossipable.ts +14 -4
  655. package/src/p2p/index.ts +4 -1
  656. package/src/p2p/message_validator.ts +14 -2
  657. package/src/p2p/signature_utils.ts +3 -1
  658. package/src/p2p/signed_txs.ts +88 -0
  659. package/src/p2p/topic_type.ts +4 -3
  660. package/src/proofs/chonk_proof.ts +9 -5
  661. package/src/rollup/block_headers_hash.ts +1 -1
  662. package/src/rollup/block_rollup_public_inputs.ts +5 -11
  663. package/src/rollup/checkpoint_header.ts +64 -21
  664. package/src/rollup/checkpoint_rollup_public_inputs.ts +17 -5
  665. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
  666. package/src/rollup/root_rollup_public_inputs.ts +16 -7
  667. package/src/slashing/empire.ts +3 -1
  668. package/src/slashing/helpers.ts +8 -0
  669. package/src/slashing/tally.ts +8 -2
  670. package/src/slashing/types.ts +14 -0
  671. package/src/stats/stats.ts +0 -2
  672. package/src/tests/factories.ts +70 -54
  673. package/src/tests/jest.ts +1 -1
  674. package/src/tests/mocks.ts +228 -95
  675. package/src/timetable/index.ts +66 -0
  676. package/src/trees/public_data_leaf.ts +11 -5
  677. package/src/tx/block_header.ts +12 -4
  678. package/src/tx/global_variable_builder.ts +1 -1
  679. package/src/tx/global_variables.ts +3 -3
  680. package/src/tx/index.ts +0 -1
  681. package/src/tx/indexed_tx_effect.ts +3 -2
  682. package/src/tx/private_execution_result.ts +1 -16
  683. package/src/tx/profiling.ts +51 -9
  684. package/src/tx/protocol_contracts.ts +2 -2
  685. package/src/tx/public_simulation_output.ts +4 -0
  686. package/src/tx/tx.ts +10 -9
  687. package/src/tx/tx_effect.ts +0 -9
  688. package/src/tx/tx_execution_request.ts +2 -0
  689. package/src/tx/tx_receipt.ts +75 -18
  690. package/src/tx/tx_request.ts +2 -2
  691. package/src/tx/validator/empty_validator.ts +1 -1
  692. package/src/tx/validator/error_texts.ts +4 -1
  693. package/src/tx/validator/tx_validator.ts +1 -1
  694. package/src/validators/schemas.ts +8 -1
  695. package/src/validators/types.ts +5 -4
  696. package/src/zkpassport/index.ts +11 -12
  697. package/dest/block/l2_block_code_to_purge.d.ts +0 -12
  698. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  699. package/dest/block/l2_block_code_to_purge.js +0 -61
  700. package/dest/block/l2_block_header.d.ts +0 -98
  701. package/dest/block/l2_block_header.d.ts.map +0 -1
  702. package/dest/block/l2_block_header.js +0 -153
  703. package/dest/block/l2_block_new.d.ts +0 -135
  704. package/dest/block/l2_block_new.d.ts.map +0 -1
  705. package/dest/block/l2_block_new.js +0 -152
  706. package/dest/contract/contract_class_metadata.d.ts +0 -8
  707. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  708. package/dest/contract/contract_class_metadata.js +0 -1
  709. package/dest/contract/contract_metadata.d.ts +0 -7
  710. package/dest/contract/contract_metadata.d.ts.map +0 -1
  711. package/dest/contract/contract_metadata.js +0 -1
  712. package/dest/database-version/index.d.ts +0 -2
  713. package/dest/database-version/index.d.ts.map +0 -1
  714. package/dest/database-version/index.js +0 -1
  715. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -25
  716. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  717. package/dest/note/notes_filter.d.ts +0 -27
  718. package/dest/note/notes_filter.d.ts.map +0 -1
  719. package/dest/note/notes_filter.js +0 -11
  720. package/dest/p2p/block_attestation.d.ts +0 -80
  721. package/dest/p2p/block_attestation.d.ts.map +0 -1
  722. package/dest/tx/content_commitment.d.ts +0 -49
  723. package/dest/tx/content_commitment.d.ts.map +0 -1
  724. package/dest/tx/content_commitment.js +0 -90
  725. package/src/block/l2_block_code_to_purge.ts +0 -88
  726. package/src/block/l2_block_header.ts +0 -246
  727. package/src/block/l2_block_new.ts +0 -207
  728. package/src/contract/contract_class_metadata.ts +0 -8
  729. package/src/contract/contract_metadata.ts +0 -7
  730. package/src/database-version/index.ts +0 -1
  731. package/src/note/notes_filter.ts +0 -38
  732. package/src/tx/content_commitment.ts +0 -113
@@ -2,7 +2,7 @@ import type { SlotNumber } from '@aztec/foundation/branded-types';
2
2
 
3
3
  import { z } from 'zod';
4
4
 
5
- import { BlockAttestation } from '../p2p/block_attestation.js';
5
+ import { CheckpointAttestation } from '../p2p/checkpoint_attestation.js';
6
6
  import type { P2PClientType } from '../p2p/client_type.js';
7
7
  import { type ApiSchemaFor, optional, schemas } from '../schemas/index.js';
8
8
  import { Tx } from '../tx/tx.js';
@@ -52,21 +52,18 @@ export interface P2PApiWithoutAttestations {
52
52
 
53
53
  export interface P2PApiWithAttestations extends P2PApiWithoutAttestations {
54
54
  /**
55
- * Queries the Attestation pool for attestations for the given slot
55
+ * Queries the Attestation pool for checkpoint attestations for the given slot
56
56
  *
57
57
  * @param slot - the slot to query
58
58
  * @param proposalId - the proposal id to query, or undefined to query all proposals for the slot
59
- * @returns BlockAttestations
59
+ * @returns CheckpointAttestations
60
60
  */
61
- getAttestationsForSlot(slot: SlotNumber, proposalId?: string): Promise<BlockAttestation[]>;
62
-
63
- /** Deletes a given attestation manually from the p2p client attestation pool. */
64
- deleteAttestation(attestation: BlockAttestation): Promise<void>;
61
+ getCheckpointAttestationsForSlot(slot: SlotNumber, proposalId?: string): Promise<CheckpointAttestation[]>;
65
62
  }
66
63
 
67
64
  export interface P2PClient extends P2PApiWithAttestations {
68
- /** Manually adds an attestation to the p2p client attestation pool. */
69
- addAttestations(attestations: BlockAttestation[]): Promise<void>;
65
+ /** Manually adds checkpoint attestations to the p2p client attestation pool. */
66
+ addOwnCheckpointAttestations(attestations: CheckpointAttestation[]): Promise<void>;
70
67
  }
71
68
 
72
69
  export type P2PApi<T extends P2PClientType = P2PClientType.Full> = T extends P2PClientType.Full
@@ -78,10 +75,10 @@ export type P2PApiFull<T extends P2PClientType = P2PClientType.Full> = T extends
78
75
  : P2PApiWithoutAttestations;
79
76
 
80
77
  export const P2PApiSchema: ApiSchemaFor<P2PApi> = {
81
- getAttestationsForSlot: z
78
+ getCheckpointAttestationsForSlot: z
82
79
  .function()
83
80
  .args(schemas.SlotNumber, optional(z.string()))
84
- .returns(z.array(BlockAttestation.schema)),
81
+ .returns(z.array(CheckpointAttestation.schema)),
85
82
  getPendingTxs: z
86
83
  .function()
87
84
  .args(optional(z.number().gte(1).lte(MAX_RPC_TXS_LEN).default(MAX_RPC_TXS_LEN)), optional(TxHash.schema))
@@ -90,5 +87,4 @@ export const P2PApiSchema: ApiSchemaFor<P2PApi> = {
90
87
  getPendingTxCount: z.function().returns(schemas.Integer),
91
88
  getEncodedEnr: z.function().returns(z.string().optional()),
92
89
  getPeers: z.function().args(optional(z.boolean())).returns(z.array(PeerInfoSchema)),
93
- deleteAttestation: z.function().args(BlockAttestation.schema).returns(z.void()),
94
90
  };
@@ -1,3 +1,5 @@
1
+ import type { EpochNumber } from '@aztec/foundation/branded-types';
2
+
1
3
  import type { ProvingRequestType } from '../proofs/proving_request_type.js';
2
4
  import type { ProofUri, ProvingJob, ProvingJobId, ProvingJobStatus } from './proving-job.js';
3
5
 
@@ -88,3 +90,23 @@ export interface ProvingJobConsumer {
88
90
  }
89
91
 
90
92
  export interface ProvingJobBroker extends ProvingJobProducer, ProvingJobConsumer {}
93
+
94
+ /**
95
+ * Debug interface for replaying proving jobs from stored inputs.
96
+ * Used for benchmarking different agent configurations against the same workload.
97
+ */
98
+ export interface ProvingJobBrokerDebug {
99
+ /**
100
+ * Replays a proving job by re-enqueuing it with inputs from the configured proof store.
101
+ * The proof type is parsed from the job ID (format: epoch:typeName:hash).
102
+ * @param jobId - The original job ID to replay
103
+ * @param epochNumber - The epoch number to assign
104
+ * @param inputsUri - The proof inputs location
105
+ */
106
+ replayProvingJob(
107
+ jobId: ProvingJobId,
108
+ type: ProvingRequestType,
109
+ epochNumber: EpochNumber,
110
+ inputsUri: ProofUri,
111
+ ): Promise<ProvingJobStatus>;
112
+ }
@@ -17,6 +17,12 @@ export type ActualProverConfig = {
17
17
  proverTestDelayMs: number;
18
18
  /** If using realistic delays, what percentage of realistic times to apply. */
19
19
  proverTestDelayFactor: number;
20
+ /**
21
+ * Whether to abort pending proving jobs when the orchestrator is cancelled.
22
+ * When false (default), jobs remain in the broker queue and can be reused on restart/reorg.
23
+ * When true, jobs are explicitly cancelled with the broker, which prevents reuse.
24
+ */
25
+ cancelJobsOnStop: boolean;
20
26
  };
21
27
 
22
28
  /**
@@ -29,6 +35,8 @@ export type ProverConfig = ActualProverConfig & {
29
35
  proverId?: EthAddress;
30
36
  /** Number of proving agents to start within the prover. */
31
37
  proverAgentCount: number;
38
+ /** Where to store proving request. Must be accessible to both prover node and agents. If not set will inline-encode the parameters */
39
+ proofStore?: string;
32
40
  /** Store for failed proof inputs. */
33
41
  failedProofStore?: string;
34
42
  };
@@ -42,7 +50,9 @@ export const ProverConfigSchema = zodFor<ProverConfig>()(
42
50
  proverTestDelayMs: z.number(),
43
51
  proverTestDelayFactor: z.number(),
44
52
  proverAgentCount: z.number(),
53
+ proofStore: z.string().optional(),
45
54
  failedProofStore: z.string().optional(),
55
+ cancelJobsOnStop: z.boolean(),
46
56
  }),
47
57
  );
48
58
 
@@ -80,11 +90,23 @@ export const proverConfigMappings: ConfigMappingsType<ProverConfig> = {
80
90
  description: 'The number of prover agents to start',
81
91
  ...numberConfigHelper(1),
82
92
  },
93
+ proofStore: {
94
+ env: 'PROVER_PROOF_STORE',
95
+ description: 'Optional proof input store for the prover',
96
+ },
83
97
  failedProofStore: {
84
98
  env: 'PROVER_FAILED_PROOF_STORE',
85
99
  description:
86
100
  'Store for failed proof inputs. Google cloud storage is only supported at the moment. Set this value as gs://bucket-name/path/to/store.',
87
101
  },
102
+ cancelJobsOnStop: {
103
+ env: 'PROVER_CANCEL_JOBS_ON_STOP',
104
+ description:
105
+ 'Whether to abort pending proving jobs when the orchestrator is cancelled. ' +
106
+ 'When false (default), jobs remain in the broker queue and can be reused on restart/reorg. ' +
107
+ 'When true, jobs are explicitly cancelled with the broker, which prevents reuse.',
108
+ ...booleanConfigHelper(false),
109
+ },
88
110
  };
89
111
 
90
112
  function parseProverId(str?: string) {
@@ -47,15 +47,6 @@ export type ProofAndVerificationKey<N extends number> = {
47
47
  verificationKey: VerificationKeyData;
48
48
  };
49
49
 
50
- function schemaForRecursiveProofAndVerificationKey<N extends number>(
51
- proofLength: N,
52
- ): ZodFor<ProofAndVerificationKey<N>> {
53
- return z.object({
54
- proof: RecursiveProof.schemaFor(proofLength),
55
- verificationKey: VerificationKeyData.schema,
56
- });
57
- }
58
-
59
50
  export function makeProofAndVerificationKey<N extends number>(
60
51
  proof: RecursiveProof<N>,
61
52
  verificationKey: VerificationKeyData,
@@ -213,7 +204,7 @@ export type ProvingJobInputsMap = {
213
204
  export const ProvingJobResult = z.discriminatedUnion('type', [
214
205
  z.object({
215
206
  type: z.literal(ProvingRequestType.PUBLIC_VM),
216
- result: schemaForRecursiveProofAndVerificationKey(AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED),
207
+ result: RecursiveProof.schemaFor(AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED),
217
208
  }),
218
209
  z.object({
219
210
  type: z.literal(ProvingRequestType.PUBLIC_CHONK_VERIFIER),
@@ -328,7 +319,7 @@ export const ProvingJobResult = z.discriminatedUnion('type', [
328
319
  ]);
329
320
  export type ProvingJobResult = z.infer<typeof ProvingJobResult>;
330
321
  export type ProvingJobResultsMap = {
331
- [ProvingRequestType.PUBLIC_VM]: ProofAndVerificationKey<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>;
322
+ [ProvingRequestType.PUBLIC_VM]: RecursiveProof<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>;
332
323
  [ProvingRequestType.PUBLIC_CHONK_VERIFIER]: PublicInputsAndRecursiveProof<
333
324
  PublicChonkVerifierPublicInputs,
334
325
  typeof NESTED_RECURSIVE_ROLLUP_HONK_PROOF_LENGTH
@@ -9,6 +9,7 @@ import type { AvmCircuitInputs } from '../avm/avm.js';
9
9
  import type { ParityBasePrivateInputs } from '../parity/parity_base_private_inputs.js';
10
10
  import type { ParityPublicInputs } from '../parity/parity_public_inputs.js';
11
11
  import type { ParityRootPrivateInputs } from '../parity/parity_root_private_inputs.js';
12
+ import type { RecursiveProof } from '../proofs/recursive_proof.js';
12
13
  import type { BlockMergeRollupPrivateInputs } from '../rollup/block_merge_rollup_private_inputs.js';
13
14
  import type { BlockRollupPublicInputs } from '../rollup/block_rollup_public_inputs.js';
14
15
  import type {
@@ -34,7 +35,7 @@ import type { RootRollupPublicInputs } from '../rollup/root_rollup_public_inputs
34
35
  import type { TxMergeRollupPrivateInputs } from '../rollup/tx_merge_rollup_private_inputs.js';
35
36
  import type { TxRollupPublicInputs } from '../rollup/tx_rollup_public_inputs.js';
36
37
  import type { Tx } from '../tx/tx.js';
37
- import type { ProofAndVerificationKey, PublicInputsAndRecursiveProof } from './proving-job.js';
38
+ import type { PublicInputsAndRecursiveProof } from './proving-job.js';
38
39
 
39
40
  /**
40
41
  * Generates proofs for parity and rollup circuits.
@@ -188,7 +189,7 @@ export interface ServerCircuitProver {
188
189
  inputs: AvmCircuitInputs,
189
190
  signal?: AbortSignal,
190
191
  epochNumber?: number,
191
- ): Promise<ProofAndVerificationKey<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>>;
192
+ ): Promise<RecursiveProof<typeof AVM_V2_PROOF_LENGTH_IN_FIELDS_PADDED>>;
192
193
  }
193
194
 
194
195
  export type IVCProofVerificationResult = {
@@ -18,6 +18,8 @@ export interface SlasherConfig {
18
18
  slashDataWithholdingPenalty: bigint;
19
19
  slashInactivityPenalty: bigint;
20
20
  slashBroadcastedInvalidBlockPenalty: bigint;
21
+ slashDuplicateProposalPenalty: bigint;
22
+ slashDuplicateAttestationPenalty: bigint;
21
23
  slashProposeInvalidAttestationsPenalty: bigint;
22
24
  slashAttestDescendantOfInvalidPenalty: bigint;
23
25
  slashUnknownPenalty: bigint;
@@ -40,6 +42,8 @@ export const SlasherConfigSchema = zodFor<SlasherConfig>()(
40
42
  slashInactivityConsecutiveEpochThreshold: z.number(),
41
43
  slashInactivityPenalty: schemas.BigInt,
42
44
  slashProposeInvalidAttestationsPenalty: schemas.BigInt,
45
+ slashDuplicateProposalPenalty: schemas.BigInt,
46
+ slashDuplicateAttestationPenalty: schemas.BigInt,
43
47
  slashAttestDescendantOfInvalidPenalty: schemas.BigInt,
44
48
  slashUnknownPenalty: schemas.BigInt,
45
49
  slashOffenseExpirationRounds: z.number(),
@@ -1,4 +1,4 @@
1
- import type { L2BlockNew } from '@aztec/stdlib/block';
1
+ import type { L2Block } from '@aztec/stdlib/block';
2
2
  import type { BlockProposal } from '@aztec/stdlib/p2p';
3
3
  import { type Tx, TxHash } from '@aztec/stdlib/tx';
4
4
 
@@ -13,5 +13,5 @@ export interface ITxProvider {
13
13
  opts: { pinnedPeer: PeerId | undefined; deadline: Date },
14
14
  ): Promise<{ txs: Tx[]; missingTxs: TxHash[] }>;
15
15
 
16
- getTxsForBlock(block: L2BlockNew, opts: { deadline: Date }): Promise<{ txs: Tx[]; missingTxs: TxHash[] }>;
16
+ getTxsForBlock(block: L2Block, opts: { deadline: Date }): Promise<{ txs: Tx[]; missingTxs: TxHash[] }>;
17
17
  }
@@ -1,23 +1,32 @@
1
+ import type { BlockNumber, CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
1
2
  import type { SecretValue } from '@aztec/foundation/config';
2
3
  import { Fr } from '@aztec/foundation/curves/bn254';
3
4
  import type { EthAddress } from '@aztec/foundation/eth-address';
4
5
  import type { Signature } from '@aztec/foundation/eth-signature';
5
6
  import { schemas, zodFor } from '@aztec/foundation/schemas';
6
7
  import type { SequencerConfig, SlasherConfig } from '@aztec/stdlib/interfaces/server';
7
- import type { BlockAttestation, BlockProposal, BlockProposalOptions } from '@aztec/stdlib/p2p';
8
- import type { Tx } from '@aztec/stdlib/tx';
8
+ import type {
9
+ BlockProposal,
10
+ BlockProposalOptions,
11
+ CheckpointAttestation,
12
+ CheckpointLastBlockData,
13
+ CheckpointProposal,
14
+ CheckpointProposalOptions,
15
+ } from '@aztec/stdlib/p2p';
16
+ import type { CheckpointHeader } from '@aztec/stdlib/rollup';
17
+ import type { BlockHeader, Tx } from '@aztec/stdlib/tx';
9
18
 
10
19
  import type { PeerId } from '@libp2p/interface';
11
20
  import { z } from 'zod';
12
21
 
13
22
  import type { CommitteeAttestationsAndSigners } from '../block/index.js';
14
- import type { CheckpointHeader } from '../rollup/checkpoint_header.js';
23
+ import { type ValidatorHASignerConfig, ValidatorHASignerConfigSchema } from '../ha-signing/index.js';
15
24
  import { AllowedElementSchema } from './allowed_element.js';
16
25
 
17
26
  /**
18
27
  * Validator client configuration
19
28
  */
20
- export interface ValidatorClientConfig {
29
+ export type ValidatorClientConfig = ValidatorHASignerConfig & {
21
30
  /** The private keys of the validators participating in attestation duties */
22
31
  validatorPrivateKeys?: SecretValue<`0x${string}`[]>;
23
32
 
@@ -36,19 +45,28 @@ export interface ValidatorClientConfig {
36
45
  /** Whether to re-execute transactions in a block proposal before attesting */
37
46
  validatorReexecute: boolean;
38
47
 
39
- /** Will re-execute until this many milliseconds are left in the slot */
40
- validatorReexecuteDeadlineMs: number;
41
-
42
48
  /** Whether to always reexecute block proposals, even for non-validator nodes or when out of the currnet committee */
43
49
  alwaysReexecuteBlockProposals?: boolean;
44
50
 
45
51
  /** Whether to run in fisherman mode: validates all proposals and attestations but does not broadcast attestations or participate in consensus */
46
52
  fishermanMode?: boolean;
47
- }
53
+
54
+ /** Skip checkpoint proposal validation and always attest (default: false) */
55
+ skipCheckpointProposalValidation?: boolean;
56
+
57
+ /** Skip pushing re-executed blocks to archiver (default: false) */
58
+ skipPushProposedBlocksToArchiver?: boolean;
59
+
60
+ /** Agree to attest to equivocated checkpoint proposals (for testing purposes only) */
61
+ attestToEquivocatedProposals?: boolean;
62
+ };
48
63
 
49
64
  export type ValidatorClientFullConfig = ValidatorClientConfig &
50
65
  Pick<SequencerConfig, 'txPublicSetupAllowList' | 'broadcastInvalidBlockProposal'> &
51
- Pick<SlasherConfig, 'slashBroadcastedInvalidBlockPenalty'> & {
66
+ Pick<
67
+ SlasherConfig,
68
+ 'slashBroadcastedInvalidBlockPenalty' | 'slashDuplicateProposalPenalty' | 'slashDuplicateAttestationPenalty'
69
+ > & {
52
70
  /**
53
71
  * Whether transactions are disabled for this node
54
72
  * @remarks This should match the property in P2PConfig. It's not picked from there to avoid circular dependencies.
@@ -57,15 +75,17 @@ export type ValidatorClientFullConfig = ValidatorClientConfig &
57
75
  };
58
76
 
59
77
  export const ValidatorClientConfigSchema = zodFor<Omit<ValidatorClientConfig, 'validatorPrivateKeys'>>()(
60
- z.object({
78
+ ValidatorHASignerConfigSchema.extend({
61
79
  validatorAddresses: z.array(schemas.EthAddress).optional(),
62
80
  disableValidator: z.boolean(),
63
81
  disabledValidators: z.array(schemas.EthAddress),
64
82
  attestationPollingIntervalMs: z.number().min(0),
65
83
  validatorReexecute: z.boolean(),
66
- validatorReexecuteDeadlineMs: z.number().min(0),
67
84
  alwaysReexecuteBlockProposals: z.boolean().optional(),
68
85
  fishermanMode: z.boolean().optional(),
86
+ skipCheckpointProposalValidation: z.boolean().optional(),
87
+ skipPushProposedBlocksToArchiver: z.boolean().optional(),
88
+ attestToEquivocatedProposals: z.boolean().optional(),
69
89
  }),
70
90
  );
71
91
 
@@ -74,29 +94,67 @@ export const ValidatorClientFullConfigSchema = zodFor<Omit<ValidatorClientFullCo
74
94
  txPublicSetupAllowList: z.array(AllowedElementSchema).optional(),
75
95
  broadcastInvalidBlockProposal: z.boolean().optional(),
76
96
  slashBroadcastedInvalidBlockPenalty: schemas.BigInt,
97
+ slashDuplicateProposalPenalty: schemas.BigInt,
98
+ slashDuplicateAttestationPenalty: schemas.BigInt,
77
99
  disableTransactions: z.boolean().optional(),
78
100
  }),
79
101
  );
80
102
 
103
+ export type CreateCheckpointProposalLastBlockData = Omit<CheckpointLastBlockData, 'txHashes'> & { txs: Tx[] };
104
+
81
105
  export interface Validator {
82
106
  start(): Promise<void>;
83
107
  updateConfig(config: Partial<ValidatorClientFullConfig>): void;
84
108
 
85
109
  // Block validation responsibilities
86
110
  createBlockProposal(
87
- blockNumber: number,
88
- header: CheckpointHeader,
111
+ blockHeader: BlockHeader,
112
+ indexWithinCheckpoint: number,
113
+ inHash: Fr,
89
114
  archive: Fr,
90
115
  txs: Tx[],
91
116
  proposerAddress: EthAddress | undefined,
92
117
  options: BlockProposalOptions,
93
118
  ): Promise<BlockProposal | undefined>;
94
- attestToProposal(proposal: BlockProposal, sender: PeerId): Promise<BlockAttestation[] | undefined>;
119
+
120
+ /** Creates a checkpoint proposal for the last block in a checkpoint */
121
+ createCheckpointProposal(
122
+ checkpointHeader: CheckpointHeader,
123
+ archive: Fr,
124
+ feeAssetPriceModifier: bigint,
125
+ lastBlockInfo: CreateCheckpointProposalLastBlockData | undefined,
126
+ proposerAddress: EthAddress | undefined,
127
+ options: CheckpointProposalOptions,
128
+ ): Promise<CheckpointProposal>;
129
+
130
+ /**
131
+ * Validate a block proposal from a peer.
132
+ * Note: Validators do NOT attest to individual blocks - attestations are only for checkpoint proposals.
133
+ * @returns true if the proposal is valid, false otherwise
134
+ */
135
+ validateBlockProposal(proposal: BlockProposal, sender: PeerId): Promise<boolean>;
136
+
137
+ /**
138
+ * Validate and attest to a checkpoint proposal from a peer.
139
+ * @returns Checkpoint attestations if valid, undefined otherwise
140
+ */
141
+ attestToCheckpointProposal(
142
+ proposal: CheckpointProposal,
143
+ sender: PeerId,
144
+ ): Promise<CheckpointAttestation[] | undefined>;
95
145
 
96
146
  broadcastBlockProposal(proposal: BlockProposal): Promise<void>;
97
- collectAttestations(proposal: BlockProposal, required: number, deadline: Date): Promise<BlockAttestation[]>;
147
+
148
+ /** Collect own attestations for a checkpoint proposal (used when skipping p2p attestation collection) */
149
+ collectOwnAttestations(proposal: CheckpointProposal): Promise<CheckpointAttestation[]>;
150
+
151
+ /** Collect attestations from the p2p network for a checkpoint proposal */
152
+ collectAttestations(proposal: CheckpointProposal, required: number, deadline: Date): Promise<CheckpointAttestation[]>;
153
+
98
154
  signAttestationsAndSigners(
99
155
  attestationsAndSigners: CommitteeAttestationsAndSigners,
100
156
  proposer: EthAddress,
157
+ slot: SlotNumber,
158
+ blockNumber: BlockNumber | CheckpointNumber,
101
159
  ): Promise<Signature>;
102
160
  }
@@ -3,6 +3,7 @@ import {
3
3
  MAX_NOTE_HASH_READ_REQUESTS_PER_TX,
4
4
  type NOTE_HASH_TREE_HEIGHT,
5
5
  } from '@aztec/constants';
6
+ import type { Fr } from '@aztec/foundation/curves/bn254';
6
7
  import type { MembershipWitness } from '@aztec/foundation/trees';
7
8
 
8
9
  import type { ClaimedLengthArray } from '../claimed_length_array.js';
@@ -61,12 +62,11 @@ export function getNoteHashReadRequestResetActions(
61
62
 
62
63
  export async function buildNoteHashReadRequestHintsFromResetActions<PENDING extends number, SETTLED extends number>(
63
64
  oracle: {
64
- getNoteHashMembershipWitness(leafIndex: bigint): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT>>;
65
+ getNoteHashMembershipWitness(noteHash: Fr): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT> | undefined>;
65
66
  },
66
67
  noteHashReadRequests: ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>,
67
68
  noteHashes: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
68
69
  resetActions: ReadRequestResetActions<typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>,
69
- noteHashLeafIndexMap: Map<bigint, bigint>,
70
70
  maxPending: PENDING = MAX_NOTE_HASH_READ_REQUESTS_PER_TX as PENDING,
71
71
  maxSettled: SETTLED = MAX_NOTE_HASH_READ_REQUESTS_PER_TX as SETTLED,
72
72
  ) {
@@ -76,18 +76,28 @@ export async function buildNoteHashReadRequestHintsFromResetActions<PENDING exte
76
76
  builder.addPendingReadRequest(hint.readRequestIndex, hint.pendingValueIndex);
77
77
  });
78
78
 
79
+ // Collect all settled read requests
80
+ const settledRequests: { index: number; readRequest: ScopedReadRequest }[] = [];
79
81
  for (let i = 0; i < resetActions.actions.length; i++) {
80
82
  if (resetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
81
- const readRequest = noteHashReadRequests.array[i];
82
- const leafIndex = noteHashLeafIndexMap.get(readRequest.value.toBigInt());
83
- if (leafIndex === undefined) {
84
- throw new Error('Read request is reading an unknown note hash.');
85
- }
86
- const membershipWitness = await oracle.getNoteHashMembershipWitness(leafIndex);
87
- builder.addSettledReadRequest(i, membershipWitness, readRequest.value);
83
+ settledRequests.push({ index: i, readRequest: noteHashReadRequests.array[i] });
88
84
  }
89
85
  }
90
86
 
87
+ // Fetch all membership witnesses in parallel
88
+ const membershipWitnesses = await Promise.all(
89
+ settledRequests.map(({ readRequest }) => oracle.getNoteHashMembershipWitness(readRequest.value)),
90
+ );
91
+
92
+ // Add settled read requests to builder
93
+ for (let i = 0; i < settledRequests.length; i++) {
94
+ const membershipWitness = membershipWitnesses[i];
95
+ if (!membershipWitness) {
96
+ throw new Error('Read request is reading an unknown note hash.');
97
+ }
98
+ builder.addSettledReadRequest(settledRequests[i].index, membershipWitness, settledRequests[i].readRequest.value);
99
+ }
100
+
91
101
  const noteHashMap: Map<bigint, { noteHash: ScopedNoteHash; index: number }[]> = new Map();
92
102
  noteHashes.getActiveItems().forEach((noteHash, index) => {
93
103
  const value = noteHash.value.toBigInt();
@@ -101,11 +111,10 @@ export async function buildNoteHashReadRequestHintsFromResetActions<PENDING exte
101
111
 
102
112
  export async function buildNoteHashReadRequestHints<PENDING extends number, SETTLED extends number>(
103
113
  oracle: {
104
- getNoteHashMembershipWitness(leafIndex: bigint): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT>>;
114
+ getNoteHashMembershipWitness(noteHash: Fr): Promise<MembershipWitness<typeof NOTE_HASH_TREE_HEIGHT>>;
105
115
  },
106
116
  noteHashReadRequests: ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>,
107
117
  noteHashes: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
108
- noteHashLeafIndexMap: Map<bigint, bigint>,
109
118
  futureNoteHashes: ScopedNoteHash[],
110
119
  maxPending: PENDING = MAX_NOTE_HASH_READ_REQUESTS_PER_TX as PENDING,
111
120
  maxSettled: SETTLED = MAX_NOTE_HASH_READ_REQUESTS_PER_TX as SETTLED,
@@ -116,7 +125,6 @@ export async function buildNoteHashReadRequestHints<PENDING extends number, SETT
116
125
  noteHashReadRequests,
117
126
  noteHashes,
118
127
  resetActions,
119
- noteHashLeafIndexMap,
120
128
  maxPending,
121
129
  maxSettled,
122
130
  );
@@ -6,7 +6,6 @@ import {
6
6
  import type { Fr } from '@aztec/foundation/curves/bn254';
7
7
  import { MembershipWitness } from '@aztec/foundation/trees';
8
8
 
9
- import { siloNullifier } from '../../hash/hash.js';
10
9
  import type { NullifierLeafPreimage } from '../../trees/nullifier_leaf.js';
11
10
  import type { ClaimedLengthArray } from '../claimed_length_array.js';
12
11
  import type { ScopedNullifier } from '../nullifier.js';
@@ -74,7 +73,6 @@ export async function buildNullifierReadRequestHintsFromResetActions<PENDING ext
74
73
  resetActions: ReadRequestResetActions<typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>,
75
74
  maxPending: PENDING = MAX_NULLIFIER_READ_REQUESTS_PER_TX as PENDING,
76
75
  maxSettled: SETTLED = MAX_NULLIFIER_READ_REQUESTS_PER_TX as SETTLED,
77
- siloed = false,
78
76
  ) {
79
77
  const builder = new NullifierReadRequestHintsBuilder(maxPending, maxSettled);
80
78
 
@@ -82,21 +80,28 @@ export async function buildNullifierReadRequestHintsFromResetActions<PENDING ext
82
80
  builder.addPendingReadRequest(hint.readRequestIndex, hint.pendingValueIndex);
83
81
  });
84
82
 
83
+ // Collect all settled read requests
84
+ const settledRequests: { index: number; readRequest: ScopedReadRequest }[] = [];
85
85
  for (let i = 0; i < resetActions.actions.length; i++) {
86
86
  if (resetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
87
- const readRequest = nullifierReadRequests.array[i];
88
- const siloedValue = siloed
89
- ? readRequest.value
90
- : await siloNullifier(readRequest.contractAddress, readRequest.value);
91
- const membershipWitnessWithPreimage = await oracle.getNullifierMembershipWitness(siloedValue);
92
- builder.addSettledReadRequest(
93
- i,
94
- membershipWitnessWithPreimage.membershipWitness,
95
- membershipWitnessWithPreimage.leafPreimage,
96
- );
87
+ settledRequests.push({ index: i, readRequest: nullifierReadRequests.array[i] });
97
88
  }
98
89
  }
99
90
 
91
+ const siloedValues = settledRequests.map(({ readRequest }) => readRequest.value);
92
+
93
+ // Fetch all membership witnesses in parallel
94
+ const membershipWitnesses = await Promise.all(siloedValues.map(value => oracle.getNullifierMembershipWitness(value)));
95
+
96
+ // Add settled read requests to builder
97
+ for (let i = 0; i < settledRequests.length; i++) {
98
+ builder.addSettledReadRequest(
99
+ settledRequests[i].index,
100
+ membershipWitnesses[i].membershipWitness,
101
+ membershipWitnesses[i].leafPreimage,
102
+ );
103
+ }
104
+
100
105
  return builder.toHints();
101
106
  }
102
107
 
@@ -109,7 +114,6 @@ export async function buildNullifierReadRequestHints<PENDING extends number, SET
109
114
  futureNullifiers: ScopedNullifier[],
110
115
  maxPending: PENDING = MAX_NULLIFIER_READ_REQUESTS_PER_TX as PENDING,
111
116
  maxSettled: SETTLED = MAX_NULLIFIER_READ_REQUESTS_PER_TX as SETTLED,
112
- siloed = false,
113
117
  ) {
114
118
  const resetActions = getNullifierReadRequestResetActions(nullifierReadRequests, nullifiers, futureNullifiers);
115
119
  return await buildNullifierReadRequestHintsFromResetActions(
@@ -118,6 +122,5 @@ export async function buildNullifierReadRequestHints<PENDING extends number, SET
118
122
  resetActions,
119
123
  maxPending,
120
124
  maxSettled,
121
- siloed,
122
125
  );
123
126
  }
@@ -6,10 +6,10 @@ export * from './note_hash_read_request_hints.js';
6
6
  export * from './nullifier_read_request_hints.js';
7
7
  export * from './read_request_hints.js';
8
8
  export * from './key_validation_hint.js';
9
- export * from './key_validation_request_and_generator.js';
9
+ export * from './key_validation_request_and_separator.js';
10
10
  export * from './read_request.js';
11
11
  export * from './key_validation_request.js';
12
- export * from './scoped_key_validation_request_and_generator.js';
12
+ export * from './scoped_key_validation_request_and_separator.js';
13
13
  export * from './transient_data_squashing_hint.js';
14
14
  export * from './private_kernel_reset_hints.js';
15
15
  export * from './tree_leaf_read_request.js';
@@ -5,48 +5,45 @@ import { BufferReader, FieldReader, serializeToBuffer } from '@aztec/foundation/
5
5
  import { KeyValidationRequest } from './key_validation_request.js';
6
6
 
7
7
  /**
8
- * Request for validating keys used in the app and a generator.
8
+ * Request for validating keys used in the app, along with a domain separator for the key type.
9
9
  */
10
- export class KeyValidationRequestAndGenerator {
10
+ export class KeyValidationRequestAndSeparator {
11
11
  constructor(
12
12
  /** The key validation request. */
13
13
  public readonly request: KeyValidationRequest,
14
- /**
15
- * The generator index which can be used along with sk_m to derive the sk_app stored in the request.
16
- * Note: This generator constrains that a correct key type gets validated in the kernel.
17
- */
18
- public readonly skAppGenerator: Fr,
14
+ /** Domain separator for the key type, used along with sk_m to derive the sk_app stored in the request. */
15
+ public readonly keyTypeDomainSeparator: Fr,
19
16
  ) {}
20
17
 
21
18
  toBuffer() {
22
- return serializeToBuffer(this.request, this.skAppGenerator);
19
+ return serializeToBuffer(this.request, this.keyTypeDomainSeparator);
23
20
  }
24
21
 
25
22
  static fromBuffer(buffer: Buffer | BufferReader) {
26
23
  const reader = BufferReader.asReader(buffer);
27
- return new KeyValidationRequestAndGenerator(reader.readObject(KeyValidationRequest), Fr.fromBuffer(reader));
24
+ return new KeyValidationRequestAndSeparator(reader.readObject(KeyValidationRequest), Fr.fromBuffer(reader));
28
25
  }
29
26
 
30
27
  toFields(): Fr[] {
31
- const fields = [...this.request.toFields(), this.skAppGenerator];
28
+ const fields = [...this.request.toFields(), this.keyTypeDomainSeparator];
32
29
  if (fields.length !== KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH) {
33
30
  throw new Error(
34
- `Invalid number of fields for KeyValidationRequestAndGenerator. Expected ${KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH}, got ${fields.length}`,
31
+ `Invalid number of fields for KeyValidationRequestAndSeparator. Expected ${KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH}, got ${fields.length}`,
35
32
  );
36
33
  }
37
34
  return fields;
38
35
  }
39
36
 
40
- static fromFields(fields: Fr[] | FieldReader): KeyValidationRequestAndGenerator {
37
+ static fromFields(fields: Fr[] | FieldReader): KeyValidationRequestAndSeparator {
41
38
  const reader = FieldReader.asReader(fields);
42
- return new KeyValidationRequestAndGenerator(KeyValidationRequest.fromFields(reader), reader.readField());
39
+ return new KeyValidationRequestAndSeparator(KeyValidationRequest.fromFields(reader), reader.readField());
43
40
  }
44
41
 
45
42
  isEmpty() {
46
- return this.request.isEmpty() && this.skAppGenerator.isZero();
43
+ return this.request.isEmpty() && this.keyTypeDomainSeparator.isZero();
47
44
  }
48
45
 
49
46
  static empty() {
50
- return new KeyValidationRequestAndGenerator(KeyValidationRequest.empty(), Fr.ZERO);
47
+ return new KeyValidationRequestAndSeparator(KeyValidationRequest.empty(), Fr.ZERO);
51
48
  }
52
49
  }