@aztec/stdlib 0.0.1-commit.d431d1c → 0.0.1-commit.dbf9cec

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 (455) hide show
  1. package/dest/abi/decoder.d.ts +1 -1
  2. package/dest/abi/decoder.d.ts.map +1 -1
  3. package/dest/abi/decoder.js +1 -4
  4. package/dest/abi/encoder.d.ts +1 -1
  5. package/dest/abi/encoder.d.ts.map +1 -1
  6. package/dest/abi/encoder.js +9 -5
  7. package/dest/abi/function_call.d.ts +39 -9
  8. package/dest/abi/function_call.d.ts.map +1 -1
  9. package/dest/abi/function_call.js +20 -3
  10. package/dest/auth_witness/auth_witness.js +3 -3
  11. package/dest/avm/avm.d.ts +300 -300
  12. package/dest/avm/avm_proving_request.d.ts +166 -166
  13. package/dest/avm/revert_code.d.ts +16 -1
  14. package/dest/avm/revert_code.d.ts.map +1 -1
  15. package/dest/avm/revert_code.js +15 -5
  16. package/dest/block/block_data.d.ts +52 -0
  17. package/dest/block/block_data.d.ts.map +1 -0
  18. package/dest/block/block_data.js +12 -0
  19. package/dest/block/block_hash.d.ts +16 -18
  20. package/dest/block/block_hash.d.ts.map +1 -1
  21. package/dest/block/block_hash.js +21 -31
  22. package/dest/block/block_parameter.d.ts +4 -4
  23. package/dest/block/block_parameter.d.ts.map +1 -1
  24. package/dest/block/block_parameter.js +2 -2
  25. package/dest/block/checkpointed_l2_block.d.ts +6 -6
  26. package/dest/block/checkpointed_l2_block.d.ts.map +1 -1
  27. package/dest/block/checkpointed_l2_block.js +3 -3
  28. package/dest/block/in_block.d.ts +11 -11
  29. package/dest/block/in_block.d.ts.map +1 -1
  30. package/dest/block/in_block.js +5 -5
  31. package/dest/block/index.d.ts +3 -2
  32. package/dest/block/index.d.ts.map +1 -1
  33. package/dest/block/index.js +2 -1
  34. package/dest/block/{l2_block_new.d.ts → l2_block.d.ts} +8 -7
  35. package/dest/block/l2_block.d.ts.map +1 -0
  36. package/dest/block/{l2_block_new.js → l2_block.js} +5 -9
  37. package/dest/block/l2_block_source.d.ts +58 -30
  38. package/dest/block/l2_block_source.d.ts.map +1 -1
  39. package/dest/block/l2_block_stream/interfaces.d.ts +3 -3
  40. package/dest/block/l2_block_stream/interfaces.d.ts.map +1 -1
  41. package/dest/block/l2_block_stream/l2_block_stream.d.ts +2 -3
  42. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  43. package/dest/block/l2_block_stream/l2_block_stream.js +14 -4
  44. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts +3 -3
  45. package/dest/block/l2_block_stream/l2_tips_store_base.d.ts.map +1 -1
  46. package/dest/block/test/l2_tips_store_test_suite.js +2 -2
  47. package/dest/checkpoint/checkpoint.d.ts +27 -13
  48. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  49. package/dest/checkpoint/checkpoint.js +27 -16
  50. package/dest/checkpoint/checkpoint_data.d.ts +120 -0
  51. package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
  52. package/dest/checkpoint/checkpoint_data.js +26 -0
  53. package/dest/checkpoint/index.d.ts +2 -1
  54. package/dest/checkpoint/index.d.ts.map +1 -1
  55. package/dest/checkpoint/index.js +1 -0
  56. package/dest/checkpoint/published_checkpoint.d.ts +19 -4
  57. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  58. package/dest/checkpoint/published_checkpoint.js +1 -2
  59. package/dest/config/index.d.ts +2 -1
  60. package/dest/config/index.d.ts.map +1 -1
  61. package/dest/config/index.js +1 -0
  62. package/dest/config/node-rpc-config.js +1 -1
  63. package/dest/config/sequencer-config.d.ts +10 -0
  64. package/dest/config/sequencer-config.d.ts.map +1 -0
  65. package/dest/config/sequencer-config.js +18 -0
  66. package/dest/contract/contract_address.js +4 -4
  67. package/dest/contract/contract_class.d.ts +2 -3
  68. package/dest/contract/contract_class.d.ts.map +1 -1
  69. package/dest/contract/contract_class_id.d.ts +2 -2
  70. package/dest/contract/contract_class_id.d.ts.map +1 -1
  71. package/dest/contract/contract_class_id.js +6 -5
  72. package/dest/contract/interfaces/node-info.d.ts +3 -1
  73. package/dest/contract/interfaces/node-info.d.ts.map +1 -1
  74. package/dest/contract/interfaces/node-info.js +2 -1
  75. package/dest/contract/private_function.d.ts +1 -1
  76. package/dest/contract/private_function.d.ts.map +1 -1
  77. package/dest/contract/private_function.js +3 -4
  78. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  79. package/dest/contract/private_function_membership_proof.js +1 -1
  80. package/dest/database-version/database_version.d.ts +58 -0
  81. package/dest/database-version/database_version.d.ts.map +1 -0
  82. package/dest/database-version/database_version.js +69 -0
  83. package/dest/database-version/version_manager.d.ts +2 -50
  84. package/dest/database-version/version_manager.d.ts.map +1 -1
  85. package/dest/database-version/version_manager.js +1 -66
  86. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts +2 -2
  87. package/dest/delayed_public_mutable/delayed_public_mutable_values.d.ts.map +1 -1
  88. package/dest/delayed_public_mutable/delayed_public_mutable_values.js +7 -10
  89. package/dest/epoch-helpers/index.d.ts +7 -1
  90. package/dest/epoch-helpers/index.d.ts.map +1 -1
  91. package/dest/epoch-helpers/index.js +9 -3
  92. package/dest/file-store/local.d.ts +3 -3
  93. package/dest/file-store/local.d.ts.map +1 -1
  94. package/dest/file-store/local.js +13 -4
  95. package/dest/file-store/s3.d.ts +1 -1
  96. package/dest/file-store/s3.d.ts.map +1 -1
  97. package/dest/file-store/s3.js +11 -3
  98. package/dest/ha-signing/config.d.ts +101 -0
  99. package/dest/ha-signing/config.d.ts.map +1 -0
  100. package/dest/ha-signing/config.js +92 -0
  101. package/dest/ha-signing/index.d.ts +3 -0
  102. package/dest/ha-signing/index.d.ts.map +1 -0
  103. package/dest/ha-signing/index.js +2 -0
  104. package/dest/ha-signing/types.d.ts +85 -0
  105. package/dest/ha-signing/types.d.ts.map +1 -0
  106. package/dest/ha-signing/types.js +32 -0
  107. package/dest/hash/hash.d.ts +2 -1
  108. package/dest/hash/hash.d.ts.map +1 -1
  109. package/dest/hash/hash.js +16 -10
  110. package/dest/hash/map_slot.d.ts +1 -1
  111. package/dest/hash/map_slot.d.ts.map +1 -1
  112. package/dest/hash/map_slot.js +4 -3
  113. package/dest/interfaces/archiver.d.ts +1 -1
  114. package/dest/interfaces/archiver.d.ts.map +1 -1
  115. package/dest/interfaces/archiver.js +22 -16
  116. package/dest/interfaces/aztec-node-admin.d.ts +49 -3
  117. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  118. package/dest/interfaces/aztec-node-admin.js +12 -4
  119. package/dest/interfaces/aztec-node.d.ts +51 -58
  120. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  121. package/dest/interfaces/aztec-node.js +13 -17
  122. package/dest/interfaces/block-builder.d.ts +13 -7
  123. package/dest/interfaces/block-builder.d.ts.map +1 -1
  124. package/dest/interfaces/block-builder.js +7 -0
  125. package/dest/interfaces/configs.d.ts +18 -3
  126. package/dest/interfaces/configs.d.ts.map +1 -1
  127. package/dest/interfaces/configs.js +4 -1
  128. package/dest/interfaces/get_logs_response.d.ts +15 -8
  129. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  130. package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
  131. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  132. package/dest/interfaces/p2p.d.ts +4 -9
  133. package/dest/interfaces/p2p.d.ts.map +1 -1
  134. package/dest/interfaces/prover-broker.d.ts +16 -1
  135. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  136. package/dest/interfaces/prover-broker.js +4 -1
  137. package/dest/interfaces/prover-client.d.ts +15 -1
  138. package/dest/interfaces/prover-client.d.ts.map +1 -1
  139. package/dest/interfaces/prover-client.js +12 -1
  140. package/dest/interfaces/proving-job.d.ts +202 -202
  141. package/dest/interfaces/slasher.d.ts +9 -1
  142. package/dest/interfaces/slasher.d.ts.map +1 -1
  143. package/dest/interfaces/slasher.js +2 -0
  144. package/dest/interfaces/tx_provider.d.ts +3 -3
  145. package/dest/interfaces/tx_provider.d.ts.map +1 -1
  146. package/dest/interfaces/validator.d.ts +52 -6
  147. package/dest/interfaces/validator.d.ts.map +1 -1
  148. package/dest/interfaces/validator.js +5 -2
  149. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +3 -3
  150. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  151. package/dest/kernel/hints/build_note_hash_read_request_hints.js +13 -10
  152. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +4 -4
  153. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  154. package/dest/kernel/hints/build_nullifier_read_request_hints.js +16 -15
  155. package/dest/kernel/hints/build_transient_data_hints.d.ts +5 -2
  156. package/dest/kernel/hints/build_transient_data_hints.d.ts.map +1 -1
  157. package/dest/kernel/hints/build_transient_data_hints.js +9 -3
  158. package/dest/kernel/hints/index.d.ts +2 -2
  159. package/dest/kernel/hints/index.js +2 -2
  160. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  161. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  162. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
  163. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
  164. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  165. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  166. package/dest/kernel/private_circuit_public_inputs.d.ts +9 -9
  167. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  168. package/dest/kernel/private_circuit_public_inputs.js +16 -16
  169. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +3 -3
  170. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  171. package/dest/kernel/private_kernel_circuit_public_inputs.js +4 -4
  172. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +3 -3
  173. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  174. package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
  175. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +3 -3
  176. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  177. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +7 -7
  178. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +3 -3
  179. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  180. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +7 -7
  181. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +3 -3
  182. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  183. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +7 -7
  184. package/dest/kernel/private_validation_requests.d.ts +3 -3
  185. package/dest/kernel/private_validation_requests.js +9 -9
  186. package/dest/keys/derivation.d.ts +3 -3
  187. package/dest/keys/derivation.js +15 -15
  188. package/dest/keys/key_types.d.ts +3 -3
  189. package/dest/keys/key_types.d.ts.map +1 -1
  190. package/dest/keys/public_keys.js +2 -2
  191. package/dest/keys/utils.d.ts +1 -1
  192. package/dest/keys/utils.d.ts.map +1 -1
  193. package/dest/keys/utils.js +8 -4
  194. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  195. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  196. package/dest/l1-contracts/slash_factory.js +1 -0
  197. package/dest/logs/debug_log_store.d.ts +30 -0
  198. package/dest/logs/debug_log_store.d.ts.map +1 -0
  199. package/dest/logs/debug_log_store.js +30 -0
  200. package/dest/logs/extended_directional_app_tagging_secret.d.ts +47 -0
  201. package/dest/logs/extended_directional_app_tagging_secret.d.ts.map +1 -0
  202. package/dest/logs/{directional_app_tagging_secret.js → extended_directional_app_tagging_secret.js} +23 -15
  203. package/dest/logs/extended_public_log.d.ts +13 -7
  204. package/dest/logs/extended_public_log.d.ts.map +1 -1
  205. package/dest/logs/index.d.ts +3 -2
  206. package/dest/logs/index.d.ts.map +1 -1
  207. package/dest/logs/index.js +2 -1
  208. package/dest/logs/log_id.d.ts +17 -14
  209. package/dest/logs/log_id.d.ts.map +1 -1
  210. package/dest/logs/log_id.js +20 -17
  211. package/dest/logs/pre_tag.d.ts +16 -11
  212. package/dest/logs/pre_tag.d.ts.map +1 -1
  213. package/dest/logs/pre_tag.js +2 -2
  214. package/dest/logs/private_log.d.ts +2 -2
  215. package/dest/logs/private_log.d.ts.map +1 -1
  216. package/dest/logs/siloed_tag.d.ts +5 -3
  217. package/dest/logs/siloed_tag.d.ts.map +1 -1
  218. package/dest/logs/siloed_tag.js +8 -6
  219. package/dest/logs/tag.js +1 -1
  220. package/dest/messaging/l2_to_l1_membership.d.ts +2 -2
  221. package/dest/messaging/l2_to_l1_membership.js +3 -3
  222. package/dest/note/index.d.ts +1 -2
  223. package/dest/note/index.d.ts.map +1 -1
  224. package/dest/note/index.js +0 -1
  225. package/dest/p2p/attestation_utils.d.ts +11 -1
  226. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  227. package/dest/p2p/attestation_utils.js +45 -0
  228. package/dest/p2p/block_proposal.d.ts +14 -7
  229. package/dest/p2p/block_proposal.d.ts.map +1 -1
  230. package/dest/p2p/block_proposal.js +3 -5
  231. package/dest/p2p/checkpoint_attestation.d.ts +2 -1
  232. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -1
  233. package/dest/p2p/checkpoint_attestation.js +1 -1
  234. package/dest/p2p/checkpoint_proposal.d.ts +27 -8
  235. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
  236. package/dest/p2p/checkpoint_proposal.js +30 -16
  237. package/dest/p2p/client_type.d.ts +2 -5
  238. package/dest/p2p/client_type.d.ts.map +1 -1
  239. package/dest/p2p/client_type.js +0 -7
  240. package/dest/p2p/consensus_payload.d.ts +12 -3
  241. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  242. package/dest/p2p/consensus_payload.js +22 -15
  243. package/dest/p2p/constants.d.ts +3 -1
  244. package/dest/p2p/constants.d.ts.map +1 -1
  245. package/dest/p2p/constants.js +1 -0
  246. package/dest/p2p/index.d.ts +1 -2
  247. package/dest/p2p/index.d.ts.map +1 -1
  248. package/dest/p2p/index.js +0 -1
  249. package/dest/p2p/message_validator.d.ts +18 -3
  250. package/dest/p2p/message_validator.d.ts.map +1 -1
  251. package/dest/p2p/message_validator.js +2 -1
  252. package/dest/p2p/topic_type.d.ts +3 -4
  253. package/dest/p2p/topic_type.d.ts.map +1 -1
  254. package/dest/p2p/topic_type.js +7 -24
  255. package/dest/rollup/checkpoint_header.d.ts +2 -2
  256. package/dest/rollup/checkpoint_header.js +2 -2
  257. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +6 -6
  258. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  259. package/dest/rollup/checkpoint_rollup_public_inputs.js +2 -2
  260. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +2 -2
  261. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  262. package/dest/rollup/root_rollup_public_inputs.d.ts +6 -6
  263. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  264. package/dest/rollup/root_rollup_public_inputs.js +3 -3
  265. package/dest/slashing/empire.d.ts +1 -1
  266. package/dest/slashing/empire.d.ts.map +1 -1
  267. package/dest/slashing/empire.js +2 -0
  268. package/dest/slashing/helpers.d.ts +2 -2
  269. package/dest/slashing/helpers.d.ts.map +1 -1
  270. package/dest/slashing/helpers.js +6 -0
  271. package/dest/slashing/tally.d.ts +2 -1
  272. package/dest/slashing/tally.d.ts.map +1 -1
  273. package/dest/slashing/tally.js +6 -2
  274. package/dest/slashing/types.d.ts +7 -3
  275. package/dest/slashing/types.d.ts.map +1 -1
  276. package/dest/slashing/types.js +13 -1
  277. package/dest/stats/stats.d.ts +1 -3
  278. package/dest/stats/stats.d.ts.map +1 -1
  279. package/dest/tests/factories.d.ts +3 -1
  280. package/dest/tests/factories.d.ts.map +1 -1
  281. package/dest/tests/factories.js +22 -14
  282. package/dest/tests/jest.d.ts +4 -4
  283. package/dest/tests/jest.js +9 -9
  284. package/dest/tests/mocks.d.ts +19 -11
  285. package/dest/tests/mocks.d.ts.map +1 -1
  286. package/dest/tests/mocks.js +37 -26
  287. package/dest/timetable/index.d.ts +37 -0
  288. package/dest/timetable/index.d.ts.map +1 -0
  289. package/dest/timetable/index.js +39 -0
  290. package/dest/trees/public_data_leaf.d.ts +2 -1
  291. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  292. package/dest/trees/public_data_leaf.js +7 -6
  293. package/dest/tx/block_header.d.ts +3 -2
  294. package/dest/tx/block_header.d.ts.map +1 -1
  295. package/dest/tx/block_header.js +4 -3
  296. package/dest/tx/global_variables.d.ts +4 -4
  297. package/dest/tx/global_variables.d.ts.map +1 -1
  298. package/dest/tx/in_tx.d.ts +3 -3
  299. package/dest/tx/indexed_tx_effect.d.ts +5 -5
  300. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  301. package/dest/tx/indexed_tx_effect.js +3 -2
  302. package/dest/tx/profiling.d.ts +4 -4
  303. package/dest/tx/profiling.d.ts.map +1 -1
  304. package/dest/tx/profiling.js +3 -3
  305. package/dest/tx/protocol_contracts.d.ts +1 -1
  306. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  307. package/dest/tx/protocol_contracts.js +2 -2
  308. package/dest/tx/public_simulation_output.d.ts +4 -2
  309. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  310. package/dest/tx/public_simulation_output.js +7 -3
  311. package/dest/tx/tx_receipt.d.ts +57 -15
  312. package/dest/tx/tx_receipt.d.ts.map +1 -1
  313. package/dest/tx/tx_receipt.js +55 -16
  314. package/dest/tx/tx_request.js +2 -2
  315. package/dest/tx/validator/empty_validator.d.ts +2 -2
  316. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  317. package/dest/tx/validator/error_texts.d.ts +1 -1
  318. package/dest/tx/validator/error_texts.js +1 -1
  319. package/dest/tx/validator/tx_validator.d.ts +2 -2
  320. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  321. package/dest/validators/schemas.d.ts +30 -30
  322. package/dest/validators/schemas.d.ts.map +1 -1
  323. package/dest/validators/schemas.js +4 -3
  324. package/dest/validators/types.d.ts +3 -3
  325. package/dest/validators/types.d.ts.map +1 -1
  326. package/package.json +25 -13
  327. package/src/abi/decoder.ts +1 -4
  328. package/src/abi/encoder.ts +8 -5
  329. package/src/abi/function_call.ts +25 -3
  330. package/src/auth_witness/auth_witness.ts +3 -3
  331. package/src/avm/revert_code.ts +15 -0
  332. package/src/block/block_data.ts +26 -0
  333. package/src/block/block_hash.ts +26 -47
  334. package/src/block/block_parameter.ts +3 -3
  335. package/src/block/checkpointed_l2_block.ts +4 -4
  336. package/src/block/in_block.ts +8 -8
  337. package/src/block/index.ts +2 -1
  338. package/src/block/{l2_block_new.ts → l2_block.ts} +8 -12
  339. package/src/block/l2_block_source.ts +62 -31
  340. package/src/block/l2_block_stream/interfaces.ts +2 -2
  341. package/src/block/l2_block_stream/l2_block_stream.ts +26 -6
  342. package/src/block/l2_block_stream/l2_tips_store_base.ts +2 -2
  343. package/src/block/test/l2_tips_store_test_suite.ts +4 -4
  344. package/src/checkpoint/checkpoint.ts +38 -20
  345. package/src/checkpoint/checkpoint_data.ts +51 -0
  346. package/src/checkpoint/index.ts +1 -0
  347. package/src/checkpoint/published_checkpoint.ts +3 -1
  348. package/src/config/index.ts +1 -0
  349. package/src/config/node-rpc-config.ts +1 -1
  350. package/src/config/sequencer-config.ts +29 -0
  351. package/src/contract/contract_address.ts +4 -4
  352. package/src/contract/contract_class.ts +3 -3
  353. package/src/contract/contract_class_id.ts +6 -5
  354. package/src/contract/interfaces/node-info.ts +3 -0
  355. package/src/contract/private_function.ts +3 -4
  356. package/src/contract/private_function_membership_proof.ts +1 -1
  357. package/src/database-version/database_version.ts +87 -0
  358. package/src/database-version/version_manager.ts +1 -77
  359. package/src/delayed_public_mutable/delayed_public_mutable_values.ts +9 -10
  360. package/src/epoch-helpers/index.ts +13 -1
  361. package/src/file-store/local.ts +15 -5
  362. package/src/file-store/s3.ts +12 -3
  363. package/src/ha-signing/config.ts +149 -0
  364. package/src/ha-signing/index.ts +18 -0
  365. package/src/ha-signing/types.ts +112 -0
  366. package/src/hash/hash.ts +14 -10
  367. package/src/hash/map_slot.ts +3 -2
  368. package/src/interfaces/archiver.ts +22 -25
  369. package/src/interfaces/aztec-node-admin.ts +26 -2
  370. package/src/interfaces/aztec-node.ts +73 -117
  371. package/src/interfaces/block-builder.ts +16 -5
  372. package/src/interfaces/configs.ts +13 -4
  373. package/src/interfaces/merkle_tree_operations.ts +1 -1
  374. package/src/interfaces/p2p.ts +3 -14
  375. package/src/interfaces/prover-broker.ts +22 -0
  376. package/src/interfaces/prover-client.ts +22 -0
  377. package/src/interfaces/slasher.ts +4 -0
  378. package/src/interfaces/tx_provider.ts +2 -2
  379. package/src/interfaces/validator.ts +14 -6
  380. package/src/kernel/hints/build_note_hash_read_request_hints.ts +14 -18
  381. package/src/kernel/hints/build_nullifier_read_request_hints.ts +16 -28
  382. package/src/kernel/hints/build_transient_data_hints.ts +17 -2
  383. package/src/kernel/hints/index.ts +2 -2
  384. package/src/kernel/hints/{key_validation_request_and_generator.ts → key_validation_request_and_separator.ts} +12 -15
  385. package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +10 -10
  386. package/src/kernel/private_circuit_public_inputs.ts +14 -14
  387. package/src/kernel/private_kernel_circuit_public_inputs.ts +2 -2
  388. package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +2 -2
  389. package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +5 -5
  390. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +5 -5
  391. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +5 -5
  392. package/src/kernel/private_validation_requests.ts +8 -8
  393. package/src/keys/derivation.ts +15 -15
  394. package/src/keys/key_types.ts +6 -2
  395. package/src/keys/public_keys.ts +2 -2
  396. package/src/keys/utils.ts +8 -4
  397. package/src/l1-contracts/slash_factory.ts +1 -0
  398. package/src/logs/debug_log_store.ts +54 -0
  399. package/src/logs/{directional_app_tagging_secret.ts → extended_directional_app_tagging_secret.ts} +24 -16
  400. package/src/logs/index.ts +2 -1
  401. package/src/logs/log_id.ts +22 -18
  402. package/src/logs/pre_tag.ts +5 -5
  403. package/src/logs/siloed_tag.ts +10 -4
  404. package/src/logs/tag.ts +1 -1
  405. package/src/messaging/l2_to_l1_membership.ts +3 -3
  406. package/src/note/index.ts +0 -1
  407. package/src/p2p/attestation_utils.ts +56 -0
  408. package/src/p2p/block_proposal.ts +13 -8
  409. package/src/p2p/checkpoint_attestation.ts +6 -1
  410. package/src/p2p/checkpoint_proposal.ts +55 -16
  411. package/src/p2p/client_type.ts +0 -6
  412. package/src/p2p/consensus_payload.ts +25 -12
  413. package/src/p2p/constants.ts +3 -0
  414. package/src/p2p/index.ts +0 -1
  415. package/src/p2p/message_validator.ts +14 -2
  416. package/src/p2p/topic_type.ts +8 -15
  417. package/src/rollup/checkpoint_header.ts +2 -2
  418. package/src/rollup/checkpoint_rollup_public_inputs.ts +5 -5
  419. package/src/rollup/root_rollup_public_inputs.ts +7 -7
  420. package/src/slashing/empire.ts +3 -1
  421. package/src/slashing/helpers.ts +8 -0
  422. package/src/slashing/tally.ts +8 -2
  423. package/src/slashing/types.ts +14 -0
  424. package/src/stats/stats.ts +0 -2
  425. package/src/tests/factories.ts +27 -18
  426. package/src/tests/jest.ts +9 -9
  427. package/src/tests/mocks.ts +54 -30
  428. package/src/timetable/index.ts +66 -0
  429. package/src/trees/public_data_leaf.ts +11 -5
  430. package/src/tx/block_header.ts +8 -5
  431. package/src/tx/global_variables.ts +3 -3
  432. package/src/tx/indexed_tx_effect.ts +3 -2
  433. package/src/tx/profiling.ts +5 -5
  434. package/src/tx/protocol_contracts.ts +2 -2
  435. package/src/tx/public_simulation_output.ts +4 -0
  436. package/src/tx/tx_receipt.ts +85 -18
  437. package/src/tx/tx_request.ts +2 -2
  438. package/src/tx/validator/empty_validator.ts +1 -1
  439. package/src/tx/validator/error_texts.ts +1 -1
  440. package/src/tx/validator/tx_validator.ts +1 -1
  441. package/src/validators/schemas.ts +8 -1
  442. package/src/validators/types.ts +5 -4
  443. package/dest/block/l2_block_new.d.ts.map +0 -1
  444. package/dest/database-version/index.d.ts +0 -2
  445. package/dest/database-version/index.d.ts.map +0 -1
  446. package/dest/database-version/index.js +0 -1
  447. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -30
  448. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  449. package/dest/logs/directional_app_tagging_secret.d.ts +0 -40
  450. package/dest/logs/directional_app_tagging_secret.d.ts.map +0 -1
  451. package/dest/note/notes_filter.d.ts +0 -27
  452. package/dest/note/notes_filter.d.ts.map +0 -1
  453. package/dest/note/notes_filter.js +0 -11
  454. package/src/database-version/index.ts +0 -1
  455. package/src/note/notes_filter.ts +0 -38
@@ -8,15 +8,16 @@ import {
8
8
  } from '@aztec/foundation/branded-types';
9
9
  import { sum } from '@aztec/foundation/collection';
10
10
  import { Fr } from '@aztec/foundation/curves/bn254';
11
- import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
11
+ import { BufferReader, serializeSignedBigInt, serializeToBuffer } from '@aztec/foundation/serialize';
12
12
  import type { FieldsOf } from '@aztec/foundation/types';
13
13
 
14
14
  import { z } from 'zod';
15
15
 
16
- import { L2BlockNew } from '../block/l2_block_new.js';
16
+ import { L2Block } from '../block/l2_block.js';
17
17
  import { MAX_BLOCKS_PER_CHECKPOINT } from '../deserialization/index.js';
18
18
  import { computeCheckpointOutHash } from '../messaging/out_hash.js';
19
19
  import { CheckpointHeader } from '../rollup/checkpoint_header.js';
20
+ import { schemas } from '../schemas/schemas.js';
20
21
  import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
21
22
  import type { CheckpointInfo } from './checkpoint_info.js';
22
23
 
@@ -29,9 +30,11 @@ export class Checkpoint {
29
30
  /** Header of the checkpoint. */
30
31
  public header: CheckpointHeader,
31
32
  /** L2 blocks in the checkpoint. */
32
- public blocks: L2BlockNew[],
33
+ public blocks: L2Block[],
33
34
  /** Number of the checkpoint. */
34
35
  public number: CheckpointNumber,
36
+ /** Fee asset price modifier in basis points (from oracle). Defaults to 0 (no change). */
37
+ public feeAssetPriceModifier: bigint = 0n,
35
38
  ) {}
36
39
 
37
40
  get slot(): SlotNumber {
@@ -43,10 +46,14 @@ export class Checkpoint {
43
46
  .object({
44
47
  archive: AppendOnlyTreeSnapshot.schema,
45
48
  header: CheckpointHeader.schema,
46
- blocks: z.array(L2BlockNew.schema),
49
+ blocks: z.array(L2Block.schema),
47
50
  number: CheckpointNumberSchema,
51
+ feeAssetPriceModifier: schemas.BigInt,
48
52
  })
49
- .transform(({ archive, header, blocks, number }) => new Checkpoint(archive, header, blocks, number));
53
+ .transform(
54
+ ({ archive, header, blocks, number, feeAssetPriceModifier }) =>
55
+ new Checkpoint(archive, header, blocks, number, feeAssetPriceModifier),
56
+ );
50
57
  }
51
58
 
52
59
  static from(fields: FieldsOfCheckpoint) {
@@ -54,21 +61,28 @@ export class Checkpoint {
54
61
  }
55
62
 
56
63
  static getFields(fields: FieldsOfCheckpoint) {
57
- return [fields.archive, fields.header, fields.blocks, fields.number] as const;
64
+ return [fields.archive, fields.header, fields.blocks, fields.number, fields.feeAssetPriceModifier] as const;
58
65
  }
59
66
 
60
67
  static fromBuffer(buf: Buffer | BufferReader) {
61
68
  const reader = BufferReader.asReader(buf);
62
- return new Checkpoint(
63
- reader.readObject(AppendOnlyTreeSnapshot),
64
- reader.readObject(CheckpointHeader),
65
- reader.readVector(L2BlockNew, MAX_BLOCKS_PER_CHECKPOINT),
66
- CheckpointNumber(reader.readNumber()),
67
- );
69
+ const archive = reader.readObject(AppendOnlyTreeSnapshot);
70
+ const header = reader.readObject(CheckpointHeader);
71
+ const blocks = reader.readVector(L2Block, MAX_BLOCKS_PER_CHECKPOINT);
72
+ const number = CheckpointNumber(reader.readNumber());
73
+ const feeAssetPriceModifier = reader.readInt256();
74
+ return new Checkpoint(archive, header, blocks, number, feeAssetPriceModifier);
68
75
  }
69
76
 
70
77
  public toBuffer() {
71
- return serializeToBuffer(this.archive, this.header, this.blocks.length, this.blocks, this.number);
78
+ return serializeToBuffer(
79
+ this.archive,
80
+ this.header,
81
+ this.blocks.length,
82
+ this.blocks,
83
+ this.number,
84
+ serializeSignedBigInt(this.feeAssetPriceModifier),
85
+ );
72
86
  }
73
87
 
74
88
  public toBlobFields(): Fr[] {
@@ -80,9 +94,11 @@ export class Checkpoint {
80
94
  return this.header.hash();
81
95
  }
82
96
 
83
- // Returns the out hash computed from all l2-to-l1 messages in this checkpoint.
84
- // Note: This value is different from the out hash in the header, which is the **accumulated** out hash over all
85
- // checkpoints up to and including this one in the epoch.
97
+ /**
98
+ * Returns the out hash computed from all l2-to-l1 messages in this checkpoint.
99
+ * Note: This value is different from the out hash in the header, which is the **accumulated** out hash over all
100
+ * checkpoints up to and including this one in the epoch.
101
+ */
86
102
  public getCheckpointOutHash(): Fr {
87
103
  const msgs = this.blocks.map(block => block.body.txEffects.map(txEffect => txEffect.l2ToL1Msgs));
88
104
  return computeCheckpointOutHash(msgs);
@@ -129,22 +145,24 @@ export class Checkpoint {
129
145
  numBlocks = 1,
130
146
  startBlockNumber = 1,
131
147
  previousArchive,
148
+ feeAssetPriceModifier = 0n,
132
149
  ...options
133
150
  }: {
134
151
  numBlocks?: number;
135
152
  startBlockNumber?: number;
136
153
  previousArchive?: AppendOnlyTreeSnapshot;
154
+ feeAssetPriceModifier?: bigint;
137
155
  } & Partial<Parameters<typeof CheckpointHeader.random>[0]> &
138
- Partial<Parameters<typeof L2BlockNew.random>[1]> = {},
156
+ Partial<Parameters<typeof L2Block.random>[1]> = {},
139
157
  ) {
140
158
  const header = CheckpointHeader.random(options);
141
159
 
142
160
  // Create blocks sequentially to chain archive roots properly.
143
161
  // Each block's header.lastArchive must equal the previous block's archive.
144
- const blocks: L2BlockNew[] = [];
162
+ const blocks: L2Block[] = [];
145
163
  let lastArchive = previousArchive;
146
164
  for (let i = 0; i < numBlocks; i++) {
147
- const block = await L2BlockNew.random(BlockNumber(startBlockNumber + i), {
165
+ const block = await L2Block.random(BlockNumber(startBlockNumber + i), {
148
166
  indexWithinCheckpoint: IndexWithinCheckpoint(i),
149
167
  ...options,
150
168
  ...(lastArchive ? { lastArchive } : {}),
@@ -153,6 +171,6 @@ export class Checkpoint {
153
171
  blocks.push(block);
154
172
  }
155
173
 
156
- return new Checkpoint(AppendOnlyTreeSnapshot.random(), header, blocks, checkpointNumber);
174
+ return new Checkpoint(AppendOnlyTreeSnapshot.random(), header, blocks, checkpointNumber, feeAssetPriceModifier);
157
175
  }
158
176
  }
@@ -0,0 +1,51 @@
1
+ import {
2
+ BlockNumber,
3
+ BlockNumberSchema,
4
+ CheckpointNumber,
5
+ CheckpointNumberSchema,
6
+ } from '@aztec/foundation/branded-types';
7
+ import { Fr } from '@aztec/foundation/curves/bn254';
8
+ import { schemas } from '@aztec/foundation/schemas';
9
+
10
+ import { z } from 'zod';
11
+
12
+ import { CommitteeAttestation } from '../block/proposal/committee_attestation.js';
13
+ import { CheckpointHeader } from '../rollup/checkpoint_header.js';
14
+ import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
15
+ import { L1PublishedData } from './published_checkpoint.js';
16
+
17
+ /** Lightweight checkpoint metadata without full block data. */
18
+ export type CheckpointData = {
19
+ checkpointNumber: CheckpointNumber;
20
+ header: CheckpointHeader;
21
+ archive: AppendOnlyTreeSnapshot;
22
+ checkpointOutHash: Fr;
23
+ startBlock: BlockNumber;
24
+ blockCount: number;
25
+ attestations: CommitteeAttestation[];
26
+ l1: L1PublishedData;
27
+ };
28
+
29
+ export const CheckpointDataSchema = z
30
+ .object({
31
+ checkpointNumber: CheckpointNumberSchema,
32
+ header: CheckpointHeader.schema,
33
+ archive: AppendOnlyTreeSnapshot.schema,
34
+ checkpointOutHash: schemas.Fr,
35
+ startBlock: BlockNumberSchema,
36
+ blockCount: schemas.Integer,
37
+ attestations: z.array(CommitteeAttestation.schema),
38
+ l1: L1PublishedData.schema,
39
+ })
40
+ .transform(
41
+ (obj): CheckpointData => ({
42
+ checkpointNumber: obj.checkpointNumber,
43
+ header: obj.header,
44
+ archive: obj.archive,
45
+ checkpointOutHash: obj.checkpointOutHash,
46
+ startBlock: obj.startBlock,
47
+ blockCount: obj.blockCount,
48
+ attestations: obj.attestations,
49
+ l1: obj.l1,
50
+ }),
51
+ );
@@ -1,3 +1,4 @@
1
1
  export * from './checkpoint.js';
2
+ export * from './checkpoint_data.js';
2
3
  export * from './checkpoint_info.js';
3
4
  export * from './published_checkpoint.js';
@@ -55,9 +55,11 @@ export class L1PublishedData {
55
55
 
56
56
  export class PublishedCheckpoint {
57
57
  constructor(
58
+ /** The checkpoint itself. */
58
59
  public checkpoint: Checkpoint,
60
+ /** Info on when this checkpoint was published on L1. */
59
61
  public l1: L1PublishedData,
60
- // The attestations for the last block in the checkpoint.
62
+ /** The attestations for the last block in the checkpoint. */
61
63
  public attestations: CommitteeAttestation[],
62
64
  ) {}
63
65
 
@@ -1,2 +1,3 @@
1
1
  export * from './chain-config.js';
2
2
  export * from './node-rpc-config.js';
3
+ export * from './sequencer-config.js';
@@ -21,7 +21,7 @@ export const nodeRpcConfigMappings: ConfigMappingsType<NodeRPCConfig> = {
21
21
  rpcMaxBodySize: {
22
22
  env: 'RPC_MAX_BODY_SIZE',
23
23
  description: 'Maximum allowed batch size for JSON RPC batch requests.',
24
- defaultValue: '50mb',
24
+ defaultValue: '1mb',
25
25
  },
26
26
  };
27
27
 
@@ -0,0 +1,29 @@
1
+ import type { ConfigMappingsType } from '@aztec/foundation/config';
2
+
3
+ import type { SequencerConfig } from '../interfaces/configs.js';
4
+
5
+ /**
6
+ * Partial sequencer config mappings for fields that need to be shared across packages.
7
+ * The full sequencer config mappings remain in sequencer-client, but shared fields
8
+ * (like blockDurationMs needed by both p2p and sequencer-client) are defined here
9
+ * to avoid duplication.
10
+ */
11
+ export const sharedSequencerConfigMappings: ConfigMappingsType<
12
+ Pick<SequencerConfig, 'blockDurationMs' | 'expectedBlockProposalsPerSlot'>
13
+ > = {
14
+ blockDurationMs: {
15
+ env: 'SEQ_BLOCK_DURATION_MS',
16
+ description:
17
+ 'Duration per block in milliseconds when building multiple blocks per slot. ' +
18
+ 'If undefined (default), builds a single block per slot using the full slot duration.',
19
+ parseEnv: (val: string) => (val ? parseInt(val, 10) : undefined),
20
+ },
21
+ expectedBlockProposalsPerSlot: {
22
+ env: 'SEQ_EXPECTED_BLOCK_PROPOSALS_PER_SLOT',
23
+ description:
24
+ 'Expected number of block proposals per slot for P2P peer scoring. ' +
25
+ '0 (default) disables block proposal scoring. Set to a positive value to enable.',
26
+ parseEnv: (val: string) => (val ? parseInt(val, 10) : 0),
27
+ defaultValue: 0,
28
+ },
29
+ };
@@ -1,4 +1,4 @@
1
- import { GeneratorIndex } from '@aztec/constants';
1
+ import { DomainSeparator } from '@aztec/constants';
2
2
  import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
3
3
  import { Fr } from '@aztec/foundation/curves/bn254';
4
4
 
@@ -44,7 +44,7 @@ export async function computePartialAddress(
44
44
 
45
45
  return poseidon2HashWithSeparator(
46
46
  [instance.originalContractClassId, saltedInitializationHash],
47
- GeneratorIndex.PARTIAL_ADDRESS,
47
+ DomainSeparator.PARTIAL_ADDRESS,
48
48
  );
49
49
  }
50
50
 
@@ -57,7 +57,7 @@ export function computeSaltedInitializationHash(
57
57
  ): Promise<Fr> {
58
58
  return poseidon2HashWithSeparator(
59
59
  [instance.salt, instance.initializationHash, instance.deployer],
60
- GeneratorIndex.PARTIAL_ADDRESS,
60
+ DomainSeparator.PARTIAL_ADDRESS,
61
61
  );
62
62
  }
63
63
 
@@ -87,5 +87,5 @@ export async function computeInitializationHashFromEncodedArgs(
87
87
  encodedArgs: Fr[],
88
88
  ): Promise<Fr> {
89
89
  const argsHash = await computeVarArgsHash(encodedArgs);
90
- return poseidon2HashWithSeparator([initFn, argsHash], GeneratorIndex.CONSTRUCTOR);
90
+ return poseidon2HashWithSeparator([initFn, argsHash], DomainSeparator.INITIALIZER);
91
91
  }
@@ -8,7 +8,7 @@ import { type ContractClassIdPreimage, computeContractClassIdWithPreimage } from
8
8
  import type { ContractClass, ContractClassWithId } from './interfaces/index.js';
9
9
 
10
10
  /** Contract artifact including its artifact hash */
11
- type ContractArtifactWithHash = ContractArtifact & { artifactHash: Fr };
11
+ export type ContractArtifactWithHash = ContractArtifact & { artifactHash: Fr };
12
12
 
13
13
  const cmpFunctionArtifacts = <T extends { selector: FunctionSelector }>(a: T, b: T) =>
14
14
  a.selector.toField().cmp(b.selector.toField());
@@ -35,8 +35,8 @@ export async function getContractClassFromArtifact(
35
35
 
36
36
  privateArtifactFunctions.sort(cmpFunctionArtifacts);
37
37
 
38
- const contractClass: ContractClass = {
39
- version: 1,
38
+ const contractClass = {
39
+ version: 1 as const,
40
40
  artifactHash,
41
41
  packedBytecode,
42
42
  privateFunctions: privateArtifactFunctions,
@@ -1,4 +1,4 @@
1
- import { GeneratorIndex, MAX_PACKED_PUBLIC_BYTECODE_SIZE_IN_FIELDS } from '@aztec/constants';
1
+ import { DomainSeparator, MAX_PACKED_PUBLIC_BYTECODE_SIZE_IN_FIELDS } from '@aztec/constants';
2
2
  import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
3
3
  import { Fr } from '@aztec/foundation/curves/bn254';
4
4
 
@@ -13,7 +13,7 @@ import { computePrivateFunctionsRoot } from './private_function.js';
13
13
  *
14
14
  * ```
15
15
  * version = 1
16
- * private_function_leaves = private_functions.map(fn => pedersen([fn.function_selector as Field, fn.vk_hash], GENERATOR__FUNCTION_LEAF))
16
+ * private_function_leaves = private_functions.map(fn => pedersen([fn.function_selector as Field, fn.vk_hash], GENERATOR__PRIVATE_FUNCTION_LEAF))
17
17
  * private_functions_root = merkleize(private_function_leaves)
18
18
  * bytecode_commitment = calculate_commitment(packed_bytecode)
19
19
  * contract_class_id = pedersen([version, artifact_hash, private_functions_root, bytecode_commitment], GENERATOR__CLASS_IDENTIFIER)
@@ -40,7 +40,7 @@ export async function computeContractClassIdWithPreimage(
40
40
  : await computePublicBytecodeCommitment(contractClass.packedBytecode);
41
41
  const id = await poseidon2HashWithSeparator(
42
42
  [artifactHash, privateFunctionsRoot, publicBytecodeCommitment],
43
- GeneratorIndex.CONTRACT_CLASS_ID,
43
+ DomainSeparator.CONTRACT_CLASS_ID,
44
44
  );
45
45
  return { id, artifactHash, privateFunctionsRoot, publicBytecodeCommitment };
46
46
  }
@@ -60,7 +60,7 @@ export type ContractClassIdPreimage = {
60
60
  };
61
61
 
62
62
  export async function computePublicBytecodeCommitment(packedBytecode: Buffer) {
63
- // Encode the buffer into field elements (chunked into 32 bytes each)
63
+ // Encode the buffer into field elements (chunked into 31 bytes each)
64
64
  // The first element is the length of the bytecode (in bytes)
65
65
  const [bytecodeLengthAsField, ...bytecodeAsFields] = bufferAsFields(
66
66
  packedBytecode,
@@ -72,5 +72,6 @@ export async function computePublicBytecodeCommitment(packedBytecode: Buffer) {
72
72
 
73
73
  // NOTE: hash the bytecode here only up to the actual length of the bytecode.
74
74
  // We do not hash the entire max bytecode length!
75
- return await poseidon2HashWithSeparator(bytecodeAsFields.slice(0, bytecodeLength), GeneratorIndex.PUBLIC_BYTECODE);
75
+ const sep = BigInt(DomainSeparator.PUBLIC_BYTECODE) + (bytecodeLengthAsField.toBigInt() << 32n);
76
+ return await poseidon2HashWithSeparator(bytecodeAsFields.slice(0, bytecodeLength), new Fr(sep).toNumber());
76
77
  }
@@ -19,6 +19,8 @@ export interface NodeInfo {
19
19
  l1ContractAddresses: L1ContractAddresses;
20
20
  /** Protocol contract addresses */
21
21
  protocolContractAddresses: ProtocolContractAddresses;
22
+ /** Whether the node requires real proofs for transaction submission. */
23
+ realProofs: boolean;
22
24
  }
23
25
 
24
26
  export const NodeInfoSchema: ZodFor<NodeInfo> = z
@@ -29,5 +31,6 @@ export const NodeInfoSchema: ZodFor<NodeInfo> = z
29
31
  enr: z.string().optional(),
30
32
  l1ContractAddresses: L1ContractAddressesSchema,
31
33
  protocolContractAddresses: ProtocolContractAddressesSchema,
34
+ realProofs: z.boolean(),
32
35
  })
33
36
  .transform(obj => ({ enr: undefined, ...obj }));
@@ -1,5 +1,4 @@
1
- import { FUNCTION_TREE_HEIGHT, GeneratorIndex } from '@aztec/constants';
2
- import { pedersenHash } from '@aztec/foundation/crypto/pedersen';
1
+ import { DomainSeparator, FUNCTION_TREE_HEIGHT } from '@aztec/constants';
3
2
  import { poseidon2Hash, poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
4
3
  import { Fr } from '@aztec/foundation/curves/bn254';
5
4
  import { type MerkleTree, MerkleTreeCalculator } from '@aztec/foundation/trees';
@@ -32,13 +31,13 @@ function computePrivateFunctionLeaves(fns: PrivateFunction[]): Promise<Buffer[]>
32
31
 
33
32
  /** Returns the leaf for a given private function. */
34
33
  export async function computePrivateFunctionLeaf(fn: PrivateFunction): Promise<Buffer> {
35
- return (await poseidon2HashWithSeparator([fn.selector, fn.vkHash], GeneratorIndex.FUNCTION_LEAF)).toBuffer();
34
+ return (await poseidon2HashWithSeparator([fn.selector, fn.vkHash], DomainSeparator.PRIVATE_FUNCTION_LEAF)).toBuffer();
36
35
  }
37
36
 
38
37
  async function getPrivateFunctionTreeCalculator(): Promise<MerkleTreeCalculator> {
39
38
  if (!privateFunctionTreeCalculator) {
40
39
  const functionTreeZeroLeaf = (
41
- await pedersenHash(new Array(PRIVATE_FUNCTION_SIZE).fill(0))
40
+ await poseidon2Hash(new Array(PRIVATE_FUNCTION_SIZE).fill(0))
42
41
  ).toBuffer() as Buffer<ArrayBuffer>;
43
42
  privateFunctionTreeCalculator = await MerkleTreeCalculator.create(
44
43
  FUNCTION_TREE_HEIGHT,
@@ -99,7 +99,7 @@ export async function createPrivateFunctionMembershipProof(
99
99
  * contract_class = db.get_contract_class(contract_class_id)
100
100
  *
101
101
  * // Compute function leaf and assert it belongs to the private functions tree
102
- * function_leaf = pedersen([selector as Field, vk_hash], GENERATOR__FUNCTION_LEAF)
102
+ * function_leaf = pedersen([selector as Field, vk_hash], GENERATOR__PRIVATE_FUNCTION_LEAF)
103
103
  * computed_private_function_tree_root = compute_root(function_leaf, private_function_tree_sibling_path)
104
104
  * assert computed_private_function_tree_root == contract_class.private_functions_root
105
105
  *
@@ -0,0 +1,87 @@
1
+ import { EthAddress } from '@aztec/foundation/eth-address';
2
+ import { jsonParseWithSchema, jsonStringify } from '@aztec/foundation/json-rpc';
3
+
4
+ import { z } from 'zod';
5
+
6
+ /**
7
+ * Symbol for Node.js custom inspect. Using Symbol.for() is the documented way to
8
+ * reference this without importing node:util. In browsers, objects with this symbol
9
+ * simply won't have custom inspect behavior (which is fine).
10
+ * @see https://nodejs.org/api/util.html#utilinspectcustom
11
+ */
12
+ const inspectCustomSymbol = Symbol.for('nodejs.util.inspect.custom');
13
+
14
+ /**
15
+ * Represents a version record for storing in a version file.
16
+ */
17
+ export class DatabaseVersion {
18
+ constructor(
19
+ /** The version of the data on disk. Used to perform upgrades */
20
+ public readonly schemaVersion: number,
21
+ /** The rollup the data pertains to */
22
+ public readonly rollupAddress: EthAddress,
23
+ ) {}
24
+
25
+ public toBuffer(): Buffer {
26
+ return Buffer.from(jsonStringify(this));
27
+ }
28
+
29
+ public static fromBuffer(buf: Buffer): DatabaseVersion {
30
+ try {
31
+ return jsonParseWithSchema(buf.toString('utf-8'), DatabaseVersion.schema);
32
+ } catch (err) {
33
+ throw new Error(`Failed to deserialize version information: ${err}`, { cause: err });
34
+ }
35
+ }
36
+
37
+ /**
38
+ * Compares two versions. If the rollups addresses are different then it returns undefined
39
+ */
40
+ public cmp(other: DatabaseVersion): undefined | -1 | 0 | 1 {
41
+ if (this.rollupAddress.equals(other.rollupAddress)) {
42
+ if (this.schemaVersion < other.schemaVersion) {
43
+ return -1;
44
+ } else if (this.schemaVersion > other.schemaVersion) {
45
+ return 1;
46
+ } else {
47
+ return 0;
48
+ }
49
+ }
50
+ return undefined;
51
+ }
52
+
53
+ /**
54
+ * Checks if two versions exactly match
55
+ */
56
+ public equals(other: DatabaseVersion): boolean {
57
+ return this.cmp(other) === 0;
58
+ }
59
+
60
+ /**
61
+ * Returns the schema for this class
62
+ */
63
+ static get schema() {
64
+ return z
65
+ .object({
66
+ schemaVersion: z.number(),
67
+ rollupAddress: EthAddress.schema,
68
+ })
69
+ .transform(({ schemaVersion, rollupAddress }) => new DatabaseVersion(schemaVersion, rollupAddress));
70
+ }
71
+
72
+ /** Allows for better introspection in Node.js console. Ignored in browser envs. */
73
+ public [inspectCustomSymbol](): string {
74
+ return this.toString();
75
+ }
76
+
77
+ public toString(): string {
78
+ return `DatabaseVersion{schemaVersion=${this.schemaVersion},rollupAddress=${this.rollupAddress}"}`;
79
+ }
80
+
81
+ /**
82
+ * Returns an empty instance
83
+ */
84
+ static empty() {
85
+ return new DatabaseVersion(0, EthAddress.ZERO);
86
+ }
87
+ }
@@ -1,86 +1,10 @@
1
1
  import { EthAddress } from '@aztec/foundation/eth-address';
2
- import { jsonParseWithSchema, jsonStringify } from '@aztec/foundation/json-rpc';
3
2
  import { type Logger, createLogger } from '@aztec/foundation/log';
4
3
 
5
4
  import fs from 'fs/promises';
6
- import { inspect } from 'node:util';
7
5
  import { join } from 'path';
8
- import { z } from 'zod';
9
6
 
10
- /**
11
- * Represents a version record for storing in a version file.
12
- */
13
- export class DatabaseVersion {
14
- constructor(
15
- /** The version of the data on disk. Used to perform upgrades */
16
- public readonly schemaVersion: number,
17
- /** The rollup the data pertains to */
18
- public readonly rollupAddress: EthAddress,
19
- ) {}
20
-
21
- public toBuffer(): Buffer {
22
- return Buffer.from(jsonStringify(this));
23
- }
24
-
25
- public static fromBuffer(buf: Buffer): DatabaseVersion {
26
- try {
27
- return jsonParseWithSchema(buf.toString('utf-8'), DatabaseVersion.schema);
28
- } catch (err) {
29
- throw new Error(`Failed to deserialize version information: ${err}`, { cause: err });
30
- }
31
- }
32
-
33
- /**
34
- * Compares two versions. If the rollups addresses are different then it returns undefined
35
- */
36
- public cmp(other: DatabaseVersion): undefined | -1 | 0 | 1 {
37
- if (this.rollupAddress.equals(other.rollupAddress)) {
38
- if (this.schemaVersion < other.schemaVersion) {
39
- return -1;
40
- } else if (this.schemaVersion > other.schemaVersion) {
41
- return 1;
42
- } else {
43
- return 0;
44
- }
45
- }
46
- return undefined;
47
- }
48
-
49
- /**
50
- * Checks if two versions exactly match
51
- */
52
- public equals(other: DatabaseVersion): boolean {
53
- return this.cmp(other) === 0;
54
- }
55
-
56
- /**
57
- * Returns the schema for this class
58
- */
59
- static get schema() {
60
- return z
61
- .object({
62
- schemaVersion: z.number(),
63
- rollupAddress: EthAddress.schema,
64
- })
65
- .transform(({ schemaVersion, rollupAddress }) => new DatabaseVersion(schemaVersion, rollupAddress));
66
- }
67
-
68
- /** Allows for better introspection. */
69
- public [inspect.custom](): string {
70
- return this.toString();
71
- }
72
-
73
- public toString(): string {
74
- return `DatabaseVersion{schemaVersion=${this.schemaVersion},rollupAddress=${this.rollupAddress}"}`;
75
- }
76
-
77
- /**
78
- * Returns an empty instance
79
- */
80
- static empty() {
81
- return new DatabaseVersion(0, EthAddress.ZERO);
82
- }
83
- }
7
+ import { DatabaseVersion } from './database_version.js';
84
8
 
85
9
  export type DatabaseVersionManagerFs = Pick<typeof fs, 'readFile' | 'writeFile' | 'rm' | 'mkdir'>;
86
10
 
@@ -68,23 +68,22 @@ export class DelayedPublicMutableValues {
68
68
  }
69
69
 
70
70
  static async readFromTree(delayedPublicMutableSlot: Fr, readStorage: (storageSlot: Fr) => Promise<Fr>) {
71
- const fields = [];
72
- for (let i = 0; i < DELAYED_PUBLIC_MUTABLE_VALUES_LEN; i++) {
73
- fields.push(await readStorage(delayedPublicMutableSlot.add(new Fr(i))));
74
- }
75
- return DelayedPublicMutableValues.fromFields(fields);
71
+ const fieldPromises = Array.from({ length: DELAYED_PUBLIC_MUTABLE_VALUES_LEN }).map((_, i) =>
72
+ readStorage(delayedPublicMutableSlot.add(new Fr(i))),
73
+ );
74
+ return DelayedPublicMutableValues.fromFields(await Promise.all(fieldPromises));
76
75
  }
77
76
 
78
77
  isEmpty(): boolean {
79
78
  return this.svc.isEmpty() && this.sdc.isEmpty();
80
79
  }
81
80
 
82
- async writeToTree(delayedPublicMutableSlot: Fr, storageWrite: (storageSlot: Fr, value: Fr) => Promise<void>) {
83
- const fields = this.toFields();
81
+ writeToTree(delayedPublicMutableSlot: Fr, storageWrite: (storageSlot: Fr, value: Fr) => Promise<void>) {
82
+ const fieldPromises = this.toFields().map((field, i) =>
83
+ storageWrite(delayedPublicMutableSlot.add(new Fr(i)), field),
84
+ );
84
85
 
85
- for (let i = 0; i < fields.length; i++) {
86
- await storageWrite(delayedPublicMutableSlot.add(new Fr(i)), fields[i]);
87
- }
86
+ return Promise.all(fieldPromises);
88
87
  }
89
88
 
90
89
  async hash(): Promise<Fr> {
@@ -11,6 +11,7 @@ export type L1RollupConstants = {
11
11
  epochDuration: number;
12
12
  ethereumSlotDuration: number;
13
13
  proofSubmissionEpochs: number;
14
+ targetCommitteeSize: number;
14
15
  };
15
16
 
16
17
  export const EmptyL1RollupConstants: L1RollupConstants = {
@@ -20,6 +21,7 @@ export const EmptyL1RollupConstants: L1RollupConstants = {
20
21
  slotDuration: 1,
21
22
  ethereumSlotDuration: 1,
22
23
  proofSubmissionEpochs: 1,
24
+ targetCommitteeSize: 48,
23
25
  };
24
26
 
25
27
  export const L1RollupConstantsSchema = zodFor<L1RollupConstants>()(
@@ -30,6 +32,7 @@ export const L1RollupConstantsSchema = zodFor<L1RollupConstants>()(
30
32
  epochDuration: z.number(),
31
33
  ethereumSlotDuration: z.number(),
32
34
  proofSubmissionEpochs: z.number(),
35
+ targetCommitteeSize: z.number(),
33
36
  }),
34
37
  );
35
38
 
@@ -51,6 +54,15 @@ export function getSlotAtTimestamp(
51
54
  : SlotNumber.fromBigInt((ts - constants.l1GenesisTime) / BigInt(constants.slotDuration));
52
55
  }
53
56
 
57
+ /** Returns the L2 slot number at the next L1 block based on the current timestamp. */
58
+ export function getSlotAtNextL1Block(
59
+ currentL1Timestamp: bigint,
60
+ constants: Pick<L1RollupConstants, 'l1GenesisTime' | 'slotDuration' | 'ethereumSlotDuration'>,
61
+ ): SlotNumber {
62
+ const nextL1BlockTimestamp = currentL1Timestamp + BigInt(constants.ethereumSlotDuration);
63
+ return getSlotAtTimestamp(nextL1BlockTimestamp, constants);
64
+ }
65
+
54
66
  /** Returns the epoch number for a given timestamp. */
55
67
  export function getEpochNumberAtTimestamp(
56
68
  ts: bigint,
@@ -69,7 +81,7 @@ export function getSlotRangeForEpoch(
69
81
  epochNumber: EpochNumber,
70
82
  constants: Pick<L1RollupConstants, 'epochDuration'>,
71
83
  ): [SlotNumber, SlotNumber] {
72
- const startSlot = SlotNumber(epochNumber * constants.epochDuration);
84
+ const startSlot = SlotNumber(Number(epochNumber) * constants.epochDuration);
73
85
  return [startSlot, SlotNumber(startSlot + constants.epochDuration - 1)];
74
86
  }
75
87