@aztec/p2p 0.0.1-commit.29c6b1a3 → 0.0.1-commit.2e2504e2

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 (218) hide show
  1. package/dest/bootstrap/bootstrap.d.ts +4 -3
  2. package/dest/bootstrap/bootstrap.d.ts.map +1 -1
  3. package/dest/bootstrap/bootstrap.js +4 -4
  4. package/dest/client/factory.d.ts +1 -1
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +8 -5
  7. package/dest/client/p2p_client.d.ts +4 -2
  8. package/dest/client/p2p_client.d.ts.map +1 -1
  9. package/dest/client/p2p_client.js +15 -4
  10. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +1 -1
  11. package/dest/config.d.ts +8 -2
  12. package/dest/config.d.ts.map +1 -1
  13. package/dest/config.js +3 -1
  14. package/dest/mem_pools/instrumentation.d.ts +1 -1
  15. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  16. package/dest/mem_pools/instrumentation.js +2 -2
  17. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  18. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  19. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  20. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  21. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  22. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  23. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  24. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  25. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +119 -0
  26. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  27. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  28. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +90 -0
  29. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  30. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  31. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +89 -0
  32. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  33. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  34. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  35. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +131 -0
  36. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  37. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +17 -0
  38. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  39. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  40. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +63 -0
  41. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  42. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  43. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +91 -0
  44. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  45. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  46. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +70 -0
  47. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  48. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  49. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +63 -0
  50. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  51. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  52. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  53. package/dest/mem_pools/tx_pool_v2/index.d.ts +5 -0
  54. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  55. package/dest/mem_pools/tx_pool_v2/index.js +4 -0
  56. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +193 -0
  57. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  58. package/dest/mem_pools/tx_pool_v2/interfaces.js +6 -0
  59. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +71 -0
  60. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  61. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +94 -0
  62. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  63. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  64. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  65. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +55 -0
  66. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  67. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +150 -0
  68. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +69 -0
  69. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  70. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +1041 -0
  71. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +1 -1
  72. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  73. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +7 -2
  74. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  75. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  76. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  77. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +5 -4
  78. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  79. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  80. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  81. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  82. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  83. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +3 -2
  84. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  85. package/dest/msg_validators/tx_validator/double_spend_validator.js +3 -2
  86. package/dest/msg_validators/tx_validator/factory.d.ts +4 -3
  87. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  88. package/dest/msg_validators/tx_validator/factory.js +12 -12
  89. package/dest/msg_validators/tx_validator/gas_validator.d.ts +3 -2
  90. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  91. package/dest/msg_validators/tx_validator/gas_validator.js +3 -2
  92. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  93. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  94. package/dest/msg_validators/tx_validator/metadata_validator.js +2 -2
  95. package/dest/msg_validators/tx_validator/phases_validator.d.ts +3 -2
  96. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  97. package/dest/msg_validators/tx_validator/phases_validator.js +3 -3
  98. package/dest/msg_validators/tx_validator/size_validator.d.ts +3 -1
  99. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -1
  100. package/dest/msg_validators/tx_validator/size_validator.js +4 -1
  101. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +3 -2
  102. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  103. package/dest/msg_validators/tx_validator/timestamp_validator.js +2 -2
  104. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  105. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  106. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  107. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  108. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  109. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  110. package/dest/services/data_store.d.ts +1 -1
  111. package/dest/services/data_store.d.ts.map +1 -1
  112. package/dest/services/data_store.js +10 -6
  113. package/dest/services/discv5/discV5_service.js +1 -1
  114. package/dest/services/index.d.ts +2 -1
  115. package/dest/services/index.d.ts.map +1 -1
  116. package/dest/services/index.js +1 -0
  117. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  118. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  119. package/dest/services/libp2p/instrumentation.js +14 -3
  120. package/dest/services/libp2p/libp2p_service.d.ts +1 -1
  121. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  122. package/dest/services/libp2p/libp2p_service.js +10 -10
  123. package/dest/services/peer-manager/metrics.d.ts +2 -2
  124. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  125. package/dest/services/peer-manager/metrics.js +20 -5
  126. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  127. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  128. package/dest/services/peer-manager/peer_scoring.js +8 -2
  129. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +2 -2
  130. package/dest/services/reqresp/metrics.d.ts +6 -5
  131. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  132. package/dest/services/reqresp/metrics.js +17 -5
  133. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +2 -2
  134. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +6 -6
  135. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  136. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +14 -14
  137. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  138. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  139. package/dest/services/tx_collection/instrumentation.js +9 -2
  140. package/dest/services/tx_file_store/config.d.ts +18 -0
  141. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  142. package/dest/services/tx_file_store/config.js +26 -0
  143. package/dest/services/tx_file_store/index.d.ts +4 -0
  144. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  145. package/dest/services/tx_file_store/index.js +3 -0
  146. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  147. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  148. package/dest/services/tx_file_store/instrumentation.js +29 -0
  149. package/dest/services/tx_file_store/tx_file_store.d.ts +47 -0
  150. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  151. package/dest/services/tx_file_store/tx_file_store.js +149 -0
  152. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  153. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  154. package/dest/services/tx_provider_instrumentation.js +5 -5
  155. package/dest/test-helpers/testbench-utils.d.ts +3 -1
  156. package/dest/test-helpers/testbench-utils.d.ts.map +1 -1
  157. package/dest/test-helpers/testbench-utils.js +2 -1
  158. package/dest/testbench/p2p_client_testbench_worker.js +1 -1
  159. package/package.json +14 -14
  160. package/src/bootstrap/bootstrap.ts +7 -4
  161. package/src/client/factory.ts +9 -9
  162. package/src/client/p2p_client.ts +14 -2
  163. package/src/client/test/tx_proposal_collector/README.md +4 -4
  164. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +1 -1
  165. package/src/config.ts +8 -1
  166. package/src/mem_pools/instrumentation.ts +2 -1
  167. package/src/mem_pools/tx_pool_v2/README.md +188 -0
  168. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  169. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  170. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +147 -0
  171. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +118 -0
  172. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +111 -0
  173. package/src/mem_pools/tx_pool_v2/eviction/index.ts +23 -0
  174. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +164 -0
  175. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  176. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  177. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +86 -0
  178. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +72 -0
  179. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +31 -0
  180. package/src/mem_pools/tx_pool_v2/index.ts +11 -0
  181. package/src/mem_pools/tx_pool_v2/interfaces.ts +225 -0
  182. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +160 -0
  183. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  184. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +209 -0
  185. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1265 -0
  186. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +8 -2
  187. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  188. package/src/msg_validators/tx_validator/block_header_validator.ts +7 -8
  189. package/src/msg_validators/tx_validator/data_validator.ts +6 -2
  190. package/src/msg_validators/tx_validator/double_spend_validator.ts +4 -3
  191. package/src/msg_validators/tx_validator/factory.ts +46 -30
  192. package/src/msg_validators/tx_validator/gas_validator.ts +9 -3
  193. package/src/msg_validators/tx_validator/metadata_validator.ts +6 -3
  194. package/src/msg_validators/tx_validator/phases_validator.ts +5 -3
  195. package/src/msg_validators/tx_validator/size_validator.ts +6 -2
  196. package/src/msg_validators/tx_validator/timestamp_validator.ts +6 -3
  197. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  198. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  199. package/src/services/data_store.ts +10 -7
  200. package/src/services/discv5/discV5_service.ts +1 -1
  201. package/src/services/index.ts +1 -0
  202. package/src/services/libp2p/instrumentation.ts +15 -2
  203. package/src/services/libp2p/libp2p_service.ts +20 -16
  204. package/src/services/peer-manager/metrics.ts +21 -4
  205. package/src/services/peer-manager/peer_scoring.ts +4 -1
  206. package/src/services/reqresp/batch-tx-requester/README.md +7 -7
  207. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +2 -2
  208. package/src/services/reqresp/metrics.ts +34 -9
  209. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +2 -2
  210. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +10 -10
  211. package/src/services/tx_collection/instrumentation.ts +11 -2
  212. package/src/services/tx_file_store/config.ts +43 -0
  213. package/src/services/tx_file_store/index.ts +3 -0
  214. package/src/services/tx_file_store/instrumentation.ts +36 -0
  215. package/src/services/tx_file_store/tx_file_store.ts +173 -0
  216. package/src/services/tx_provider_instrumentation.ts +11 -5
  217. package/src/test-helpers/testbench-utils.ts +2 -0
  218. package/src/testbench/p2p_client_testbench_worker.ts +1 -1
@@ -1,6 +1,6 @@
1
1
  import type { EpochCacheInterface } from '@aztec/epoch-cache';
2
2
  import { type CheckpointAttestation, PeerErrorSeverity, type ValidationResult } from '@aztec/stdlib/p2p';
3
- import { Attributes, Metrics, type TelemetryClient } from '@aztec/telemetry-client';
3
+ import { Attributes, Metrics, type TelemetryClient, createUpDownCounterWithDefault } from '@aztec/telemetry-client';
4
4
 
5
5
  import type { AttestationPool } from '../../mem_pools/attestation_pool/attestation_pool.js';
6
6
  import { CheckpointAttestationValidator } from './attestation_validator.js';
@@ -25,7 +25,13 @@ export class FishermanAttestationValidator extends CheckpointAttestationValidato
25
25
  this.logger = this.logger.createChild('[FISHERMAN]');
26
26
 
27
27
  const meter = telemetryClient.getMeter('FishermanAttestationValidator');
28
- this.invalidAttestationCounter = meter.createUpDownCounter(Metrics.VALIDATOR_INVALID_ATTESTATION_RECEIVED_COUNT);
28
+ this.invalidAttestationCounter = createUpDownCounterWithDefault(
29
+ meter,
30
+ Metrics.VALIDATOR_INVALID_ATTESTATION_RECEIVED_COUNT,
31
+ {
32
+ [Attributes.ERROR_TYPE]: ['base_validation_failed', 'payload_mismatch'],
33
+ },
34
+ );
29
35
  }
30
36
 
31
37
  override async validate(message: CheckpointAttestation): Promise<ValidationResult> {
@@ -1,5 +1,5 @@
1
- import type { Fr } from '@aztec/foundation/curves/bn254';
2
1
  import type { ArchiveSource } from '@aztec/p2p';
2
+ import type { BlockHash } from '@aztec/stdlib/block';
3
3
  import type { MerkleTreeReadOperations } from '@aztec/stdlib/interfaces/server';
4
4
  import { MerkleTreeId } from '@aztec/stdlib/trees';
5
5
 
@@ -14,8 +14,8 @@ export class ArchiveCache implements ArchiveSource {
14
14
  this.archives = new Map<string, bigint>();
15
15
  }
16
16
 
17
- public async getArchiveIndices(archives: Fr[]): Promise<(bigint | undefined)[]> {
18
- const toCheckDb = archives.filter(n => !this.archives.has(n.toString()));
17
+ public async getArchiveIndices(archives: BlockHash[]): Promise<(bigint | undefined)[]> {
18
+ const toCheckDb = archives.filter(n => !this.archives.has(n.toString())).map(n => n.toFr());
19
19
  const dbHits = await this.db.findLeafIndices(MerkleTreeId.ARCHIVE, toCheckDb);
20
20
  dbHits.forEach((x, index) => {
21
21
  if (x !== undefined) {
@@ -1,23 +1,22 @@
1
- import type { Fr } from '@aztec/foundation/curves/bn254';
2
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
+ import type { BlockHash } from '@aztec/stdlib/block';
3
3
  import { type AnyTx, TX_ERROR_BLOCK_HEADER, type TxValidationResult, type TxValidator } from '@aztec/stdlib/tx';
4
4
 
5
5
  export interface ArchiveSource {
6
- getArchiveIndices: (archives: Fr[]) => Promise<(bigint | undefined)[]>;
6
+ getArchiveIndices: (archives: BlockHash[]) => Promise<(bigint | undefined)[]>;
7
7
  }
8
8
 
9
9
  export class BlockHeaderTxValidator<T extends AnyTx> implements TxValidator<T> {
10
- #log = createLogger('p2p:tx_validator:tx_block_header');
10
+ #log: Logger;
11
11
  #archiveSource: ArchiveSource;
12
12
 
13
- constructor(archiveSource: ArchiveSource) {
13
+ constructor(archiveSource: ArchiveSource, bindings?: LoggerBindings) {
14
14
  this.#archiveSource = archiveSource;
15
+ this.#log = createLogger('p2p:tx_validator:tx_block_header', bindings);
15
16
  }
16
17
 
17
18
  async validateTx(tx: T): Promise<TxValidationResult> {
18
- const [index] = await this.#archiveSource.getArchiveIndices([
19
- (await tx.data.constants.anchorBlockHeader.hash()).toField(),
20
- ]);
19
+ const [index] = await this.#archiveSource.getArchiveIndices([await tx.data.constants.anchorBlockHeader.hash()]);
21
20
  if (index === undefined) {
22
21
  this.#log.verbose(`Rejecting tx ${'txHash' in tx ? tx.txHash : tx.hash} for referencing an unknown block header`);
23
22
  return { result: 'invalid', reason: [TX_ERROR_BLOCK_HEADER] };
@@ -1,5 +1,5 @@
1
1
  import { MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS } from '@aztec/constants';
2
- import { createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import { computeCalldataHash } from '@aztec/stdlib/hash';
4
4
  import {
5
5
  TX_ERROR_CALLDATA_COUNT_MISMATCH,
@@ -16,7 +16,11 @@ import {
16
16
  } from '@aztec/stdlib/tx';
17
17
 
18
18
  export class DataTxValidator implements TxValidator<Tx> {
19
- #log = createLogger('p2p:tx_validator:tx_data');
19
+ #log: Logger;
20
+
21
+ constructor(bindings?: LoggerBindings) {
22
+ this.#log = createLogger('p2p:tx_validator:tx_data', bindings);
23
+ }
20
24
 
21
25
  async validateTx(tx: Tx): Promise<TxValidationResult> {
22
26
  const reason =
@@ -1,4 +1,4 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import {
3
3
  type AnyTx,
4
4
  TX_ERROR_DUPLICATE_NULLIFIER_IN_TX,
@@ -13,11 +13,12 @@ export interface NullifierSource {
13
13
  }
14
14
 
15
15
  export class DoubleSpendTxValidator<T extends AnyTx> implements TxValidator<T> {
16
- #log = createLogger('p2p:tx_validator:tx_double_spend');
16
+ #log: Logger;
17
17
  #nullifierSource: NullifierSource;
18
18
 
19
- constructor(nullifierSource: NullifierSource) {
19
+ constructor(nullifierSource: NullifierSource, bindings?: LoggerBindings) {
20
20
  this.#nullifierSource = nullifierSource;
21
+ this.#log = createLogger('p2p:tx_validator:tx_double_spend', bindings);
21
22
  }
22
23
 
23
24
  async validateTx(tx: T): Promise<TxValidationResult> {
@@ -1,5 +1,6 @@
1
1
  import { BlockNumber } from '@aztec/foundation/branded-types';
2
2
  import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import type { LoggerBindings } from '@aztec/foundation/log';
3
4
  import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
4
5
  import { ProtocolContractAddress, protocolContractsHash } from '@aztec/protocol-contracts';
5
6
  import type { ContractDataSource } from '@aztec/stdlib/contract';
@@ -46,43 +47,53 @@ export function createTxMessageValidators(
46
47
  proofVerifier: ClientProtocolCircuitVerifier,
47
48
  txsPermitted: boolean,
48
49
  allowedInSetup: AllowedElement[] = [],
50
+ bindings?: LoggerBindings,
49
51
  ): Record<string, MessageValidator>[] {
50
52
  const merkleTree = worldStateSynchronizer.getCommitted();
51
53
 
52
54
  return [
53
55
  {
54
56
  txsPermittedValidator: {
55
- validator: new TxPermittedValidator(txsPermitted),
57
+ validator: new TxPermittedValidator(txsPermitted, bindings),
56
58
  severity: PeerErrorSeverity.MidToleranceError,
57
59
  },
58
60
  dataValidator: {
59
- validator: new DataTxValidator(),
61
+ validator: new DataTxValidator(bindings),
60
62
  severity: PeerErrorSeverity.HighToleranceError,
61
63
  },
62
64
  metadataValidator: {
63
- validator: new MetadataTxValidator({
64
- l1ChainId: new Fr(l1ChainId),
65
- rollupVersion: new Fr(rollupVersion),
66
- protocolContractsHash,
67
- vkTreeRoot: getVKTreeRoot(),
68
- }),
65
+ validator: new MetadataTxValidator(
66
+ {
67
+ l1ChainId: new Fr(l1ChainId),
68
+ rollupVersion: new Fr(rollupVersion),
69
+ protocolContractsHash,
70
+ vkTreeRoot: getVKTreeRoot(),
71
+ },
72
+ bindings,
73
+ ),
69
74
  severity: PeerErrorSeverity.HighToleranceError,
70
75
  },
71
76
  timestampValidator: {
72
- validator: new TimestampTxValidator<Tx>({
73
- timestamp,
74
- blockNumber,
75
- }),
77
+ validator: new TimestampTxValidator<Tx>(
78
+ {
79
+ timestamp,
80
+ blockNumber,
81
+ },
82
+ bindings,
83
+ ),
76
84
  severity: PeerErrorSeverity.MidToleranceError,
77
85
  },
78
86
  doubleSpendValidator: {
79
- validator: new DoubleSpendTxValidator({
80
- nullifiersExist: async (nullifiers: Buffer[]) => {
81
- const merkleTree = worldStateSynchronizer.getCommitted();
82
- const indices = await merkleTree.findLeafIndices(MerkleTreeId.NULLIFIER_TREE, nullifiers);
83
- return indices.map(index => index !== undefined);
87
+ validator: new DoubleSpendTxValidator(
88
+ {
89
+ nullifiersExist: async (nullifiers: Buffer[]) => {
90
+ const merkleTree = worldStateSynchronizer.getCommitted();
91
+ const indices = await merkleTree.findLeafIndices(MerkleTreeId.NULLIFIER_TREE, nullifiers);
92
+ return indices.map(index => index !== undefined);
93
+ },
84
94
  },
85
- }),
95
+ bindings,
96
+ ),
86
97
  severity: PeerErrorSeverity.HighToleranceError,
87
98
  },
88
99
  gasValidator: {
@@ -90,21 +101,22 @@ export function createTxMessageValidators(
90
101
  new DatabasePublicStateSource(merkleTree),
91
102
  ProtocolContractAddress.FeeJuice,
92
103
  gasFees,
104
+ bindings,
93
105
  ),
94
106
  severity: PeerErrorSeverity.HighToleranceError,
95
107
  },
96
108
  phasesValidator: {
97
- validator: new PhasesTxValidator(contractDataSource, allowedInSetup, timestamp),
109
+ validator: new PhasesTxValidator(contractDataSource, allowedInSetup, timestamp, bindings),
98
110
  severity: PeerErrorSeverity.MidToleranceError,
99
111
  },
100
112
  blockHeaderValidator: {
101
- validator: new BlockHeaderTxValidator(new ArchiveCache(merkleTree)),
113
+ validator: new BlockHeaderTxValidator(new ArchiveCache(merkleTree), bindings),
102
114
  severity: PeerErrorSeverity.HighToleranceError,
103
115
  },
104
116
  },
105
117
  {
106
118
  proofValidator: {
107
- validator: new TxProofValidator(proofVerifier),
119
+ validator: new TxProofValidator(proofVerifier, bindings),
108
120
  severity: PeerErrorSeverity.MidToleranceError,
109
121
  },
110
122
  },
@@ -120,16 +132,20 @@ export function createTxReqRespValidator(
120
132
  l1ChainId: number;
121
133
  rollupVersion: number;
122
134
  },
135
+ bindings?: LoggerBindings,
123
136
  ): TxValidator {
124
137
  return new AggregateTxValidator(
125
- new MetadataTxValidator({
126
- l1ChainId: new Fr(l1ChainId),
127
- rollupVersion: new Fr(rollupVersion),
128
- protocolContractsHash,
129
- vkTreeRoot: getVKTreeRoot(),
130
- }),
131
- new SizeTxValidator(),
132
- new DataTxValidator(),
133
- new TxProofValidator(verifier),
138
+ new MetadataTxValidator(
139
+ {
140
+ l1ChainId: new Fr(l1ChainId),
141
+ rollupVersion: new Fr(rollupVersion),
142
+ protocolContractsHash,
143
+ vkTreeRoot: getVKTreeRoot(),
144
+ },
145
+ bindings,
146
+ ),
147
+ new SizeTxValidator(bindings),
148
+ new DataTxValidator(bindings),
149
+ new TxProofValidator(verifier, bindings),
134
150
  );
135
151
  }
@@ -1,5 +1,5 @@
1
1
  import { AVM_MAX_PROCESSABLE_L2_GAS, FIXED_DA_GAS, FIXED_L2_GAS } from '@aztec/constants';
2
- import { createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import { computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
4
4
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
5
5
  import { Gas, GasFees } from '@aztec/stdlib/gas';
@@ -17,12 +17,18 @@ import {
17
17
  import { getFeePayerClaimAmount, getTxFeeLimit } from './fee_payer_balance.js';
18
18
 
19
19
  export class GasTxValidator implements TxValidator<Tx> {
20
- #log = createLogger('sequencer:tx_validator:tx_gas');
20
+ #log: Logger;
21
21
  #publicDataSource: PublicStateSource;
22
22
  #feeJuiceAddress: AztecAddress;
23
23
  #gasFees: GasFees;
24
24
 
25
- constructor(publicDataSource: PublicStateSource, feeJuiceAddress: AztecAddress, gasFees: GasFees) {
25
+ constructor(
26
+ publicDataSource: PublicStateSource,
27
+ feeJuiceAddress: AztecAddress,
28
+ gasFees: GasFees,
29
+ bindings?: LoggerBindings,
30
+ ) {
31
+ this.#log = createLogger('sequencer:tx_validator:tx_gas', bindings);
26
32
  this.#publicDataSource = publicDataSource;
27
33
  this.#feeJuiceAddress = feeJuiceAddress;
28
34
  this.#gasFees = gasFees;
@@ -1,5 +1,5 @@
1
1
  import type { Fr } from '@aztec/foundation/curves/bn254';
2
- import { createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import {
4
4
  type AnyTx,
5
5
  TX_ERROR_INCORRECT_L1_CHAIN_ID,
@@ -11,7 +11,7 @@ import {
11
11
  } from '@aztec/stdlib/tx';
12
12
 
13
13
  export class MetadataTxValidator<T extends AnyTx> implements TxValidator<T> {
14
- #log = createLogger('p2p:tx_validator:tx_metadata');
14
+ #log: Logger;
15
15
 
16
16
  constructor(
17
17
  private values: {
@@ -20,7 +20,10 @@ export class MetadataTxValidator<T extends AnyTx> implements TxValidator<T> {
20
20
  vkTreeRoot: Fr;
21
21
  protocolContractsHash: Fr;
22
22
  },
23
- ) {}
23
+ bindings?: LoggerBindings,
24
+ ) {
25
+ this.#log = createLogger('p2p:tx_validator:tx_metadata', bindings);
26
+ }
24
27
 
25
28
  validateTx(tx: T): Promise<TxValidationResult> {
26
29
  const errors = [];
@@ -1,4 +1,4 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import { PublicContractsDB, getCallRequestsWithCalldataByPhase } from '@aztec/simulator/server';
3
3
  import type { ContractDataSource } from '@aztec/stdlib/contract';
4
4
  import type { AllowedElement } from '@aztec/stdlib/interfaces/server';
@@ -14,15 +14,17 @@ import {
14
14
  import type { UInt64 } from '@aztec/stdlib/types';
15
15
 
16
16
  export class PhasesTxValidator implements TxValidator<Tx> {
17
- #log = createLogger('sequencer:tx_validator:tx_phases');
17
+ #log: Logger;
18
18
  private contractsDB: PublicContractsDB;
19
19
 
20
20
  constructor(
21
21
  contracts: ContractDataSource,
22
22
  private setupAllowList: AllowedElement[],
23
23
  private timestamp: UInt64,
24
+ bindings?: LoggerBindings,
24
25
  ) {
25
- this.contractsDB = new PublicContractsDB(contracts);
26
+ this.#log = createLogger('sequencer:tx_validator:tx_phases', bindings);
27
+ this.contractsDB = new PublicContractsDB(contracts, bindings);
26
28
  }
27
29
 
28
30
  async validateTx(tx: Tx): Promise<TxValidationResult> {
@@ -1,9 +1,13 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import { MAX_TX_SIZE_KB } from '@aztec/stdlib/p2p';
3
3
  import { Tx, type TxValidationResult, type TxValidator } from '@aztec/stdlib/tx';
4
4
 
5
5
  export class SizeTxValidator implements TxValidator<Tx> {
6
- #log = createLogger('sequencer:tx_validator:tx_size');
6
+ #log: Logger;
7
+
8
+ constructor(bindings?: LoggerBindings) {
9
+ this.#log = createLogger('p2p:tx_validator:tx_size', bindings);
10
+ }
7
11
 
8
12
  validateTx(tx: Tx): Promise<TxValidationResult> {
9
13
  const txSize = tx.getSize();
@@ -1,5 +1,5 @@
1
1
  import { BlockNumber } from '@aztec/foundation/branded-types';
2
- import { createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import {
4
4
  type AnyTx,
5
5
  TX_ERROR_INVALID_INCLUDE_BY_TIMESTAMP,
@@ -10,7 +10,7 @@ import {
10
10
  import type { UInt64 } from '@aztec/stdlib/types';
11
11
 
12
12
  export class TimestampTxValidator<T extends AnyTx> implements TxValidator<T> {
13
- #log = createLogger('p2p:tx_validator:timestamp');
13
+ #log: Logger;
14
14
 
15
15
  constructor(
16
16
  private values: {
@@ -20,7 +20,10 @@ export class TimestampTxValidator<T extends AnyTx> implements TxValidator<T> {
20
20
  // Block number in which the tx is considered to be included.
21
21
  blockNumber: BlockNumber;
22
22
  },
23
- ) {}
23
+ bindings?: LoggerBindings,
24
+ ) {
25
+ this.#log = createLogger('p2p:tx_validator:timestamp', bindings);
26
+ }
24
27
 
25
28
  validateTx(tx: T): Promise<TxValidationResult> {
26
29
  const includeByTimestamp = tx.data.includeByTimestamp;
@@ -1,10 +1,15 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import type { Tx, TxValidationResult, TxValidator } from '@aztec/stdlib/tx';
3
3
 
4
4
  export class TxPermittedValidator implements TxValidator<Tx> {
5
- #log = createLogger('p2p:tx_validator:tx_permitted');
5
+ #log: Logger;
6
6
 
7
- constructor(private permitted: boolean) {}
7
+ constructor(
8
+ private permitted: boolean,
9
+ bindings?: LoggerBindings,
10
+ ) {
11
+ this.#log = createLogger('p2p:tx_validator:tx_permitted', bindings);
12
+ }
8
13
 
9
14
  validateTx(tx: Tx): Promise<TxValidationResult> {
10
15
  if (!this.permitted) {
@@ -1,11 +1,16 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import type { ClientProtocolCircuitVerifier } from '@aztec/stdlib/interfaces/server';
3
3
  import { TX_ERROR_INVALID_PROOF, Tx, type TxValidationResult, type TxValidator } from '@aztec/stdlib/tx';
4
4
 
5
5
  export class TxProofValidator implements TxValidator<Tx> {
6
- #log = createLogger('p2p:tx_validator:private_proof');
6
+ #log: Logger;
7
7
 
8
- constructor(private verifier: ClientProtocolCircuitVerifier) {}
8
+ constructor(
9
+ private verifier: ClientProtocolCircuitVerifier,
10
+ bindings?: LoggerBindings,
11
+ ) {
12
+ this.#log = createLogger('p2p:tx_validator:proof', bindings);
13
+ }
9
14
 
10
15
  async validateTx(tx: Tx): Promise<TxValidationResult> {
11
16
  const result = await this.verifier.verifyProof(tx);
@@ -24,6 +24,7 @@ class KeyNotFoundError extends Error {
24
24
  }
25
25
 
26
26
  export class AztecDatastore implements Datastore {
27
+ #db: AztecAsyncKVStore;
27
28
  #memoryDatastore: Map<string, MemoryItem>;
28
29
  #dbDatastore: AztecAsyncMap<string, Uint8Array>;
29
30
 
@@ -32,9 +33,9 @@ export class AztecDatastore implements Datastore {
32
33
  private maxMemoryItems: number;
33
34
 
34
35
  constructor(db: AztecAsyncKVStore, { maxMemoryItems } = { maxMemoryItems: 50 }) {
36
+ this.#db = db;
35
37
  this.#memoryDatastore = new Map();
36
38
  this.#dbDatastore = db.openMap('p2p_datastore');
37
-
38
39
  this.maxMemoryItems = maxMemoryItems;
39
40
  }
40
41
 
@@ -106,13 +107,15 @@ export class AztecDatastore implements Datastore {
106
107
  });
107
108
  },
108
109
  commit: async () => {
109
- for (const op of this.#batchOps) {
110
- if (op.type === 'put' && op.value) {
111
- await this.put(op.key, op.value);
112
- } else if (op.type === 'del') {
113
- await this.delete(op.key);
110
+ await this.#db.transactionAsync(async () => {
111
+ for (const op of this.#batchOps) {
112
+ if (op.type === 'put' && op.value) {
113
+ await this.put(op.key, op.value);
114
+ } else if (op.type === 'del') {
115
+ await this.delete(op.key);
116
+ }
114
117
  }
115
- }
118
+ });
116
119
  this.#batchOps = []; // Clear operations after commit
117
120
  },
118
121
  };
@@ -87,7 +87,7 @@ export class DiscV5Service extends EventEmitter implements PeerDiscoveryService
87
87
  this.packageVersion,
88
88
  ));
89
89
 
90
- const metricsRegistry = new OtelMetricsAdapter(telemetry);
90
+ const metricsRegistry = new OtelMetricsAdapter(telemetry, this.logger.getBindings());
91
91
  this.discv5 = Discv5.create({
92
92
  enr: this.enr,
93
93
  peerId,
@@ -3,4 +3,5 @@ export * from './libp2p/libp2p_service.js';
3
3
  export * from './tx_provider.js';
4
4
  export * from './dummy_service.js';
5
5
  export * from './reqresp/index.js';
6
+ export * from './tx_file_store/index.js';
6
7
  export * from './tx_collection/index.js';
@@ -8,6 +8,7 @@ import {
8
8
  type ObservableGauge,
9
9
  type TelemetryClient,
10
10
  type UpDownCounter,
11
+ createUpDownCounterWithDefault,
11
12
  } from '@aztec/telemetry-client';
12
13
 
13
14
  import { type RecordableHistogram, createHistogram } from 'node:perf_hooks';
@@ -29,11 +30,23 @@ export class P2PInstrumentation {
29
30
 
30
31
  this.messageValidationDuration = meter.createHistogram(Metrics.P2P_GOSSIP_MESSAGE_VALIDATION_DURATION);
31
32
 
32
- this.messagePrevalidationCount = meter.createUpDownCounter(Metrics.P2P_GOSSIP_MESSAGE_PREVALIDATION_COUNT);
33
+ this.messagePrevalidationCount = createUpDownCounterWithDefault(
34
+ meter,
35
+ Metrics.P2P_GOSSIP_MESSAGE_PREVALIDATION_COUNT,
36
+ {
37
+ [Attributes.TOPIC_NAME]: [
38
+ TopicType.tx,
39
+ TopicType.block_proposal,
40
+ TopicType.checkpoint_proposal,
41
+ TopicType.checkpoint_attestation,
42
+ ],
43
+ [Attributes.OK]: [true, false],
44
+ },
45
+ );
33
46
 
34
47
  this.messageLatency = meter.createHistogram(Metrics.P2P_GOSSIP_MESSAGE_LATENCY);
35
48
 
36
- this.txReceivedCount = meter.createUpDownCounter(Metrics.P2P_GOSSIP_TX_RECEIVED_COUNT);
49
+ this.txReceivedCount = createUpDownCounterWithDefault(meter, Metrics.P2P_GOSSIP_TX_RECEIVED_COUNT);
37
50
 
38
51
  this.aggLatencyMetrics = {
39
52
  avg: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_AVG),
@@ -284,14 +284,14 @@ export class LibP2PService<T extends P2PClientType = P2PClientType.Full> extends
284
284
 
285
285
  const datastore = new AztecDatastore(peerStore);
286
286
 
287
- const otelMetricsAdapter = new OtelMetricsAdapter(telemetry);
287
+ const otelMetricsAdapter = new OtelMetricsAdapter(telemetry, logger.getBindings());
288
288
 
289
289
  const peerDiscoveryService = new DiscV5Service(
290
290
  peerId,
291
291
  config,
292
292
  packageVersion,
293
293
  telemetry,
294
- createLogger(`${logger.module}:discv5_service`),
294
+ createLogger(`${logger.module}:discv5_service`, logger.getBindings()),
295
295
  );
296
296
 
297
297
  // Seed libp2p's bootstrap discovery with private and trusted peers
@@ -452,7 +452,7 @@ export class LibP2PService<T extends P2PClientType = P2PClientType.Full> extends
452
452
  connectionManager: components.connectionManager,
453
453
  }),
454
454
  },
455
- logger: createLibp2pComponentLogger(logger.module),
455
+ logger: createLibp2pComponentLogger(logger.module, logger.getBindings()),
456
456
  });
457
457
 
458
458
  const peerScoring = new PeerScoring(config, telemetry);
@@ -1214,7 +1214,7 @@ export class LibP2PService<T extends P2PClientType = P2PClientType.Full> extends
1214
1214
  * @returns True if the requested block transactions are valid, false otherwise.
1215
1215
  */
1216
1216
  @trackSpan('Libp2pService.validateRequestedBlockTxs', request => ({
1217
- [Attributes.BLOCK_HASH]: request.blockHash.toString(),
1217
+ [Attributes.BLOCK_ARCHIVE]: request.archiveRoot.toString(),
1218
1218
  }))
1219
1219
  private async validateRequestedBlockTxs(
1220
1220
  request: BlockTxsRequest,
@@ -1224,10 +1224,10 @@ export class LibP2PService<T extends P2PClientType = P2PClientType.Full> extends
1224
1224
  const requestedTxValidator = this.createRequestedTxValidator();
1225
1225
 
1226
1226
  try {
1227
- if (!response.blockHash.equals(request.blockHash)) {
1227
+ if (!response.archiveRoot.equals(request.archiveRoot)) {
1228
1228
  this.peerManager.penalizePeer(peerId, PeerErrorSeverity.MidToleranceError);
1229
1229
  throw new ValidationError(
1230
- `Received block txs for unexpected block: expected ${request.blockHash.toString()}, got ${response.blockHash.toString()}`,
1230
+ `Received block txs for unexpected archive root: expected ${request.archiveRoot.toString()}, got ${response.archiveRoot.toString()}`,
1231
1231
  );
1232
1232
  }
1233
1233
 
@@ -1257,7 +1257,7 @@ export class LibP2PService<T extends P2PClientType = P2PClientType.Full> extends
1257
1257
  }
1258
1258
 
1259
1259
  // Given proposal (should have locally), ensure returned txs are valid subset and match request indices
1260
- const proposal = await this.mempools.attestationPool.getBlockProposal(request.blockHash.toString());
1260
+ const proposal = await this.mempools.attestationPool.getBlockProposal(request.archiveRoot.toString());
1261
1261
  if (proposal) {
1262
1262
  // Build intersected indices
1263
1263
  const intersectIdx = request.txIndices.getTrueIndices().filter(i => response.txIndices.isSet(i));
@@ -1277,7 +1277,7 @@ export class LibP2PService<T extends P2PClientType = P2PClientType.Full> extends
1277
1277
  } else {
1278
1278
  // No local proposal, cannot check the membership/order of the returned txs
1279
1279
  this.logger.warn(
1280
- `Block proposal not found for block hash ${request.blockHash.toString()}; cannot validate membership/order of returned txs`,
1280
+ `Block proposal not found for archive root ${request.archiveRoot.toString()}; cannot validate membership/order of returned txs`,
1281
1281
  );
1282
1282
  return false;
1283
1283
  }
@@ -1508,6 +1508,7 @@ export class LibP2PService<T extends P2PClientType = P2PClientType.Full> extends
1508
1508
  this.proofVerifier,
1509
1509
  !this.config.disableTransactions,
1510
1510
  allowedInSetup,
1511
+ this.logger.getBindings(),
1511
1512
  );
1512
1513
  }
1513
1514
 
@@ -1561,15 +1562,18 @@ export class LibP2PService<T extends P2PClientType = P2PClientType.Full> extends
1561
1562
  return PeerErrorSeverity.HighToleranceError;
1562
1563
  }
1563
1564
 
1564
- const snapshotValidator = new DoubleSpendTxValidator({
1565
- nullifiersExist: async (nullifiers: Buffer[]) => {
1566
- const merkleTree = this.worldStateSynchronizer.getSnapshot(
1567
- BlockNumber(blockNumber - this.config.doubleSpendSeverePeerPenaltyWindow),
1568
- );
1569
- const indices = await merkleTree.findLeafIndices(MerkleTreeId.NULLIFIER_TREE, nullifiers);
1570
- return indices.map(index => index !== undefined);
1565
+ const snapshotValidator = new DoubleSpendTxValidator(
1566
+ {
1567
+ nullifiersExist: async (nullifiers: Buffer[]) => {
1568
+ const merkleTree = this.worldStateSynchronizer.getSnapshot(
1569
+ BlockNumber(blockNumber - this.config.doubleSpendSeverePeerPenaltyWindow),
1570
+ );
1571
+ const indices = await merkleTree.findLeafIndices(MerkleTreeId.NULLIFIER_TREE, nullifiers);
1572
+ return indices.map(index => index !== undefined);
1573
+ },
1571
1574
  },
1572
- });
1575
+ this.logger.getBindings(),
1576
+ );
1573
1577
 
1574
1578
  const validSnapshot = await snapshotValidator.validateTx(tx);
1575
1579
  if (validSnapshot.result !== 'valid') {