@aztec/stdlib 0.0.1-commit.c80b6263 → 0.0.1-commit.cd76b27

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 (328) hide show
  1. package/dest/abi/function_call.d.ts +39 -9
  2. package/dest/abi/function_call.d.ts.map +1 -1
  3. package/dest/abi/function_call.js +20 -3
  4. package/dest/auth_witness/auth_witness.js +3 -3
  5. package/dest/block/block_data.d.ts +52 -0
  6. package/dest/block/block_data.d.ts.map +1 -0
  7. package/dest/block/block_data.js +12 -0
  8. package/dest/block/block_hash.d.ts +14 -17
  9. package/dest/block/block_hash.d.ts.map +1 -1
  10. package/dest/block/block_hash.js +21 -34
  11. package/dest/block/block_parameter.d.ts +2 -2
  12. package/dest/block/block_parameter.d.ts.map +1 -1
  13. package/dest/block/in_block.d.ts +5 -5
  14. package/dest/block/in_block.js +2 -2
  15. package/dest/block/index.d.ts +2 -1
  16. package/dest/block/index.d.ts.map +1 -1
  17. package/dest/block/index.js +1 -0
  18. package/dest/block/l2_block.d.ts +3 -2
  19. package/dest/block/l2_block.d.ts.map +1 -1
  20. package/dest/block/l2_block.js +2 -3
  21. package/dest/block/l2_block_source.d.ts +24 -4
  22. package/dest/block/l2_block_source.d.ts.map +1 -1
  23. package/dest/checkpoint/checkpoint.d.ts +21 -7
  24. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  25. package/dest/checkpoint/checkpoint.js +24 -13
  26. package/dest/checkpoint/checkpoint_data.d.ts +120 -0
  27. package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
  28. package/dest/checkpoint/checkpoint_data.js +26 -0
  29. package/dest/checkpoint/index.d.ts +2 -1
  30. package/dest/checkpoint/index.d.ts.map +1 -1
  31. package/dest/checkpoint/index.js +1 -0
  32. package/dest/checkpoint/published_checkpoint.d.ts +17 -2
  33. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  34. package/dest/checkpoint/published_checkpoint.js +1 -2
  35. package/dest/config/index.d.ts +2 -1
  36. package/dest/config/index.d.ts.map +1 -1
  37. package/dest/config/index.js +1 -0
  38. package/dest/config/sequencer-config.d.ts +10 -0
  39. package/dest/config/sequencer-config.d.ts.map +1 -0
  40. package/dest/config/sequencer-config.js +18 -0
  41. package/dest/contract/contract_address.js +4 -4
  42. package/dest/contract/contract_class_id.d.ts +2 -2
  43. package/dest/contract/contract_class_id.d.ts.map +1 -1
  44. package/dest/contract/contract_class_id.js +6 -5
  45. package/dest/contract/interfaces/node-info.d.ts +3 -1
  46. package/dest/contract/interfaces/node-info.d.ts.map +1 -1
  47. package/dest/contract/interfaces/node-info.js +2 -1
  48. package/dest/contract/private_function.js +2 -2
  49. package/dest/contract/private_function_membership_proof.d.ts +1 -1
  50. package/dest/contract/private_function_membership_proof.js +1 -1
  51. package/dest/database-version/database_version.d.ts +58 -0
  52. package/dest/database-version/database_version.d.ts.map +1 -0
  53. package/dest/database-version/database_version.js +69 -0
  54. package/dest/database-version/version_manager.d.ts +2 -50
  55. package/dest/database-version/version_manager.d.ts.map +1 -1
  56. package/dest/database-version/version_manager.js +1 -66
  57. package/dest/epoch-helpers/index.d.ts +5 -1
  58. package/dest/epoch-helpers/index.d.ts.map +1 -1
  59. package/dest/epoch-helpers/index.js +4 -2
  60. package/dest/file-store/local.d.ts +3 -3
  61. package/dest/file-store/local.d.ts.map +1 -1
  62. package/dest/file-store/local.js +13 -4
  63. package/dest/file-store/s3.d.ts +1 -1
  64. package/dest/file-store/s3.d.ts.map +1 -1
  65. package/dest/file-store/s3.js +11 -3
  66. package/dest/hash/hash.d.ts +2 -1
  67. package/dest/hash/hash.d.ts.map +1 -1
  68. package/dest/hash/hash.js +16 -10
  69. package/dest/hash/map_slot.d.ts +1 -1
  70. package/dest/hash/map_slot.d.ts.map +1 -1
  71. package/dest/hash/map_slot.js +4 -3
  72. package/dest/interfaces/archiver.d.ts +1 -1
  73. package/dest/interfaces/archiver.d.ts.map +1 -1
  74. package/dest/interfaces/archiver.js +9 -3
  75. package/dest/interfaces/aztec-node-admin.d.ts +46 -3
  76. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  77. package/dest/interfaces/aztec-node-admin.js +12 -4
  78. package/dest/interfaces/aztec-node.d.ts +31 -52
  79. package/dest/interfaces/aztec-node.d.ts.map +1 -1
  80. package/dest/interfaces/aztec-node.js +3 -7
  81. package/dest/interfaces/block-builder.d.ts +9 -4
  82. package/dest/interfaces/block-builder.d.ts.map +1 -1
  83. package/dest/interfaces/block-builder.js +7 -0
  84. package/dest/interfaces/configs.d.ts +17 -2
  85. package/dest/interfaces/configs.d.ts.map +1 -1
  86. package/dest/interfaces/configs.js +4 -1
  87. package/dest/interfaces/get_logs_response.d.ts +14 -7
  88. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  89. package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
  90. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  91. package/dest/interfaces/p2p.d.ts +2 -2
  92. package/dest/interfaces/p2p.d.ts.map +1 -1
  93. package/dest/interfaces/prover-broker.d.ts +16 -1
  94. package/dest/interfaces/prover-broker.d.ts.map +1 -1
  95. package/dest/interfaces/prover-broker.js +4 -1
  96. package/dest/interfaces/prover-client.d.ts +6 -1
  97. package/dest/interfaces/prover-client.d.ts.map +1 -1
  98. package/dest/interfaces/prover-client.js +5 -0
  99. package/dest/interfaces/proving-job.d.ts +202 -202
  100. package/dest/interfaces/slasher.d.ts +9 -1
  101. package/dest/interfaces/slasher.d.ts.map +1 -1
  102. package/dest/interfaces/slasher.js +2 -0
  103. package/dest/interfaces/validator.d.ts +49 -3
  104. package/dest/interfaces/validator.d.ts.map +1 -1
  105. package/dest/interfaces/validator.js +4 -1
  106. package/dest/kernel/hints/index.d.ts +2 -2
  107. package/dest/kernel/hints/index.js +2 -2
  108. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  109. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  110. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
  111. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
  112. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  113. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  114. package/dest/kernel/private_circuit_public_inputs.d.ts +9 -9
  115. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  116. package/dest/kernel/private_circuit_public_inputs.js +16 -16
  117. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +3 -3
  118. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  119. package/dest/kernel/private_kernel_circuit_public_inputs.js +4 -4
  120. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +3 -3
  121. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  122. package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
  123. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +3 -3
  124. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  125. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +7 -7
  126. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +3 -3
  127. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  128. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +7 -7
  129. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +3 -3
  130. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  131. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +7 -7
  132. package/dest/kernel/private_validation_requests.d.ts +3 -3
  133. package/dest/kernel/private_validation_requests.js +9 -9
  134. package/dest/keys/derivation.d.ts +3 -3
  135. package/dest/keys/derivation.js +15 -15
  136. package/dest/keys/key_types.d.ts +3 -3
  137. package/dest/keys/key_types.d.ts.map +1 -1
  138. package/dest/keys/public_keys.js +2 -2
  139. package/dest/keys/utils.d.ts +1 -1
  140. package/dest/keys/utils.d.ts.map +1 -1
  141. package/dest/keys/utils.js +8 -4
  142. package/dest/l1-contracts/slash_factory.d.ts +1 -1
  143. package/dest/l1-contracts/slash_factory.d.ts.map +1 -1
  144. package/dest/l1-contracts/slash_factory.js +1 -0
  145. package/dest/logs/extended_public_log.d.ts +12 -6
  146. package/dest/logs/extended_public_log.d.ts.map +1 -1
  147. package/dest/logs/log_id.d.ts +13 -10
  148. package/dest/logs/log_id.d.ts.map +1 -1
  149. package/dest/logs/log_id.js +17 -14
  150. package/dest/logs/private_log.d.ts +2 -2
  151. package/dest/logs/private_log.d.ts.map +1 -1
  152. package/dest/logs/siloed_tag.d.ts +1 -1
  153. package/dest/logs/siloed_tag.d.ts.map +1 -1
  154. package/dest/logs/siloed_tag.js +2 -5
  155. package/dest/messaging/l2_to_l1_membership.d.ts +2 -2
  156. package/dest/messaging/l2_to_l1_membership.js +3 -3
  157. package/dest/note/index.d.ts +1 -2
  158. package/dest/note/index.d.ts.map +1 -1
  159. package/dest/note/index.js +0 -1
  160. package/dest/p2p/block_proposal.d.ts +1 -1
  161. package/dest/p2p/block_proposal.d.ts.map +1 -1
  162. package/dest/p2p/block_proposal.js +1 -3
  163. package/dest/p2p/checkpoint_attestation.d.ts +2 -1
  164. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -1
  165. package/dest/p2p/checkpoint_attestation.js +1 -1
  166. package/dest/p2p/checkpoint_proposal.d.ts +17 -5
  167. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
  168. package/dest/p2p/checkpoint_proposal.js +29 -15
  169. package/dest/p2p/consensus_payload.d.ts +12 -3
  170. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  171. package/dest/p2p/consensus_payload.js +22 -15
  172. package/dest/p2p/constants.d.ts +3 -1
  173. package/dest/p2p/constants.d.ts.map +1 -1
  174. package/dest/p2p/constants.js +1 -0
  175. package/dest/rollup/checkpoint_header.d.ts +2 -2
  176. package/dest/rollup/checkpoint_header.js +2 -2
  177. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +6 -6
  178. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  179. package/dest/rollup/checkpoint_rollup_public_inputs.js +2 -2
  180. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +2 -2
  181. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  182. package/dest/rollup/root_rollup_public_inputs.d.ts +6 -6
  183. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  184. package/dest/rollup/root_rollup_public_inputs.js +3 -3
  185. package/dest/slashing/empire.d.ts +1 -1
  186. package/dest/slashing/empire.d.ts.map +1 -1
  187. package/dest/slashing/empire.js +2 -0
  188. package/dest/slashing/helpers.d.ts +2 -2
  189. package/dest/slashing/helpers.d.ts.map +1 -1
  190. package/dest/slashing/helpers.js +6 -0
  191. package/dest/slashing/tally.d.ts +2 -1
  192. package/dest/slashing/tally.d.ts.map +1 -1
  193. package/dest/slashing/tally.js +6 -2
  194. package/dest/slashing/types.d.ts +7 -3
  195. package/dest/slashing/types.d.ts.map +1 -1
  196. package/dest/slashing/types.js +13 -1
  197. package/dest/stats/stats.d.ts +1 -3
  198. package/dest/stats/stats.d.ts.map +1 -1
  199. package/dest/tests/factories.js +13 -13
  200. package/dest/tests/mocks.d.ts +4 -1
  201. package/dest/tests/mocks.d.ts.map +1 -1
  202. package/dest/tests/mocks.js +14 -9
  203. package/dest/timetable/index.d.ts +37 -0
  204. package/dest/timetable/index.d.ts.map +1 -0
  205. package/dest/timetable/index.js +39 -0
  206. package/dest/trees/public_data_leaf.d.ts +2 -1
  207. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  208. package/dest/trees/public_data_leaf.js +7 -6
  209. package/dest/tx/block_header.js +3 -3
  210. package/dest/tx/global_variables.d.ts +4 -4
  211. package/dest/tx/global_variables.d.ts.map +1 -1
  212. package/dest/tx/in_tx.d.ts +2 -2
  213. package/dest/tx/indexed_tx_effect.d.ts +3 -3
  214. package/dest/tx/indexed_tx_effect.d.ts.map +1 -1
  215. package/dest/tx/indexed_tx_effect.js +2 -1
  216. package/dest/tx/profiling.d.ts +4 -4
  217. package/dest/tx/profiling.d.ts.map +1 -1
  218. package/dest/tx/profiling.js +3 -3
  219. package/dest/tx/protocol_contracts.d.ts +1 -1
  220. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  221. package/dest/tx/protocol_contracts.js +2 -2
  222. package/dest/tx/tx_request.js +2 -2
  223. package/dest/tx/validator/empty_validator.d.ts +2 -2
  224. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  225. package/dest/tx/validator/error_texts.d.ts +1 -1
  226. package/dest/tx/validator/error_texts.js +1 -1
  227. package/dest/tx/validator/tx_validator.d.ts +2 -2
  228. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  229. package/dest/validators/schemas.d.ts +30 -30
  230. package/dest/validators/schemas.d.ts.map +1 -1
  231. package/dest/validators/schemas.js +4 -3
  232. package/dest/validators/types.d.ts +3 -3
  233. package/dest/validators/types.d.ts.map +1 -1
  234. package/package.json +24 -12
  235. package/src/abi/function_call.ts +25 -3
  236. package/src/auth_witness/auth_witness.ts +3 -3
  237. package/src/block/block_data.ts +26 -0
  238. package/src/block/block_hash.ts +25 -50
  239. package/src/block/in_block.ts +2 -2
  240. package/src/block/index.ts +1 -0
  241. package/src/block/l2_block.ts +3 -3
  242. package/src/block/l2_block_source.ts +26 -3
  243. package/src/checkpoint/checkpoint.ts +32 -14
  244. package/src/checkpoint/checkpoint_data.ts +51 -0
  245. package/src/checkpoint/index.ts +1 -0
  246. package/src/checkpoint/published_checkpoint.ts +3 -1
  247. package/src/config/index.ts +1 -0
  248. package/src/config/sequencer-config.ts +29 -0
  249. package/src/contract/contract_address.ts +4 -4
  250. package/src/contract/contract_class_id.ts +6 -5
  251. package/src/contract/interfaces/node-info.ts +3 -0
  252. package/src/contract/private_function.ts +2 -2
  253. package/src/contract/private_function_membership_proof.ts +1 -1
  254. package/src/database-version/database_version.ts +87 -0
  255. package/src/database-version/version_manager.ts +1 -77
  256. package/src/epoch-helpers/index.ts +3 -0
  257. package/src/file-store/local.ts +15 -5
  258. package/src/file-store/s3.ts +12 -3
  259. package/src/hash/hash.ts +14 -10
  260. package/src/hash/map_slot.ts +3 -2
  261. package/src/interfaces/archiver.ts +9 -3
  262. package/src/interfaces/aztec-node-admin.ts +26 -2
  263. package/src/interfaces/aztec-node.ts +38 -89
  264. package/src/interfaces/block-builder.ts +11 -2
  265. package/src/interfaces/configs.ts +12 -1
  266. package/src/interfaces/merkle_tree_operations.ts +1 -1
  267. package/src/interfaces/p2p.ts +1 -1
  268. package/src/interfaces/prover-broker.ts +22 -0
  269. package/src/interfaces/prover-client.ts +7 -0
  270. package/src/interfaces/slasher.ts +4 -0
  271. package/src/interfaces/validator.ts +11 -1
  272. package/src/kernel/hints/index.ts +2 -2
  273. package/src/kernel/hints/{key_validation_request_and_generator.ts → key_validation_request_and_separator.ts} +12 -15
  274. package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +10 -10
  275. package/src/kernel/private_circuit_public_inputs.ts +14 -14
  276. package/src/kernel/private_kernel_circuit_public_inputs.ts +2 -2
  277. package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +2 -2
  278. package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +5 -5
  279. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +5 -5
  280. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +5 -5
  281. package/src/kernel/private_validation_requests.ts +8 -8
  282. package/src/keys/derivation.ts +15 -15
  283. package/src/keys/key_types.ts +6 -2
  284. package/src/keys/public_keys.ts +2 -2
  285. package/src/keys/utils.ts +8 -4
  286. package/src/l1-contracts/slash_factory.ts +1 -0
  287. package/src/logs/log_id.ts +17 -13
  288. package/src/logs/siloed_tag.ts +2 -2
  289. package/src/messaging/l2_to_l1_membership.ts +3 -3
  290. package/src/note/index.ts +0 -1
  291. package/src/p2p/block_proposal.ts +0 -2
  292. package/src/p2p/checkpoint_attestation.ts +6 -1
  293. package/src/p2p/checkpoint_proposal.ts +45 -13
  294. package/src/p2p/consensus_payload.ts +25 -12
  295. package/src/p2p/constants.ts +3 -0
  296. package/src/rollup/checkpoint_header.ts +2 -2
  297. package/src/rollup/checkpoint_rollup_public_inputs.ts +5 -5
  298. package/src/rollup/root_rollup_public_inputs.ts +7 -7
  299. package/src/slashing/empire.ts +3 -1
  300. package/src/slashing/helpers.ts +8 -0
  301. package/src/slashing/tally.ts +8 -2
  302. package/src/slashing/types.ts +14 -0
  303. package/src/stats/stats.ts +0 -2
  304. package/src/tests/factories.ts +17 -17
  305. package/src/tests/mocks.ts +21 -10
  306. package/src/timetable/index.ts +66 -0
  307. package/src/trees/public_data_leaf.ts +11 -5
  308. package/src/tx/block_header.ts +4 -4
  309. package/src/tx/global_variables.ts +3 -3
  310. package/src/tx/indexed_tx_effect.ts +2 -1
  311. package/src/tx/profiling.ts +5 -5
  312. package/src/tx/protocol_contracts.ts +2 -2
  313. package/src/tx/tx_request.ts +2 -2
  314. package/src/tx/validator/empty_validator.ts +1 -1
  315. package/src/tx/validator/error_texts.ts +1 -1
  316. package/src/tx/validator/tx_validator.ts +1 -1
  317. package/src/validators/schemas.ts +8 -1
  318. package/src/validators/types.ts +5 -4
  319. package/dest/database-version/index.d.ts +0 -2
  320. package/dest/database-version/index.d.ts.map +0 -1
  321. package/dest/database-version/index.js +0 -1
  322. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -30
  323. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  324. package/dest/note/notes_filter.d.ts +0 -27
  325. package/dest/note/notes_filter.d.ts.map +0 -1
  326. package/dest/note/notes_filter.js +0 -11
  327. package/src/database-version/index.ts +0 -1
  328. package/src/note/notes_filter.ts +0 -38
@@ -1,70 +1,45 @@
1
- import { Buffer32 } from '@aztec/foundation/buffer';
2
1
  import { Fr } from '@aztec/foundation/curves/bn254';
3
- import { BufferReader } from '@aztec/foundation/serialize';
2
+ import type { ZodFor } from '@aztec/foundation/schemas';
4
3
 
5
- import { schemas } from '../schemas/schemas.js';
4
+ import { inspect } from 'util';
6
5
 
7
- /** Hash of an L2 block. */
8
- export class BlockHash extends Buffer32 {
9
- constructor(
10
- /** The buffer containing the hash. */
11
- hash: Buffer,
12
- ) {
13
- super(hash);
14
- }
6
+ import { hexSchemaFor } from '../schemas/schemas.js';
15
7
 
16
- /**
17
- * Type guard that checks if a value is an BlockHash instance.
18
- * Uses duck typing to handle cases where instanceof fails due to module duplication.
19
- * Checks for Buffer32-like structure with a 32-byte buffer.
20
- */
21
- static isL2BlockHash(value: unknown): value is BlockHash {
22
- if (value instanceof BlockHash) {
23
- return true;
24
- }
25
- // Duck typing fallback: check if it looks like a Buffer32 with a 32-byte buffer
26
- // This helps when instanceof fails due to module duplication
27
- return (
28
- typeof value === 'object' &&
29
- value !== null &&
30
- 'buffer' in value &&
31
- Buffer.isBuffer((value as Buffer32).buffer) &&
32
- (value as Buffer32).buffer.length === 32 &&
33
- 'toBuffer' in value &&
34
- typeof (value as Buffer32).toBuffer === 'function'
35
- );
36
- }
8
+ const BLOCK_HASH_BRAND = Symbol.for('aztec.BlockHash');
37
9
 
38
- static override random() {
39
- return new BlockHash(Fr.random().toBuffer());
40
- }
10
+ /** Hash of an L2 block. */
11
+ export class BlockHash extends Fr {
12
+ readonly [BLOCK_HASH_BRAND] = true as const;
41
13
 
42
- static override fromNumber(num: number): BlockHash {
43
- return new BlockHash(super.fromNumber(num).toBuffer());
14
+ constructor(hash: Fr) {
15
+ super(hash);
44
16
  }
45
17
 
46
- static override fromBuffer(buffer: Buffer | BufferReader) {
47
- const reader = BufferReader.asReader(buffer);
48
- return new BlockHash(reader.readBytes(BlockHash.SIZE));
18
+ override [inspect.custom]() {
19
+ return `BlockHash<${this.toString()}>`;
49
20
  }
50
21
 
51
- static override fromString(str: string): BlockHash {
52
- return new BlockHash(super.fromString(str).toBuffer());
22
+ toFr(): Fr {
23
+ return new Fr(this.toBigInt());
53
24
  }
54
25
 
55
- static get schema() {
56
- return schemas.BufferHex.transform(value => new BlockHash(value));
26
+ /**
27
+ * Type guard that checks if a value is a BlockHash instance.
28
+ * Uses Symbol.for to ensure cross-module compatibility.
29
+ */
30
+ static isBlockHash(value: unknown): value is BlockHash {
31
+ return typeof value === 'object' && value !== null && BLOCK_HASH_BRAND in value;
57
32
  }
58
33
 
59
- static zero() {
60
- return new BlockHash(Buffer32.ZERO.toBuffer());
34
+ static override random() {
35
+ return new BlockHash(Fr.random());
61
36
  }
62
37
 
63
- static override fromField(hash: Fr) {
64
- return new BlockHash(hash.toBuffer());
38
+ static override fromString(str: string): BlockHash {
39
+ return new BlockHash(Fr.fromString(str));
65
40
  }
66
41
 
67
- toField(): Fr {
68
- return Fr.fromBuffer(this.toBuffer());
42
+ static override get schema() {
43
+ return hexSchemaFor(BlockHash) as ZodFor<BlockHash>;
69
44
  }
70
45
  }
@@ -17,7 +17,7 @@ export type DataInBlock<T> = {
17
17
 
18
18
  export function randomInBlock(): InBlock {
19
19
  return {
20
- l2BlockNumber: BlockNumber(Math.floor(Math.random() * 1000)),
20
+ l2BlockNumber: BlockNumber(Math.floor(Math.random() * 1000) + 1),
21
21
  l2BlockHash: BlockHash.random(),
22
22
  };
23
23
  }
@@ -33,7 +33,7 @@ export async function wrapDataInBlock<T>(data: T, block: L2Block): Promise<DataI
33
33
  return {
34
34
  data,
35
35
  l2BlockNumber: block.number,
36
- l2BlockHash: BlockHash.fromField(await block.hash()),
36
+ l2BlockHash: await block.hash(),
37
37
  };
38
38
  }
39
39
 
@@ -1,3 +1,4 @@
1
+ export * from './block_data.js';
1
2
  export * from './l2_block.js';
2
3
  export * from './l2_block_stream/index.js';
3
4
  export * from './in_block.js';
@@ -15,6 +15,7 @@ import { z } from 'zod';
15
15
  import type { PrivateLog } from '../logs/private_log.js';
16
16
  import { AppendOnlyTreeSnapshot } from '../trees/append_only_tree_snapshot.js';
17
17
  import { BlockHeader } from '../tx/block_header.js';
18
+ import type { BlockHash } from './block_hash.js';
18
19
  import { Body } from './body.js';
19
20
  import type { L2BlockInfo } from './l2_block_info.js';
20
21
 
@@ -89,9 +90,8 @@ export class L2Block {
89
90
  * Returns the block's hash (hash of block header).
90
91
  * @returns The block's hash.
91
92
  */
92
- public async hash(): Promise<Fr> {
93
- const blockHash = await this.header.hash();
94
- return blockHash.toField();
93
+ public hash(): Promise<BlockHash> {
94
+ return this.header.hash();
95
95
  }
96
96
 
97
97
  /**
@@ -13,6 +13,7 @@ import type { TypedEventEmitter } from '@aztec/foundation/types';
13
13
  import { z } from 'zod';
14
14
 
15
15
  import type { Checkpoint } from '../checkpoint/checkpoint.js';
16
+ import type { CheckpointData } from '../checkpoint/checkpoint_data.js';
16
17
  import type { PublishedCheckpoint } from '../checkpoint/published_checkpoint.js';
17
18
  import type { L1RollupConstants } from '../epoch-helpers/index.js';
18
19
  import { CheckpointHeader } from '../rollup/checkpoint_header.js';
@@ -20,6 +21,8 @@ import type { BlockHeader } from '../tx/block_header.js';
20
21
  import type { IndexedTxEffect } from '../tx/indexed_tx_effect.js';
21
22
  import type { TxHash } from '../tx/tx_hash.js';
22
23
  import type { TxReceipt } from '../tx/tx_receipt.js';
24
+ import type { BlockData } from './block_data.js';
25
+ import type { BlockHash } from './block_hash.js';
23
26
  import type { CheckpointedL2Block } from './checkpointed_l2_block.js';
24
27
  import type { L2Block } from './l2_block.js';
25
28
  import type { ValidateCheckpointNegativeResult, ValidateCheckpointResult } from './validate_block_result.js';
@@ -97,12 +100,18 @@ export interface L2BlockSource {
97
100
  */
98
101
  getCheckpointsForEpoch(epochNumber: EpochNumber): Promise<Checkpoint[]>;
99
102
 
103
+ /**
104
+ * Gets lightweight checkpoint metadata for a given epoch, without fetching full block data.
105
+ * @param epochNumber - Epoch for which we want checkpoint data
106
+ */
107
+ getCheckpointsDataForEpoch(epochNumber: EpochNumber): Promise<CheckpointData[]>;
108
+
100
109
  /**
101
110
  * Gets a block header by its hash.
102
111
  * @param blockHash - The block hash to retrieve.
103
112
  * @returns The requested block header (or undefined if not found).
104
113
  */
105
- getBlockHeaderByHash(blockHash: Fr): Promise<BlockHeader | undefined>;
114
+ getBlockHeaderByHash(blockHash: BlockHash): Promise<BlockHeader | undefined>;
106
115
 
107
116
  /**
108
117
  * Gets a block header by its archive root.
@@ -111,6 +120,20 @@ export interface L2BlockSource {
111
120
  */
112
121
  getBlockHeaderByArchive(archive: Fr): Promise<BlockHeader | undefined>;
113
122
 
123
+ /**
124
+ * Gets block metadata (without tx data) by block number.
125
+ * @param number - The block number to retrieve.
126
+ * @returns The requested block data (or undefined if not found).
127
+ */
128
+ getBlockData(number: BlockNumber): Promise<BlockData | undefined>;
129
+
130
+ /**
131
+ * Gets block metadata (without tx data) by archive root.
132
+ * @param archive - The archive root to retrieve.
133
+ * @returns The requested block data (or undefined if not found).
134
+ */
135
+ getBlockDataByArchive(archive: Fr): Promise<BlockData | undefined>;
136
+
114
137
  /**
115
138
  * Gets an L2 block by block number.
116
139
  * @param number - The block number to return.
@@ -123,7 +146,7 @@ export interface L2BlockSource {
123
146
  * @param blockHash - The block hash to retrieve.
124
147
  * @returns The requested L2 block (or undefined if not found).
125
148
  */
126
- getL2BlockByHash(blockHash: Fr): Promise<L2Block | undefined>;
149
+ getL2BlockByHash(blockHash: BlockHash): Promise<L2Block | undefined>;
127
150
 
128
151
  /**
129
152
  * Gets an L2 block by its archive root.
@@ -228,7 +251,7 @@ export interface L2BlockSource {
228
251
  * @param blockHash - The block hash to retrieve.
229
252
  * @returns The requested block (or undefined if not found).
230
253
  */
231
- getCheckpointedBlockByHash(blockHash: Fr): Promise<CheckpointedL2Block | undefined>;
254
+ getCheckpointedBlockByHash(blockHash: BlockHash): Promise<CheckpointedL2Block | undefined>;
232
255
 
233
256
  /**
234
257
  * Gets a checkpointed block by its archive root.
@@ -8,7 +8,7 @@ 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';
@@ -17,6 +17,7 @@ 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
 
@@ -32,6 +33,8 @@ export class Checkpoint {
32
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 {
@@ -45,8 +48,12 @@ export class Checkpoint {
45
48
  header: CheckpointHeader.schema,
46
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(L2Block, 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,11 +145,13 @@ 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
156
  Partial<Parameters<typeof L2Block.random>[1]> = {},
139
157
  ) {
@@ -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';
@@ -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
  }
@@ -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,4 +1,4 @@
1
- import { FUNCTION_TREE_HEIGHT, GeneratorIndex } from '@aztec/constants';
1
+ import { DomainSeparator, FUNCTION_TREE_HEIGHT } from '@aztec/constants';
2
2
  import { poseidon2Hash, poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
3
3
  import { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { type MerkleTree, MerkleTreeCalculator } from '@aztec/foundation/trees';
@@ -31,7 +31,7 @@ function computePrivateFunctionLeaves(fns: PrivateFunction[]): Promise<Buffer[]>
31
31
 
32
32
  /** Returns the leaf for a given private function. */
33
33
  export async function computePrivateFunctionLeaf(fn: PrivateFunction): Promise<Buffer> {
34
- return (await poseidon2HashWithSeparator([fn.selector, fn.vkHash], GeneratorIndex.FUNCTION_LEAF)).toBuffer();
34
+ return (await poseidon2HashWithSeparator([fn.selector, fn.vkHash], DomainSeparator.PRIVATE_FUNCTION_LEAF)).toBuffer();
35
35
  }
36
36
 
37
37
  async function getPrivateFunctionTreeCalculator(): Promise<MerkleTreeCalculator> {
@@ -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
+ }