@aztec/stdlib 0.0.1-commit.96bb3f7 → 0.0.1-commit.96dac018d

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 (660) hide show
  1. package/dest/abi/function_call.d.ts +47 -9
  2. package/dest/abi/function_call.d.ts.map +1 -1
  3. package/dest/abi/function_call.js +20 -3
  4. package/dest/abi/utils.d.ts +7 -1
  5. package/dest/abi/utils.d.ts.map +1 -1
  6. package/dest/abi/utils.js +7 -0
  7. package/dest/auth_witness/auth_witness.d.ts +2 -1
  8. package/dest/auth_witness/auth_witness.d.ts.map +1 -1
  9. package/dest/auth_witness/auth_witness.js +3 -3
  10. package/dest/avm/avm.d.ts +62 -62
  11. package/dest/avm/avm_accumulated_data.d.ts +30 -3
  12. package/dest/avm/avm_accumulated_data.d.ts.map +1 -1
  13. package/dest/avm/avm_circuit_public_inputs.d.ts +9 -9
  14. package/dest/avm/avm_proving_request.d.ts +299 -299
  15. package/dest/avm/contract_storage_read.d.ts +13 -1
  16. package/dest/avm/contract_storage_read.d.ts.map +1 -1
  17. package/dest/avm/contract_storage_update_request.d.ts +13 -1
  18. package/dest/avm/contract_storage_update_request.d.ts.map +1 -1
  19. package/dest/avm/public_call_stack_item_compressed.d.ts +3 -1
  20. package/dest/avm/public_call_stack_item_compressed.d.ts.map +1 -1
  21. package/dest/avm/public_data_read.d.ts +10 -1
  22. package/dest/avm/public_data_read.d.ts.map +1 -1
  23. package/dest/avm/public_data_update_request.d.ts +10 -1
  24. package/dest/avm/public_data_update_request.d.ts.map +1 -1
  25. package/dest/avm/public_data_write.d.ts +7 -1
  26. package/dest/avm/public_data_write.d.ts.map +1 -1
  27. package/dest/avm/public_inner_call_request.d.ts +4 -1
  28. package/dest/avm/public_inner_call_request.d.ts.map +1 -1
  29. package/dest/avm/revert_code.d.ts +4 -4
  30. package/dest/avm/revert_code.d.ts.map +1 -1
  31. package/dest/block/block_data.d.ts +52 -0
  32. package/dest/block/block_data.d.ts.map +1 -0
  33. package/dest/block/block_data.js +12 -0
  34. package/dest/block/block_hash.d.ts +18 -14
  35. package/dest/block/block_hash.d.ts.map +1 -1
  36. package/dest/block/block_hash.js +22 -20
  37. package/dest/block/block_parameter.d.ts +4 -3
  38. package/dest/block/block_parameter.d.ts.map +1 -1
  39. package/dest/block/block_parameter.js +2 -0
  40. package/dest/block/body.d.ts +1 -1
  41. package/dest/block/body.d.ts.map +1 -1
  42. package/dest/block/body.js +2 -1
  43. package/dest/block/checkpointed_l2_block.d.ts +20 -137
  44. package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
  45. package/dest/block/checkpointed_l2_block.js +7 -45
  46. package/dest/block/in_block.d.ts +9 -9
  47. package/dest/block/in_block.d.ts.map +1 -1
  48. package/dest/block/in_block.js +5 -5
  49. package/dest/block/index.d.ts +2 -3
  50. package/dest/block/index.d.ts.map +1 -1
  51. package/dest/block/index.js +1 -2
  52. package/dest/block/l2_block.d.ts +56 -59
  53. package/dest/block/l2_block.d.ts.map +1 -1
  54. package/dest/block/l2_block.js +64 -110
  55. package/dest/block/l2_block_source.d.ts +84 -39
  56. package/dest/block/l2_block_source.d.ts.map +1 -1
  57. package/dest/block/l2_block_source.js +2 -1
  58. package/dest/block/l2_block_stream/interfaces.d.ts +9 -6
  59. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  60. package/dest/block/l2_block_stream/l2_block_stream.d.ts +6 -3
  61. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  62. package/dest/block/l2_block_stream/l2_block_stream.js +37 -34
  63. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +3 -3
  64. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -1
  65. package/dest/block/test/l2_tips_store_test_suite.d.ts +1 -1
  66. package/dest/block/test/l2_tips_store_test_suite.d.ts.map +1 -1
  67. package/dest/block/test/l2_tips_store_test_suite.js +2 -7
  68. package/dest/block/validate_block_result.d.ts +1 -1
  69. package/dest/block/validate_block_result.d.ts.map +1 -1
  70. package/dest/block/validate_block_result.js +5 -4
  71. package/dest/checkpoint/checkpoint.d.ts +43 -19
  72. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  73. package/dest/checkpoint/checkpoint.js +37 -14
  74. package/dest/checkpoint/checkpoint_data.d.ts +120 -0
  75. package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
  76. package/dest/checkpoint/checkpoint_data.js +26 -0
  77. package/dest/checkpoint/index.d.ts +2 -1
  78. package/dest/checkpoint/index.d.ts.map +1 -1
  79. package/dest/checkpoint/index.js +1 -0
  80. package/dest/checkpoint/published_checkpoint.d.ts +33 -16
  81. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  82. package/dest/checkpoint/published_checkpoint.js +5 -5
  83. package/dest/config/index.d.ts +2 -1
  84. package/dest/config/index.d.ts.map +1 -1
  85. package/dest/config/index.js +1 -0
  86. package/dest/config/node-rpc-config.js +1 -1
  87. package/dest/config/sequencer-config.d.ts +10 -0
  88. package/dest/config/sequencer-config.d.ts.map +1 -0
  89. package/dest/config/sequencer-config.js +18 -0
  90. package/dest/contract/complete_address.d.ts +4 -1
  91. package/dest/contract/complete_address.d.ts.map +1 -1
  92. package/dest/contract/contract_address.js +4 -4
  93. package/dest/contract/contract_class.d.ts +2 -3
  94. package/dest/contract/contract_class.d.ts.map +1 -1
  95. package/dest/contract/contract_class_id.d.ts +2 -2
  96. package/dest/contract/contract_class_id.d.ts.map +1 -1
  97. package/dest/contract/contract_class_id.js +6 -5
  98. package/dest/contract/contract_deployment_data.d.ts +5 -5
  99. package/dest/contract/index.d.ts +1 -3
  100. package/dest/contract/index.d.ts.map +1 -1
  101. package/dest/contract/index.js +0 -2
  102. package/dest/contract/interfaces/contract_instance.d.ts +16 -16
  103. package/dest/contract/interfaces/node-info.d.ts +3 -1
  104. package/dest/contract/interfaces/node-info.d.ts.map +1 -1
  105. package/dest/contract/interfaces/node-info.js +2 -1
  106. package/dest/contract/private_function.d.ts +1 -1
  107. package/dest/contract/private_function.d.ts.map +1 -1
  108. package/dest/contract/private_function.js +3 -4
  109. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  110. package/dest/contract/private_function_membership_proof.js +1 -1
  111. package/dest/database-version/database_version.d.ts +58 -0
  112. package/dest/database-version/database_version.d.ts.map +1 -0
  113. package/dest/database-version/database_version.js +69 -0
  114. package/dest/database-version/version_manager.d.ts +3 -49
  115. package/dest/database-version/version_manager.d.ts.map +1 -1
  116. package/dest/database-version/version_manager.js +1 -66
  117. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  118. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  119. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  120. package/dest/deserialization/index.d.ts +11 -0
  121. package/dest/deserialization/index.d.ts.map +1 -0
  122. package/dest/deserialization/index.js +10 -0
  123. package/dest/epoch-helpers/index.d.ts +7 -1
  124. package/dest/epoch-helpers/index.d.ts.map +1 -1
  125. package/dest/epoch-helpers/index.js +9 -3
  126. package/dest/errors/proving_error.d.ts +2 -2
  127. package/dest/errors/proving_error.d.ts.map +1 -1
  128. package/dest/file-store/local.d.ts +3 -3
  129. package/dest/file-store/local.d.ts.map +1 -1
  130. package/dest/file-store/local.js +13 -4
  131. package/dest/file-store/s3.d.ts +1 -1
  132. package/dest/file-store/s3.d.ts.map +1 -1
  133. package/dest/file-store/s3.js +11 -3
  134. package/dest/ha-signing/config.d.ts +101 -0
  135. package/dest/ha-signing/config.d.ts.map +1 -0
  136. package/dest/ha-signing/config.js +92 -0
  137. package/dest/ha-signing/index.d.ts +3 -0
  138. package/dest/ha-signing/index.d.ts.map +1 -0
  139. package/dest/ha-signing/index.js +2 -0
  140. package/dest/ha-signing/types.d.ts +85 -0
  141. package/dest/ha-signing/types.d.ts.map +1 -0
  142. package/dest/ha-signing/types.js +32 -0
  143. package/dest/hash/hash.d.ts +2 -1
  144. package/dest/hash/hash.d.ts.map +1 -1
  145. package/dest/hash/hash.js +16 -10
  146. package/dest/hash/map_slot.d.ts +1 -1
  147. package/dest/hash/map_slot.d.ts.map +1 -1
  148. package/dest/hash/map_slot.js +4 -3
  149. package/dest/interfaces/api_limit.d.ts +2 -1
  150. package/dest/interfaces/api_limit.d.ts.map +1 -1
  151. package/dest/interfaces/api_limit.js +1 -0
  152. package/dest/interfaces/archiver.d.ts +1 -1
  153. package/dest/interfaces/archiver.d.ts.map +1 -1
  154. package/dest/interfaces/archiver.js +23 -15
  155. package/dest/interfaces/aztec-node-admin.d.ts +101 -28
  156. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  157. package/dest/interfaces/aztec-node-admin.js +12 -4
  158. package/dest/interfaces/aztec-node.d.ts +66 -69
  159. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  160. package/dest/interfaces/aztec-node.js +10 -16
  161. package/dest/interfaces/block-builder.d.ts +22 -14
  162. package/dest/interfaces/block-builder.d.ts.map +1 -1
  163. package/dest/interfaces/block-builder.js +7 -0
  164. package/dest/interfaces/configs.d.ts +24 -9
  165. package/dest/interfaces/configs.d.ts.map +1 -1
  166. package/dest/interfaces/configs.js +4 -1
  167. package/dest/interfaces/get_logs_response.d.ts +16 -9
  168. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  169. package/dest/interfaces/l2_logs_source.d.ts +14 -5
  170. package/dest/interfaces/l2_logs_source.d.ts.map +1 -1
  171. package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
  172. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  173. package/dest/interfaces/p2p.d.ts +2 -2
  174. package/dest/interfaces/p2p.d.ts.map +1 -1
  175. package/dest/interfaces/prover-broker.d.ts +16 -1
  176. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  177. package/dest/interfaces/prover-broker.js +4 -1
  178. package/dest/interfaces/prover-client.d.ts +15 -1
  179. package/dest/interfaces/prover-client.d.ts.map +1 -1
  180. package/dest/interfaces/prover-client.js +12 -1
  181. package/dest/interfaces/proving-job.d.ts +216 -216
  182. package/dest/interfaces/slasher.d.ts +9 -1
  183. package/dest/interfaces/slasher.d.ts.map +1 -1
  184. package/dest/interfaces/slasher.js +2 -0
  185. package/dest/interfaces/tx_provider.d.ts +3 -3
  186. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  187. package/dest/interfaces/validator.d.ts +118 -16
  188. package/dest/interfaces/validator.d.ts.map +1 -1
  189. package/dest/interfaces/validator.js +6 -3
  190. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +3 -3
  191. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  192. package/dest/kernel/hints/build_note_hash_read_request_hints.js +29 -16
  193. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +4 -4
  194. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  195. package/dest/kernel/hints/build_nullifier_read_request_hints.js +28 -17
  196. package/dest/kernel/hints/build_transient_data_hints.d.ts +5 -2
  197. package/dest/kernel/hints/build_transient_data_hints.d.ts.map +1 -1
  198. package/dest/kernel/hints/build_transient_data_hints.js +9 -3
  199. package/dest/kernel/hints/index.d.ts +2 -2
  200. package/dest/kernel/hints/index.js +2 -2
  201. package/dest/kernel/hints/key_validation_hint.d.ts +2 -1
  202. package/dest/kernel/hints/key_validation_hint.d.ts.map +1 -1
  203. package/dest/kernel/hints/key_validation_request.d.ts +2 -1
  204. package/dest/kernel/hints/key_validation_request.d.ts.map +1 -1
  205. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  206. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  207. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
  208. package/dest/kernel/hints/private_kernel_reset_hints.d.ts +13 -1
  209. package/dest/kernel/hints/private_kernel_reset_hints.d.ts.map +1 -1
  210. package/dest/kernel/hints/read_request.d.ts +7 -1
  211. package/dest/kernel/hints/read_request.d.ts.map +1 -1
  212. package/dest/kernel/hints/read_request_hints.d.ts +7 -1
  213. package/dest/kernel/hints/read_request_hints.d.ts.map +1 -1
  214. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
  215. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  216. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  217. package/dest/kernel/private_accumulated_data.d.ts +23 -1
  218. package/dest/kernel/private_accumulated_data.d.ts.map +1 -1
  219. package/dest/kernel/private_call_data.d.ts +25 -1
  220. package/dest/kernel/private_call_data.d.ts.map +1 -1
  221. package/dest/kernel/private_call_request.d.ts +16 -1
  222. package/dest/kernel/private_call_request.d.ts.map +1 -1
  223. package/dest/kernel/private_circuit_public_inputs.d.ts +81 -8
  224. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  225. package/dest/kernel/private_circuit_public_inputs.js +16 -16
  226. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +33 -3
  227. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  228. package/dest/kernel/private_kernel_circuit_public_inputs.js +4 -4
  229. package/dest/kernel/private_kernel_data.d.ts +7 -1
  230. package/dest/kernel/private_kernel_data.d.ts.map +1 -1
  231. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts +22 -1
  232. package/dest/kernel/private_kernel_init_circuit_private_inputs.d.ts.map +1 -1
  233. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts +7 -1
  234. package/dest/kernel/private_kernel_inner_circuit_private_inputs.d.ts.map +1 -1
  235. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts +4 -1
  236. package/dest/kernel/private_kernel_reset_circuit_private_inputs.d.ts.map +1 -1
  237. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +12 -3
  238. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  239. package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
  240. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +25 -3
  241. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  242. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +7 -7
  243. package/dest/kernel/private_to_avm_accumulated_data.d.ts +2 -2
  244. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +3 -3
  245. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  246. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +7 -7
  247. package/dest/kernel/private_to_rollup_accumulated_data.d.ts +17 -1
  248. package/dest/kernel/private_to_rollup_accumulated_data.d.ts.map +1 -1
  249. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +18 -3
  250. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  251. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +7 -7
  252. package/dest/kernel/private_validation_requests.d.ts +13 -4
  253. package/dest/kernel/private_validation_requests.d.ts.map +1 -1
  254. package/dest/kernel/private_validation_requests.js +9 -9
  255. package/dest/kernel/public_call_request.d.ts +22 -1
  256. package/dest/kernel/public_call_request.d.ts.map +1 -1
  257. package/dest/kernel/utils/optional_number.d.ts +7 -1
  258. package/dest/kernel/utils/optional_number.d.ts.map +1 -1
  259. package/dest/keys/derivation.d.ts +3 -3
  260. package/dest/keys/derivation.js +15 -15
  261. package/dest/keys/key_types.d.ts +3 -3
  262. package/dest/keys/key_types.d.ts.map +1 -1
  263. package/dest/keys/public_keys.d.ts +5 -1
  264. package/dest/keys/public_keys.d.ts.map +1 -1
  265. package/dest/keys/public_keys.js +2 -2
  266. package/dest/keys/utils.d.ts +1 -1
  267. package/dest/keys/utils.d.ts.map +1 -1
  268. package/dest/keys/utils.js +8 -4
  269. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  270. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  271. package/dest/l1-contracts/slash_factory.js +1 -0
  272. package/dest/logs/debug_log_store.d.ts +30 -0
  273. package/dest/logs/debug_log_store.d.ts.map +1 -0
  274. package/dest/logs/debug_log_store.js +30 -0
  275. package/dest/logs/extended_contract_class_log.d.ts +3 -1
  276. package/dest/logs/extended_contract_class_log.d.ts.map +1 -1
  277. package/dest/logs/extended_public_log.d.ts +17 -9
  278. package/dest/logs/extended_public_log.d.ts.map +1 -1
  279. package/dest/logs/index.d.ts +2 -1
  280. package/dest/logs/index.d.ts.map +1 -1
  281. package/dest/logs/index.js +1 -0
  282. package/dest/logs/log_id.d.ts +21 -14
  283. package/dest/logs/log_id.d.ts.map +1 -1
  284. package/dest/logs/log_id.js +20 -17
  285. package/dest/logs/private_log.d.ts +2 -2
  286. package/dest/logs/private_log.d.ts.map +1 -1
  287. package/dest/logs/siloed_tag.d.ts +1 -1
  288. package/dest/logs/siloed_tag.d.ts.map +1 -1
  289. package/dest/logs/siloed_tag.js +2 -5
  290. package/dest/messaging/inbox_leaf.d.ts +3 -1
  291. package/dest/messaging/inbox_leaf.d.ts.map +1 -1
  292. package/dest/messaging/l1_actor.d.ts +7 -1
  293. package/dest/messaging/l1_actor.d.ts.map +1 -1
  294. package/dest/messaging/l1_to_l2_message.d.ts +6 -1
  295. package/dest/messaging/l1_to_l2_message.d.ts.map +1 -1
  296. package/dest/messaging/l2_actor.d.ts +7 -1
  297. package/dest/messaging/l2_actor.d.ts.map +1 -1
  298. package/dest/messaging/l2_to_l1_membership.d.ts +3 -3
  299. package/dest/messaging/l2_to_l1_membership.d.ts.map +1 -1
  300. package/dest/messaging/l2_to_l1_membership.js +8 -6
  301. package/dest/messaging/out_hash.d.ts +41 -4
  302. package/dest/messaging/out_hash.d.ts.map +1 -1
  303. package/dest/messaging/out_hash.js +52 -26
  304. package/dest/note/index.d.ts +1 -2
  305. package/dest/note/index.d.ts.map +1 -1
  306. package/dest/note/index.js +0 -1
  307. package/dest/note/note_dao.d.ts +36 -5
  308. package/dest/note/note_dao.d.ts.map +1 -1
  309. package/dest/note/note_dao.js +15 -12
  310. package/dest/p2p/attestation_utils.d.ts +11 -1
  311. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  312. package/dest/p2p/attestation_utils.js +45 -0
  313. package/dest/p2p/block_proposal.d.ts +23 -8
  314. package/dest/p2p/block_proposal.d.ts.map +1 -1
  315. package/dest/p2p/block_proposal.js +26 -10
  316. package/dest/p2p/checkpoint_attestation.d.ts +6 -1
  317. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -1
  318. package/dest/p2p/checkpoint_attestation.js +1 -1
  319. package/dest/p2p/checkpoint_proposal.d.ts +34 -9
  320. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
  321. package/dest/p2p/checkpoint_proposal.js +46 -20
  322. package/dest/p2p/consensus_payload.d.ts +15 -5
  323. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  324. package/dest/p2p/consensus_payload.js +22 -18
  325. package/dest/p2p/constants.d.ts +5 -0
  326. package/dest/p2p/constants.d.ts.map +1 -0
  327. package/dest/p2p/constants.js +3 -0
  328. package/dest/p2p/index.d.ts +2 -1
  329. package/dest/p2p/index.d.ts.map +1 -1
  330. package/dest/p2p/index.js +1 -0
  331. package/dest/p2p/message_validator.d.ts +18 -3
  332. package/dest/p2p/message_validator.d.ts.map +1 -1
  333. package/dest/p2p/message_validator.js +2 -1
  334. package/dest/p2p/signed_txs.d.ts +3 -1
  335. package/dest/p2p/signed_txs.d.ts.map +1 -1
  336. package/dest/p2p/signed_txs.js +6 -1
  337. package/dest/p2p/topic_type.js +2 -1
  338. package/dest/parity/parity_base_private_inputs.d.ts +3 -1
  339. package/dest/parity/parity_base_private_inputs.d.ts.map +1 -1
  340. package/dest/parity/parity_public_inputs.d.ts +4 -1
  341. package/dest/parity/parity_public_inputs.d.ts.map +1 -1
  342. package/dest/parity/parity_root_private_inputs.d.ts +2 -1
  343. package/dest/parity/parity_root_private_inputs.d.ts.map +1 -1
  344. package/dest/proofs/chonk_proof.d.ts +1 -1
  345. package/dest/proofs/chonk_proof.d.ts.map +1 -1
  346. package/dest/proofs/chonk_proof.js +9 -4
  347. package/dest/proofs/proof.d.ts +4 -1
  348. package/dest/proofs/proof.d.ts.map +1 -1
  349. package/dest/proofs/recursive_proof.d.ts +10 -1
  350. package/dest/proofs/recursive_proof.d.ts.map +1 -1
  351. package/dest/rollup/base_rollup_hints.d.ts +34 -1
  352. package/dest/rollup/base_rollup_hints.d.ts.map +1 -1
  353. package/dest/rollup/block_constant_data.d.ts +12 -1
  354. package/dest/rollup/block_constant_data.d.ts.map +1 -1
  355. package/dest/rollup/block_headers_hash.js +1 -1
  356. package/dest/rollup/block_merge_rollup_private_inputs.d.ts +4 -1
  357. package/dest/rollup/block_merge_rollup_private_inputs.d.ts.map +1 -1
  358. package/dest/rollup/block_rollup_public_inputs.d.ts +44 -3
  359. package/dest/rollup/block_rollup_public_inputs.d.ts.map +1 -1
  360. package/dest/rollup/block_rollup_public_inputs.js +2 -2
  361. package/dest/rollup/block_root_rollup_private_inputs.d.ts +64 -1
  362. package/dest/rollup/block_root_rollup_private_inputs.d.ts.map +1 -1
  363. package/dest/rollup/checkpoint_constant_data.d.ts +10 -1
  364. package/dest/rollup/checkpoint_constant_data.d.ts.map +1 -1
  365. package/dest/rollup/checkpoint_header.d.ts +31 -4
  366. package/dest/rollup/checkpoint_header.d.ts.map +1 -1
  367. package/dest/rollup/checkpoint_header.js +23 -7
  368. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts +4 -1
  369. package/dest/rollup/checkpoint_merge_rollup_private_inputs.d.ts.map +1 -1
  370. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +45 -10
  371. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  372. package/dest/rollup/checkpoint_rollup_public_inputs.js +11 -7
  373. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +44 -3
  374. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  375. package/dest/rollup/checkpoint_root_rollup_private_inputs.js +13 -2
  376. package/dest/rollup/epoch_constant_data.d.ts +16 -1
  377. package/dest/rollup/epoch_constant_data.d.ts.map +1 -1
  378. package/dest/rollup/root_rollup_private_inputs.d.ts +6 -1
  379. package/dest/rollup/root_rollup_private_inputs.d.ts.map +1 -1
  380. package/dest/rollup/root_rollup_public_inputs.d.ts +17 -7
  381. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  382. package/dest/rollup/root_rollup_public_inputs.js +7 -4
  383. package/dest/rollup/tree_snapshot_diff_hints.d.ts +24 -1
  384. package/dest/rollup/tree_snapshot_diff_hints.d.ts.map +1 -1
  385. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts +4 -1
  386. package/dest/rollup/tx_merge_rollup_private_inputs.d.ts.map +1 -1
  387. package/dest/rollup/tx_rollup_public_inputs.d.ts +29 -1
  388. package/dest/rollup/tx_rollup_public_inputs.d.ts.map +1 -1
  389. package/dest/schemas/schemas.d.ts +1 -1
  390. package/dest/slashing/empire.d.ts +1 -1
  391. package/dest/slashing/empire.d.ts.map +1 -1
  392. package/dest/slashing/empire.js +2 -0
  393. package/dest/slashing/helpers.d.ts +2 -2
  394. package/dest/slashing/helpers.d.ts.map +1 -1
  395. package/dest/slashing/helpers.js +6 -0
  396. package/dest/slashing/tally.d.ts +2 -1
  397. package/dest/slashing/tally.d.ts.map +1 -1
  398. package/dest/slashing/tally.js +6 -2
  399. package/dest/slashing/types.d.ts +7 -3
  400. package/dest/slashing/types.d.ts.map +1 -1
  401. package/dest/slashing/types.js +13 -1
  402. package/dest/stats/stats.d.ts +1 -3
  403. package/dest/stats/stats.d.ts.map +1 -1
  404. package/dest/tests/factories.d.ts +2 -4
  405. package/dest/tests/factories.d.ts.map +1 -1
  406. package/dest/tests/factories.js +18 -27
  407. package/dest/tests/jest.js +1 -1
  408. package/dest/tests/mocks.d.ts +24 -15
  409. package/dest/tests/mocks.d.ts.map +1 -1
  410. package/dest/tests/mocks.js +63 -40
  411. package/dest/timetable/index.d.ts +37 -0
  412. package/dest/timetable/index.d.ts.map +1 -0
  413. package/dest/timetable/index.js +39 -0
  414. package/dest/trees/append_only_tree_snapshot.d.ts +13 -1
  415. package/dest/trees/append_only_tree_snapshot.d.ts.map +1 -1
  416. package/dest/trees/nullifier_leaf.d.ts +13 -1
  417. package/dest/trees/nullifier_leaf.d.ts.map +1 -1
  418. package/dest/trees/nullifier_membership_witness.d.ts +10 -1
  419. package/dest/trees/nullifier_membership_witness.d.ts.map +1 -1
  420. package/dest/trees/public_data_leaf.d.ts +17 -1
  421. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  422. package/dest/trees/public_data_leaf.js +7 -6
  423. package/dest/trees/public_data_witness.d.ts +11 -1
  424. package/dest/trees/public_data_witness.d.ts.map +1 -1
  425. package/dest/tx/block_header.d.ts +14 -2
  426. package/dest/tx/block_header.d.ts.map +1 -1
  427. package/dest/tx/block_header.js +6 -2
  428. package/dest/tx/call_context.d.ts +13 -1
  429. package/dest/tx/call_context.d.ts.map +1 -1
  430. package/dest/tx/capsule.d.ts +4 -1
  431. package/dest/tx/capsule.d.ts.map +1 -1
  432. package/dest/tx/execution_payload.d.ts +9 -1
  433. package/dest/tx/execution_payload.d.ts.map +1 -1
  434. package/dest/tx/function_data.d.ts +4 -2
  435. package/dest/tx/function_data.d.ts.map +1 -1
  436. package/dest/tx/global_variables.d.ts +12 -4
  437. package/dest/tx/global_variables.d.ts.map +1 -1
  438. package/dest/tx/hashed_values.d.ts +7 -1
  439. package/dest/tx/hashed_values.d.ts.map +1 -1
  440. package/dest/tx/in_tx.d.ts +4 -4
  441. package/dest/tx/indexed_tx_effect.d.ts +5 -5
  442. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  443. package/dest/tx/indexed_tx_effect.js +3 -2
  444. package/dest/tx/partial_state_reference.d.ts +4 -1
  445. package/dest/tx/partial_state_reference.d.ts.map +1 -1
  446. package/dest/tx/private_execution_result.d.ts +23 -2
  447. package/dest/tx/private_execution_result.d.ts.map +1 -1
  448. package/dest/tx/private_execution_result.js +1 -1
  449. package/dest/tx/private_tx_constant_data.d.ts +16 -1
  450. package/dest/tx/private_tx_constant_data.d.ts.map +1 -1
  451. package/dest/tx/profiling.d.ts +152 -29
  452. package/dest/tx/profiling.d.ts.map +1 -1
  453. package/dest/tx/profiling.js +47 -10
  454. package/dest/tx/protocol_contracts.d.ts +2 -2
  455. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  456. package/dest/tx/protocol_contracts.js +2 -2
  457. package/dest/tx/public_call_request_with_calldata.d.ts +7 -1
  458. package/dest/tx/public_call_request_with_calldata.d.ts.map +1 -1
  459. package/dest/tx/public_simulation_output.d.ts +4 -2
  460. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  461. package/dest/tx/public_simulation_output.js +7 -3
  462. package/dest/tx/state_reference.d.ts +3 -1
  463. package/dest/tx/state_reference.d.ts.map +1 -1
  464. package/dest/tx/tx.d.ts +24 -1
  465. package/dest/tx/tx.d.ts.map +1 -1
  466. package/dest/tx/tx.js +6 -3
  467. package/dest/tx/tx_context.d.ts +2 -1
  468. package/dest/tx/tx_context.d.ts.map +1 -1
  469. package/dest/tx/tx_effect.d.ts +32 -6
  470. package/dest/tx/tx_effect.d.ts.map +1 -1
  471. package/dest/tx/tx_effect.js +0 -7
  472. package/dest/tx/tx_execution_request.d.ts +30 -1
  473. package/dest/tx/tx_execution_request.d.ts.map +1 -1
  474. package/dest/tx/tx_hash.d.ts +2 -1
  475. package/dest/tx/tx_hash.d.ts.map +1 -1
  476. package/dest/tx/tx_receipt.d.ts +62 -14
  477. package/dest/tx/tx_receipt.d.ts.map +1 -1
  478. package/dest/tx/tx_receipt.js +55 -16
  479. package/dest/tx/tx_request.d.ts +6 -1
  480. package/dest/tx/tx_request.d.ts.map +1 -1
  481. package/dest/tx/tx_request.js +2 -2
  482. package/dest/tx/validator/empty_validator.d.ts +2 -2
  483. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  484. package/dest/tx/validator/error_texts.d.ts +3 -2
  485. package/dest/tx/validator/error_texts.d.ts.map +1 -1
  486. package/dest/tx/validator/error_texts.js +3 -1
  487. package/dest/tx/validator/tx_validator.d.ts +2 -2
  488. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  489. package/dest/types/shared.d.ts +4 -1
  490. package/dest/types/shared.d.ts.map +1 -1
  491. package/dest/validators/schemas.d.ts +38 -38
  492. package/dest/validators/schemas.d.ts.map +1 -1
  493. package/dest/validators/schemas.js +4 -3
  494. package/dest/validators/types.d.ts +3 -3
  495. package/dest/validators/types.d.ts.map +1 -1
  496. package/dest/vks/verification_key.d.ts +22 -1
  497. package/dest/vks/verification_key.d.ts.map +1 -1
  498. package/dest/vks/vk_data.d.ts +7 -1
  499. package/dest/vks/vk_data.d.ts.map +1 -1
  500. package/dest/zkpassport/index.d.ts +3 -4
  501. package/dest/zkpassport/index.d.ts.map +1 -1
  502. package/dest/zkpassport/index.js +9 -9
  503. package/package.json +27 -13
  504. package/src/abi/function_call.ts +25 -3
  505. package/src/abi/utils.ts +17 -0
  506. package/src/auth_witness/auth_witness.ts +3 -3
  507. package/src/block/block_data.ts +26 -0
  508. package/src/block/block_hash.ts +26 -25
  509. package/src/block/block_parameter.ts +4 -2
  510. package/src/block/body.ts +2 -1
  511. package/src/block/checkpointed_l2_block.ts +8 -58
  512. package/src/block/in_block.ts +6 -6
  513. package/src/block/index.ts +1 -2
  514. package/src/block/l2_block.ts +102 -150
  515. package/src/block/l2_block_source.ts +93 -42
  516. package/src/block/l2_block_stream/interfaces.ts +8 -5
  517. package/src/block/l2_block_stream/l2_block_stream.ts +45 -37
  518. package/src/block/l2_block_stream/l2_tips_store_base.ts +2 -2
  519. package/src/block/test/l2_tips_store_test_suite.ts +4 -9
  520. package/src/block/validate_block_result.ts +5 -4
  521. package/src/checkpoint/checkpoint.ts +61 -21
  522. package/src/checkpoint/checkpoint_data.ts +51 -0
  523. package/src/checkpoint/index.ts +1 -0
  524. package/src/checkpoint/published_checkpoint.ts +7 -4
  525. package/src/config/index.ts +1 -0
  526. package/src/config/node-rpc-config.ts +1 -1
  527. package/src/config/sequencer-config.ts +29 -0
  528. package/src/contract/contract_address.ts +4 -4
  529. package/src/contract/contract_class.ts +3 -3
  530. package/src/contract/contract_class_id.ts +6 -5
  531. package/src/contract/index.ts +0 -2
  532. package/src/contract/interfaces/node-info.ts +3 -0
  533. package/src/contract/private_function.ts +3 -4
  534. package/src/contract/private_function_membership_proof.ts +1 -1
  535. package/src/database-version/database_version.ts +87 -0
  536. package/src/database-version/version_manager.ts +1 -77
  537. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  538. package/src/deserialization/index.ts +21 -0
  539. package/src/epoch-helpers/index.ts +13 -1
  540. package/src/file-store/local.ts +15 -5
  541. package/src/file-store/s3.ts +12 -3
  542. package/src/ha-signing/config.ts +149 -0
  543. package/src/ha-signing/index.ts +18 -0
  544. package/src/ha-signing/types.ts +112 -0
  545. package/src/hash/hash.ts +14 -10
  546. package/src/hash/map_slot.ts +3 -2
  547. package/src/interfaces/api_limit.ts +1 -0
  548. package/src/interfaces/archiver.ts +23 -24
  549. package/src/interfaces/aztec-node-admin.ts +26 -2
  550. package/src/interfaces/aztec-node.ts +86 -135
  551. package/src/interfaces/block-builder.ts +41 -23
  552. package/src/interfaces/configs.ts +13 -4
  553. package/src/interfaces/l2_logs_source.ts +17 -4
  554. package/src/interfaces/merkle_tree_operations.ts +1 -1
  555. package/src/interfaces/p2p.ts +1 -1
  556. package/src/interfaces/prover-broker.ts +22 -0
  557. package/src/interfaces/prover-client.ts +22 -0
  558. package/src/interfaces/slasher.ts +4 -0
  559. package/src/interfaces/tx_provider.ts +2 -2
  560. package/src/interfaces/validator.ts +20 -12
  561. package/src/kernel/hints/build_note_hash_read_request_hints.ts +31 -24
  562. package/src/kernel/hints/build_nullifier_read_request_hints.ts +32 -32
  563. package/src/kernel/hints/build_transient_data_hints.ts +17 -2
  564. package/src/kernel/hints/index.ts +2 -2
  565. package/src/kernel/hints/{key_validation_request_and_generator.ts → key_validation_request_and_separator.ts} +12 -15
  566. package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +10 -10
  567. package/src/kernel/private_circuit_public_inputs.ts +14 -14
  568. package/src/kernel/private_kernel_circuit_public_inputs.ts +2 -2
  569. package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +2 -2
  570. package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +5 -5
  571. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +5 -5
  572. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +5 -5
  573. package/src/kernel/private_validation_requests.ts +8 -8
  574. package/src/keys/derivation.ts +15 -15
  575. package/src/keys/key_types.ts +6 -2
  576. package/src/keys/public_keys.ts +2 -2
  577. package/src/keys/utils.ts +8 -4
  578. package/src/l1-contracts/slash_factory.ts +1 -0
  579. package/src/logs/debug_log_store.ts +54 -0
  580. package/src/logs/index.ts +1 -0
  581. package/src/logs/log_id.ts +22 -18
  582. package/src/logs/siloed_tag.ts +2 -2
  583. package/src/messaging/l2_to_l1_membership.ts +8 -6
  584. package/src/messaging/out_hash.ts +60 -29
  585. package/src/note/index.ts +0 -1
  586. package/src/note/note_dao.ts +18 -13
  587. package/src/p2p/attestation_utils.ts +56 -0
  588. package/src/p2p/block_proposal.ts +36 -15
  589. package/src/p2p/checkpoint_attestation.ts +6 -1
  590. package/src/p2p/checkpoint_proposal.ts +74 -24
  591. package/src/p2p/consensus_payload.ts +25 -17
  592. package/src/p2p/constants.ts +6 -0
  593. package/src/p2p/index.ts +1 -0
  594. package/src/p2p/message_validator.ts +14 -2
  595. package/src/p2p/signed_txs.ts +6 -1
  596. package/src/p2p/topic_type.ts +1 -1
  597. package/src/proofs/chonk_proof.ts +9 -5
  598. package/src/rollup/block_headers_hash.ts +1 -1
  599. package/src/rollup/block_rollup_public_inputs.ts +2 -2
  600. package/src/rollup/checkpoint_header.ts +22 -2
  601. package/src/rollup/checkpoint_rollup_public_inputs.ts +16 -10
  602. package/src/rollup/checkpoint_root_rollup_private_inputs.ts +14 -1
  603. package/src/rollup/root_rollup_public_inputs.ts +11 -8
  604. package/src/slashing/empire.ts +3 -1
  605. package/src/slashing/helpers.ts +8 -0
  606. package/src/slashing/tally.ts +8 -2
  607. package/src/slashing/types.ts +14 -0
  608. package/src/stats/stats.ts +0 -2
  609. package/src/tests/factories.ts +23 -43
  610. package/src/tests/jest.ts +1 -1
  611. package/src/tests/mocks.ts +90 -55
  612. package/src/timetable/index.ts +66 -0
  613. package/src/trees/public_data_leaf.ts +11 -5
  614. package/src/tx/block_header.ts +12 -4
  615. package/src/tx/global_variables.ts +3 -3
  616. package/src/tx/indexed_tx_effect.ts +3 -2
  617. package/src/tx/private_execution_result.ts +1 -1
  618. package/src/tx/profiling.ts +51 -9
  619. package/src/tx/protocol_contracts.ts +2 -2
  620. package/src/tx/public_simulation_output.ts +4 -0
  621. package/src/tx/tx.ts +8 -9
  622. package/src/tx/tx_effect.ts +0 -9
  623. package/src/tx/tx_receipt.ts +85 -18
  624. package/src/tx/tx_request.ts +2 -2
  625. package/src/tx/validator/empty_validator.ts +1 -1
  626. package/src/tx/validator/error_texts.ts +4 -1
  627. package/src/tx/validator/tx_validator.ts +1 -1
  628. package/src/validators/schemas.ts +8 -1
  629. package/src/validators/types.ts +5 -4
  630. package/src/zkpassport/index.ts +11 -12
  631. package/dest/block/l2_block_code_to_purge.d.ts +0 -11
  632. package/dest/block/l2_block_code_to_purge.d.ts.map +0 -1
  633. package/dest/block/l2_block_code_to_purge.js +0 -55
  634. package/dest/block/l2_block_header.d.ts +0 -94
  635. package/dest/block/l2_block_header.d.ts.map +0 -1
  636. package/dest/block/l2_block_header.js +0 -160
  637. package/dest/block/l2_block_new.d.ts +0 -134
  638. package/dest/block/l2_block_new.d.ts.map +0 -1
  639. package/dest/block/l2_block_new.js +0 -155
  640. package/dest/contract/contract_class_metadata.d.ts +0 -8
  641. package/dest/contract/contract_class_metadata.d.ts.map +0 -1
  642. package/dest/contract/contract_class_metadata.js +0 -1
  643. package/dest/contract/contract_metadata.d.ts +0 -7
  644. package/dest/contract/contract_metadata.d.ts.map +0 -1
  645. package/dest/contract/contract_metadata.js +0 -1
  646. package/dest/database-version/index.d.ts +0 -2
  647. package/dest/database-version/index.d.ts.map +0 -1
  648. package/dest/database-version/index.js +0 -1
  649. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -25
  650. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  651. package/dest/note/notes_filter.d.ts +0 -27
  652. package/dest/note/notes_filter.d.ts.map +0 -1
  653. package/dest/note/notes_filter.js +0 -11
  654. package/src/block/l2_block_code_to_purge.ts +0 -80
  655. package/src/block/l2_block_header.ts +0 -255
  656. package/src/block/l2_block_new.ts +0 -211
  657. package/src/contract/contract_class_metadata.ts +0 -8
  658. package/src/contract/contract_metadata.ts +0 -7
  659. package/src/database-version/index.ts +0 -1
  660. package/src/note/notes_filter.ts +0 -38
@@ -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) {
@@ -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,3 +1,4 @@
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';
@@ -19,12 +20,13 @@ import type { PeerId } from '@libp2p/interface';
19
20
  import { z } from 'zod';
20
21
 
21
22
  import type { CommitteeAttestationsAndSigners } from '../block/index.js';
23
+ import { type ValidatorHASignerConfig, ValidatorHASignerConfigSchema } from '../ha-signing/index.js';
22
24
  import { AllowedElementSchema } from './allowed_element.js';
23
25
 
24
26
  /**
25
27
  * Validator client configuration
26
28
  */
27
- export interface ValidatorClientConfig {
29
+ export type ValidatorClientConfig = ValidatorHASignerConfig & {
28
30
  /** The private keys of the validators participating in attestation duties */
29
31
  validatorPrivateKeys?: SecretValue<`0x${string}`[]>;
30
32
 
@@ -43,27 +45,28 @@ export interface ValidatorClientConfig {
43
45
  /** Whether to re-execute transactions in a block proposal before attesting */
44
46
  validatorReexecute: boolean;
45
47
 
46
- /** Will re-execute until this many milliseconds are left in the slot */
47
- validatorReexecuteDeadlineMs: number;
48
-
49
48
  /** Whether to always reexecute block proposals, even for non-validator nodes or when out of the currnet committee */
50
49
  alwaysReexecuteBlockProposals?: boolean;
51
50
 
52
51
  /** Whether to run in fisherman mode: validates all proposals and attestations but does not broadcast attestations or participate in consensus */
53
52
  fishermanMode?: boolean;
54
53
 
55
- // TODO(palla/mbps): Change default to false once checkpoint validation is stable
56
- /** Skip checkpoint proposal validation and always attest (default: true) */
54
+ /** Skip checkpoint proposal validation and always attest (default: false) */
57
55
  skipCheckpointProposalValidation?: boolean;
58
56
 
59
- // TODO(palla/mbps): Change default to false once block sync is stable
60
- /** Skip pushing re-executed blocks to archiver (default: true) */
57
+ /** Skip pushing re-executed blocks to archiver (default: false) */
61
58
  skipPushProposedBlocksToArchiver?: boolean;
62
- }
59
+
60
+ /** Agree to attest to equivocated checkpoint proposals (for testing purposes only) */
61
+ attestToEquivocatedProposals?: boolean;
62
+ };
63
63
 
64
64
  export type ValidatorClientFullConfig = ValidatorClientConfig &
65
65
  Pick<SequencerConfig, 'txPublicSetupAllowList' | 'broadcastInvalidBlockProposal'> &
66
- Pick<SlasherConfig, 'slashBroadcastedInvalidBlockPenalty'> & {
66
+ Pick<
67
+ SlasherConfig,
68
+ 'slashBroadcastedInvalidBlockPenalty' | 'slashDuplicateProposalPenalty' | 'slashDuplicateAttestationPenalty'
69
+ > & {
67
70
  /**
68
71
  * Whether transactions are disabled for this node
69
72
  * @remarks This should match the property in P2PConfig. It's not picked from there to avoid circular dependencies.
@@ -72,17 +75,17 @@ export type ValidatorClientFullConfig = ValidatorClientConfig &
72
75
  };
73
76
 
74
77
  export const ValidatorClientConfigSchema = zodFor<Omit<ValidatorClientConfig, 'validatorPrivateKeys'>>()(
75
- z.object({
78
+ ValidatorHASignerConfigSchema.extend({
76
79
  validatorAddresses: z.array(schemas.EthAddress).optional(),
77
80
  disableValidator: z.boolean(),
78
81
  disabledValidators: z.array(schemas.EthAddress),
79
82
  attestationPollingIntervalMs: z.number().min(0),
80
83
  validatorReexecute: z.boolean(),
81
- validatorReexecuteDeadlineMs: z.number().min(0),
82
84
  alwaysReexecuteBlockProposals: z.boolean().optional(),
83
85
  fishermanMode: z.boolean().optional(),
84
86
  skipCheckpointProposalValidation: z.boolean().optional(),
85
87
  skipPushProposedBlocksToArchiver: z.boolean().optional(),
88
+ attestToEquivocatedProposals: z.boolean().optional(),
86
89
  }),
87
90
  );
88
91
 
@@ -91,6 +94,8 @@ export const ValidatorClientFullConfigSchema = zodFor<Omit<ValidatorClientFullCo
91
94
  txPublicSetupAllowList: z.array(AllowedElementSchema).optional(),
92
95
  broadcastInvalidBlockProposal: z.boolean().optional(),
93
96
  slashBroadcastedInvalidBlockPenalty: schemas.BigInt,
97
+ slashDuplicateProposalPenalty: schemas.BigInt,
98
+ slashDuplicateAttestationPenalty: schemas.BigInt,
94
99
  disableTransactions: z.boolean().optional(),
95
100
  }),
96
101
  );
@@ -116,6 +121,7 @@ export interface Validator {
116
121
  createCheckpointProposal(
117
122
  checkpointHeader: CheckpointHeader,
118
123
  archive: Fr,
124
+ feeAssetPriceModifier: bigint,
119
125
  lastBlockInfo: CreateCheckpointProposalLastBlockData | undefined,
120
126
  proposerAddress: EthAddress | undefined,
121
127
  options: CheckpointProposalOptions,
@@ -148,5 +154,7 @@ export interface Validator {
148
154
  signAttestationsAndSigners(
149
155
  attestationsAndSigners: CommitteeAttestationsAndSigners,
150
156
  proposer: EthAddress,
157
+ slot: SlotNumber,
158
+ blockNumber: BlockNumber | CheckpointNumber,
151
159
  ): Promise<Signature>;
152
160
  }
@@ -11,7 +11,6 @@ import type { ScopedNoteHash } from '../note_hash.js';
11
11
  import { NoteHashReadRequestHintsBuilder } from './note_hash_read_request_hints.js';
12
12
  import type { ScopedReadRequest } from './read_request.js';
13
13
  import { PendingReadHint, ReadRequestActionEnum, ReadRequestResetActions } from './read_request_hints.js';
14
- import { ScopedValueCache } from './scoped_value_cache.js';
15
14
 
16
15
  export function isValidNoteHashReadRequest(readRequest: ScopedReadRequest, noteHash: ScopedNoteHash) {
17
16
  return (
@@ -24,7 +23,6 @@ export function isValidNoteHashReadRequest(readRequest: ScopedReadRequest, noteH
24
23
  export function getNoteHashReadRequestResetActions(
25
24
  noteHashReadRequests: ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>,
26
25
  noteHashes: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
27
- futureNoteHashes: ScopedNoteHash[],
28
26
  ): ReadRequestResetActions<typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX> {
29
27
  const resetActions = ReadRequestResetActions.empty(MAX_NOTE_HASH_READ_REQUESTS_PER_TX);
30
28
 
@@ -36,24 +34,23 @@ export function getNoteHashReadRequestResetActions(
36
34
  noteHashMap.set(value, arr);
37
35
  });
38
36
 
39
- const futureNoteHashMap = new ScopedValueCache(futureNoteHashes);
40
-
41
37
  for (let i = 0; i < noteHashReadRequests.claimedLength; ++i) {
42
38
  const readRequest = noteHashReadRequests.array[i];
43
39
 
44
- const pendingNoteHash = noteHashMap
45
- .get(readRequest.value.toBigInt())
46
- ?.find(n => isValidNoteHashReadRequest(readRequest, n.noteHash));
47
-
48
- if (pendingNoteHash !== undefined) {
49
- resetActions.actions[i] = ReadRequestActionEnum.READ_AS_PENDING;
50
- resetActions.pendingReadHints.push(new PendingReadHint(i, pendingNoteHash.index));
51
- } else if (
52
- !futureNoteHashMap
53
- .get(readRequest)
54
- .find(futureNoteHash => isValidNoteHashReadRequest(readRequest, futureNoteHash))
55
- ) {
40
+ if (readRequest.contractAddress.isZero()) {
41
+ // Settled read: empty contract address means resolve against the note hash tree.
56
42
  resetActions.actions[i] = ReadRequestActionEnum.READ_AS_SETTLED;
43
+ } else {
44
+ // Pending read: non-empty contract address means match against a pending note hash.
45
+ const pendingNoteHash = noteHashMap
46
+ .get(readRequest.value.toBigInt())
47
+ ?.find(n => isValidNoteHashReadRequest(readRequest, n.noteHash));
48
+
49
+ if (pendingNoteHash) {
50
+ resetActions.actions[i] = ReadRequestActionEnum.READ_AS_PENDING;
51
+ resetActions.pendingReadHints.push(new PendingReadHint(i, pendingNoteHash.index));
52
+ }
53
+ // Otherwise, the read request may be resolved by a future note hash. Leave as NOOP.
57
54
  }
58
55
  }
59
56
 
@@ -76,15 +73,26 @@ export async function buildNoteHashReadRequestHintsFromResetActions<PENDING exte
76
73
  builder.addPendingReadRequest(hint.readRequestIndex, hint.pendingValueIndex);
77
74
  });
78
75
 
76
+ // Collect all settled read requests
77
+ const settledRequests: { index: number; readRequest: ScopedReadRequest }[] = [];
79
78
  for (let i = 0; i < resetActions.actions.length; i++) {
80
79
  if (resetActions.actions[i] === ReadRequestActionEnum.READ_AS_SETTLED) {
81
- const readRequest = noteHashReadRequests.array[i];
82
- const membershipWitness = await oracle.getNoteHashMembershipWitness(readRequest.value);
83
- if (!membershipWitness) {
84
- throw new Error('Read request is reading an unknown note hash.');
85
- }
86
- builder.addSettledReadRequest(i, membershipWitness, readRequest.value);
80
+ settledRequests.push({ index: i, readRequest: noteHashReadRequests.array[i] });
81
+ }
82
+ }
83
+
84
+ // Fetch all membership witnesses in parallel
85
+ const membershipWitnesses = await Promise.all(
86
+ settledRequests.map(({ readRequest }) => oracle.getNoteHashMembershipWitness(readRequest.value)),
87
+ );
88
+
89
+ // Add settled read requests to builder
90
+ for (let i = 0; i < settledRequests.length; i++) {
91
+ const membershipWitness = membershipWitnesses[i];
92
+ if (!membershipWitness) {
93
+ throw new Error('Read request is reading an unknown note hash.');
87
94
  }
95
+ builder.addSettledReadRequest(settledRequests[i].index, membershipWitness, settledRequests[i].readRequest.value);
88
96
  }
89
97
 
90
98
  const noteHashMap: Map<bigint, { noteHash: ScopedNoteHash; index: number }[]> = new Map();
@@ -104,11 +112,10 @@ export async function buildNoteHashReadRequestHints<PENDING extends number, SETT
104
112
  },
105
113
  noteHashReadRequests: ClaimedLengthArray<ScopedReadRequest, typeof MAX_NOTE_HASH_READ_REQUESTS_PER_TX>,
106
114
  noteHashes: ClaimedLengthArray<ScopedNoteHash, typeof MAX_NOTE_HASHES_PER_TX>,
107
- futureNoteHashes: ScopedNoteHash[],
108
115
  maxPending: PENDING = MAX_NOTE_HASH_READ_REQUESTS_PER_TX as PENDING,
109
116
  maxSettled: SETTLED = MAX_NOTE_HASH_READ_REQUESTS_PER_TX as SETTLED,
110
117
  ) {
111
- const resetActions = getNoteHashReadRequestResetActions(noteHashReadRequests, noteHashes, futureNoteHashes);
118
+ const resetActions = getNoteHashReadRequestResetActions(noteHashReadRequests, noteHashes);
112
119
  return await buildNoteHashReadRequestHintsFromResetActions(
113
120
  oracle,
114
121
  noteHashReadRequests,
@@ -6,14 +6,12 @@ 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';
13
12
  import { NullifierReadRequestHintsBuilder } from './nullifier_read_request_hints.js';
14
13
  import { ScopedReadRequest } from './read_request.js';
15
14
  import { PendingReadHint, ReadRequestActionEnum, ReadRequestResetActions } from './read_request_hints.js';
16
- import { ScopedValueCache } from './scoped_value_cache.js';
17
15
 
18
16
  export function isValidNullifierReadRequest(readRequest: ScopedReadRequest, nullifier: ScopedNullifier) {
19
17
  return (
@@ -31,7 +29,6 @@ interface NullifierMembershipWitnessWithPreimage {
31
29
  export function getNullifierReadRequestResetActions(
32
30
  nullifierReadRequests: ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>,
33
31
  nullifiers: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
34
- futureNullifiers: ScopedNullifier[],
35
32
  ): ReadRequestResetActions<typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX> {
36
33
  const resetActions = ReadRequestResetActions.empty(MAX_NULLIFIER_READ_REQUESTS_PER_TX);
37
34
 
@@ -43,23 +40,23 @@ export function getNullifierReadRequestResetActions(
43
40
  nullifierMap.set(value, arr);
44
41
  });
45
42
 
46
- const futureNullifiersMap = new ScopedValueCache(futureNullifiers);
47
-
48
43
  for (let i = 0; i < nullifierReadRequests.claimedLength; ++i) {
49
44
  const readRequest = nullifierReadRequests.array[i];
50
- const pendingNullifier = nullifierMap
51
- .get(readRequest.value.toBigInt())
52
- ?.find(({ nullifier }) => isValidNullifierReadRequest(readRequest, nullifier));
53
-
54
- if (pendingNullifier !== undefined) {
55
- resetActions.actions[i] = ReadRequestActionEnum.READ_AS_PENDING;
56
- resetActions.pendingReadHints.push(new PendingReadHint(i, pendingNullifier.index));
57
- } else if (
58
- !futureNullifiersMap
59
- .get(readRequest)
60
- .some(futureNullifier => isValidNullifierReadRequest(readRequest, futureNullifier))
61
- ) {
45
+
46
+ if (readRequest.contractAddress.isZero()) {
47
+ // Settled read: empty contract address means resolve against the nullifier tree.
62
48
  resetActions.actions[i] = ReadRequestActionEnum.READ_AS_SETTLED;
49
+ } else {
50
+ // Pending read: non-empty contract address means match against a pending nullifier.
51
+ const pendingNullifier = nullifierMap
52
+ .get(readRequest.value.toBigInt())
53
+ ?.find(({ nullifier }) => isValidNullifierReadRequest(readRequest, nullifier));
54
+
55
+ if (pendingNullifier) {
56
+ resetActions.actions[i] = ReadRequestActionEnum.READ_AS_PENDING;
57
+ resetActions.pendingReadHints.push(new PendingReadHint(i, pendingNullifier.index));
58
+ }
59
+ // Otherwise, the read request may be resolved by a future nullifier. Leave as NOOP.
63
60
  }
64
61
  }
65
62
 
@@ -74,7 +71,6 @@ export async function buildNullifierReadRequestHintsFromResetActions<PENDING ext
74
71
  resetActions: ReadRequestResetActions<typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>,
75
72
  maxPending: PENDING = MAX_NULLIFIER_READ_REQUESTS_PER_TX as PENDING,
76
73
  maxSettled: SETTLED = MAX_NULLIFIER_READ_REQUESTS_PER_TX as SETTLED,
77
- siloed = false,
78
74
  ) {
79
75
  const builder = new NullifierReadRequestHintsBuilder(maxPending, maxSettled);
80
76
 
@@ -82,21 +78,28 @@ export async function buildNullifierReadRequestHintsFromResetActions<PENDING ext
82
78
  builder.addPendingReadRequest(hint.readRequestIndex, hint.pendingValueIndex);
83
79
  });
84
80
 
81
+ // Collect all settled read requests
82
+ const settledRequests: { index: number; readRequest: ScopedReadRequest }[] = [];
85
83
  for (let i = 0; i < resetActions.actions.length; i++) {
86
84
  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
- );
85
+ settledRequests.push({ index: i, readRequest: nullifierReadRequests.array[i] });
97
86
  }
98
87
  }
99
88
 
89
+ const siloedValues = settledRequests.map(({ readRequest }) => readRequest.value);
90
+
91
+ // Fetch all membership witnesses in parallel
92
+ const membershipWitnesses = await Promise.all(siloedValues.map(value => oracle.getNullifierMembershipWitness(value)));
93
+
94
+ // Add settled read requests to builder
95
+ for (let i = 0; i < settledRequests.length; i++) {
96
+ builder.addSettledReadRequest(
97
+ settledRequests[i].index,
98
+ membershipWitnesses[i].membershipWitness,
99
+ membershipWitnesses[i].leafPreimage,
100
+ );
101
+ }
102
+
100
103
  return builder.toHints();
101
104
  }
102
105
 
@@ -106,18 +109,15 @@ export async function buildNullifierReadRequestHints<PENDING extends number, SET
106
109
  },
107
110
  nullifierReadRequests: ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_TX>,
108
111
  nullifiers: ClaimedLengthArray<ScopedNullifier, typeof MAX_NULLIFIERS_PER_TX>,
109
- futureNullifiers: ScopedNullifier[],
110
112
  maxPending: PENDING = MAX_NULLIFIER_READ_REQUESTS_PER_TX as PENDING,
111
113
  maxSettled: SETTLED = MAX_NULLIFIER_READ_REQUESTS_PER_TX as SETTLED,
112
- siloed = false,
113
114
  ) {
114
- const resetActions = getNullifierReadRequestResetActions(nullifierReadRequests, nullifiers, futureNullifiers);
115
+ const resetActions = getNullifierReadRequestResetActions(nullifierReadRequests, nullifiers);
115
116
  return await buildNullifierReadRequestHintsFromResetActions(
116
117
  oracle,
117
118
  nullifierReadRequests,
118
119
  resetActions,
119
120
  maxPending,
120
121
  maxSettled,
121
- siloed,
122
122
  );
123
123
  }
@@ -4,6 +4,7 @@ import type { Tuple } from '@aztec/foundation/serialize';
4
4
  import type { ClaimedLengthArray } from '../claimed_length_array.js';
5
5
  import type { ScopedNoteHash } from '../note_hash.js';
6
6
  import type { ScopedNullifier } from '../nullifier.js';
7
+ import type { PrivateLogData, ScopedPrivateLogData } from '../private_log_data.js';
7
8
  import { isValidNoteHashReadRequest } from './build_note_hash_read_request_hints.js';
8
9
  import { isValidNullifierReadRequest } from './build_nullifier_read_request_hints.js';
9
10
  import type { ScopedReadRequest } from './read_request.js';
@@ -15,11 +16,13 @@ export function buildTransientDataHints<NOTE_HASHES_LEN extends number, NULLIFIE
15
16
  nullifiers: ClaimedLengthArray<ScopedNullifier, NULLIFIERS_LEN>,
16
17
  futureNoteHashReads: ScopedReadRequest[],
17
18
  futureNullifierReads: ScopedReadRequest[],
19
+ futureLogs: PrivateLogData[],
18
20
  noteHashNullifierCounterMap: Map<number, number>,
19
21
  splitCounter: number,
20
22
  ): { numTransientData: number; hints: Tuple<TransientDataSquashingHint, NULLIFIERS_LEN> } {
21
23
  const futureNoteHashReadsMap = new ScopedValueCache(futureNoteHashReads);
22
24
  const futureNullifierReadsMap = new ScopedValueCache(futureNullifierReads);
25
+ const futureLogNoteHashCounters = new Set(futureLogs.filter(l => l.noteHashCounter > 0).map(l => l.noteHashCounter));
23
26
 
24
27
  const nullifierIndexMap: Map<number, number> = new Map();
25
28
  nullifiers.getActiveItems().forEach((n, i) => nullifierIndexMap.set(n.counter, i));
@@ -28,10 +31,12 @@ export function buildTransientDataHints<NOTE_HASHES_LEN extends number, NULLIFIE
28
31
  for (let noteHashIndex = 0; noteHashIndex < noteHashes.claimedLength; noteHashIndex++) {
29
32
  const noteHash = noteHashes.array[noteHashIndex];
30
33
  const noteHashNullifierCounter = noteHashNullifierCounterMap.get(noteHash.counter);
31
- // The note hash might not be linked to a nullifier or it might be read in the future
34
+ // The note hash might not be linked to a nullifier, or it might be read in the future, or a future log might be
35
+ // linked to it.
32
36
  if (
33
37
  !noteHashNullifierCounter ||
34
- futureNoteHashReadsMap.get(noteHash).find(read => isValidNoteHashReadRequest(read, noteHash))
38
+ futureNoteHashReadsMap.get(noteHash).find(read => isValidNoteHashReadRequest(read, noteHash)) ||
39
+ futureLogNoteHashCounters.has(noteHash.counter)
35
40
  ) {
36
41
  continue;
37
42
  }
@@ -77,3 +82,13 @@ export function buildTransientDataHints<NOTE_HASHES_LEN extends number, NULLIFIE
77
82
  hints: padArrayEnd(hints, noActionHint, nullifiers.array.length as NULLIFIERS_LEN),
78
83
  };
79
84
  }
85
+
86
+ /** Counts private logs that are linked to squashed note hashes and would be removed along with them. */
87
+ export function countSquashedLogs<NOTE_HASHES_LEN extends number, LOGS_LEN extends number>(
88
+ noteHashes: ClaimedLengthArray<ScopedNoteHash, NOTE_HASHES_LEN>,
89
+ privateLogs: ClaimedLengthArray<ScopedPrivateLogData, LOGS_LEN>,
90
+ squashingHints: TransientDataSquashingHint[],
91
+ ): number {
92
+ const squashedNoteHashCounters = new Set(squashingHints.map(h => noteHashes.array[h.noteHashIndex].counter));
93
+ return privateLogs.getActiveItems().filter(l => squashedNoteHashCounters.has(l.inner.noteHashCounter)).length;
94
+ }
@@ -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
  }
@@ -3,14 +3,14 @@ import type { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { BufferReader, FieldReader, serializeToBuffer } from '@aztec/foundation/serialize';
4
4
 
5
5
  import { AztecAddress } from '../../aztec-address/index.js';
6
- import { KeyValidationRequestAndGenerator } from './key_validation_request_and_generator.js';
6
+ import { KeyValidationRequestAndSeparator } from './key_validation_request_and_separator.js';
7
7
 
8
8
  /**
9
9
  * Request for validating keys used in the app.
10
10
  */
11
- export class ScopedKeyValidationRequestAndGenerator {
11
+ export class ScopedKeyValidationRequestAndSeparator {
12
12
  constructor(
13
- public readonly request: KeyValidationRequestAndGenerator,
13
+ public readonly request: KeyValidationRequestAndSeparator,
14
14
  public readonly contractAddress: AztecAddress,
15
15
  ) {}
16
16
 
@@ -20,8 +20,8 @@ export class ScopedKeyValidationRequestAndGenerator {
20
20
 
21
21
  static fromBuffer(buffer: Buffer | BufferReader) {
22
22
  const reader = BufferReader.asReader(buffer);
23
- return new ScopedKeyValidationRequestAndGenerator(
24
- KeyValidationRequestAndGenerator.fromBuffer(reader),
23
+ return new ScopedKeyValidationRequestAndSeparator(
24
+ KeyValidationRequestAndSeparator.fromBuffer(reader),
25
25
  AztecAddress.fromBuffer(reader),
26
26
  );
27
27
  }
@@ -30,16 +30,16 @@ export class ScopedKeyValidationRequestAndGenerator {
30
30
  const fields = [...this.request.toFields(), this.contractAddress.toField()];
31
31
  if (fields.length !== SCOPED_KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH) {
32
32
  throw new Error(
33
- `Invalid number of fields for ScopedKeyValidationRequestAndGenerator. Expected ${SCOPED_KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH}, got ${fields.length}`,
33
+ `Invalid number of fields for ScopedKeyValidationRequestAndSeparator. Expected ${SCOPED_KEY_VALIDATION_REQUEST_AND_GENERATOR_LENGTH}, got ${fields.length}`,
34
34
  );
35
35
  }
36
36
  return fields;
37
37
  }
38
38
 
39
- static fromFields(fields: Fr[] | FieldReader): ScopedKeyValidationRequestAndGenerator {
39
+ static fromFields(fields: Fr[] | FieldReader): ScopedKeyValidationRequestAndSeparator {
40
40
  const reader = FieldReader.asReader(fields);
41
- return new ScopedKeyValidationRequestAndGenerator(
42
- KeyValidationRequestAndGenerator.fromFields(reader),
41
+ return new ScopedKeyValidationRequestAndSeparator(
42
+ KeyValidationRequestAndSeparator.fromFields(reader),
43
43
  AztecAddress.fromFields(reader),
44
44
  );
45
45
  }
@@ -49,6 +49,6 @@ export class ScopedKeyValidationRequestAndGenerator {
49
49
  }
50
50
 
51
51
  static empty() {
52
- return new ScopedKeyValidationRequestAndGenerator(KeyValidationRequestAndGenerator.empty(), AztecAddress.ZERO);
52
+ return new ScopedKeyValidationRequestAndSeparator(KeyValidationRequestAndSeparator.empty(), AztecAddress.ZERO);
53
53
  }
54
54
  }