@aztec/stdlib 0.0.1-commit.8f9871590 → 0.0.1-commit.9117c5f5a

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 (235) 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 +6 -1
  25. package/dest/checkpoint/checkpoint.d.ts.map +1 -1
  26. package/dest/checkpoint/checkpoint.js +5 -4
  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 +11 -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.js +3 -3
  43. package/dest/contract/private_function.js +2 -2
  44. package/dest/file-store/local.d.ts +3 -3
  45. package/dest/file-store/local.d.ts.map +1 -1
  46. package/dest/file-store/local.js +13 -4
  47. package/dest/file-store/s3.d.ts +1 -1
  48. package/dest/file-store/s3.d.ts.map +1 -1
  49. package/dest/file-store/s3.js +11 -3
  50. package/dest/ha-signing/config.d.ts +101 -0
  51. package/dest/ha-signing/config.d.ts.map +1 -0
  52. package/dest/ha-signing/config.js +92 -0
  53. package/dest/ha-signing/index.d.ts +3 -0
  54. package/dest/ha-signing/index.d.ts.map +1 -0
  55. package/dest/ha-signing/index.js +2 -0
  56. package/dest/ha-signing/types.d.ts +85 -0
  57. package/dest/ha-signing/types.d.ts.map +1 -0
  58. package/dest/ha-signing/types.js +32 -0
  59. package/dest/hash/hash.js +11 -11
  60. package/dest/hash/map_slot.js +2 -2
  61. package/dest/interfaces/archiver.d.ts +1 -1
  62. package/dest/interfaces/archiver.d.ts.map +1 -1
  63. package/dest/interfaces/archiver.js +5 -0
  64. package/dest/interfaces/aztec-node-admin.d.ts +30 -2
  65. package/dest/interfaces/aztec-node-admin.d.ts.map +1 -1
  66. package/dest/interfaces/aztec-node-admin.js +9 -3
  67. package/dest/interfaces/configs.d.ts +17 -2
  68. package/dest/interfaces/configs.d.ts.map +1 -1
  69. package/dest/interfaces/configs.js +4 -1
  70. package/dest/interfaces/merkle_tree_operations.d.ts +2 -2
  71. package/dest/interfaces/merkle_tree_operations.d.ts.map +1 -1
  72. package/dest/interfaces/p2p.d.ts +3 -8
  73. package/dest/interfaces/p2p.d.ts.map +1 -1
  74. package/dest/interfaces/validator.d.ts +2 -2
  75. package/dest/interfaces/validator.d.ts.map +1 -1
  76. package/dest/interfaces/validator.js +1 -1
  77. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts +3 -3
  78. package/dest/kernel/hints/build_note_hash_read_request_hints.d.ts.map +1 -1
  79. package/dest/kernel/hints/build_note_hash_read_request_hints.js +13 -10
  80. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts +3 -3
  81. package/dest/kernel/hints/build_nullifier_read_request_hints.d.ts.map +1 -1
  82. package/dest/kernel/hints/build_nullifier_read_request_hints.js +13 -10
  83. package/dest/kernel/hints/build_transient_data_hints.d.ts +5 -2
  84. package/dest/kernel/hints/build_transient_data_hints.d.ts.map +1 -1
  85. package/dest/kernel/hints/build_transient_data_hints.js +9 -3
  86. package/dest/kernel/hints/index.d.ts +2 -2
  87. package/dest/kernel/hints/index.js +2 -2
  88. package/dest/kernel/hints/key_validation_request_and_separator.d.ts +24 -0
  89. package/dest/kernel/hints/key_validation_request_and_separator.d.ts.map +1 -0
  90. package/dest/kernel/hints/{key_validation_request_and_generator.js → key_validation_request_and_separator.js} +12 -15
  91. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts → scoped_key_validation_request_and_separator.d.ts} +8 -8
  92. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.d.ts.map → scoped_key_validation_request_and_separator.d.ts.map} +1 -1
  93. package/dest/kernel/hints/{scoped_key_validation_request_and_generator.js → scoped_key_validation_request_and_separator.js} +6 -6
  94. package/dest/kernel/private_circuit_public_inputs.d.ts +6 -6
  95. package/dest/kernel/private_circuit_public_inputs.js +11 -11
  96. package/dest/kernel/private_to_public_kernel_circuit_public_inputs.js +2 -2
  97. package/dest/kernel/private_to_rollup_kernel_circuit_public_inputs.js +2 -2
  98. package/dest/kernel/private_validation_requests.d.ts +3 -3
  99. package/dest/kernel/private_validation_requests.js +9 -9
  100. package/dest/keys/derivation.js +8 -8
  101. package/dest/keys/key_types.d.ts +3 -3
  102. package/dest/keys/key_types.d.ts.map +1 -1
  103. package/dest/keys/public_keys.js +2 -2
  104. package/dest/keys/utils.js +5 -5
  105. package/dest/logs/debug_log_store.d.ts +30 -0
  106. package/dest/logs/debug_log_store.d.ts.map +1 -0
  107. package/dest/logs/debug_log_store.js +30 -0
  108. package/dest/logs/extended_directional_app_tagging_secret.d.ts +47 -0
  109. package/dest/logs/extended_directional_app_tagging_secret.d.ts.map +1 -0
  110. package/dest/logs/{directional_app_tagging_secret.js → extended_directional_app_tagging_secret.js} +23 -15
  111. package/dest/logs/index.d.ts +3 -2
  112. package/dest/logs/index.d.ts.map +1 -1
  113. package/dest/logs/index.js +2 -1
  114. package/dest/logs/pre_tag.d.ts +16 -11
  115. package/dest/logs/pre_tag.d.ts.map +1 -1
  116. package/dest/logs/pre_tag.js +2 -2
  117. package/dest/logs/private_log.d.ts +2 -2
  118. package/dest/logs/private_log.d.ts.map +1 -1
  119. package/dest/logs/siloed_tag.d.ts +5 -3
  120. package/dest/logs/siloed_tag.d.ts.map +1 -1
  121. package/dest/logs/siloed_tag.js +6 -1
  122. package/dest/logs/tag.js +1 -1
  123. package/dest/p2p/attestation_utils.d.ts +11 -1
  124. package/dest/p2p/attestation_utils.d.ts.map +1 -1
  125. package/dest/p2p/attestation_utils.js +45 -0
  126. package/dest/p2p/block_proposal.d.ts +2 -2
  127. package/dest/p2p/block_proposal.d.ts.map +1 -1
  128. package/dest/p2p/block_proposal.js +2 -4
  129. package/dest/p2p/checkpoint_proposal.d.ts +2 -2
  130. package/dest/p2p/checkpoint_proposal.d.ts.map +1 -1
  131. package/dest/p2p/checkpoint_proposal.js +1 -1
  132. package/dest/p2p/client_type.d.ts +2 -5
  133. package/dest/p2p/client_type.d.ts.map +1 -1
  134. package/dest/p2p/client_type.js +0 -7
  135. package/dest/p2p/index.d.ts +1 -2
  136. package/dest/p2p/index.d.ts.map +1 -1
  137. package/dest/p2p/index.js +0 -1
  138. package/dest/p2p/topic_type.d.ts +3 -4
  139. package/dest/p2p/topic_type.d.ts.map +1 -1
  140. package/dest/p2p/topic_type.js +7 -24
  141. package/dest/rollup/checkpoint_header.d.ts +2 -2
  142. package/dest/rollup/checkpoint_header.js +2 -2
  143. package/dest/tests/factories.d.ts +3 -1
  144. package/dest/tests/factories.d.ts.map +1 -1
  145. package/dest/tests/factories.js +18 -10
  146. package/dest/tests/mocks.d.ts +2 -2
  147. package/dest/tests/mocks.d.ts.map +1 -1
  148. package/dest/tests/mocks.js +5 -5
  149. package/dest/tx/block_header.js +2 -2
  150. package/dest/tx/global_variables.d.ts +4 -4
  151. package/dest/tx/global_variables.d.ts.map +1 -1
  152. package/dest/tx/profiling.d.ts +4 -4
  153. package/dest/tx/profiling.d.ts.map +1 -1
  154. package/dest/tx/profiling.js +3 -3
  155. package/dest/tx/protocol_contracts.d.ts +1 -1
  156. package/dest/tx/protocol_contracts.d.ts.map +1 -1
  157. package/dest/tx/protocol_contracts.js +2 -2
  158. package/dest/tx/public_simulation_output.d.ts +4 -2
  159. package/dest/tx/public_simulation_output.d.ts.map +1 -1
  160. package/dest/tx/public_simulation_output.js +7 -3
  161. package/dest/tx/tx_receipt.d.ts +16 -2
  162. package/dest/tx/tx_receipt.d.ts.map +1 -1
  163. package/dest/tx/tx_receipt.js +11 -3
  164. package/dest/tx/tx_request.js +2 -2
  165. package/package.json +10 -10
  166. package/src/abi/decoder.ts +1 -4
  167. package/src/abi/encoder.ts +8 -5
  168. package/src/auth_witness/auth_witness.ts +3 -3
  169. package/src/avm/revert_code.ts +15 -0
  170. package/src/block/block_data.ts +26 -0
  171. package/src/block/index.ts +1 -0
  172. package/src/block/l2_block_source.ts +22 -0
  173. package/src/block/l2_block_stream/l2_block_stream.ts +21 -0
  174. package/src/checkpoint/checkpoint.ts +5 -3
  175. package/src/checkpoint/checkpoint_data.ts +51 -0
  176. package/src/checkpoint/index.ts +1 -0
  177. package/src/checkpoint/published_checkpoint.ts +3 -1
  178. package/src/config/sequencer-config.ts +11 -1
  179. package/src/contract/contract_address.ts +4 -4
  180. package/src/contract/contract_class.ts +3 -3
  181. package/src/contract/contract_class_id.ts +3 -3
  182. package/src/contract/private_function.ts +2 -2
  183. package/src/file-store/local.ts +15 -5
  184. package/src/file-store/s3.ts +12 -3
  185. package/src/ha-signing/config.ts +149 -0
  186. package/src/ha-signing/index.ts +18 -0
  187. package/src/ha-signing/types.ts +112 -0
  188. package/src/hash/hash.ts +11 -11
  189. package/src/hash/map_slot.ts +2 -2
  190. package/src/interfaces/archiver.ts +5 -0
  191. package/src/interfaces/aztec-node-admin.ts +23 -0
  192. package/src/interfaces/configs.ts +12 -1
  193. package/src/interfaces/merkle_tree_operations.ts +1 -1
  194. package/src/interfaces/p2p.ts +2 -13
  195. package/src/interfaces/validator.ts +1 -1
  196. package/src/kernel/hints/build_note_hash_read_request_hints.ts +14 -18
  197. package/src/kernel/hints/build_nullifier_read_request_hints.ts +15 -18
  198. package/src/kernel/hints/build_transient_data_hints.ts +17 -2
  199. package/src/kernel/hints/index.ts +2 -2
  200. package/src/kernel/hints/{key_validation_request_and_generator.ts → key_validation_request_and_separator.ts} +12 -15
  201. package/src/kernel/hints/{scoped_key_validation_request_and_generator.ts → scoped_key_validation_request_and_separator.ts} +10 -10
  202. package/src/kernel/private_circuit_public_inputs.ts +10 -10
  203. package/src/kernel/private_to_public_kernel_circuit_public_inputs.ts +2 -2
  204. package/src/kernel/private_to_rollup_kernel_circuit_public_inputs.ts +2 -2
  205. package/src/kernel/private_validation_requests.ts +8 -8
  206. package/src/keys/derivation.ts +8 -8
  207. package/src/keys/key_types.ts +6 -2
  208. package/src/keys/public_keys.ts +2 -2
  209. package/src/keys/utils.ts +5 -5
  210. package/src/logs/debug_log_store.ts +54 -0
  211. package/src/logs/{directional_app_tagging_secret.ts → extended_directional_app_tagging_secret.ts} +24 -16
  212. package/src/logs/index.ts +2 -1
  213. package/src/logs/pre_tag.ts +5 -5
  214. package/src/logs/siloed_tag.ts +8 -2
  215. package/src/logs/tag.ts +1 -1
  216. package/src/p2p/attestation_utils.ts +56 -0
  217. package/src/p2p/block_proposal.ts +1 -3
  218. package/src/p2p/checkpoint_proposal.ts +1 -1
  219. package/src/p2p/client_type.ts +0 -6
  220. package/src/p2p/index.ts +0 -1
  221. package/src/p2p/topic_type.ts +8 -15
  222. package/src/rollup/checkpoint_header.ts +2 -2
  223. package/src/tests/factories.ts +20 -11
  224. package/src/tests/mocks.ts +7 -3
  225. package/src/tx/block_header.ts +2 -2
  226. package/src/tx/global_variables.ts +3 -3
  227. package/src/tx/profiling.ts +5 -5
  228. package/src/tx/protocol_contracts.ts +2 -2
  229. package/src/tx/public_simulation_output.ts +4 -0
  230. package/src/tx/tx_receipt.ts +10 -0
  231. package/src/tx/tx_request.ts +2 -2
  232. package/dest/kernel/hints/key_validation_request_and_generator.d.ts +0 -30
  233. package/dest/kernel/hints/key_validation_request_and_generator.d.ts.map +0 -1
  234. package/dest/logs/directional_app_tagging_secret.d.ts +0 -40
  235. package/dest/logs/directional_app_tagging_secret.d.ts.map +0 -1
@@ -21,7 +21,7 @@ import {
21
21
  } from '@aztec/foundation/serialize';
22
22
  import type { FieldsOf } from '@aztec/foundation/types';
23
23
 
24
- import { KeyValidationRequestAndGenerator } from '../kernel/hints/key_validation_request_and_generator.js';
24
+ import { KeyValidationRequestAndSeparator } from '../kernel/hints/key_validation_request_and_separator.js';
25
25
  import { CountedLogHash } from '../kernel/log_hash.js';
26
26
  import { PrivateCallRequest } from '../kernel/private_call_request.js';
27
27
  import { PrivateLogData } from '../kernel/private_log_data.js';
@@ -106,10 +106,10 @@ export class PrivateCircuitPublicInputs {
106
106
  */
107
107
  public nullifierReadRequests: ClaimedLengthArray<ScopedReadRequest, typeof MAX_NULLIFIER_READ_REQUESTS_PER_CALL>,
108
108
  /**
109
- * Key validation requests and generators created by the corresponding function call.
109
+ * Key validation requests and separators created by the corresponding function call.
110
110
  */
111
- public keyValidationRequestsAndGenerators: ClaimedLengthArray<
112
- KeyValidationRequestAndGenerator,
111
+ public keyValidationRequestsAndSeparators: ClaimedLengthArray<
112
+ KeyValidationRequestAndSeparator,
113
113
  typeof MAX_KEY_VALIDATION_REQUESTS_PER_CALL
114
114
  >,
115
115
  /**
@@ -178,7 +178,7 @@ export class PrivateCircuitPublicInputs {
178
178
  reader.readObject(ClaimedLengthArrayFromBuffer(ScopedReadRequest, MAX_NOTE_HASH_READ_REQUESTS_PER_CALL)),
179
179
  reader.readObject(ClaimedLengthArrayFromBuffer(ScopedReadRequest, MAX_NULLIFIER_READ_REQUESTS_PER_CALL)),
180
180
  reader.readObject(
181
- ClaimedLengthArrayFromBuffer(KeyValidationRequestAndGenerator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
181
+ ClaimedLengthArrayFromBuffer(KeyValidationRequestAndSeparator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
182
182
  ),
183
183
  reader.readObject(ClaimedLengthArrayFromBuffer(PrivateCallRequest, MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL)),
184
184
  reader.readObject(ClaimedLengthArrayFromBuffer(CountedPublicCallRequest, MAX_ENQUEUED_CALLS_PER_CALL)),
@@ -209,7 +209,7 @@ export class PrivateCircuitPublicInputs {
209
209
  reader.readObject(ClaimedLengthArrayFromFields(ScopedReadRequest, MAX_NOTE_HASH_READ_REQUESTS_PER_CALL)),
210
210
  reader.readObject(ClaimedLengthArrayFromFields(ScopedReadRequest, MAX_NULLIFIER_READ_REQUESTS_PER_CALL)),
211
211
  reader.readObject(
212
- ClaimedLengthArrayFromFields(KeyValidationRequestAndGenerator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
212
+ ClaimedLengthArrayFromFields(KeyValidationRequestAndSeparator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
213
213
  ),
214
214
  reader.readObject(ClaimedLengthArrayFromFields(PrivateCallRequest, MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL)),
215
215
  reader.readObject(ClaimedLengthArrayFromFields(CountedPublicCallRequest, MAX_ENQUEUED_CALLS_PER_CALL)),
@@ -242,7 +242,7 @@ export class PrivateCircuitPublicInputs {
242
242
  Fr.ZERO,
243
243
  ClaimedLengthArray.empty(ScopedReadRequest, MAX_NOTE_HASH_READ_REQUESTS_PER_CALL),
244
244
  ClaimedLengthArray.empty(ScopedReadRequest, MAX_NULLIFIER_READ_REQUESTS_PER_CALL),
245
- ClaimedLengthArray.empty(KeyValidationRequestAndGenerator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
245
+ ClaimedLengthArray.empty(KeyValidationRequestAndSeparator, MAX_KEY_VALIDATION_REQUESTS_PER_CALL),
246
246
  ClaimedLengthArray.empty(PrivateCallRequest, MAX_PRIVATE_CALL_STACK_LENGTH_PER_CALL),
247
247
  ClaimedLengthArray.empty(CountedPublicCallRequest, MAX_ENQUEUED_CALLS_PER_CALL),
248
248
  PublicCallRequest.empty(),
@@ -270,7 +270,7 @@ export class PrivateCircuitPublicInputs {
270
270
  this.expectedRevertibleSideEffectCounter.isZero() &&
271
271
  this.noteHashReadRequests.isEmpty() &&
272
272
  this.nullifierReadRequests.isEmpty() &&
273
- this.keyValidationRequestsAndGenerators.isEmpty() &&
273
+ this.keyValidationRequestsAndSeparators.isEmpty() &&
274
274
  this.privateCallRequests.isEmpty() &&
275
275
  this.publicCallRequests.isEmpty() &&
276
276
  this.publicTeardownCallRequest.isEmpty() &&
@@ -303,7 +303,7 @@ export class PrivateCircuitPublicInputs {
303
303
  fields.expectedRevertibleSideEffectCounter,
304
304
  fields.noteHashReadRequests,
305
305
  fields.nullifierReadRequests,
306
- fields.keyValidationRequestsAndGenerators,
306
+ fields.keyValidationRequestsAndSeparators,
307
307
  fields.privateCallRequests,
308
308
  fields.publicCallRequests,
309
309
  fields.publicTeardownCallRequest,
@@ -337,7 +337,7 @@ export class PrivateCircuitPublicInputs {
337
337
  this.expectedRevertibleSideEffectCounter,
338
338
  this.noteHashReadRequests,
339
339
  this.nullifierReadRequests,
340
- this.keyValidationRequestsAndGenerators,
340
+ this.keyValidationRequestsAndSeparators,
341
341
  this.privateCallRequests,
342
342
  this.publicCallRequests,
343
343
  this.publicTeardownCallRequest,
@@ -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';
@@ -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';
@@ -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
  }
@@ -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
  });
@@ -4,7 +4,8 @@ import type { ZodFor } from '@aztec/foundation/schemas';
4
4
  import type { AztecAddress } from '../aztec-address/index.js';
5
5
  import { computeSiloedPrivateLogFirstField } from '../hash/hash.js';
6
6
  import { schemas } from '../schemas/schemas.js';
7
- import type { Tag } from './tag.js';
7
+ import type { PreTag } from './pre_tag.js';
8
+ import { Tag } from './tag.js';
8
9
 
9
10
  /* eslint-disable @typescript-eslint/no-unsafe-declaration-merging */
10
11
 
@@ -21,7 +22,12 @@ export interface SiloedTag {
21
22
  export class SiloedTag {
22
23
  constructor(public readonly value: Fr) {}
23
24
 
24
- static async compute(tag: Tag, app: AztecAddress): Promise<SiloedTag> {
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> {
25
31
  const siloedTag = await computeSiloedPrivateLogFirstField(app, tag.value);
26
32
  return new SiloedTag(siloedTag);
27
33
  }
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
 
@@ -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
 
@@ -6,10 +6,10 @@ 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, serializeSignedBigInt, serializeToBuffer } from '@aztec/foundation/serialize';
9
- import { DutyType, type SigningContext } from '@aztec/validator-ha-signer/types';
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';
@@ -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
- }
package/src/p2p/index.ts CHANGED
@@ -8,7 +8,6 @@ export * from './interface.js';
8
8
  export * from './signature_utils.js';
9
9
  export * from './signed_txs.js';
10
10
  export * from './topic_type.js';
11
- export * from './client_type.js';
12
11
  export * from './message_validator.js';
13
12
  export * from './peer_error.js';
14
13
  export * from './constants.js';
@@ -1,5 +1,3 @@
1
- import { P2PClientType } from './client_type.js';
2
-
3
1
  /**
4
2
  * Creates the topic channel identifier string from a given topic type
5
3
  */
@@ -27,19 +25,14 @@ export enum TopicType {
27
25
  checkpoint_attestation = 'checkpoint_attestation',
28
26
  }
29
27
 
30
- export function getTopicTypeForClientType(clientType: P2PClientType) {
31
- if (clientType === P2PClientType.Full) {
32
- return [TopicType.tx, TopicType.block_proposal, TopicType.checkpoint_proposal, TopicType.checkpoint_attestation];
33
- } else if (clientType === P2PClientType.Prover) {
34
- return [TopicType.tx, TopicType.block_proposal, TopicType.checkpoint_proposal];
35
- } else {
36
- const _: never = clientType;
37
- return [TopicType.tx];
38
- }
39
- }
40
-
41
- export function getTopicsForClientAndConfig(clientType: P2PClientType, disableTransactions: boolean) {
42
- const topics = getTopicTypeForClientType(clientType);
28
+ /** Returns all gossip topics, optionally filtering out transactions. */
29
+ export function getTopicsForConfig(disableTransactions: boolean) {
30
+ const topics = [
31
+ TopicType.tx,
32
+ TopicType.block_proposal,
33
+ TopicType.checkpoint_proposal,
34
+ TopicType.checkpoint_attestation,
35
+ ];
43
36
  if (disableTransactions) {
44
37
  return topics.filter(topic => topic !== TopicType.tx);
45
38
  }
@@ -19,8 +19,8 @@ import type { UInt64 } from '../types/shared.js';
19
19
 
20
20
  /**
21
21
  * Header of a checkpoint. A checkpoint is a collection of blocks submitted to L1 all within the same slot.
22
- * TODO(palla/mbps): Should this include chainId and version as well? Is this used just in circuits?
23
- * TODO(palla/mbps): What about CheckpointNumber?
22
+ * This header is verified as-is in the rollup circuits, posted to the L1 rollup contract, stored in the archiver,
23
+ * and exposed via the Aztec Node API. See `CheckpointData` for a struct that includes the header plus extra metadata.
24
24
  */
25
25
  export class CheckpointHeader {
26
26
  constructor(