@aztec/stdlib 0.0.1-commit.d6f2b3f94 → 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 (296) 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/auth_witness/auth_witness.js +3 -3
  8. package/dest/avm/avm.d.ts +300 -300
  9. package/dest/avm/avm_proving_request.d.ts +166 -166
  10. package/dest/avm/revert_code.d.ts +16 -1
  11. package/dest/avm/revert_code.d.ts.map +1 -1
  12. package/dest/avm/revert_code.js +15 -5
  13. package/dest/block/block_data.d.ts +52 -0
  14. package/dest/block/block_data.d.ts.map +1 -0
  15. package/dest/block/block_data.js +12 -0
  16. package/dest/block/index.d.ts +2 -1
  17. package/dest/block/index.d.ts.map +1 -1
  18. package/dest/block/index.js +1 -0
  19. package/dest/block/l2_block_source.d.ts +20 -1
  20. package/dest/block/l2_block_source.d.ts.map +1 -1
  21. package/dest/block/l2_block_stream/l2_block_stream.d.ts +1 -1
  22. package/dest/block/l2_block_stream/l2_block_stream.d.ts.map +1 -1
  23. package/dest/block/l2_block_stream/l2_block_stream.js +10 -0
  24. package/dest/checkpoint/checkpoint.d.ts +21 -7
  25. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  26. package/dest/checkpoint/checkpoint.js +24 -13
  27. package/dest/checkpoint/checkpoint_data.d.ts +120 -0
  28. package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
  29. package/dest/checkpoint/checkpoint_data.js +26 -0
  30. package/dest/checkpoint/index.d.ts +2 -1
  31. package/dest/checkpoint/index.d.ts.map +1 -1
  32. package/dest/checkpoint/index.js +1 -0
  33. package/dest/checkpoint/published_checkpoint.d.ts +17 -2
  34. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  35. package/dest/checkpoint/published_checkpoint.js +1 -2
  36. package/dest/config/sequencer-config.d.ts +2 -2
  37. package/dest/config/sequencer-config.d.ts.map +1 -1
  38. package/dest/config/sequencer-config.js +6 -0
  39. package/dest/contract/contract_address.js +4 -4
  40. package/dest/contract/contract_class.d.ts +2 -3
  41. package/dest/contract/contract_class.d.ts.map +1 -1
  42. package/dest/contract/contract_class_id.d.ts +1 -1
  43. package/dest/contract/contract_class_id.d.ts.map +1 -1
  44. package/dest/contract/contract_class_id.js +5 -4
  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/file-store/local.d.ts +3 -3
  50. package/dest/file-store/local.d.ts.map +1 -1
  51. package/dest/file-store/local.js +13 -4
  52. package/dest/file-store/s3.d.ts +1 -1
  53. package/dest/file-store/s3.d.ts.map +1 -1
  54. package/dest/file-store/s3.js +11 -3
  55. package/dest/ha-signing/config.d.ts +101 -0
  56. package/dest/ha-signing/config.d.ts.map +1 -0
  57. package/dest/ha-signing/config.js +92 -0
  58. package/dest/ha-signing/index.d.ts +3 -0
  59. package/dest/ha-signing/index.d.ts.map +1 -0
  60. package/dest/ha-signing/index.js +2 -0
  61. package/dest/ha-signing/types.d.ts +85 -0
  62. package/dest/ha-signing/types.d.ts.map +1 -0
  63. package/dest/ha-signing/types.js +32 -0
  64. package/dest/hash/hash.d.ts +2 -1
  65. package/dest/hash/hash.d.ts.map +1 -1
  66. package/dest/hash/hash.js +16 -10
  67. package/dest/hash/map_slot.js +2 -2
  68. package/dest/interfaces/archiver.d.ts +1 -1
  69. package/dest/interfaces/archiver.d.ts.map +1 -1
  70. package/dest/interfaces/archiver.js +5 -0
  71. package/dest/interfaces/aztec-node-admin.d.ts +30 -2
  72. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  73. package/dest/interfaces/aztec-node-admin.js +9 -3
  74. package/dest/interfaces/aztec-node.d.ts +1 -1
  75. package/dest/interfaces/block-builder.d.ts +2 -2
  76. package/dest/interfaces/block-builder.d.ts.map +1 -1
  77. package/dest/interfaces/configs.d.ts +17 -2
  78. package/dest/interfaces/configs.d.ts.map +1 -1
  79. package/dest/interfaces/configs.js +4 -1
  80. package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
  81. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  82. package/dest/interfaces/p2p.d.ts +3 -8
  83. package/dest/interfaces/p2p.d.ts.map +1 -1
  84. package/dest/interfaces/proving-job.d.ts +2 -2
  85. package/dest/interfaces/validator.d.ts +3 -3
  86. package/dest/interfaces/validator.d.ts.map +1 -1
  87. package/dest/interfaces/validator.js +1 -1
  88. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +3 -3
  89. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  90. package/dest/kernel/hints/build_note_hash_read_request_hints.js +13 -10
  91. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
  92. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  93. package/dest/kernel/hints/build_nullifier_read_request_hints.js +13 -10
  94. package/dest/kernel/hints/build_transient_data_hints.d.ts +5 -2
  95. package/dest/kernel/hints/build_transient_data_hints.d.ts.map +1 -1
  96. package/dest/kernel/hints/build_transient_data_hints.js +9 -3
  97. package/dest/kernel/hints/index.d.ts +2 -2
  98. package/dest/kernel/hints/index.js +2 -2
  99. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  100. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  101. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
  102. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
  103. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  104. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  105. package/dest/kernel/private_circuit_public_inputs.d.ts +9 -9
  106. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  107. package/dest/kernel/private_circuit_public_inputs.js +16 -16
  108. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +3 -3
  109. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  110. package/dest/kernel/private_kernel_circuit_public_inputs.js +4 -4
  111. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +3 -3
  112. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  113. package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
  114. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +3 -3
  115. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  116. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +7 -7
  117. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +3 -3
  118. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  119. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +7 -7
  120. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +3 -3
  121. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  122. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +7 -7
  123. package/dest/kernel/private_validation_requests.d.ts +3 -3
  124. package/dest/kernel/private_validation_requests.js +9 -9
  125. package/dest/keys/derivation.js +8 -8
  126. package/dest/keys/key_types.d.ts +3 -3
  127. package/dest/keys/key_types.d.ts.map +1 -1
  128. package/dest/keys/public_keys.js +2 -2
  129. package/dest/keys/utils.js +5 -5
  130. package/dest/logs/debug_log_store.d.ts +30 -0
  131. package/dest/logs/debug_log_store.d.ts.map +1 -0
  132. package/dest/logs/debug_log_store.js +30 -0
  133. package/dest/logs/extended_directional_app_tagging_secret.d.ts +47 -0
  134. package/dest/logs/extended_directional_app_tagging_secret.d.ts.map +1 -0
  135. package/dest/logs/{directional_app_tagging_secret.js → extended_directional_app_tagging_secret.js} +23 -15
  136. package/dest/logs/index.d.ts +3 -2
  137. package/dest/logs/index.d.ts.map +1 -1
  138. package/dest/logs/index.js +2 -1
  139. package/dest/logs/pre_tag.d.ts +16 -11
  140. package/dest/logs/pre_tag.d.ts.map +1 -1
  141. package/dest/logs/pre_tag.js +2 -2
  142. package/dest/logs/private_log.d.ts +2 -2
  143. package/dest/logs/private_log.d.ts.map +1 -1
  144. package/dest/logs/siloed_tag.d.ts +5 -3
  145. package/dest/logs/siloed_tag.d.ts.map +1 -1
  146. package/dest/logs/siloed_tag.js +8 -7
  147. package/dest/logs/tag.js +1 -1
  148. package/dest/note/index.d.ts +1 -2
  149. package/dest/note/index.d.ts.map +1 -1
  150. package/dest/note/index.js +0 -1
  151. package/dest/p2p/attestation_utils.d.ts +11 -1
  152. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  153. package/dest/p2p/attestation_utils.js +45 -0
  154. package/dest/p2p/block_proposal.d.ts +2 -2
  155. package/dest/p2p/block_proposal.d.ts.map +1 -1
  156. package/dest/p2p/block_proposal.js +2 -4
  157. package/dest/p2p/checkpoint_attestation.d.ts +2 -1
  158. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -1
  159. package/dest/p2p/checkpoint_attestation.js +1 -1
  160. package/dest/p2p/checkpoint_proposal.d.ts +11 -6
  161. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
  162. package/dest/p2p/checkpoint_proposal.js +21 -16
  163. package/dest/p2p/client_type.d.ts +2 -5
  164. package/dest/p2p/client_type.d.ts.map +1 -1
  165. package/dest/p2p/client_type.js +0 -7
  166. package/dest/p2p/consensus_payload.d.ts +12 -3
  167. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  168. package/dest/p2p/consensus_payload.js +22 -15
  169. package/dest/p2p/index.d.ts +1 -2
  170. package/dest/p2p/index.d.ts.map +1 -1
  171. package/dest/p2p/index.js +0 -1
  172. package/dest/p2p/topic_type.d.ts +3 -4
  173. package/dest/p2p/topic_type.d.ts.map +1 -1
  174. package/dest/p2p/topic_type.js +7 -24
  175. package/dest/rollup/checkpoint_header.d.ts +2 -2
  176. package/dest/rollup/checkpoint_header.js +2 -2
  177. package/dest/tests/factories.d.ts +3 -1
  178. package/dest/tests/factories.d.ts.map +1 -1
  179. package/dest/tests/factories.js +19 -11
  180. package/dest/tests/mocks.d.ts +5 -2
  181. package/dest/tests/mocks.d.ts.map +1 -1
  182. package/dest/tests/mocks.js +18 -13
  183. package/dest/trees/public_data_leaf.d.ts +2 -1
  184. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  185. package/dest/trees/public_data_leaf.js +7 -6
  186. package/dest/tx/block_header.js +2 -2
  187. package/dest/tx/global_variables.d.ts +4 -4
  188. package/dest/tx/global_variables.d.ts.map +1 -1
  189. package/dest/tx/profiling.d.ts +4 -4
  190. package/dest/tx/profiling.d.ts.map +1 -1
  191. package/dest/tx/profiling.js +3 -3
  192. package/dest/tx/protocol_contracts.d.ts +1 -1
  193. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  194. package/dest/tx/protocol_contracts.js +2 -2
  195. package/dest/tx/public_simulation_output.d.ts +4 -2
  196. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  197. package/dest/tx/public_simulation_output.js +7 -3
  198. package/dest/tx/tx_receipt.d.ts +16 -2
  199. package/dest/tx/tx_receipt.d.ts.map +1 -1
  200. package/dest/tx/tx_receipt.js +11 -3
  201. package/dest/tx/tx_request.js +2 -2
  202. package/dest/tx/validator/error_texts.d.ts +1 -1
  203. package/dest/tx/validator/error_texts.js +1 -1
  204. package/dest/validators/schemas.d.ts +30 -30
  205. package/dest/validators/schemas.d.ts.map +1 -1
  206. package/dest/validators/schemas.js +4 -3
  207. package/dest/validators/types.d.ts +3 -3
  208. package/dest/validators/types.d.ts.map +1 -1
  209. package/package.json +10 -10
  210. package/src/abi/decoder.ts +1 -4
  211. package/src/abi/encoder.ts +8 -5
  212. package/src/auth_witness/auth_witness.ts +3 -3
  213. package/src/avm/revert_code.ts +15 -0
  214. package/src/block/block_data.ts +26 -0
  215. package/src/block/index.ts +1 -0
  216. package/src/block/l2_block_source.ts +22 -0
  217. package/src/block/l2_block_stream/l2_block_stream.ts +21 -0
  218. package/src/checkpoint/checkpoint.ts +32 -14
  219. package/src/checkpoint/checkpoint_data.ts +51 -0
  220. package/src/checkpoint/index.ts +1 -0
  221. package/src/checkpoint/published_checkpoint.ts +3 -1
  222. package/src/config/sequencer-config.ts +11 -1
  223. package/src/contract/contract_address.ts +4 -4
  224. package/src/contract/contract_class.ts +3 -3
  225. package/src/contract/contract_class_id.ts +5 -4
  226. package/src/contract/interfaces/node-info.ts +3 -0
  227. package/src/contract/private_function.ts +2 -2
  228. package/src/file-store/local.ts +15 -5
  229. package/src/file-store/s3.ts +12 -3
  230. package/src/ha-signing/config.ts +149 -0
  231. package/src/ha-signing/index.ts +18 -0
  232. package/src/ha-signing/types.ts +112 -0
  233. package/src/hash/hash.ts +14 -10
  234. package/src/hash/map_slot.ts +2 -2
  235. package/src/interfaces/archiver.ts +5 -0
  236. package/src/interfaces/aztec-node-admin.ts +23 -0
  237. package/src/interfaces/aztec-node.ts +1 -1
  238. package/src/interfaces/block-builder.ts +1 -0
  239. package/src/interfaces/configs.ts +12 -1
  240. package/src/interfaces/merkle_tree_operations.ts +1 -1
  241. package/src/interfaces/p2p.ts +2 -13
  242. package/src/interfaces/validator.ts +2 -1
  243. package/src/kernel/hints/build_note_hash_read_request_hints.ts +14 -18
  244. package/src/kernel/hints/build_nullifier_read_request_hints.ts +15 -18
  245. package/src/kernel/hints/build_transient_data_hints.ts +17 -2
  246. package/src/kernel/hints/index.ts +2 -2
  247. package/src/kernel/hints/{key_validation_request_and_generator.ts → key_validation_request_and_separator.ts} +12 -15
  248. package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +10 -10
  249. package/src/kernel/private_circuit_public_inputs.ts +14 -14
  250. package/src/kernel/private_kernel_circuit_public_inputs.ts +2 -2
  251. package/src/kernel/private_kernel_tail_circuit_private_inputs.ts +2 -2
  252. package/src/kernel/private_kernel_tail_circuit_public_inputs.ts +5 -5
  253. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +5 -5
  254. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +5 -5
  255. package/src/kernel/private_validation_requests.ts +8 -8
  256. package/src/keys/derivation.ts +8 -8
  257. package/src/keys/key_types.ts +6 -2
  258. package/src/keys/public_keys.ts +2 -2
  259. package/src/keys/utils.ts +5 -5
  260. package/src/logs/debug_log_store.ts +54 -0
  261. package/src/logs/{directional_app_tagging_secret.ts → extended_directional_app_tagging_secret.ts} +24 -16
  262. package/src/logs/index.ts +2 -1
  263. package/src/logs/pre_tag.ts +5 -5
  264. package/src/logs/siloed_tag.ts +10 -5
  265. package/src/logs/tag.ts +1 -1
  266. package/src/note/index.ts +0 -1
  267. package/src/p2p/attestation_utils.ts +56 -0
  268. package/src/p2p/block_proposal.ts +1 -3
  269. package/src/p2p/checkpoint_attestation.ts +6 -1
  270. package/src/p2p/checkpoint_proposal.ts +36 -14
  271. package/src/p2p/client_type.ts +0 -6
  272. package/src/p2p/consensus_payload.ts +25 -12
  273. package/src/p2p/index.ts +0 -1
  274. package/src/p2p/topic_type.ts +8 -15
  275. package/src/rollup/checkpoint_header.ts +2 -2
  276. package/src/tests/factories.ts +21 -12
  277. package/src/tests/mocks.ts +28 -13
  278. package/src/trees/public_data_leaf.ts +11 -5
  279. package/src/tx/block_header.ts +2 -2
  280. package/src/tx/global_variables.ts +3 -3
  281. package/src/tx/profiling.ts +5 -5
  282. package/src/tx/protocol_contracts.ts +2 -2
  283. package/src/tx/public_simulation_output.ts +4 -0
  284. package/src/tx/tx_receipt.ts +10 -0
  285. package/src/tx/tx_request.ts +2 -2
  286. package/src/tx/validator/error_texts.ts +1 -1
  287. package/src/validators/schemas.ts +8 -1
  288. package/src/validators/types.ts +5 -4
  289. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -30
  290. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  291. package/dest/logs/directional_app_tagging_secret.d.ts +0 -40
  292. package/dest/logs/directional_app_tagging_secret.d.ts.map +0 -1
  293. package/dest/note/notes_filter.d.ts +0 -27
  294. package/dest/note/notes_filter.d.ts.map +0 -1
  295. package/dest/note/notes_filter.js +0 -11
  296. package/src/note/notes_filter.ts +0 -38
@@ -1,4 +1,4 @@
1
- import { GeneratorIndex } from '@aztec/constants';
1
+ import { DomainSeparator } from '@aztec/constants';
2
2
  import { Grumpkin } from '@aztec/foundation/crypto/grumpkin';
3
3
  import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
4
4
  import { sha512ToGrumpkinScalar } from '@aztec/foundation/crypto/sha512';
@@ -27,29 +27,29 @@ export async function computeOvskApp(ovsk: GrumpkinScalar, app: AztecAddress): P
27
27
  }
28
28
 
29
29
  export function deriveMasterNullifierHidingKey(secretKey: Fr): GrumpkinScalar {
30
- return sha512ToGrumpkinScalar([secretKey, GeneratorIndex.NHK_M]);
30
+ return sha512ToGrumpkinScalar([secretKey, DomainSeparator.NHK_M]);
31
31
  }
32
32
 
33
33
  export function deriveMasterIncomingViewingSecretKey(secretKey: Fr): GrumpkinScalar {
34
- return sha512ToGrumpkinScalar([secretKey, GeneratorIndex.IVSK_M]);
34
+ return sha512ToGrumpkinScalar([secretKey, DomainSeparator.IVSK_M]);
35
35
  }
36
36
 
37
37
  export function deriveMasterOutgoingViewingSecretKey(secretKey: Fr): GrumpkinScalar {
38
- return sha512ToGrumpkinScalar([secretKey, GeneratorIndex.OVSK_M]);
38
+ return sha512ToGrumpkinScalar([secretKey, DomainSeparator.OVSK_M]);
39
39
  }
40
40
 
41
41
  export function deriveSigningKey(secretKey: Fr): GrumpkinScalar {
42
42
  // TODO(#5837): come up with a standard signing key derivation scheme instead of using ivsk_m as signing keys here
43
- return sha512ToGrumpkinScalar([secretKey, GeneratorIndex.IVSK_M]);
43
+ return sha512ToGrumpkinScalar([secretKey, DomainSeparator.IVSK_M]);
44
44
  }
45
45
 
46
46
  export function computePreaddress(publicKeysHash: Fr, partialAddress: Fr) {
47
- return poseidon2HashWithSeparator([publicKeysHash, partialAddress], GeneratorIndex.CONTRACT_ADDRESS_V1);
47
+ return poseidon2HashWithSeparator([publicKeysHash, partialAddress], DomainSeparator.CONTRACT_ADDRESS_V1);
48
48
  }
49
49
 
50
50
  export async function computeAddress(publicKeys: PublicKeys, partialAddress: Fr): Promise<AztecAddress> {
51
51
  // Given public keys and a partial address, we can compute our address in the following steps.
52
- // 1. preaddress = poseidon2([publicKeysHash, partialAddress], GeneratorIndex.CONTRACT_ADDRESS_V1);
52
+ // 1. preaddress = poseidon2([publicKeysHash, partialAddress], DomainSeparator.CONTRACT_ADDRESS_V1);
53
53
  // 2. addressPoint = (preaddress * G) + ivpk_m
54
54
  // 3. address = addressPoint.x
55
55
  const preaddress = await computePreaddress(await publicKeys.hash(), partialAddress);
@@ -98,7 +98,7 @@ export async function deriveKeys(secretKey: Fr) {
98
98
  const masterNullifierHidingKey = deriveMasterNullifierHidingKey(secretKey);
99
99
  const masterIncomingViewingSecretKey = deriveMasterIncomingViewingSecretKey(secretKey);
100
100
  const masterOutgoingViewingSecretKey = deriveMasterOutgoingViewingSecretKey(secretKey);
101
- const masterTaggingSecretKey = sha512ToGrumpkinScalar([secretKey, GeneratorIndex.TSK_M]);
101
+ const masterTaggingSecretKey = sha512ToGrumpkinScalar([secretKey, DomainSeparator.TSK_M]);
102
102
 
103
103
  // Then we derive master public keys
104
104
  const masterNullifierPublicKey = await derivePublicKeyFromSecretKey(masterNullifierHidingKey);
@@ -1,5 +1,9 @@
1
- import type { GeneratorIndex } from '@aztec/constants';
1
+ import type { DomainSeparator } from '@aztec/constants';
2
2
 
3
- export type KeyGenerator = GeneratorIndex.NHK_M | GeneratorIndex.IVSK_M | GeneratorIndex.OVSK_M | GeneratorIndex.TSK_M;
3
+ export type KeyGenerator =
4
+ | DomainSeparator.NHK_M
5
+ | DomainSeparator.IVSK_M
6
+ | DomainSeparator.OVSK_M
7
+ | DomainSeparator.TSK_M;
4
8
  export type KeyPrefix = 'n' | 'iv' | 'ov' | 't';
5
9
  export const KEY_PREFIXES: KeyPrefix[] = ['n', 'iv', 'ov', 't'];
@@ -7,7 +7,7 @@ import {
7
7
  DEFAULT_OVPK_M_Y,
8
8
  DEFAULT_TPK_M_X,
9
9
  DEFAULT_TPK_M_Y,
10
- GeneratorIndex,
10
+ DomainSeparator,
11
11
  } from '@aztec/constants';
12
12
  import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
13
13
  import { Fr } from '@aztec/foundation/curves/bn254';
@@ -82,7 +82,7 @@ export class PublicKeys {
82
82
  this.masterOutgoingViewingPublicKey,
83
83
  this.masterTaggingPublicKey,
84
84
  ],
85
- GeneratorIndex.PUBLIC_KEYS_HASH,
85
+ DomainSeparator.PUBLIC_KEYS_HASH,
86
86
  );
87
87
  }
88
88
 
package/src/keys/utils.ts CHANGED
@@ -1,13 +1,13 @@
1
- import { GeneratorIndex } from '@aztec/constants';
1
+ import { DomainSeparator } from '@aztec/constants';
2
2
 
3
3
  import type { KeyGenerator, KeyPrefix } from './key_types.js';
4
4
 
5
5
  export function getKeyGenerator(prefix: KeyPrefix): KeyGenerator {
6
6
  const map: Record<KeyPrefix, KeyGenerator> = {
7
- n: GeneratorIndex.NHK_M,
8
- iv: GeneratorIndex.IVSK_M,
9
- ov: GeneratorIndex.OVSK_M,
10
- t: GeneratorIndex.TSK_M,
7
+ n: DomainSeparator.NHK_M,
8
+ iv: DomainSeparator.IVSK_M,
9
+ ov: DomainSeparator.OVSK_M,
10
+ t: DomainSeparator.TSK_M,
11
11
  };
12
12
  return map[prefix];
13
13
  }
@@ -0,0 +1,54 @@
1
+ import type { TxReceipt } from '../tx/tx_receipt.js';
2
+ import type { DebugLog } from './debug_log.js';
3
+
4
+ /**
5
+ * Store for debug logs emitted by public functions during transaction execution.
6
+ *
7
+ * Uses the Null Object pattern: production code uses NullDebugLogStore (no-op), while test mode uses
8
+ * InMemoryDebugLogStore (stores and serves logs).
9
+ */
10
+ export interface DebugLogStore {
11
+ /** Store debug logs for a processed transaction. */
12
+ storeLogs(txHash: string, logs: DebugLog[]): void;
13
+ /** Decorate a TxReceipt with any stored debug logs for the given tx. */
14
+ decorateReceiptWithLogs(txHash: string, receipt: TxReceipt): void;
15
+ /** Whether debug log collection is enabled. */
16
+ readonly isEnabled: boolean;
17
+ }
18
+
19
+ /** No-op implementation for production mode. */
20
+ export class NullDebugLogStore implements DebugLogStore {
21
+ storeLogs(_txHash: string, _logs: DebugLog[]): void {
22
+ return;
23
+ }
24
+ decorateReceiptWithLogs(_txHash: string, _receipt: TxReceipt): void {
25
+ return;
26
+ }
27
+ get isEnabled(): boolean {
28
+ return false;
29
+ }
30
+ }
31
+
32
+ /** In-memory implementation for test mode that stores and serves debug logs. */
33
+ export class InMemoryDebugLogStore implements DebugLogStore {
34
+ private map = new Map<string, DebugLog[]>();
35
+
36
+ storeLogs(txHash: string, logs: DebugLog[]): void {
37
+ if (logs.length > 0) {
38
+ this.map.set(txHash, logs);
39
+ }
40
+ }
41
+
42
+ decorateReceiptWithLogs(txHash: string, receipt: TxReceipt): void {
43
+ if (receipt.isMined()) {
44
+ const debugLogs = this.map.get(txHash);
45
+ if (debugLogs) {
46
+ receipt.debugLogs = debugLogs;
47
+ }
48
+ }
49
+ }
50
+
51
+ get isEnabled(): boolean {
52
+ return true;
53
+ }
54
+ }
@@ -5,22 +5,28 @@ import type { Point } from '@aztec/foundation/curves/grumpkin';
5
5
 
6
6
  import { z } from 'zod';
7
7
 
8
- import type { AztecAddress } from '../aztec-address/index.js';
8
+ import { AztecAddress } from '../aztec-address/index.js';
9
9
  import type { CompleteAddress } from '../contract/complete_address.js';
10
10
  import { computeAddressSecret, computePreaddress } from '../keys/derivation.js';
11
11
 
12
12
  /**
13
- * Directional application tagging secret used for log tagging.
13
+ * Extended directional application tagging secret used for log tagging.
14
14
  *
15
- * "Directional" because the derived secret is bound to the recipient
16
- * address: A→B differs from B→A even with the same participants and app.
15
+ * "Extended" because it bundles the directional app tagging secret with the app (contract) address. This bundling was
16
+ * done because where this type is used we commonly need access to both the secret and the address.
17
17
  *
18
- * Note: It's a bit unfortunate that this type resides in `stdlib` as the rest of the tagging functionality resides
19
- * in `pxe/src/tagging`. We need to use this type in `PreTag` that in turn is used by other types
20
- * in stdlib hence there doesn't seem to be a good way around this.
18
+ * "Directional" because the derived secret is bound to the recipient address: A→B differs from B→A even with the same
19
+ * participants and app.
20
+ *
21
+ * Note: It's a bit unfortunate that this type resides in `stdlib` as the rest of the tagging functionality resides in
22
+ * `pxe/src/tagging`. We need to use this type in `PreTag` that in turn is used by other types in stdlib hence there
23
+ * doesn't seem to be a good way around this.
21
24
  */
22
- export class DirectionalAppTaggingSecret {
23
- private constructor(public readonly value: Fr) {}
25
+ export class ExtendedDirectionalAppTaggingSecret {
26
+ private constructor(
27
+ public readonly secret: Fr,
28
+ public readonly app: AztecAddress,
29
+ ) {}
24
30
 
25
31
  /**
26
32
  * Derives shared tagging secret and from that, the app address and recipient derives the directional app tagging
@@ -39,20 +45,21 @@ export class DirectionalAppTaggingSecret {
39
45
  externalAddress: AztecAddress,
40
46
  app: AztecAddress,
41
47
  recipient: AztecAddress,
42
- ): Promise<DirectionalAppTaggingSecret> {
48
+ ): Promise<ExtendedDirectionalAppTaggingSecret> {
43
49
  const taggingSecretPoint = await computeSharedTaggingSecret(localAddress, localIvsk, externalAddress);
44
50
  const appTaggingSecret = await poseidon2Hash([taggingSecretPoint.x, taggingSecretPoint.y, app]);
45
51
  const directionalAppTaggingSecret = await poseidon2Hash([appTaggingSecret, recipient]);
46
52
 
47
- return new DirectionalAppTaggingSecret(directionalAppTaggingSecret);
53
+ return new ExtendedDirectionalAppTaggingSecret(directionalAppTaggingSecret, app);
48
54
  }
49
55
 
50
56
  toString(): string {
51
- return this.value.toString();
57
+ return `${this.secret.toString()}:${this.app.toString()}`;
52
58
  }
53
59
 
54
- static fromString(str: string): DirectionalAppTaggingSecret {
55
- return new DirectionalAppTaggingSecret(Fr.fromString(str));
60
+ static fromString(str: string): ExtendedDirectionalAppTaggingSecret {
61
+ const [secretStr, appStr] = str.split(':');
62
+ return new ExtendedDirectionalAppTaggingSecret(Fr.fromString(secretStr), AztecAddress.fromString(appStr));
56
63
  }
57
64
  }
58
65
 
@@ -74,6 +81,7 @@ async function computeSharedTaggingSecret(
74
81
  return Grumpkin.mul(externalAddressPoint, await computeAddressSecret(knownPreaddress, localIvsk));
75
82
  }
76
83
 
77
- export const DirectionalAppTaggingSecretSchema = z.object({
78
- value: Fr.schema,
84
+ export const ExtendedDirectionalAppTaggingSecretSchema = z.object({
85
+ secret: Fr.schema,
86
+ app: AztecAddress.schema,
79
87
  });
package/src/logs/index.ts CHANGED
@@ -1,4 +1,4 @@
1
- export * from './directional_app_tagging_secret.js';
1
+ export * from './extended_directional_app_tagging_secret.js';
2
2
  export * from './pre_tag.js';
3
3
  export * from './contract_class_log.js';
4
4
  export * from './public_log.js';
@@ -12,5 +12,6 @@ export * from './shared_secret_derivation.js';
12
12
  export * from './tx_scoped_l2_log.js';
13
13
  export * from './message_context.js';
14
14
  export * from './debug_log.js';
15
+ export * from './debug_log_store.js';
15
16
  export * from './tag.js';
16
17
  export * from './siloed_tag.js';
@@ -3,9 +3,9 @@ import { schemas } from '@aztec/foundation/schemas';
3
3
  import { z } from 'zod';
4
4
 
5
5
  import {
6
- type DirectionalAppTaggingSecret,
7
- DirectionalAppTaggingSecretSchema,
8
- } from './directional_app_tagging_secret.js';
6
+ type ExtendedDirectionalAppTaggingSecret,
7
+ ExtendedDirectionalAppTaggingSecretSchema,
8
+ } from './extended_directional_app_tagging_secret.js';
9
9
 
10
10
  /**
11
11
  * Represents a preimage of a private log tag (see `Tag` in `pxe/src/tagging`).
@@ -15,11 +15,11 @@ import {
15
15
  * around this.
16
16
  */
17
17
  export type PreTag = {
18
- secret: DirectionalAppTaggingSecret;
18
+ extendedSecret: ExtendedDirectionalAppTaggingSecret;
19
19
  index: number;
20
20
  };
21
21
 
22
22
  export const PreTagSchema = z.object({
23
- secret: DirectionalAppTaggingSecretSchema,
23
+ extendedSecret: ExtendedDirectionalAppTaggingSecretSchema,
24
24
  index: schemas.Integer,
25
25
  });
@@ -1,11 +1,11 @@
1
- import { GeneratorIndex } from '@aztec/constants';
2
- import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
3
1
  import type { Fr } from '@aztec/foundation/curves/bn254';
4
2
  import type { ZodFor } from '@aztec/foundation/schemas';
5
3
 
6
4
  import type { AztecAddress } from '../aztec-address/index.js';
5
+ import { computeSiloedPrivateLogFirstField } from '../hash/hash.js';
7
6
  import { schemas } from '../schemas/schemas.js';
8
- import type { Tag } from './tag.js';
7
+ import type { PreTag } from './pre_tag.js';
8
+ import { Tag } from './tag.js';
9
9
 
10
10
  /* eslint-disable @typescript-eslint/no-unsafe-declaration-merging */
11
11
 
@@ -22,8 +22,13 @@ export interface SiloedTag {
22
22
  export class SiloedTag {
23
23
  constructor(public readonly value: Fr) {}
24
24
 
25
- static async compute(tag: Tag, app: AztecAddress): Promise<SiloedTag> {
26
- const siloedTag = await poseidon2HashWithSeparator([app, tag.value], GeneratorIndex.PRIVATE_LOG_FIRST_FIELD);
25
+ static async compute(preTag: PreTag): Promise<SiloedTag> {
26
+ const tag = await Tag.compute(preTag);
27
+ return SiloedTag.computeFromTagAndApp(tag, preTag.extendedSecret.app);
28
+ }
29
+
30
+ static async computeFromTagAndApp(tag: Tag, app: AztecAddress): Promise<SiloedTag> {
31
+ const siloedTag = await computeSiloedPrivateLogFirstField(app, tag.value);
27
32
  return new SiloedTag(siloedTag);
28
33
  }
29
34
 
package/src/logs/tag.ts CHANGED
@@ -20,7 +20,7 @@ export class Tag {
20
20
  constructor(public readonly value: Fr) {}
21
21
 
22
22
  static async compute(preTag: PreTag): Promise<Tag> {
23
- const tag = await poseidon2Hash([preTag.secret.value, preTag.index]);
23
+ const tag = await poseidon2Hash([preTag.extendedSecret.secret, preTag.index]);
24
24
  return new Tag(tag);
25
25
  }
26
26
 
package/src/note/index.ts CHANGED
@@ -1,5 +1,4 @@
1
1
  export * from './comparator.js';
2
2
  export * from './note_dao.js';
3
- export * from './notes_filter.js';
4
3
  export * from './note_status.js';
5
4
  export * from './note.js';
@@ -33,3 +33,59 @@ export function orderAttestations(
33
33
 
34
34
  return orderedAttestations;
35
35
  }
36
+
37
+ /**
38
+ * Trims attestations to the minimum required number to save L1 calldata gas.
39
+ * Each signature costs 65 bytes of calldata vs 20 bytes for just an address.
40
+ *
41
+ * Priority order for keeping attestations:
42
+ * 1. The proposer's attestation (required by L1 contract - MissingProposerSignature revert)
43
+ * 2. Attestations from the local node's validator keys
44
+ * 3. Remaining attestations filled to reach the required count
45
+ */
46
+ export function trimAttestations(
47
+ attestations: CheckpointAttestation[],
48
+ required: number,
49
+ proposerAddress: EthAddress,
50
+ localAddresses: EthAddress[],
51
+ ): CheckpointAttestation[] {
52
+ if (attestations.length <= required) {
53
+ return attestations;
54
+ }
55
+
56
+ const proposerAttestation: CheckpointAttestation[] = [];
57
+ const localAttestations: CheckpointAttestation[] = [];
58
+ const otherAttestations: CheckpointAttestation[] = [];
59
+
60
+ for (const attestation of attestations) {
61
+ const sender = attestation.getSender();
62
+ if (!sender) {
63
+ continue;
64
+ }
65
+ if (sender.equals(proposerAddress)) {
66
+ proposerAttestation.push(attestation);
67
+ } else if (localAddresses.some(addr => addr.equals(sender))) {
68
+ localAttestations.push(attestation);
69
+ } else {
70
+ otherAttestations.push(attestation);
71
+ }
72
+ }
73
+
74
+ const result: CheckpointAttestation[] = [...proposerAttestation];
75
+
76
+ for (const att of localAttestations) {
77
+ if (result.length >= required) {
78
+ break;
79
+ }
80
+ result.push(att);
81
+ }
82
+
83
+ for (const att of otherAttestations) {
84
+ if (result.length >= required) {
85
+ break;
86
+ }
87
+ result.push(att);
88
+ }
89
+
90
+ return result;
91
+ }
@@ -6,11 +6,11 @@ import { Fr } from '@aztec/foundation/curves/bn254';
6
6
  import type { EthAddress } from '@aztec/foundation/eth-address';
7
7
  import { Signature } from '@aztec/foundation/eth-signature';
8
8
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
9
- import { DutyType, type SigningContext } from '@aztec/validator-ha-signer/types';
10
9
 
11
10
  import type { L2Block } from '../block/l2_block.js';
12
11
  import type { L2BlockInfo } from '../block/l2_block_info.js';
13
12
  import { MAX_TXS_PER_BLOCK } from '../deserialization/index.js';
13
+ import { DutyType, type SigningContext } from '../ha-signing/index.js';
14
14
  import { BlockHeader } from '../tx/block_header.js';
15
15
  import { TxHash } from '../tx/index.js';
16
16
  import type { Tx } from '../tx/tx.js';
@@ -56,8 +56,6 @@ export class BlockProposal extends Gossipable {
56
56
  /** The per-block header containing block state and global variables */
57
57
  public readonly blockHeader: BlockHeader,
58
58
 
59
- // TODO(palla/mbps): Is this really needed? Can we just derive it from the indexWithinCheckpoint of the parent block and the slot number?
60
- // See the block-proposal-handler, we have a lot of extra validations to check this is correct, so maybe we can avoid storing it here.
61
59
  /** Index of this block within the checkpoint (0-indexed) */
62
60
  public readonly indexWithinCheckpoint: IndexWithinCheckpoint,
63
61
 
@@ -96,7 +96,12 @@ export class CheckpointAttestation extends Gossipable {
96
96
  // Create a temporary CheckpointProposal to recover the proposer address.
97
97
  // We need to use CheckpointProposal because it has a different getPayloadToSign()
98
98
  // implementation than ConsensusPayload (uses serializeToBuffer vs ABI encoding).
99
- const proposal = new CheckpointProposal(this.payload.header, this.payload.archive, this.proposerSignature);
99
+ const proposal = new CheckpointProposal(
100
+ this.payload.header,
101
+ this.payload.archive,
102
+ this.payload.feeAssetPriceModifier,
103
+ this.proposerSignature,
104
+ );
100
105
  // Cache the proposer for later use
101
106
  this.proposer = proposal.getSender();
102
107
  }
@@ -5,11 +5,11 @@ import { tryRecoverAddress } from '@aztec/foundation/crypto/secp256k1-signer';
5
5
  import { Fr } from '@aztec/foundation/curves/bn254';
6
6
  import type { EthAddress } from '@aztec/foundation/eth-address';
7
7
  import { Signature } from '@aztec/foundation/eth-signature';
8
- import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
9
- import { DutyType, type SigningContext } from '@aztec/validator-ha-signer/types';
8
+ import { BufferReader, serializeSignedBigInt, serializeToBuffer } from '@aztec/foundation/serialize';
10
9
 
11
10
  import type { L2BlockInfo } from '../block/l2_block_info.js';
12
11
  import { MAX_TXS_PER_BLOCK } from '../deserialization/index.js';
12
+ import { DutyType, type SigningContext } from '../ha-signing/index.js';
13
13
  import { CheckpointHeader } from '../rollup/checkpoint_header.js';
14
14
  import { BlockHeader } from '../tx/block_header.js';
15
15
  import { TxHash } from '../tx/index.js';
@@ -81,7 +81,10 @@ export class CheckpointProposal extends Gossipable {
81
81
  /** Archive root after this checkpoint is applied */
82
82
  public readonly archive: Fr,
83
83
 
84
- /** The proposer's signature over the checkpoint payload (checkpointHeader + archive) */
84
+ /** The fee asset price modifier in basis points (from oracle) */
85
+ public readonly feeAssetPriceModifier: bigint,
86
+
87
+ /** The proposer's signature over the checkpoint payload (checkpointHeader + archive + feeAssetPriceModifier) */
85
88
  public readonly signature: Signature,
86
89
 
87
90
  /** Optional last block info, including its own signature for BlockProposal extraction */
@@ -160,20 +163,31 @@ export class CheckpointProposal extends Gossipable {
160
163
 
161
164
  /**
162
165
  * Get the payload to sign for this checkpoint proposal.
163
- * The signature is over the checkpoint header + archive root (for consensus).
166
+ * The signature is over the checkpoint header + archive root + feeAssetPriceModifier (for consensus).
164
167
  */
165
168
  getPayloadToSign(domainSeparator: SignatureDomainSeparator): Buffer {
166
- return serializeToBuffer([domainSeparator, this.checkpointHeader, this.archive]);
169
+ return serializeToBuffer([
170
+ domainSeparator,
171
+ this.checkpointHeader,
172
+ this.archive,
173
+ serializeSignedBigInt(this.feeAssetPriceModifier),
174
+ ]);
167
175
  }
168
176
 
169
177
  static async createProposalFromSigner(
170
178
  checkpointHeader: CheckpointHeader,
171
179
  archiveRoot: Fr,
180
+ feeAssetPriceModifier: bigint,
172
181
  lastBlockInfo: CheckpointLastBlockData | undefined,
173
182
  payloadSigner: (payload: Buffer32, context: SigningContext) => Promise<Signature>,
174
183
  ): Promise<CheckpointProposal> {
175
184
  // Sign the checkpoint payload with CHECKPOINT_PROPOSAL duty type
176
- const tempProposal = new CheckpointProposal(checkpointHeader, archiveRoot, Signature.empty(), undefined);
185
+ const tempProposal = new CheckpointProposal(
186
+ checkpointHeader,
187
+ archiveRoot,
188
+ feeAssetPriceModifier,
189
+ Signature.empty(),
190
+ );
177
191
  const checkpointHash = getHashedSignaturePayload(tempProposal, SignatureDomainSeparator.checkpointProposal);
178
192
 
179
193
  const checkpointContext: SigningContext = {
@@ -184,7 +198,7 @@ export class CheckpointProposal extends Gossipable {
184
198
  const checkpointSignature = await payloadSigner(checkpointHash, checkpointContext);
185
199
 
186
200
  if (!lastBlockInfo) {
187
- return new CheckpointProposal(checkpointHeader, archiveRoot, checkpointSignature);
201
+ return new CheckpointProposal(checkpointHeader, archiveRoot, feeAssetPriceModifier, checkpointSignature);
188
202
  }
189
203
 
190
204
  const lastBlockProposal = await BlockProposal.createProposalFromSigner(
@@ -197,7 +211,7 @@ export class CheckpointProposal extends Gossipable {
197
211
  payloadSigner,
198
212
  );
199
213
 
200
- return new CheckpointProposal(checkpointHeader, archiveRoot, checkpointSignature, {
214
+ return new CheckpointProposal(checkpointHeader, archiveRoot, feeAssetPriceModifier, checkpointSignature, {
201
215
  blockHeader: lastBlockInfo.blockHeader,
202
216
  indexWithinCheckpoint: lastBlockInfo.indexWithinCheckpoint,
203
217
  txHashes: lastBlockInfo.txHashes,
@@ -237,7 +251,12 @@ export class CheckpointProposal extends Gossipable {
237
251
  }
238
252
 
239
253
  toBuffer(): Buffer {
240
- const buffer: any[] = [this.checkpointHeader, this.archive, this.signature];
254
+ const buffer: any[] = [
255
+ this.checkpointHeader,
256
+ this.archive,
257
+ serializeSignedBigInt(this.feeAssetPriceModifier),
258
+ this.signature,
259
+ ];
241
260
 
242
261
  if (this.lastBlock) {
243
262
  buffer.push(1); // hasLastBlock = true
@@ -264,6 +283,7 @@ export class CheckpointProposal extends Gossipable {
264
283
 
265
284
  const checkpointHeader = reader.readObject(CheckpointHeader);
266
285
  const archive = reader.readObject(Fr);
286
+ const feeAssetPriceModifier = reader.readInt256();
267
287
  const signature = reader.readObject(Signature);
268
288
 
269
289
  const hasLastBlock = reader.readNumber();
@@ -286,7 +306,7 @@ export class CheckpointProposal extends Gossipable {
286
306
  }
287
307
  }
288
308
 
289
- return new CheckpointProposal(checkpointHeader, archive, signature, {
309
+ return new CheckpointProposal(checkpointHeader, archive, feeAssetPriceModifier, signature, {
290
310
  blockHeader,
291
311
  indexWithinCheckpoint,
292
312
  txHashes,
@@ -295,7 +315,7 @@ export class CheckpointProposal extends Gossipable {
295
315
  });
296
316
  }
297
317
 
298
- return new CheckpointProposal(checkpointHeader, archive, signature);
318
+ return new CheckpointProposal(checkpointHeader, archive, feeAssetPriceModifier, signature);
299
319
  }
300
320
 
301
321
  getSize(): number {
@@ -303,6 +323,7 @@ export class CheckpointProposal extends Gossipable {
303
323
  this.checkpointHeader.toBuffer().length +
304
324
  this.archive.size +
305
325
  this.signature.getSize() +
326
+ 8 /* feeAssetPriceModifier */ +
306
327
  4; /* hasLastBlock flag */
307
328
 
308
329
  if (this.lastBlock) {
@@ -320,11 +341,11 @@ export class CheckpointProposal extends Gossipable {
320
341
  }
321
342
 
322
343
  static empty(): CheckpointProposal {
323
- return new CheckpointProposal(CheckpointHeader.empty(), Fr.ZERO, Signature.empty());
344
+ return new CheckpointProposal(CheckpointHeader.empty(), Fr.ZERO, 0n, Signature.empty());
324
345
  }
325
346
 
326
347
  static random(): CheckpointProposal {
327
- return new CheckpointProposal(CheckpointHeader.random(), Fr.random(), Signature.random(), {
348
+ return new CheckpointProposal(CheckpointHeader.random(), Fr.random(), 0n, Signature.random(), {
328
349
  blockHeader: BlockHeader.random(),
329
350
  indexWithinCheckpoint: IndexWithinCheckpoint(Math.floor(Math.random() * 5)),
330
351
  txHashes: [TxHash.random(), TxHash.random()],
@@ -337,6 +358,7 @@ export class CheckpointProposal extends Gossipable {
337
358
  checkpointHeader: this.checkpointHeader.toInspect(),
338
359
  archive: this.archive.toString(),
339
360
  signature: this.signature.toString(),
361
+ feeAssetPriceModifier: this.feeAssetPriceModifier.toString(),
340
362
  lastBlock: this.lastBlock
341
363
  ? {
342
364
  blockHeader: this.lastBlock.blockHeader.toInspect(),
@@ -353,7 +375,7 @@ export class CheckpointProposal extends Gossipable {
353
375
  * Used when the lastBlock has been extracted and stored separately.
354
376
  */
355
377
  toCore(): CheckpointProposalCore {
356
- return new CheckpointProposal(this.checkpointHeader, this.archive, this.signature);
378
+ return new CheckpointProposal(this.checkpointHeader, this.archive, this.feeAssetPriceModifier, this.signature);
357
379
  }
358
380
  }
359
381
 
@@ -1,6 +0,0 @@
1
- export enum P2PClientType {
2
- // Full p2p clients will subscribe to all gossip topics
3
- Full,
4
- // Prove p2p clients will only subscribe to transaction and proving topics
5
- Prover,
6
- }