@aztec/p2p 0.0.1-commit.f504929 → 0.0.1-commit.f5d02921e
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.
- package/README.md +129 -3
- package/dest/client/factory.d.ts +2 -2
- package/dest/client/factory.d.ts.map +1 -1
- package/dest/client/factory.js +25 -11
- package/dest/client/interface.d.ts +9 -2
- package/dest/client/interface.d.ts.map +1 -1
- package/dest/client/p2p_client.d.ts +3 -2
- package/dest/client/p2p_client.d.ts.map +1 -1
- package/dest/client/p2p_client.js +37 -36
- package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +17 -6
- package/dest/config.d.ts +24 -2
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +66 -7
- package/dest/errors/p2p-service.error.d.ts +9 -0
- package/dest/errors/p2p-service.error.d.ts.map +1 -0
- package/dest/errors/p2p-service.error.js +10 -0
- package/dest/index.d.ts +1 -2
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +0 -1
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +4 -4
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/attestation_pool.js +6 -5
- package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +6 -6
- package/dest/mem_pools/index.d.ts +1 -2
- package/dest/mem_pools/index.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +1 -1
- package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +2 -1
- package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +7 -1
- package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +1 -1
- package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +8 -6
- package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +2 -2
- package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +2 -2
- package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +9 -5
- package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/interfaces.js +2 -1
- package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +25 -10
- package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/tx_metadata.js +38 -11
- package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +1 -1
- package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +26 -43
- package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +4 -2
- package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +3 -0
- package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +1 -1
- package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +21 -6
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +1 -1
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
- package/dest/msg_validators/attestation_validator/attestation_validator.js +5 -4
- package/dest/msg_validators/clock_tolerance.d.ts +1 -1
- package/dest/msg_validators/clock_tolerance.d.ts.map +1 -1
- package/dest/msg_validators/clock_tolerance.js +4 -3
- package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +5 -4
- package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -1
- package/dest/msg_validators/proposal_validator/block_proposal_validator.js +10 -2
- package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +5 -4
- package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -1
- package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +16 -2
- package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +12 -9
- package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
- package/dest/msg_validators/proposal_validator/proposal_validator.js +51 -49
- package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +1 -1
- package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/allowed_public_setup.js +21 -32
- package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
- package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
- package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts +9 -0
- package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/contract_instance_validator.js +48 -0
- package/dest/msg_validators/tx_validator/data_validator.d.ts +1 -1
- package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/data_validator.js +35 -2
- package/dest/msg_validators/tx_validator/factory.d.ts +23 -4
- package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/factory.js +36 -10
- package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +1 -1
- package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/fee_payer_balance.js +6 -2
- package/dest/msg_validators/tx_validator/gas_validator.d.ts +13 -4
- package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/gas_validator.js +39 -9
- package/dest/msg_validators/tx_validator/index.d.ts +2 -1
- package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/index.js +1 -0
- package/dest/msg_validators/tx_validator/metadata_validator.d.ts +1 -1
- package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/metadata_validator.js +4 -4
- package/dest/msg_validators/tx_validator/phases_validator.d.ts +21 -1
- package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/phases_validator.js +49 -2
- package/dest/services/dummy_service.d.ts +5 -3
- package/dest/services/dummy_service.d.ts.map +1 -1
- package/dest/services/dummy_service.js +5 -1
- package/dest/services/encoding.d.ts +5 -1
- package/dest/services/encoding.d.ts.map +1 -1
- package/dest/services/encoding.js +7 -1
- package/dest/services/libp2p/libp2p_service.d.ts +14 -11
- package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
- package/dest/services/libp2p/libp2p_service.js +146 -74
- package/dest/services/peer-manager/peer_manager.d.ts +6 -2
- package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
- package/dest/services/peer-manager/peer_manager.js +22 -8
- package/dest/services/peer-manager/peer_scoring.d.ts +5 -2
- package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
- package/dest/services/peer-manager/peer_scoring.js +28 -10
- package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +11 -8
- package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -1
- package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +69 -65
- package/dest/services/reqresp/batch-tx-requester/interface.d.ts +3 -2
- package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -1
- package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +5 -4
- package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -1
- package/dest/services/reqresp/batch-tx-requester/missing_txs.js +13 -7
- package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +3 -1
- package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -1
- package/dest/services/reqresp/batch-tx-requester/peer_collection.js +3 -0
- package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +5 -4
- package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -1
- package/dest/services/reqresp/rate-limiter/rate_limiter.js +10 -8
- package/dest/services/reqresp/reqresp.d.ts +1 -1
- package/dest/services/reqresp/reqresp.d.ts.map +1 -1
- package/dest/services/reqresp/reqresp.js +17 -9
- package/dest/services/service.d.ts +5 -2
- package/dest/services/service.d.ts.map +1 -1
- package/dest/services/tx_collection/fast_tx_collection.d.ts +1 -4
- package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
- package/dest/services/tx_collection/fast_tx_collection.js +57 -73
- package/dest/services/tx_collection/file_store_tx_source.d.ts +5 -4
- package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -1
- package/dest/services/tx_collection/file_store_tx_source.js +39 -29
- package/dest/services/tx_collection/proposal_tx_collector.d.ts +6 -7
- package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -1
- package/dest/services/tx_collection/proposal_tx_collector.js +4 -4
- package/dest/services/tx_collection/request_tracker.d.ts +53 -0
- package/dest/services/tx_collection/request_tracker.d.ts.map +1 -0
- package/dest/services/tx_collection/request_tracker.js +84 -0
- package/dest/services/tx_collection/slow_tx_collection.js +1 -1
- package/dest/services/tx_collection/tx_collection.d.ts +3 -6
- package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
- package/dest/services/tx_collection/tx_source.d.ts +6 -5
- package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
- package/dest/services/tx_collection/tx_source.js +9 -7
- package/dest/test-helpers/make-test-p2p-clients.d.ts +1 -1
- package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
- package/dest/test-helpers/reqresp-nodes.d.ts +1 -1
- package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
- package/dest/test-helpers/testbench-utils.d.ts +1 -1
- package/dest/test-helpers/testbench-utils.d.ts.map +1 -1
- package/dest/test-helpers/testbench-utils.js +22 -3
- package/dest/testbench/p2p_client_testbench_worker.js +46 -16
- package/dest/testbench/worker_client_manager.d.ts +3 -1
- package/dest/testbench/worker_client_manager.d.ts.map +1 -1
- package/dest/testbench/worker_client_manager.js +6 -3
- package/dest/util.d.ts +1 -1
- package/package.json +14 -14
- package/src/client/factory.ts +43 -14
- package/src/client/interface.ts +9 -1
- package/src/client/p2p_client.ts +39 -36
- package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +19 -9
- package/src/config.ts +92 -4
- package/src/errors/p2p-service.error.ts +11 -0
- package/src/index.ts +0 -1
- package/src/mem_pools/attestation_pool/attestation_pool.ts +7 -5
- package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +6 -6
- package/src/mem_pools/index.ts +0 -3
- package/src/mem_pools/tx_pool_v2/README.md +9 -1
- package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +2 -1
- package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +11 -1
- package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +15 -6
- package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +2 -1
- package/src/mem_pools/tx_pool_v2/interfaces.ts +9 -4
- package/src/mem_pools/tx_pool_v2/tx_metadata.ts +59 -13
- package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +29 -43
- package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +13 -1
- package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +23 -6
- package/src/msg_validators/attestation_validator/README.md +49 -0
- package/src/msg_validators/attestation_validator/attestation_validator.ts +5 -4
- package/src/msg_validators/clock_tolerance.ts +4 -3
- package/src/msg_validators/proposal_validator/README.md +123 -0
- package/src/msg_validators/proposal_validator/block_proposal_validator.ts +13 -3
- package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +19 -6
- package/src/msg_validators/proposal_validator/proposal_validator.ts +63 -53
- package/src/msg_validators/tx_validator/README.md +5 -1
- package/src/msg_validators/tx_validator/allowed_public_setup.ts +16 -35
- package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
- package/src/msg_validators/tx_validator/contract_instance_validator.ts +56 -0
- package/src/msg_validators/tx_validator/data_validator.ts +42 -1
- package/src/msg_validators/tx_validator/factory.ts +43 -3
- package/src/msg_validators/tx_validator/fee_payer_balance.ts +6 -2
- package/src/msg_validators/tx_validator/gas_validator.ts +41 -8
- package/src/msg_validators/tx_validator/index.ts +1 -0
- package/src/msg_validators/tx_validator/metadata_validator.ts +12 -4
- package/src/msg_validators/tx_validator/phases_validator.ts +60 -1
- package/src/services/dummy_service.ts +7 -2
- package/src/services/encoding.ts +9 -1
- package/src/services/libp2p/libp2p_service.ts +147 -87
- package/src/services/peer-manager/peer_manager.ts +26 -8
- package/src/services/peer-manager/peer_scoring.ts +21 -5
- package/src/services/reqresp/README.md +229 -0
- package/src/services/reqresp/batch-tx-requester/README.md +46 -7
- package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +64 -69
- package/src/services/reqresp/batch-tx-requester/interface.ts +2 -1
- package/src/services/reqresp/batch-tx-requester/missing_txs.ts +13 -6
- package/src/services/reqresp/batch-tx-requester/peer_collection.ts +5 -0
- package/src/services/reqresp/rate-limiter/rate_limiter.ts +13 -9
- package/src/services/reqresp/reqresp.ts +19 -11
- package/src/services/service.ts +6 -1
- package/src/services/tx_collection/fast_tx_collection.ts +57 -83
- package/src/services/tx_collection/file_store_tx_source.ts +43 -31
- package/src/services/tx_collection/proposal_tx_collector.ts +8 -13
- package/src/services/tx_collection/request_tracker.ts +127 -0
- package/src/services/tx_collection/slow_tx_collection.ts +1 -1
- package/src/services/tx_collection/tx_collection.ts +3 -5
- package/src/services/tx_collection/tx_source.ts +8 -7
- package/src/test-helpers/make-test-p2p-clients.ts +1 -1
- package/src/test-helpers/reqresp-nodes.ts +1 -1
- package/src/test-helpers/testbench-utils.ts +29 -3
- package/src/testbench/p2p_client_testbench_worker.ts +45 -15
- package/src/testbench/worker_client_manager.ts +13 -6
- package/src/util.ts +1 -1
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +0 -125
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +0 -596
- package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +0 -32
- package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +0 -112
- package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +0 -157
- package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +0 -52
- package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +0 -16
- package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +0 -122
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +0 -17
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +0 -84
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +0 -19
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +0 -78
- package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +0 -26
- package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +0 -84
- package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +0 -25
- package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +0 -57
- package/dest/mem_pools/tx_pool/index.d.ts +0 -3
- package/dest/mem_pools/tx_pool/index.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/index.js +0 -2
- package/dest/mem_pools/tx_pool/priority.d.ts +0 -12
- package/dest/mem_pools/tx_pool/priority.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/priority.js +0 -15
- package/dest/mem_pools/tx_pool/tx_pool.d.ts +0 -127
- package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/tx_pool.js +0 -3
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +0 -7
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +0 -400
- package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +0 -24
- package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +0 -1
- package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +0 -378
- package/dest/services/tx_collection/missing_txs_tracker.d.ts +0 -32
- package/dest/services/tx_collection/missing_txs_tracker.d.ts.map +0 -1
- package/dest/services/tx_collection/missing_txs_tracker.js +0 -27
- package/src/mem_pools/tx_pool/README.md +0 -270
- package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +0 -746
- package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +0 -132
- package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +0 -208
- package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +0 -162
- package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +0 -104
- package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +0 -93
- package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +0 -106
- package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +0 -75
- package/src/mem_pools/tx_pool/index.ts +0 -2
- package/src/mem_pools/tx_pool/priority.ts +0 -20
- package/src/mem_pools/tx_pool/tx_pool.ts +0 -141
- package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +0 -319
- package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +0 -373
- package/src/services/tx_collection/missing_txs_tracker.ts +0 -52
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import type { EpochCacheInterface } from '@aztec/epoch-cache';
|
|
2
2
|
import { BlockNumber, type SlotNumber } from '@aztec/foundation/branded-types';
|
|
3
|
+
import { maxBy } from '@aztec/foundation/collection';
|
|
3
4
|
import { Fr } from '@aztec/foundation/curves/bn254';
|
|
4
5
|
import { type Logger, createLibp2pComponentLogger, createLogger } from '@aztec/foundation/log';
|
|
5
6
|
import { RunningPromise } from '@aztec/foundation/running-promise';
|
|
@@ -17,8 +18,8 @@ import {
|
|
|
17
18
|
type CheckpointProposalCore,
|
|
18
19
|
type Gossipable,
|
|
19
20
|
P2PMessage,
|
|
20
|
-
type ValidationResult as P2PValidationResult,
|
|
21
21
|
PeerErrorSeverity,
|
|
22
|
+
PeerErrorSeverityByHarshness,
|
|
22
23
|
TopicType,
|
|
23
24
|
createTopicString,
|
|
24
25
|
getTopicsForConfig,
|
|
@@ -57,6 +58,7 @@ import { ENR } from '@nethermindeth/enr';
|
|
|
57
58
|
import { createLibp2p } from 'libp2p';
|
|
58
59
|
|
|
59
60
|
import type { P2PConfig } from '../../config.js';
|
|
61
|
+
import { CheckpointProposalReceivedCallbackNotRegisteredError } from '../../errors/p2p-service.error.js';
|
|
60
62
|
import type { MemPools } from '../../mem_pools/interface.js';
|
|
61
63
|
import {
|
|
62
64
|
BlockProposalValidator,
|
|
@@ -129,7 +131,7 @@ type ValidationOutcome = { allPassed: true } | { allPassed: false; failure: Vali
|
|
|
129
131
|
// REFACTOR: Unify with the type above
|
|
130
132
|
type ReceivedMessageValidationResult<T, M = undefined> =
|
|
131
133
|
| { obj: T; result: Exclude<TopicValidatorResult, TopicValidatorResult.Reject>; metadata?: M }
|
|
132
|
-
| { obj?: T; result: TopicValidatorResult.Reject; metadata?: M };
|
|
134
|
+
| { obj?: T; result: TopicValidatorResult.Reject; metadata?: M; severity: PeerErrorSeverity };
|
|
133
135
|
|
|
134
136
|
/**
|
|
135
137
|
* Lib P2P implementation of the P2PService interface.
|
|
@@ -170,7 +172,13 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
170
172
|
* @param checkpoint - The checkpoint proposal received from the peer.
|
|
171
173
|
* @returns The attestations for the checkpoint, if any.
|
|
172
174
|
*/
|
|
173
|
-
private
|
|
175
|
+
private allNodesCheckpointReceivedCallback: P2PCheckpointReceivedCallback;
|
|
176
|
+
/**
|
|
177
|
+
* Callback for when a checkpoint proposal is received - specifically for validators - from a peer.
|
|
178
|
+
* @param checkpoint - The checkpoint proposal received from the peer.
|
|
179
|
+
* @returns The attestations for the checkpoint, if any.
|
|
180
|
+
*/
|
|
181
|
+
private validatorCheckpointReceivedCallback: P2PCheckpointReceivedCallback;
|
|
174
182
|
|
|
175
183
|
private gossipSubEventHandler: (e: CustomEvent<GossipsubMessage>) => void;
|
|
176
184
|
|
|
@@ -222,14 +230,12 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
222
230
|
this.protocolVersion,
|
|
223
231
|
);
|
|
224
232
|
|
|
225
|
-
|
|
233
|
+
const proposalValidatorOpts = {
|
|
226
234
|
txsPermitted: !config.disableTransactions,
|
|
227
|
-
maxTxsPerBlock: config.
|
|
228
|
-
}
|
|
229
|
-
this.
|
|
230
|
-
|
|
231
|
-
maxTxsPerBlock: config.maxTxsPerBlock,
|
|
232
|
-
});
|
|
235
|
+
maxTxsPerBlock: config.validateMaxTxsPerBlock ?? config.validateMaxTxsPerCheckpoint,
|
|
236
|
+
};
|
|
237
|
+
this.blockProposalValidator = new BlockProposalValidator(epochCache, proposalValidatorOpts);
|
|
238
|
+
this.checkpointProposalValidator = new CheckpointProposalValidator(epochCache, proposalValidatorOpts);
|
|
233
239
|
this.checkpointAttestationValidator = config.fishermanMode
|
|
234
240
|
? new FishermanAttestationValidator(epochCache, mempools.attestationPool, telemetry)
|
|
235
241
|
: new CheckpointAttestationValidator(epochCache);
|
|
@@ -237,19 +243,22 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
237
243
|
this.gossipSubEventHandler = this.handleGossipSubEvent.bind(this);
|
|
238
244
|
|
|
239
245
|
this.blockReceivedCallback = async (block: BlockProposal): Promise<boolean> => {
|
|
240
|
-
this.logger.
|
|
241
|
-
`Handler not yet registered
|
|
246
|
+
this.logger.warn(
|
|
247
|
+
`Handler for block received not yet registered on P2P service. Received block ${block.blockNumber} for slot ${block.slotNumber} from peer.`,
|
|
242
248
|
{ p2pMessageIdentifier: await block.p2pMessageLoggingIdentifier() },
|
|
243
249
|
);
|
|
244
|
-
return
|
|
250
|
+
return true;
|
|
245
251
|
};
|
|
246
252
|
|
|
247
|
-
this.
|
|
248
|
-
|
|
253
|
+
this.allNodesCheckpointReceivedCallback = (
|
|
254
|
+
_checkpoint: CheckpointProposalCore,
|
|
255
|
+
): Promise<CheckpointAttestation[] | undefined> => {
|
|
256
|
+
throw new CheckpointProposalReceivedCallbackNotRegisteredError();
|
|
257
|
+
};
|
|
258
|
+
|
|
259
|
+
this.validatorCheckpointReceivedCallback = (
|
|
260
|
+
_checkpoint: CheckpointProposalCore,
|
|
249
261
|
): Promise<CheckpointAttestation[] | undefined> => {
|
|
250
|
-
this.logger.debug(
|
|
251
|
-
`Handler not yet registered: Checkpoint received callback not set. Received checkpoint for slot ${checkpoint.slotNumber} from peer.`,
|
|
252
|
-
);
|
|
253
262
|
return Promise.resolve(undefined);
|
|
254
263
|
};
|
|
255
264
|
}
|
|
@@ -667,8 +676,16 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
667
676
|
this.blockReceivedCallback = callback;
|
|
668
677
|
}
|
|
669
678
|
|
|
670
|
-
public
|
|
671
|
-
this.
|
|
679
|
+
public registerValidatorCheckpointReceivedCallback(callback: P2PCheckpointReceivedCallback) {
|
|
680
|
+
this.validatorCheckpointReceivedCallback = callback;
|
|
681
|
+
}
|
|
682
|
+
|
|
683
|
+
public registerAllNodesCheckpointReceivedCallback(callback: P2PCheckpointReceivedCallback) {
|
|
684
|
+
this.allNodesCheckpointReceivedCallback = callback;
|
|
685
|
+
}
|
|
686
|
+
|
|
687
|
+
public async notifyOwnCheckpointProposal(checkpoint: CheckpointProposalCore): Promise<void> {
|
|
688
|
+
await this.allNodesCheckpointReceivedCallback(checkpoint, this.node.peerId);
|
|
672
689
|
}
|
|
673
690
|
|
|
674
691
|
/**
|
|
@@ -754,6 +771,9 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
754
771
|
if (!validator || !validator.addMessage(msgId)) {
|
|
755
772
|
this.instrumentation.incMessagePrevalidationStatus(false, topicType);
|
|
756
773
|
this.node.services.pubsub.reportMessageValidationResult(msgId, source.toString(), TopicValidatorResult.Ignore);
|
|
774
|
+
if (topicType === TopicType.tx) {
|
|
775
|
+
this.logger.verbose(`Ignoring already-seen tx gossip message`, { msgId, source: source.toString() });
|
|
776
|
+
}
|
|
757
777
|
return { result: false, topicType };
|
|
758
778
|
}
|
|
759
779
|
|
|
@@ -880,30 +900,56 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
880
900
|
source: PeerId,
|
|
881
901
|
topicType: TopicType,
|
|
882
902
|
): Promise<ReceivedMessageValidationResult<T, M>> {
|
|
883
|
-
|
|
903
|
+
// Default to reject result with a penalty if validation function throws an error
|
|
904
|
+
let resultAndObj: ReceivedMessageValidationResult<T, M> = {
|
|
905
|
+
result: TopicValidatorResult.Reject,
|
|
906
|
+
severity: PeerErrorSeverity.MidToleranceError,
|
|
907
|
+
};
|
|
884
908
|
const timer = new Timer();
|
|
885
909
|
try {
|
|
886
910
|
resultAndObj = await validationFunc();
|
|
887
911
|
} catch (err) {
|
|
888
|
-
this.
|
|
889
|
-
this.logger.error(`Error deserializing and validating gossipsub message`, err, {
|
|
890
|
-
msgId,
|
|
891
|
-
source: source.toString(),
|
|
892
|
-
topicType,
|
|
893
|
-
});
|
|
912
|
+
this.logger.error(`Error validating gossipsub message`, err, { msgId, source: source.toString(), topicType });
|
|
894
913
|
}
|
|
895
914
|
|
|
896
915
|
if (resultAndObj.result === TopicValidatorResult.Accept) {
|
|
916
|
+
this.logger.debug(`Message ${topicType} accepted by validator`, { msgId, source: source.toString(), topicType });
|
|
897
917
|
this.instrumentation.recordMessageValidation(topicType, timer);
|
|
918
|
+
} else if (resultAndObj.result === TopicValidatorResult.Reject) {
|
|
919
|
+
this.logger.warn(`Message ${topicType} rejected by validator with severity ${resultAndObj.severity}`, {
|
|
920
|
+
msgId,
|
|
921
|
+
source: source.toString(),
|
|
922
|
+
topicType,
|
|
923
|
+
severity: resultAndObj.severity,
|
|
924
|
+
});
|
|
925
|
+
this.peerManager.penalizePeer(source, resultAndObj.severity);
|
|
926
|
+
} else {
|
|
927
|
+
this.logger.trace(`Message ${topicType} ignored by validator`, { msgId, source: source.toString(), topicType });
|
|
898
928
|
}
|
|
899
929
|
|
|
900
930
|
this.node.services.pubsub.reportMessageValidationResult(msgId, source.toString(), resultAndObj.result);
|
|
901
931
|
return resultAndObj;
|
|
902
932
|
}
|
|
903
933
|
|
|
934
|
+
private tryDeserialize<T>(deserializeFunc: () => T, msgId: string, source: PeerId): T | undefined {
|
|
935
|
+
try {
|
|
936
|
+
return deserializeFunc();
|
|
937
|
+
} catch (err) {
|
|
938
|
+
this.logger.warn(`Failed to deserialize gossipsub message from buffer`, {
|
|
939
|
+
err,
|
|
940
|
+
msgId,
|
|
941
|
+
source: source.toString(),
|
|
942
|
+
});
|
|
943
|
+
return undefined;
|
|
944
|
+
}
|
|
945
|
+
}
|
|
946
|
+
|
|
904
947
|
protected async handleGossipedTx(payloadData: Buffer, msgId: string, source: PeerId) {
|
|
905
948
|
const validationFunc: () => Promise<ReceivedMessageValidationResult<Tx>> = async () => {
|
|
906
|
-
const tx = Tx.fromBuffer(payloadData);
|
|
949
|
+
const tx = this.tryDeserialize(() => Tx.fromBuffer(payloadData), msgId, source);
|
|
950
|
+
if (!tx) {
|
|
951
|
+
return { result: TopicValidatorResult.Reject, severity: PeerErrorSeverity.LowToleranceError };
|
|
952
|
+
}
|
|
907
953
|
|
|
908
954
|
const currentBlockNumber = await this.archiver.getBlockNumber();
|
|
909
955
|
const { ts: nextSlotTimestamp } = this.epochCache.getEpochAndSlotInNextL1Slot();
|
|
@@ -923,13 +969,20 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
923
969
|
severity = await this.handleDoubleSpendFailure(tx, txBlockNumber);
|
|
924
970
|
}
|
|
925
971
|
|
|
926
|
-
this.
|
|
927
|
-
|
|
972
|
+
this.logger.verbose(`Rejecting gossiped tx ${tx.getTxHash().toString()}: stage 1 validation failed`, {
|
|
973
|
+
validator: name,
|
|
974
|
+
severity,
|
|
975
|
+
source: source.toString(),
|
|
976
|
+
});
|
|
977
|
+
return { result: TopicValidatorResult.Reject, severity };
|
|
928
978
|
}
|
|
929
979
|
|
|
930
980
|
// Pool pre-check: see if the pool would accept this tx before doing expensive proof verification
|
|
931
981
|
const canAdd = await this.mempools.txPool.canAddPendingTx(tx);
|
|
932
982
|
if (canAdd === 'ignored') {
|
|
983
|
+
this.logger.verbose(`Ignoring gossiped tx ${tx.getTxHash().toString()}: pool pre-check returned ignored`, {
|
|
984
|
+
source: source.toString(),
|
|
985
|
+
});
|
|
933
986
|
return { result: TopicValidatorResult.Ignore, obj: tx };
|
|
934
987
|
}
|
|
935
988
|
|
|
@@ -937,9 +990,13 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
937
990
|
const secondStageValidators = this.createSecondStageMessageValidators();
|
|
938
991
|
const secondStageOutcome = await this.runValidations(tx, secondStageValidators);
|
|
939
992
|
if (!secondStageOutcome.allPassed) {
|
|
940
|
-
const { severity } = secondStageOutcome.failure;
|
|
941
|
-
this.
|
|
942
|
-
|
|
993
|
+
const { severity, name } = secondStageOutcome.failure;
|
|
994
|
+
this.logger.verbose(`Rejecting gossiped tx ${tx.getTxHash().toString()}: stage 2 validation failed`, {
|
|
995
|
+
validator: name,
|
|
996
|
+
severity,
|
|
997
|
+
source: source.toString(),
|
|
998
|
+
});
|
|
999
|
+
return { result: TopicValidatorResult.Reject, severity };
|
|
943
1000
|
}
|
|
944
1001
|
|
|
945
1002
|
// Pool add: persist the tx
|
|
@@ -949,7 +1006,7 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
949
1006
|
const wasAccepted = addResult.accepted.some(h => h.equals(txHash));
|
|
950
1007
|
const wasIgnored = addResult.ignored.some(h => h.equals(txHash));
|
|
951
1008
|
|
|
952
|
-
this.logger.
|
|
1009
|
+
this.logger.verbose(`Validate propagated tx ${txHash.toString()}`, {
|
|
953
1010
|
wasAccepted,
|
|
954
1011
|
wasIgnored,
|
|
955
1012
|
[Attributes.P2P_ID]: source.toString(),
|
|
@@ -960,7 +1017,11 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
960
1017
|
} else if (wasIgnored) {
|
|
961
1018
|
return { result: TopicValidatorResult.Ignore, obj: tx };
|
|
962
1019
|
} else {
|
|
963
|
-
|
|
1020
|
+
this.logger.warn(`Gossiped tx ${txHash.toString()} unexpectedly rejected by pool`, {
|
|
1021
|
+
source: source.toString(),
|
|
1022
|
+
txHash: txHash.toString(),
|
|
1023
|
+
});
|
|
1024
|
+
return { result: TopicValidatorResult.Reject, severity: PeerErrorSeverity.HighToleranceError };
|
|
964
1025
|
}
|
|
965
1026
|
};
|
|
966
1027
|
|
|
@@ -990,7 +1051,16 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
990
1051
|
source: PeerId,
|
|
991
1052
|
): Promise<void> {
|
|
992
1053
|
const { result, obj: attestation } = await this.validateReceivedMessage<CheckpointAttestation>(
|
|
993
|
-
() =>
|
|
1054
|
+
() => {
|
|
1055
|
+
const attestation = this.tryDeserialize(() => CheckpointAttestation.fromBuffer(payloadData), msgId, source);
|
|
1056
|
+
if (!attestation) {
|
|
1057
|
+
return Promise.resolve({
|
|
1058
|
+
result: TopicValidatorResult.Reject,
|
|
1059
|
+
severity: PeerErrorSeverity.LowToleranceError,
|
|
1060
|
+
});
|
|
1061
|
+
}
|
|
1062
|
+
return this.validateAndStoreCheckpointAttestation(source, attestation);
|
|
1063
|
+
},
|
|
994
1064
|
msgId,
|
|
995
1065
|
source,
|
|
996
1066
|
TopicType.checkpoint_attestation,
|
|
@@ -1023,8 +1093,7 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1023
1093
|
|
|
1024
1094
|
if (validationResult.result === 'reject') {
|
|
1025
1095
|
this.logger.warn(`Penalizing peer ${peerId} for checkpoint attestation validation failure`);
|
|
1026
|
-
|
|
1027
|
-
return { result: TopicValidatorResult.Reject };
|
|
1096
|
+
return { result: TopicValidatorResult.Reject, severity: validationResult.severity };
|
|
1028
1097
|
}
|
|
1029
1098
|
|
|
1030
1099
|
if (validationResult.result === 'ignore') {
|
|
@@ -1050,16 +1119,16 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1050
1119
|
return { result: TopicValidatorResult.Ignore, obj: attestation };
|
|
1051
1120
|
}
|
|
1052
1121
|
|
|
1053
|
-
// Could not add (cap reached for signer),
|
|
1122
|
+
// Could not add (cap reached for signer), penalize and do not re-broadcast
|
|
1054
1123
|
if (!added) {
|
|
1055
|
-
this.logger.warn(`
|
|
1124
|
+
this.logger.warn(`Rejecting checkpoint attestation due to cap`, {
|
|
1056
1125
|
slot: slot.toString(),
|
|
1057
1126
|
archive: attestation.archive.toString(),
|
|
1058
1127
|
source: peerId.toString(),
|
|
1059
1128
|
attester: attestation.getSender()?.toString(),
|
|
1060
1129
|
count,
|
|
1061
1130
|
});
|
|
1062
|
-
return { result: TopicValidatorResult.
|
|
1131
|
+
return { result: TopicValidatorResult.Reject, severity: PeerErrorSeverity.HighToleranceError };
|
|
1063
1132
|
}
|
|
1064
1133
|
|
|
1065
1134
|
// Check if this is a duplicate attestation (signer attested to a different proposal at the same slot)
|
|
@@ -1114,8 +1183,7 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1114
1183
|
|
|
1115
1184
|
if (validationResult.result === 'reject') {
|
|
1116
1185
|
this.logger.warn(`Penalizing peer ${peerId} for block proposal validation failure`);
|
|
1117
|
-
|
|
1118
|
-
return { result: TopicValidatorResult.Reject };
|
|
1186
|
+
return { result: TopicValidatorResult.Reject, severity: validationResult.severity };
|
|
1119
1187
|
}
|
|
1120
1188
|
|
|
1121
1189
|
if (validationResult.result === 'ignore') {
|
|
@@ -1139,7 +1207,6 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1139
1207
|
|
|
1140
1208
|
// Too many blocks received for this slot and index, penalize peer and do not re-broadcast
|
|
1141
1209
|
if (!added) {
|
|
1142
|
-
this.peerManager.penalizePeer(peerId, PeerErrorSeverity.HighToleranceError);
|
|
1143
1210
|
this.logger.warn(`Penalizing peer for block proposal exceeding per-position cap`, {
|
|
1144
1211
|
...block.toBlockInfo(),
|
|
1145
1212
|
indexWithinCheckpoint: block.indexWithinCheckpoint,
|
|
@@ -1147,7 +1214,11 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1147
1214
|
proposer: block.getSender()?.toString(),
|
|
1148
1215
|
source: peerId.toString(),
|
|
1149
1216
|
});
|
|
1150
|
-
return {
|
|
1217
|
+
return {
|
|
1218
|
+
result: TopicValidatorResult.Reject,
|
|
1219
|
+
metadata: { isEquivocated },
|
|
1220
|
+
severity: PeerErrorSeverity.HighToleranceError,
|
|
1221
|
+
};
|
|
1151
1222
|
}
|
|
1152
1223
|
|
|
1153
1224
|
// If this was a duplicate proposal, do not process it, but do invoke the duplicate callback,
|
|
@@ -1192,7 +1263,7 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1192
1263
|
// Note: Validators do NOT attest to individual blocks, only to checkpoint proposals.
|
|
1193
1264
|
const isValid = await this.blockReceivedCallback(block, sender);
|
|
1194
1265
|
if (!isValid) {
|
|
1195
|
-
this.logger.
|
|
1266
|
+
this.logger.info(`Block proposal validation failed for block ${block.blockNumber}`, block.toBlockInfo());
|
|
1196
1267
|
}
|
|
1197
1268
|
}
|
|
1198
1269
|
|
|
@@ -1240,8 +1311,7 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1240
1311
|
|
|
1241
1312
|
if (validationResult.result === 'reject') {
|
|
1242
1313
|
this.logger.warn(`Penalizing peer ${peerId} for checkpoint proposal validation failure`);
|
|
1243
|
-
|
|
1244
|
-
return { result: TopicValidatorResult.Reject };
|
|
1314
|
+
return { result: TopicValidatorResult.Reject, severity: validationResult.severity };
|
|
1245
1315
|
}
|
|
1246
1316
|
|
|
1247
1317
|
if (validationResult.result === 'ignore') {
|
|
@@ -1256,20 +1326,21 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1256
1326
|
[Attributes.SLOT_NUMBER]: checkpoint.slotNumber.toString(),
|
|
1257
1327
|
[Attributes.P2P_ID]: peerId.toString(),
|
|
1258
1328
|
});
|
|
1259
|
-
const
|
|
1260
|
-
|
|
1261
|
-
|
|
1262
|
-
metadata: { isEquivocated } = {},
|
|
1263
|
-
} = await this.validateAndStoreBlockProposal(peerId, blockProposal);
|
|
1264
|
-
if (result === TopicValidatorResult.Reject || !obj || isEquivocated) {
|
|
1329
|
+
const blockProposalResult = await this.validateAndStoreBlockProposal(peerId, blockProposal);
|
|
1330
|
+
const { obj, metadata: { isEquivocated } = {} } = blockProposalResult;
|
|
1331
|
+
if (blockProposalResult.result === TopicValidatorResult.Reject || !obj || isEquivocated) {
|
|
1265
1332
|
this.logger.debug(`Rejecting checkpoint due to invalid last block proposal`, {
|
|
1266
1333
|
[Attributes.SLOT_NUMBER]: checkpoint.slotNumber.toString(),
|
|
1267
1334
|
[Attributes.P2P_ID]: peerId.toString(),
|
|
1268
1335
|
isEquivocated,
|
|
1269
|
-
result,
|
|
1336
|
+
result: blockProposalResult.result,
|
|
1270
1337
|
});
|
|
1271
|
-
return {
|
|
1272
|
-
|
|
1338
|
+
return {
|
|
1339
|
+
result: TopicValidatorResult.Reject,
|
|
1340
|
+
severity:
|
|
1341
|
+
'severity' in blockProposalResult ? blockProposalResult.severity : PeerErrorSeverity.MidToleranceError,
|
|
1342
|
+
};
|
|
1343
|
+
} else if (blockProposalResult.result === TopicValidatorResult.Accept && obj && !isEquivocated) {
|
|
1273
1344
|
processBlock = true;
|
|
1274
1345
|
}
|
|
1275
1346
|
}
|
|
@@ -1296,13 +1367,17 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1296
1367
|
// Too many checkpoint proposals received for this slot, penalize peer and do not re-broadcast
|
|
1297
1368
|
// Note: We still return the checkpoint obj so the lastBlock can be processed if valid
|
|
1298
1369
|
if (!added) {
|
|
1299
|
-
this.peerManager.penalizePeer(peerId, PeerErrorSeverity.HighToleranceError);
|
|
1300
1370
|
this.logger.warn(`Penalizing peer for checkpoint proposal exceeding per-slot cap`, {
|
|
1301
1371
|
...checkpoint.toCheckpointInfo(),
|
|
1302
1372
|
count,
|
|
1303
1373
|
source: peerId.toString(),
|
|
1304
1374
|
});
|
|
1305
|
-
return {
|
|
1375
|
+
return {
|
|
1376
|
+
result: TopicValidatorResult.Reject,
|
|
1377
|
+
obj: checkpoint,
|
|
1378
|
+
metadata: { isEquivocated, processBlock },
|
|
1379
|
+
severity: PeerErrorSeverity.HighToleranceError,
|
|
1380
|
+
};
|
|
1306
1381
|
}
|
|
1307
1382
|
|
|
1308
1383
|
// If this was a duplicate proposal, do not process it, but do invoke the duplicate callback,
|
|
@@ -1347,9 +1422,11 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1347
1422
|
source: sender.toString(),
|
|
1348
1423
|
});
|
|
1349
1424
|
|
|
1425
|
+
await this.allNodesCheckpointReceivedCallback(checkpoint, sender);
|
|
1426
|
+
|
|
1350
1427
|
// Call the checkpoint received callback with the core version (without lastBlock)
|
|
1351
1428
|
// to validate and potentially generate attestations
|
|
1352
|
-
const attestations = await this.
|
|
1429
|
+
const attestations = await this.validatorCheckpointReceivedCallback(checkpoint, sender);
|
|
1353
1430
|
if (attestations && attestations.length > 0) {
|
|
1354
1431
|
// If the callback returned attestations, add them to the pool and propagate them
|
|
1355
1432
|
await this.mempools.attestationPool.addOwnCheckpointAttestations(attestations);
|
|
@@ -1626,6 +1703,7 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1626
1703
|
...(this.config.txPublicSetupAllowListExtend ?? []),
|
|
1627
1704
|
];
|
|
1628
1705
|
const blockNumber = BlockNumber(currentBlockNumber + 1);
|
|
1706
|
+
const l1Constants = await this.archiver.getL1Constants();
|
|
1629
1707
|
|
|
1630
1708
|
return createFirstStageTxValidationsForGossipedTransactions(
|
|
1631
1709
|
nextSlotTimestamp,
|
|
@@ -1639,6 +1717,11 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1639
1717
|
!this.config.disableTransactions,
|
|
1640
1718
|
allowedInSetup,
|
|
1641
1719
|
this.logger.getBindings(),
|
|
1720
|
+
{
|
|
1721
|
+
rollupManaLimit: l1Constants.rollupManaLimit,
|
|
1722
|
+
maxBlockL2Gas: this.config.validateMaxL2BlockGas,
|
|
1723
|
+
maxBlockDAGas: this.config.validateMaxDABlockGas,
|
|
1724
|
+
},
|
|
1642
1725
|
);
|
|
1643
1726
|
}
|
|
1644
1727
|
|
|
@@ -1664,8 +1747,10 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1664
1747
|
|
|
1665
1748
|
// A promise that resolves when all validations have been run
|
|
1666
1749
|
const allValidations = await Promise.all(validationPromises);
|
|
1667
|
-
const
|
|
1668
|
-
if (
|
|
1750
|
+
const failures = allValidations.filter(x => !x.isValid);
|
|
1751
|
+
if (failures.length > 0) {
|
|
1752
|
+
// Pick the most severe failure (lowest tolerance = harshest penalty)
|
|
1753
|
+
const failed = maxBy(failures, f => PeerErrorSeverityByHarshness.indexOf(f.severity))!;
|
|
1669
1754
|
return {
|
|
1670
1755
|
allPassed: false,
|
|
1671
1756
|
failure: {
|
|
@@ -1718,31 +1803,6 @@ export class LibP2PService extends WithTracer implements P2PService {
|
|
|
1718
1803
|
return PeerErrorSeverity.HighToleranceError;
|
|
1719
1804
|
}
|
|
1720
1805
|
|
|
1721
|
-
/**
|
|
1722
|
-
* Validate a checkpoint attestation.
|
|
1723
|
-
*
|
|
1724
|
-
* @param attestation - The checkpoint attestation to validate.
|
|
1725
|
-
* @returns True if the checkpoint attestation is valid, false otherwise.
|
|
1726
|
-
*/
|
|
1727
|
-
@trackSpan('Libp2pService.validateCheckpointAttestation', async (_, attestation) => ({
|
|
1728
|
-
[Attributes.SLOT_NUMBER]: attestation.payload.header.slotNumber,
|
|
1729
|
-
[Attributes.BLOCK_ARCHIVE]: attestation.archive.toString(),
|
|
1730
|
-
[Attributes.P2P_ID]: await attestation.p2pMessageLoggingIdentifier().then(i => i.toString()),
|
|
1731
|
-
}))
|
|
1732
|
-
public async validateCheckpointAttestation(
|
|
1733
|
-
peerId: PeerId,
|
|
1734
|
-
attestation: CheckpointAttestation,
|
|
1735
|
-
): Promise<P2PValidationResult> {
|
|
1736
|
-
const result = await this.checkpointAttestationValidator.validate(attestation);
|
|
1737
|
-
|
|
1738
|
-
if (result.result === 'reject') {
|
|
1739
|
-
this.logger.warn(`Penalizing peer ${peerId} for checkpoint attestation validation failure`);
|
|
1740
|
-
this.peerManager.penalizePeer(peerId, result.severity);
|
|
1741
|
-
}
|
|
1742
|
-
|
|
1743
|
-
return result;
|
|
1744
|
-
}
|
|
1745
|
-
|
|
1746
1806
|
public getPeerScore(peerId: PeerId): number {
|
|
1747
1807
|
return this.node.services.pubsub.score.score(peerId.toString());
|
|
1748
1808
|
}
|
|
@@ -32,7 +32,7 @@ import { PeerScoreState, type PeerScoring } from './peer_scoring.js';
|
|
|
32
32
|
const MAX_DIAL_ATTEMPTS = 3;
|
|
33
33
|
const MAX_CACHED_PEERS = 100;
|
|
34
34
|
const MAX_CACHED_PEER_AGE_MS = 5 * 60 * 1000; // 5 minutes
|
|
35
|
-
const
|
|
35
|
+
const DEFAULT_FAILED_PEER_BAN_TIME_MS = 5 * 60 * 1000; // 5 minutes timeout after failing MAX_DIAL_ATTEMPTS
|
|
36
36
|
const GOODBYE_DIAL_TIMEOUT_MS = 1000;
|
|
37
37
|
const FAILED_AUTH_HANDSHAKE_EXPIRY_MS = 60 * 60 * 1000; // 1 hour
|
|
38
38
|
|
|
@@ -226,20 +226,30 @@ export class PeerManager implements PeerManagerInterface {
|
|
|
226
226
|
}
|
|
227
227
|
|
|
228
228
|
/**
|
|
229
|
-
* Cleans up expired timeouts.
|
|
229
|
+
* Cleans up expired timeouts and stale failed-auth-handshake entries.
|
|
230
230
|
*
|
|
231
231
|
* When peers fail to dial after a number of retries, they are temporarily timed out.
|
|
232
232
|
* This function removes any peers that have been in the timed out state for too long.
|
|
233
233
|
* To give them a chance to reconnect.
|
|
234
|
+
*
|
|
235
|
+
* Also evicts entries from the failed-auth-handshake map whose expiry window has passed.
|
|
236
|
+
* Without this, peers that probe once and never reconnect would leave their entries in the
|
|
237
|
+
* map forever, causing an unbounded memory leak.
|
|
234
238
|
*/
|
|
235
239
|
private cleanupExpiredTimeouts() {
|
|
236
|
-
// Clean up expired timeouts
|
|
237
240
|
const now = this.dateProvider.now();
|
|
241
|
+
|
|
238
242
|
for (const [peerId, timedOutPeer] of this.timedOutPeers.entries()) {
|
|
239
243
|
if (now >= timedOutPeer.timeoutUntilMs) {
|
|
240
244
|
this.timedOutPeers.delete(peerId);
|
|
241
245
|
}
|
|
242
246
|
}
|
|
247
|
+
|
|
248
|
+
for (const [id, entry] of this.failedAuthHandshakes.entries()) {
|
|
249
|
+
if (now - entry.lastFailureTimestamp > FAILED_AUTH_HANDSHAKE_EXPIRY_MS) {
|
|
250
|
+
this.failedAuthHandshakes.delete(id);
|
|
251
|
+
}
|
|
252
|
+
}
|
|
243
253
|
}
|
|
244
254
|
|
|
245
255
|
/**
|
|
@@ -303,15 +313,20 @@ export class PeerManager implements PeerManagerInterface {
|
|
|
303
313
|
*/
|
|
304
314
|
private handleDisconnectedPeerEvent(e: CustomEvent<PeerId>) {
|
|
305
315
|
const peerId = e.detail;
|
|
316
|
+
const peerIdStr = peerId.toString();
|
|
306
317
|
this.metrics.peerDisconnected(peerId);
|
|
307
|
-
this.logger.verbose(`Disconnected from peer ${
|
|
308
|
-
const validatorAddress = this.authenticatedPeerIdToValidatorAddress.get(
|
|
318
|
+
this.logger.verbose(`Disconnected from peer ${peerIdStr}`);
|
|
319
|
+
const validatorAddress = this.authenticatedPeerIdToValidatorAddress.get(peerIdStr);
|
|
309
320
|
if (validatorAddress !== undefined) {
|
|
310
321
|
this.logger.info(
|
|
311
|
-
`Removing authentication for validator ${validatorAddress} at peer id ${
|
|
322
|
+
`Removing authentication for validator ${validatorAddress} at peer id ${peerIdStr} due to disconnection`,
|
|
312
323
|
);
|
|
313
324
|
this.authenticatedValidatorAddressToPeerId.delete(validatorAddress.toString());
|
|
314
|
-
this.authenticatedPeerIdToValidatorAddress.delete(
|
|
325
|
+
this.authenticatedPeerIdToValidatorAddress.delete(peerIdStr);
|
|
326
|
+
}
|
|
327
|
+
|
|
328
|
+
if (this.peerScoring.getScoreState(peerIdStr) === PeerScoreState.Healthy) {
|
|
329
|
+
this.peerScoring.removePeer(peerIdStr);
|
|
315
330
|
}
|
|
316
331
|
}
|
|
317
332
|
|
|
@@ -776,7 +791,8 @@ export class PeerManager implements PeerManagerInterface {
|
|
|
776
791
|
// Add to timed out peers
|
|
777
792
|
this.timedOutPeers.set(id, {
|
|
778
793
|
peerId: id,
|
|
779
|
-
timeoutUntilMs:
|
|
794
|
+
timeoutUntilMs:
|
|
795
|
+
this.dateProvider.now() + (this.config.peerFailedBanTimeMs ?? DEFAULT_FAILED_PEER_BAN_TIME_MS),
|
|
780
796
|
});
|
|
781
797
|
}
|
|
782
798
|
}
|
|
@@ -938,6 +954,8 @@ export class PeerManager implements PeerManagerInterface {
|
|
|
938
954
|
`Received auth for validator ${sender.toString()} from peer ${peerIdString}, but this validator is already authenticated to peer ${peerForAddress.toString()}`,
|
|
939
955
|
{ ...logData, address: sender.toString() },
|
|
940
956
|
);
|
|
957
|
+
this.markAuthHandshakeFailed(peerId);
|
|
958
|
+
this.markPeerForDisconnect(peerId);
|
|
941
959
|
return;
|
|
942
960
|
}
|
|
943
961
|
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { median } from '@aztec/foundation/collection';
|
|
2
2
|
import { createLogger } from '@aztec/foundation/log';
|
|
3
|
+
import { DateProvider } from '@aztec/foundation/timer';
|
|
3
4
|
import { PeerErrorSeverity } from '@aztec/stdlib/p2p';
|
|
4
5
|
import {
|
|
5
6
|
Attributes,
|
|
@@ -54,6 +55,7 @@ export enum PeerScoreState {
|
|
|
54
55
|
// TODO: move into config / constants
|
|
55
56
|
const MIN_SCORE_BEFORE_BAN = -100;
|
|
56
57
|
const MIN_SCORE_BEFORE_DISCONNECT = -50;
|
|
58
|
+
const SCORE_CLEANUP_THRESHOLD = 0.1;
|
|
57
59
|
|
|
58
60
|
export class PeerScoring {
|
|
59
61
|
private logger = createLogger('p2p:peer-scoring');
|
|
@@ -65,7 +67,11 @@ export class PeerScoring {
|
|
|
65
67
|
|
|
66
68
|
private peerStateCounter: UpDownCounter;
|
|
67
69
|
|
|
68
|
-
constructor(
|
|
70
|
+
constructor(
|
|
71
|
+
config: P2PConfig,
|
|
72
|
+
telemetry: TelemetryClient = getTelemetryClient(),
|
|
73
|
+
private readonly dateProvider: DateProvider = new DateProvider(),
|
|
74
|
+
) {
|
|
69
75
|
const orderedValues = config.peerPenaltyValues?.sort((a, b) => a - b);
|
|
70
76
|
this.peerPenalties = {
|
|
71
77
|
[PeerErrorSeverity.HighToleranceError]:
|
|
@@ -92,7 +98,7 @@ export class PeerScoring {
|
|
|
92
98
|
}
|
|
93
99
|
|
|
94
100
|
updateScore(peerId: string, scoreDelta: number): number {
|
|
95
|
-
const currentTime =
|
|
101
|
+
const currentTime = this.dateProvider.now();
|
|
96
102
|
const lastUpdate = this.lastUpdateTime.get(peerId) || currentTime;
|
|
97
103
|
const timePassed = currentTime - lastUpdate;
|
|
98
104
|
const decayPeriods = Math.floor(timePassed / this.decayInterval);
|
|
@@ -111,19 +117,29 @@ export class PeerScoring {
|
|
|
111
117
|
}
|
|
112
118
|
|
|
113
119
|
decayAllScores(): void {
|
|
114
|
-
const currentTime =
|
|
120
|
+
const currentTime = this.dateProvider.now();
|
|
115
121
|
for (const [peerId, lastUpdate] of this.lastUpdateTime.entries()) {
|
|
116
122
|
const timePassed = currentTime - lastUpdate;
|
|
117
123
|
const decayPeriods = Math.floor(timePassed / this.decayInterval);
|
|
118
124
|
if (decayPeriods > 0) {
|
|
119
125
|
let score = this.scores.get(peerId) || 0;
|
|
120
126
|
score *= Math.pow(this.decayFactor, decayPeriods);
|
|
121
|
-
|
|
122
|
-
|
|
127
|
+
if (Math.abs(score) < SCORE_CLEANUP_THRESHOLD) {
|
|
128
|
+
this.scores.delete(peerId);
|
|
129
|
+
this.lastUpdateTime.delete(peerId);
|
|
130
|
+
} else {
|
|
131
|
+
this.scores.set(peerId, score);
|
|
132
|
+
this.lastUpdateTime.set(peerId, currentTime);
|
|
133
|
+
}
|
|
123
134
|
}
|
|
124
135
|
}
|
|
125
136
|
}
|
|
126
137
|
|
|
138
|
+
removePeer(peerId: string): void {
|
|
139
|
+
this.scores.delete(peerId);
|
|
140
|
+
this.lastUpdateTime.delete(peerId);
|
|
141
|
+
}
|
|
142
|
+
|
|
127
143
|
getScore(peerId: string): number {
|
|
128
144
|
return this.scores.get(peerId) || 0;
|
|
129
145
|
}
|