@aztec/stdlib 0.0.1-commit.6230a0c → 0.0.1-commit.643667a5cb

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 (297) 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/in_block.js +1 -1
  9. package/dest/block/index.d.ts +2 -1
  10. package/dest/block/index.d.ts.map +1 -1
  11. package/dest/block/index.js +1 -0
  12. package/dest/block/l2_block_source.d.ts +20 -1
  13. package/dest/block/l2_block_source.d.ts.map +1 -1
  14. package/dest/checkpoint/checkpoint.d.ts +21 -7
  15. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  16. package/dest/checkpoint/checkpoint.js +24 -13
  17. package/dest/checkpoint/checkpoint_data.d.ts +120 -0
  18. package/dest/checkpoint/checkpoint_data.d.ts.map +1 -0
  19. package/dest/checkpoint/checkpoint_data.js +26 -0
  20. package/dest/checkpoint/index.d.ts +2 -1
  21. package/dest/checkpoint/index.d.ts.map +1 -1
  22. package/dest/checkpoint/index.js +1 -0
  23. package/dest/checkpoint/published_checkpoint.d.ts +17 -2
  24. package/dest/checkpoint/published_checkpoint.d.ts.map +1 -1
  25. package/dest/checkpoint/published_checkpoint.js +1 -2
  26. package/dest/config/index.d.ts +2 -1
  27. package/dest/config/index.d.ts.map +1 -1
  28. package/dest/config/index.js +1 -0
  29. package/dest/config/sequencer-config.d.ts +10 -0
  30. package/dest/config/sequencer-config.d.ts.map +1 -0
  31. package/dest/config/sequencer-config.js +18 -0
  32. package/dest/contract/contract_address.js +4 -4
  33. package/dest/contract/contract_class.d.ts +2 -3
  34. package/dest/contract/contract_class.d.ts.map +1 -1
  35. package/dest/contract/contract_class_id.d.ts +1 -1
  36. package/dest/contract/contract_class_id.d.ts.map +1 -1
  37. package/dest/contract/contract_class_id.js +5 -4
  38. package/dest/contract/interfaces/node-info.d.ts +3 -1
  39. package/dest/contract/interfaces/node-info.d.ts.map +1 -1
  40. package/dest/contract/interfaces/node-info.js +2 -1
  41. package/dest/contract/private_function.js +2 -2
  42. package/dest/epoch-helpers/index.d.ts +5 -1
  43. package/dest/epoch-helpers/index.d.ts.map +1 -1
  44. package/dest/epoch-helpers/index.js +4 -2
  45. package/dest/file-store/local.d.ts +3 -3
  46. package/dest/file-store/local.d.ts.map +1 -1
  47. package/dest/file-store/local.js +13 -4
  48. package/dest/file-store/s3.d.ts +1 -1
  49. package/dest/file-store/s3.d.ts.map +1 -1
  50. package/dest/file-store/s3.js +11 -3
  51. package/dest/ha-signing/config.d.ts +101 -0
  52. package/dest/ha-signing/config.d.ts.map +1 -0
  53. package/dest/ha-signing/config.js +92 -0
  54. package/dest/ha-signing/index.d.ts +3 -0
  55. package/dest/ha-signing/index.d.ts.map +1 -0
  56. package/dest/ha-signing/index.js +2 -0
  57. package/dest/ha-signing/types.d.ts +85 -0
  58. package/dest/ha-signing/types.d.ts.map +1 -0
  59. package/dest/ha-signing/types.js +32 -0
  60. package/dest/hash/hash.d.ts +2 -1
  61. package/dest/hash/hash.d.ts.map +1 -1
  62. package/dest/hash/hash.js +16 -10
  63. package/dest/hash/map_slot.js +2 -2
  64. package/dest/interfaces/archiver.d.ts +1 -1
  65. package/dest/interfaces/archiver.d.ts.map +1 -1
  66. package/dest/interfaces/archiver.js +5 -0
  67. package/dest/interfaces/aztec-node-admin.d.ts +39 -2
  68. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  69. package/dest/interfaces/aztec-node-admin.js +9 -3
  70. package/dest/interfaces/aztec-node.d.ts +1 -1
  71. package/dest/interfaces/block-builder.d.ts +2 -2
  72. package/dest/interfaces/block-builder.d.ts.map +1 -1
  73. package/dest/interfaces/configs.d.ts +17 -2
  74. package/dest/interfaces/configs.d.ts.map +1 -1
  75. package/dest/interfaces/configs.js +4 -1
  76. package/dest/interfaces/get_logs_response.d.ts +8 -1
  77. package/dest/interfaces/get_logs_response.d.ts.map +1 -1
  78. package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
  79. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  80. package/dest/interfaces/p2p.d.ts +2 -2
  81. package/dest/interfaces/p2p.d.ts.map +1 -1
  82. package/dest/interfaces/proving-job.d.ts +168 -168
  83. package/dest/interfaces/slasher.d.ts +9 -1
  84. package/dest/interfaces/slasher.d.ts.map +1 -1
  85. package/dest/interfaces/slasher.js +2 -0
  86. package/dest/interfaces/validator.d.ts +18 -4
  87. package/dest/interfaces/validator.d.ts.map +1 -1
  88. package/dest/interfaces/validator.js +5 -2
  89. package/dest/kernel/hints/index.d.ts +2 -2
  90. package/dest/kernel/hints/index.js +2 -2
  91. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  92. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  93. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
  94. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
  95. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  96. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  97. package/dest/kernel/private_circuit_public_inputs.d.ts +9 -9
  98. package/dest/kernel/private_circuit_public_inputs.d.ts.map +1 -1
  99. package/dest/kernel/private_circuit_public_inputs.js +16 -16
  100. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts +3 -3
  101. package/dest/kernel/private_kernel_circuit_public_inputs.d.ts.map +1 -1
  102. package/dest/kernel/private_kernel_circuit_public_inputs.js +4 -4
  103. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts +3 -3
  104. package/dest/kernel/private_kernel_tail_circuit_private_inputs.d.ts.map +1 -1
  105. package/dest/kernel/private_kernel_tail_circuit_private_inputs.js +4 -4
  106. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts +3 -3
  107. package/dest/kernel/private_kernel_tail_circuit_public_inputs.d.ts.map +1 -1
  108. package/dest/kernel/private_kernel_tail_circuit_public_inputs.js +7 -7
  109. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts +3 -3
  110. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.d.ts.map +1 -1
  111. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +7 -7
  112. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts +3 -3
  113. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.d.ts.map +1 -1
  114. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +7 -7
  115. package/dest/kernel/private_validation_requests.d.ts +3 -3
  116. package/dest/kernel/private_validation_requests.js +9 -9
  117. package/dest/keys/derivation.js +8 -8
  118. package/dest/keys/key_types.d.ts +3 -3
  119. package/dest/keys/key_types.d.ts.map +1 -1
  120. package/dest/keys/public_keys.js +2 -2
  121. package/dest/keys/utils.js +5 -5
  122. package/dest/logs/extended_public_log.d.ts +7 -1
  123. package/dest/logs/extended_public_log.d.ts.map +1 -1
  124. package/dest/logs/log_id.d.ts +10 -7
  125. package/dest/logs/log_id.d.ts.map +1 -1
  126. package/dest/logs/log_id.js +15 -13
  127. package/dest/logs/private_log.d.ts +2 -2
  128. package/dest/logs/private_log.d.ts.map +1 -1
  129. package/dest/logs/siloed_tag.d.ts +1 -1
  130. package/dest/logs/siloed_tag.d.ts.map +1 -1
  131. package/dest/logs/siloed_tag.js +2 -6
  132. package/dest/messaging/l2_to_l1_membership.d.ts +2 -2
  133. package/dest/messaging/l2_to_l1_membership.js +3 -3
  134. package/dest/note/index.d.ts +1 -2
  135. package/dest/note/index.d.ts.map +1 -1
  136. package/dest/note/index.js +0 -1
  137. package/dest/p2p/attestation_utils.d.ts +11 -1
  138. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  139. package/dest/p2p/attestation_utils.js +45 -0
  140. package/dest/p2p/block_proposal.d.ts +2 -2
  141. package/dest/p2p/block_proposal.d.ts.map +1 -1
  142. package/dest/p2p/block_proposal.js +2 -4
  143. package/dest/p2p/checkpoint_attestation.d.ts +2 -1
  144. package/dest/p2p/checkpoint_attestation.d.ts.map +1 -1
  145. package/dest/p2p/checkpoint_attestation.js +1 -1
  146. package/dest/p2p/checkpoint_proposal.d.ts +18 -6
  147. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
  148. package/dest/p2p/checkpoint_proposal.js +30 -16
  149. package/dest/p2p/consensus_payload.d.ts +12 -3
  150. package/dest/p2p/consensus_payload.d.ts.map +1 -1
  151. package/dest/p2p/consensus_payload.js +22 -15
  152. package/dest/p2p/constants.d.ts +3 -1
  153. package/dest/p2p/constants.d.ts.map +1 -1
  154. package/dest/p2p/constants.js +1 -0
  155. package/dest/rollup/checkpoint_header.d.ts +2 -2
  156. package/dest/rollup/checkpoint_header.js +2 -2
  157. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts +6 -6
  158. package/dest/rollup/checkpoint_rollup_public_inputs.d.ts.map +1 -1
  159. package/dest/rollup/checkpoint_rollup_public_inputs.js +2 -2
  160. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts +2 -2
  161. package/dest/rollup/checkpoint_root_rollup_private_inputs.d.ts.map +1 -1
  162. package/dest/rollup/root_rollup_public_inputs.d.ts +6 -6
  163. package/dest/rollup/root_rollup_public_inputs.d.ts.map +1 -1
  164. package/dest/rollup/root_rollup_public_inputs.js +3 -3
  165. package/dest/slashing/empire.d.ts +1 -1
  166. package/dest/slashing/empire.d.ts.map +1 -1
  167. package/dest/slashing/empire.js +2 -0
  168. package/dest/slashing/helpers.d.ts +2 -2
  169. package/dest/slashing/helpers.d.ts.map +1 -1
  170. package/dest/slashing/helpers.js +6 -0
  171. package/dest/slashing/tally.d.ts +2 -1
  172. package/dest/slashing/tally.d.ts.map +1 -1
  173. package/dest/slashing/tally.js +6 -2
  174. package/dest/slashing/types.d.ts +7 -3
  175. package/dest/slashing/types.d.ts.map +1 -1
  176. package/dest/slashing/types.js +13 -1
  177. package/dest/tests/factories.js +13 -13
  178. package/dest/tests/mocks.d.ts +5 -2
  179. package/dest/tests/mocks.d.ts.map +1 -1
  180. package/dest/tests/mocks.js +18 -13
  181. package/dest/timetable/index.d.ts +37 -0
  182. package/dest/timetable/index.d.ts.map +1 -0
  183. package/dest/timetable/index.js +39 -0
  184. package/dest/trees/public_data_leaf.d.ts +2 -1
  185. package/dest/trees/public_data_leaf.d.ts.map +1 -1
  186. package/dest/trees/public_data_leaf.js +7 -6
  187. package/dest/tx/block_header.js +2 -2
  188. package/dest/tx/global_variables.d.ts +4 -4
  189. package/dest/tx/global_variables.d.ts.map +1 -1
  190. package/dest/tx/profiling.d.ts +4 -4
  191. package/dest/tx/profiling.d.ts.map +1 -1
  192. package/dest/tx/profiling.js +3 -3
  193. package/dest/tx/protocol_contracts.d.ts +1 -1
  194. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  195. package/dest/tx/protocol_contracts.js +2 -2
  196. package/dest/tx/public_simulation_output.d.ts +4 -2
  197. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  198. package/dest/tx/public_simulation_output.js +7 -3
  199. package/dest/tx/tx_request.js +2 -2
  200. package/dest/tx/validator/empty_validator.d.ts +2 -2
  201. package/dest/tx/validator/empty_validator.d.ts.map +1 -1
  202. package/dest/tx/validator/error_texts.d.ts +1 -1
  203. package/dest/tx/validator/error_texts.js +1 -1
  204. package/dest/tx/validator/tx_validator.d.ts +2 -2
  205. package/dest/tx/validator/tx_validator.d.ts.map +1 -1
  206. package/dest/validators/schemas.d.ts +30 -30
  207. package/dest/validators/schemas.d.ts.map +1 -1
  208. package/dest/validators/schemas.js +4 -3
  209. package/dest/validators/types.d.ts +3 -3
  210. package/dest/validators/types.d.ts.map +1 -1
  211. package/package.json +22 -11
  212. package/src/abi/function_call.ts +25 -3
  213. package/src/auth_witness/auth_witness.ts +3 -3
  214. package/src/block/block_data.ts +26 -0
  215. package/src/block/in_block.ts +1 -1
  216. package/src/block/index.ts +1 -0
  217. package/src/block/l2_block_source.ts +22 -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/index.ts +1 -0
  223. package/src/config/sequencer-config.ts +29 -0
  224. package/src/contract/contract_address.ts +4 -4
  225. package/src/contract/contract_class.ts +3 -3
  226. package/src/contract/contract_class_id.ts +5 -4
  227. package/src/contract/interfaces/node-info.ts +3 -0
  228. package/src/contract/private_function.ts +2 -2
  229. package/src/epoch-helpers/index.ts +3 -0
  230. package/src/file-store/local.ts +15 -5
  231. package/src/file-store/s3.ts +12 -3
  232. package/src/ha-signing/config.ts +149 -0
  233. package/src/ha-signing/index.ts +18 -0
  234. package/src/ha-signing/types.ts +112 -0
  235. package/src/hash/hash.ts +14 -10
  236. package/src/hash/map_slot.ts +2 -2
  237. package/src/interfaces/archiver.ts +5 -0
  238. package/src/interfaces/aztec-node-admin.ts +23 -0
  239. package/src/interfaces/aztec-node.ts +1 -1
  240. package/src/interfaces/block-builder.ts +1 -0
  241. package/src/interfaces/configs.ts +12 -1
  242. package/src/interfaces/merkle_tree_operations.ts +1 -1
  243. package/src/interfaces/p2p.ts +1 -1
  244. package/src/interfaces/slasher.ts +4 -0
  245. package/src/interfaces/validator.ts +12 -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/log_id.ts +15 -12
  261. package/src/logs/siloed_tag.ts +2 -3
  262. package/src/messaging/l2_to_l1_membership.ts +3 -3
  263. package/src/note/index.ts +0 -1
  264. package/src/p2p/attestation_utils.ts +56 -0
  265. package/src/p2p/block_proposal.ts +1 -3
  266. package/src/p2p/checkpoint_attestation.ts +6 -1
  267. package/src/p2p/checkpoint_proposal.ts +46 -14
  268. package/src/p2p/consensus_payload.ts +25 -12
  269. package/src/p2p/constants.ts +3 -0
  270. package/src/rollup/checkpoint_header.ts +2 -2
  271. package/src/rollup/checkpoint_rollup_public_inputs.ts +5 -5
  272. package/src/rollup/root_rollup_public_inputs.ts +7 -7
  273. package/src/slashing/empire.ts +3 -1
  274. package/src/slashing/helpers.ts +8 -0
  275. package/src/slashing/tally.ts +8 -2
  276. package/src/slashing/types.ts +14 -0
  277. package/src/tests/factories.ts +17 -17
  278. package/src/tests/mocks.ts +28 -13
  279. package/src/timetable/index.ts +66 -0
  280. package/src/trees/public_data_leaf.ts +11 -5
  281. package/src/tx/block_header.ts +2 -2
  282. package/src/tx/global_variables.ts +3 -3
  283. package/src/tx/profiling.ts +5 -5
  284. package/src/tx/protocol_contracts.ts +2 -2
  285. package/src/tx/public_simulation_output.ts +4 -0
  286. package/src/tx/tx_request.ts +2 -2
  287. package/src/tx/validator/empty_validator.ts +1 -1
  288. package/src/tx/validator/error_texts.ts +1 -1
  289. package/src/tx/validator/tx_validator.ts +1 -1
  290. package/src/validators/schemas.ts +8 -1
  291. package/src/validators/types.ts +5 -4
  292. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -30
  293. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  294. package/dest/note/notes_filter.d.ts +0 -27
  295. package/dest/note/notes_filter.d.ts.map +0 -1
  296. package/dest/note/notes_filter.js +0 -11
  297. package/src/note/notes_filter.ts +0 -38
@@ -116,7 +116,7 @@ export class PrivateKernelTailCircuitPublicInputs {
116
116
  /**
117
117
  * The timestamp by which the transaction must be included in a block.
118
118
  */
119
- public includeByTimestamp: UInt64,
119
+ public expirationTimestamp: UInt64,
120
120
 
121
121
  public forPublic?: PartialPrivateTailPublicInputsForPublic,
122
122
  public forRollup?: PartialPrivateTailPublicInputsForRollup,
@@ -146,7 +146,7 @@ export class PrivateKernelTailCircuitPublicInputs {
146
146
  this.constants.getSize() +
147
147
  this.gasUsed.getSize() +
148
148
  this.feePayer.size +
149
- 8 // includeByTimestamp
149
+ 8 // expirationTimestamp
150
150
  );
151
151
  }
152
152
 
@@ -161,7 +161,7 @@ export class PrivateKernelTailCircuitPublicInputs {
161
161
  this.forPublic.publicTeardownCallRequest,
162
162
  this.gasUsed,
163
163
  this.feePayer,
164
- this.includeByTimestamp,
164
+ this.expirationTimestamp,
165
165
  );
166
166
  }
167
167
 
@@ -180,7 +180,7 @@ export class PrivateKernelTailCircuitPublicInputs {
180
180
  this.forRollup.end,
181
181
  this.gasUsed,
182
182
  this.feePayer,
183
- this.includeByTimestamp,
183
+ this.expirationTimestamp,
184
184
  );
185
185
  }
186
186
 
@@ -298,7 +298,7 @@ export class PrivateKernelTailCircuitPublicInputs {
298
298
  this.constants,
299
299
  this.gasUsed,
300
300
  this.feePayer,
301
- bigintToUInt64BE(this.includeByTimestamp),
301
+ bigintToUInt64BE(this.expirationTimestamp),
302
302
  isForPublic ? this.forPublic!.toBuffer() : this.forRollup!.toBuffer(),
303
303
  );
304
304
  }
@@ -1,4 +1,4 @@
1
- import { GeneratorIndex, PRIVATE_TO_PUBLIC_KERNEL_CIRCUIT_PUBLIC_INPUTS_LENGTH } from '@aztec/constants';
1
+ import { DomainSeparator, PRIVATE_TO_PUBLIC_KERNEL_CIRCUIT_PUBLIC_INPUTS_LENGTH } from '@aztec/constants';
2
2
  import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
3
3
  import type { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { bufferSchemaFor } from '@aztec/foundation/schemas';
@@ -21,7 +21,7 @@ export class PrivateToPublicKernelCircuitPublicInputs {
21
21
  public publicTeardownCallRequest: PublicCallRequest,
22
22
  public gasUsed: Gas,
23
23
  public feePayer: AztecAddress,
24
- public includeByTimestamp: UInt64,
24
+ public expirationTimestamp: UInt64,
25
25
  ) {}
26
26
 
27
27
  toBuffer() {
@@ -32,7 +32,7 @@ export class PrivateToPublicKernelCircuitPublicInputs {
32
32
  this.publicTeardownCallRequest,
33
33
  this.gasUsed,
34
34
  this.feePayer,
35
- bigintToUInt64BE(this.includeByTimestamp),
35
+ bigintToUInt64BE(this.expirationTimestamp),
36
36
  );
37
37
  }
38
38
 
@@ -44,7 +44,7 @@ export class PrivateToPublicKernelCircuitPublicInputs {
44
44
  fields.publicTeardownCallRequest,
45
45
  fields.gasUsed,
46
46
  fields.feePayer,
47
- fields.includeByTimestamp,
47
+ fields.expirationTimestamp,
48
48
  ] as const;
49
49
  }
50
50
 
@@ -92,7 +92,7 @@ export class PrivateToPublicKernelCircuitPublicInputs {
92
92
  }
93
93
 
94
94
  hash() {
95
- return poseidon2HashWithSeparator(this.toFields(), GeneratorIndex.PUBLIC_TX_HASH);
95
+ return poseidon2HashWithSeparator(this.toFields(), DomainSeparator.PUBLIC_TX_HASH);
96
96
  }
97
97
 
98
98
  toJSON() {
@@ -1,4 +1,4 @@
1
- import { GeneratorIndex, PRIVATE_TO_ROLLUP_KERNEL_CIRCUIT_PUBLIC_INPUTS_LENGTH } from '@aztec/constants';
1
+ import { DomainSeparator, PRIVATE_TO_ROLLUP_KERNEL_CIRCUIT_PUBLIC_INPUTS_LENGTH } from '@aztec/constants';
2
2
  import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto/poseidon';
3
3
  import type { Fr } from '@aztec/foundation/curves/bn254';
4
4
  import { bufferSchemaFor } from '@aztec/foundation/schemas';
@@ -37,7 +37,7 @@ export class PrivateToRollupKernelCircuitPublicInputs {
37
37
  /**
38
38
  * The timestamp by which the transaction must be included in a block.
39
39
  */
40
- public includeByTimestamp: UInt64,
40
+ public expirationTimestamp: UInt64,
41
41
  ) {}
42
42
 
43
43
  getNonEmptyNullifiers() {
@@ -50,7 +50,7 @@ export class PrivateToRollupKernelCircuitPublicInputs {
50
50
  this.end,
51
51
  this.gasUsed,
52
52
  this.feePayer,
53
- bigintToUInt64BE(this.includeByTimestamp),
53
+ bigintToUInt64BE(this.expirationTimestamp),
54
54
  );
55
55
  }
56
56
 
@@ -94,7 +94,7 @@ export class PrivateToRollupKernelCircuitPublicInputs {
94
94
  }
95
95
 
96
96
  static getFields(fields: FieldsOf<PrivateToRollupKernelCircuitPublicInputs>) {
97
- return [fields.constants, fields.end, fields.gasUsed, fields.feePayer, fields.includeByTimestamp] as const;
97
+ return [fields.constants, fields.end, fields.gasUsed, fields.feePayer, fields.expirationTimestamp] as const;
98
98
  }
99
99
 
100
100
  /** Creates an instance from a hex string. */
@@ -113,6 +113,6 @@ export class PrivateToRollupKernelCircuitPublicInputs {
113
113
  }
114
114
 
115
115
  hash() {
116
- return poseidon2HashWithSeparator(this.toFields(), GeneratorIndex.PRIVATE_TX_HASH);
116
+ return poseidon2HashWithSeparator(this.toFields(), DomainSeparator.PRIVATE_TX_HASH);
117
117
  }
118
118
  }
@@ -8,7 +8,7 @@ import { bufferToHex, hexToBuffer } from '@aztec/foundation/string';
8
8
 
9
9
  import { inspect } from 'util';
10
10
 
11
- import { ScopedKeyValidationRequestAndGenerator } from '../kernel/hints/scoped_key_validation_request_and_generator.js';
11
+ import { ScopedKeyValidationRequestAndSeparator } from '../kernel/hints/scoped_key_validation_request_and_separator.js';
12
12
  import { ClaimedLengthArray, ClaimedLengthArrayFromBuffer } from './claimed_length_array.js';
13
13
  import { ScopedReadRequest } from './hints/read_request.js';
14
14
 
@@ -28,8 +28,8 @@ export class PrivateValidationRequests {
28
28
  /**
29
29
  * All the key validation requests made in this transaction.
30
30
  */
31
- public scopedKeyValidationRequestsAndGenerators: ClaimedLengthArray<
32
- ScopedKeyValidationRequestAndGenerator,
31
+ public scopedKeyValidationRequestsAndSeparators: ClaimedLengthArray<
32
+ ScopedKeyValidationRequestAndSeparator,
33
33
  typeof MAX_KEY_VALIDATION_REQUESTS_PER_TX
34
34
  >,
35
35
  ) {}
@@ -38,7 +38,7 @@ export class PrivateValidationRequests {
38
38
  return (
39
39
  this.noteHashReadRequests.getSize() +
40
40
  this.nullifierReadRequests.getSize() +
41
- this.scopedKeyValidationRequestsAndGenerators.getSize()
41
+ this.scopedKeyValidationRequestsAndSeparators.getSize()
42
42
  );
43
43
  }
44
44
 
@@ -46,7 +46,7 @@ export class PrivateValidationRequests {
46
46
  return serializeToBuffer(
47
47
  this.noteHashReadRequests,
48
48
  this.nullifierReadRequests,
49
- this.scopedKeyValidationRequestsAndGenerators,
49
+ this.scopedKeyValidationRequestsAndSeparators,
50
50
  );
51
51
  }
52
52
 
@@ -65,7 +65,7 @@ export class PrivateValidationRequests {
65
65
  reader.readObject(ClaimedLengthArrayFromBuffer(ScopedReadRequest, MAX_NOTE_HASH_READ_REQUESTS_PER_TX)),
66
66
  reader.readObject(ClaimedLengthArrayFromBuffer(ScopedReadRequest, MAX_NULLIFIER_READ_REQUESTS_PER_TX)),
67
67
  reader.readObject(
68
- ClaimedLengthArrayFromBuffer(ScopedKeyValidationRequestAndGenerator, MAX_KEY_VALIDATION_REQUESTS_PER_TX),
68
+ ClaimedLengthArrayFromBuffer(ScopedKeyValidationRequestAndSeparator, MAX_KEY_VALIDATION_REQUESTS_PER_TX),
69
69
  ),
70
70
  );
71
71
  }
@@ -83,7 +83,7 @@ export class PrivateValidationRequests {
83
83
  return new PrivateValidationRequests(
84
84
  ClaimedLengthArray.empty(ScopedReadRequest, MAX_NOTE_HASH_READ_REQUESTS_PER_TX),
85
85
  ClaimedLengthArray.empty(ScopedReadRequest, MAX_NULLIFIER_READ_REQUESTS_PER_TX),
86
- ClaimedLengthArray.empty(ScopedKeyValidationRequestAndGenerator, MAX_KEY_VALIDATION_REQUESTS_PER_TX),
86
+ ClaimedLengthArray.empty(ScopedKeyValidationRequestAndSeparator, MAX_KEY_VALIDATION_REQUESTS_PER_TX),
87
87
  );
88
88
  }
89
89
 
@@ -91,7 +91,7 @@ export class PrivateValidationRequests {
91
91
  return `PrivateValidationRequests {
92
92
  noteHashReadRequests: ${inspect(this.noteHashReadRequests)},
93
93
  nullifierReadRequests: ${inspect(this.nullifierReadRequests)},
94
- scopedKeyValidationRequestsAndGenerators: ${inspect(this.scopedKeyValidationRequestsAndGenerators)},
94
+ scopedKeyValidationRequestsAndSeparators: ${inspect(this.scopedKeyValidationRequestsAndSeparators)},
95
95
  `;
96
96
  }
97
97
  }
@@ -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
  }
@@ -8,20 +8,17 @@ import { z } from 'zod';
8
8
 
9
9
  import { BlockHash } from '../block/block_hash.js';
10
10
  import { schemas } from '../schemas/index.js';
11
+ import { TxHash } from '../tx/tx_hash.js';
11
12
 
12
13
  /** A globally unique log id. */
13
14
  export class LogId {
14
- /**
15
- * Parses a log id from a string.
16
- * @param blockNumber - The block number.
17
- * @param txIndex - The transaction index.
18
- * @param logIndex - The log index.
19
- */
20
15
  constructor(
21
16
  /** The block number the log was emitted in. */
22
17
  public readonly blockNumber: BlockNumber,
23
18
  /** The hash of the block the log was emitted in. */
24
19
  public readonly blockHash: BlockHash,
20
+ /** The hash of the transaction the log was emitted in. */
21
+ public readonly txHash: TxHash,
25
22
  /** The index of a tx in a block the log was emitted in. */
26
23
  public readonly txIndex: number,
27
24
  /** The index of a log the tx was emitted in. */
@@ -42,6 +39,7 @@ export class LogId {
42
39
  return new LogId(
43
40
  BlockNumber(Math.floor(Math.random() * 1000) + 1),
44
41
  BlockHash.random(),
42
+ TxHash.random(),
45
43
  Math.floor(Math.random() * 1000),
46
44
  Math.floor(Math.random() * 100),
47
45
  );
@@ -52,11 +50,13 @@ export class LogId {
52
50
  .object({
53
51
  blockNumber: BlockNumberSchema,
54
52
  blockHash: BlockHash.schema,
53
+ txHash: TxHash.schema,
55
54
  txIndex: schemas.Integer,
56
55
  logIndex: schemas.Integer,
57
56
  })
58
57
  .transform(
59
- ({ blockNumber, blockHash, txIndex, logIndex }) => new LogId(blockNumber, blockHash, txIndex, logIndex),
58
+ ({ blockNumber, blockHash, txHash, txIndex, logIndex }) =>
59
+ new LogId(blockNumber, blockHash, txHash, txIndex, logIndex),
60
60
  );
61
61
  }
62
62
 
@@ -68,6 +68,7 @@ export class LogId {
68
68
  return Buffer.concat([
69
69
  toBufferBE(BigInt(this.blockNumber), 4),
70
70
  this.blockHash.toBuffer(),
71
+ this.txHash.toBuffer(),
71
72
  toBufferBE(BigInt(this.txIndex), 4),
72
73
  toBufferBE(BigInt(this.logIndex), 4),
73
74
  ]);
@@ -83,10 +84,11 @@ export class LogId {
83
84
 
84
85
  const blockNumber = BlockNumber(reader.readNumber());
85
86
  const blockHash = new BlockHash(reader.readObject(Fr));
87
+ const txHash = reader.readObject(TxHash);
86
88
  const txIndex = reader.readNumber();
87
89
  const logIndex = reader.readNumber();
88
90
 
89
- return new LogId(blockNumber, blockHash, txIndex, logIndex);
91
+ return new LogId(blockNumber, blockHash, txHash, txIndex, logIndex);
90
92
  }
91
93
 
92
94
  /**
@@ -94,7 +96,7 @@ export class LogId {
94
96
  * @returns A string representation of the log id.
95
97
  */
96
98
  public toString(): string {
97
- return `${this.blockNumber}-${this.txIndex}-${this.logIndex}-${this.blockHash.toString()}`;
99
+ return `${this.blockNumber}-${this.txIndex}-${this.logIndex}-${this.blockHash.toString()}-${this.txHash.toString()}`;
98
100
  }
99
101
 
100
102
  /**
@@ -103,13 +105,14 @@ export class LogId {
103
105
  * @returns A log id.
104
106
  */
105
107
  static fromString(data: string): LogId {
106
- const [rawBlockNumber, rawTxIndex, rawLogIndex, rawBlockHash] = data.split('-');
108
+ const [rawBlockNumber, rawTxIndex, rawLogIndex, rawBlockHash, rawTxHash] = data.split('-');
107
109
  const blockNumber = BlockNumber(Number(rawBlockNumber));
108
110
  const blockHash = BlockHash.fromString(rawBlockHash);
111
+ const txHash = TxHash.fromString(rawTxHash);
109
112
  const txIndex = Number(rawTxIndex);
110
113
  const logIndex = Number(rawLogIndex);
111
114
 
112
- return new LogId(blockNumber, blockHash, txIndex, logIndex);
115
+ return new LogId(blockNumber, blockHash, txHash, txIndex, logIndex);
113
116
  }
114
117
 
115
118
  /**
@@ -117,6 +120,6 @@ export class LogId {
117
120
  * @returns A human readable representation of the log id.
118
121
  */
119
122
  public toHumanReadable(): string {
120
- return `logId: (blockNumber: ${this.blockNumber}, blockHash: ${this.blockHash.toString()}, txIndex: ${this.txIndex}, logIndex: ${this.logIndex})`;
123
+ return `logId: (blockNumber: ${this.blockNumber}, blockHash: ${this.blockHash.toString()}, txHash: ${this.txHash.toString()}, txIndex: ${this.txIndex}, logIndex: ${this.logIndex})`;
121
124
  }
122
125
  }
@@ -1,9 +1,8 @@
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
7
  import type { Tag } from './tag.js';
9
8
 
@@ -23,7 +22,7 @@ export class SiloedTag {
23
22
  constructor(public readonly value: Fr) {}
24
23
 
25
24
  static async compute(tag: Tag, app: AztecAddress): Promise<SiloedTag> {
26
- const siloedTag = await poseidon2HashWithSeparator([app, tag.value], GeneratorIndex.PRIVATE_LOG_FIRST_FIELD);
25
+ const siloedTag = await computeSiloedPrivateLogFirstField(app, tag.value);
27
26
  return new SiloedTag(siloedTag);
28
27
  }
29
28
 
@@ -32,10 +32,10 @@ import { SiblingPath, UnbalancedMerkleTreeCalculator, computeUnbalancedShaRoot }
32
32
  * - Compression: If a block has no messages (out hash = 0), that branch is ignored
33
33
  *
34
34
  * 4. **Epoch Tree**
35
- * - Leaves: Checkpoint out hashes from all checkpoints in an epoch (padded to AZTEC_MAX_EPOCH_DURATION)
35
+ * - Leaves: Checkpoint out hashes from all checkpoints in an epoch (padded to OUT_HASH_TREE_LEAF_COUNT)
36
36
  * - Root: Epoch out hash (set in the root rollup's public inputs and inserted into the Outbox on L1 when the epoch is proven)
37
37
  * - Type: Unbalanced, non-compressed
38
- * - **Important**: Padded with zeros up to AZTEC_MAX_EPOCH_DURATION to allow for proofs of partial epochs
38
+ * - **Important**: Padded with zeros up to OUT_HASH_TREE_LEAF_COUNT to allow for proofs of partial epochs
39
39
  *
40
40
  * ## Combined Membership Proof
41
41
  * To prove a message exists in an epoch, we combine the sibling paths from all 4 trees:
@@ -163,7 +163,7 @@ export function computeL2ToL1MembershipWitnessFromMessagesInEpoch(
163
163
  }
164
164
  return buildCheckpointTree(messagesInCheckpoint).getRoot();
165
165
  });
166
- // Pad to AZTEC_MAX_EPOCH_DURATION with zeros.
166
+ // Pad to OUT_HASH_TREE_LEAF_COUNT with zeros.
167
167
  checkpointOutHashes = checkpointOutHashes.concat(
168
168
  Array.from({ length: OUT_HASH_TREE_LEAF_COUNT - messagesInEpoch.length }, () => Buffer.alloc(32)),
169
169
  );
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
  }