@aztec/p2p 0.0.0-test.0 → 0.0.1-commit.023c3e5
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/dest/bootstrap/bootstrap.d.ts +4 -3
- package/dest/bootstrap/bootstrap.d.ts.map +1 -1
- package/dest/bootstrap/bootstrap.js +26 -13
- package/dest/client/factory.d.ts +15 -5
- package/dest/client/factory.d.ts.map +1 -1
- package/dest/client/factory.js +61 -25
- package/dest/client/index.d.ts +2 -1
- package/dest/client/index.d.ts.map +1 -1
- package/dest/client/index.js +1 -0
- package/dest/client/interface.d.ts +170 -0
- package/dest/client/interface.d.ts.map +1 -0
- package/dest/client/interface.js +9 -0
- package/dest/client/p2p_client.d.ts +75 -193
- package/dest/client/p2p_client.d.ts.map +1 -1
- package/dest/client/p2p_client.js +765 -229
- package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts +2 -0
- package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts.map +1 -0
- package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +305 -0
- package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts +73 -0
- package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts.map +1 -0
- package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.js +8 -0
- package/dest/config.d.ts +154 -125
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +182 -34
- package/dest/enr/generate-enr.d.ts +11 -3
- package/dest/enr/generate-enr.d.ts.map +1 -1
- package/dest/enr/generate-enr.js +27 -5
- package/dest/enr/index.d.ts +1 -1
- package/dest/errors/attestation-pool.error.d.ts +7 -0
- package/dest/errors/attestation-pool.error.d.ts.map +1 -0
- package/dest/errors/attestation-pool.error.js +12 -0
- package/dest/errors/reqresp.error.d.ts +1 -1
- package/dest/errors/reqresp.error.d.ts.map +1 -1
- package/dest/index.d.ts +4 -1
- package/dest/index.d.ts.map +1 -1
- package/dest/index.js +2 -0
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +104 -25
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +1 -1
- package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +299 -174
- package/dest/mem_pools/attestation_pool/index.d.ts +1 -1
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +29 -11
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +168 -62
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +24 -10
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +133 -82
- package/dest/mem_pools/attestation_pool/mocks.d.ts +234 -11
- package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/mocks.js +19 -21
- package/dest/mem_pools/index.d.ts +1 -1
- package/dest/mem_pools/instrumentation.d.ts +16 -12
- package/dest/mem_pools/instrumentation.d.ts.map +1 -1
- package/dest/mem_pools/instrumentation.js +56 -41
- package/dest/mem_pools/interface.d.ts +3 -4
- package/dest/mem_pools/interface.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +75 -16
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +493 -142
- package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +32 -0
- package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +112 -0
- package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +157 -0
- package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +52 -0
- package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
- package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +122 -0
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +17 -0
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +84 -0
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +19 -0
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +78 -0
- package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +26 -0
- package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +84 -0
- package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
- package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
- package/dest/mem_pools/tx_pool/index.d.ts +1 -2
- package/dest/mem_pools/tx_pool/index.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/index.js +0 -1
- package/dest/mem_pools/tx_pool/priority.d.ts +5 -1
- package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/priority.js +7 -2
- package/dest/mem_pools/tx_pool/tx_pool.d.ts +72 -11
- package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +276 -45
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +7 -5
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
- package/dest/msg_validators/attestation_validator/attestation_validator.js +79 -10
- package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +20 -0
- package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -0
- package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +76 -0
- package/dest/msg_validators/attestation_validator/index.d.ts +2 -1
- package/dest/msg_validators/attestation_validator/index.d.ts.map +1 -1
- package/dest/msg_validators/attestation_validator/index.js +1 -0
- package/dest/msg_validators/clock_tolerance.d.ts +21 -0
- package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
- package/dest/msg_validators/clock_tolerance.js +37 -0
- package/dest/msg_validators/index.d.ts +2 -2
- package/dest/msg_validators/index.d.ts.map +1 -1
- package/dest/msg_validators/index.js +1 -1
- package/dest/msg_validators/msg_seen_validator/msg_seen_validator.d.ts +10 -0
- package/dest/msg_validators/msg_seen_validator/msg_seen_validator.d.ts.map +1 -0
- package/dest/msg_validators/msg_seen_validator/msg_seen_validator.js +36 -0
- package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +9 -0
- package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
- package/dest/msg_validators/proposal_validator/block_proposal_validator.js +6 -0
- package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +9 -0
- package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
- package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +6 -0
- package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
- package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
- package/dest/msg_validators/proposal_validator/index.js +3 -0
- package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -0
- package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
- package/dest/msg_validators/proposal_validator/proposal_validator.js +104 -0
- package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +23 -0
- package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +1 -0
- package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +212 -0
- package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +1 -1
- package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +3 -0
- package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/allowed_public_setup.js +27 -0
- package/dest/msg_validators/tx_validator/archive_cache.d.ts +14 -0
- package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/archive_cache.js +22 -0
- package/dest/msg_validators/tx_validator/block_header_validator.d.ts +5 -4
- package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/block_header_validator.js +7 -6
- package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
- package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/data_validator.js +60 -87
- package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +3 -4
- package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/double_spend_validator.js +24 -29
- package/dest/msg_validators/tx_validator/factory.d.ts +21 -0
- package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/factory.js +84 -0
- package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
- package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/fee_payer_balance.js +20 -0
- package/dest/msg_validators/tx_validator/gas_validator.d.ts +12 -0
- package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/gas_validator.js +110 -0
- package/dest/msg_validators/tx_validator/index.d.ts +9 -1
- package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/index.js +8 -0
- package/dest/msg_validators/tx_validator/metadata_validator.d.ts +10 -5
- package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/metadata_validator.js +40 -21
- package/dest/msg_validators/tx_validator/phases_validator.d.ts +15 -0
- package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/phases_validator.js +93 -0
- package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
- package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/size_validator.js +23 -0
- package/dest/msg_validators/tx_validator/test_utils.d.ts +17 -0
- package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/test_utils.js +22 -0
- package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +14 -0
- package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/timestamp_validator.js +32 -0
- package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +9 -0
- package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/tx_permitted_validator.js +24 -0
- package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
- package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/tx_proof_validator.js +8 -7
- package/dest/services/data_store.d.ts +1 -1
- package/dest/services/data_store.d.ts.map +1 -1
- package/dest/services/data_store.js +10 -6
- package/dest/services/discv5/discV5_service.d.ts +10 -9
- package/dest/services/discv5/discV5_service.d.ts.map +1 -1
- package/dest/services/discv5/discV5_service.js +64 -37
- package/dest/services/dummy_service.d.ts +66 -11
- package/dest/services/dummy_service.d.ts.map +1 -1
- package/dest/services/dummy_service.js +130 -5
- package/dest/services/encoding.d.ts +26 -7
- package/dest/services/encoding.d.ts.map +1 -1
- package/dest/services/encoding.js +75 -6
- package/dest/services/gossipsub/scoring.d.ts +1 -1
- package/dest/services/index.d.ts +5 -1
- package/dest/services/index.d.ts.map +1 -1
- package/dest/services/index.js +4 -0
- package/dest/services/libp2p/instrumentation.d.ts +20 -0
- package/dest/services/libp2p/instrumentation.d.ts.map +1 -0
- package/dest/services/libp2p/instrumentation.js +122 -0
- package/dest/services/libp2p/libp2p_service.d.ts +107 -95
- package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
- package/dest/services/libp2p/libp2p_service.js +1328 -313
- package/dest/services/peer-manager/interface.d.ts +23 -0
- package/dest/services/peer-manager/interface.d.ts.map +1 -0
- package/dest/services/peer-manager/interface.js +1 -0
- package/dest/services/peer-manager/metrics.d.ts +12 -3
- package/dest/services/peer-manager/metrics.d.ts.map +1 -1
- package/dest/services/peer-manager/metrics.js +44 -12
- package/dest/services/peer-manager/peer_manager.d.ts +103 -23
- package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
- package/dest/services/peer-manager/peer_manager.js +551 -82
- package/dest/services/peer-manager/peer_scoring.d.ts +7 -2
- package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
- package/dest/services/peer-manager/peer_scoring.js +43 -2
- package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +47 -0
- package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
- package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +566 -0
- package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
- package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
- package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
- package/dest/services/reqresp/batch-tx-requester/interface.d.ts +50 -0
- package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
- package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
- package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +37 -0
- package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
- package/dest/services/reqresp/batch-tx-requester/missing_txs.js +151 -0
- package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +54 -0
- package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
- package/dest/services/reqresp/batch-tx-requester/peer_collection.js +139 -0
- package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
- package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
- package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
- package/dest/services/reqresp/config.d.ts +11 -9
- package/dest/services/reqresp/config.d.ts.map +1 -1
- package/dest/services/reqresp/config.js +18 -4
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +23 -4
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +73 -10
- package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +32 -17
- package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
- package/dest/services/reqresp/connection-sampler/connection_sampler.js +154 -84
- package/dest/services/reqresp/constants.d.ts +12 -0
- package/dest/services/reqresp/constants.d.ts.map +1 -0
- package/dest/services/reqresp/constants.js +7 -0
- package/dest/services/reqresp/index.d.ts +3 -2
- package/dest/services/reqresp/index.d.ts.map +1 -1
- package/dest/services/reqresp/index.js +2 -1
- package/dest/services/reqresp/interface.d.ts +75 -24
- package/dest/services/reqresp/interface.d.ts.map +1 -1
- package/dest/services/reqresp/interface.js +46 -27
- package/dest/services/reqresp/metrics.d.ts +6 -5
- package/dest/services/reqresp/metrics.d.ts.map +1 -1
- package/dest/services/reqresp/metrics.js +17 -21
- package/dest/services/reqresp/protocols/auth.d.ts +43 -0
- package/dest/services/reqresp/protocols/auth.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/auth.js +71 -0
- package/dest/services/reqresp/protocols/block.d.ts +6 -1
- package/dest/services/reqresp/protocols/block.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/block.js +30 -6
- package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +34 -0
- package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/block_txs/bitvector.js +87 -0
- package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +11 -0
- package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +52 -0
- package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +59 -0
- package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +105 -0
- package/dest/services/reqresp/protocols/block_txs/index.d.ts +4 -0
- package/dest/services/reqresp/protocols/block_txs/index.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/block_txs/index.js +3 -0
- package/dest/services/reqresp/protocols/goodbye.d.ts +3 -5
- package/dest/services/reqresp/protocols/goodbye.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/goodbye.js +7 -7
- package/dest/services/reqresp/protocols/index.d.ts +3 -1
- package/dest/services/reqresp/protocols/index.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/index.js +2 -0
- package/dest/services/reqresp/protocols/ping.d.ts +1 -3
- package/dest/services/reqresp/protocols/ping.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/status.d.ts +40 -7
- package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/status.js +76 -5
- package/dest/services/reqresp/protocols/tx.d.ts +14 -4
- package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/tx.js +34 -6
- package/dest/services/reqresp/rate-limiter/index.d.ts +1 -1
- package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +6 -4
- package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -1
- package/dest/services/reqresp/rate-limiter/rate_limiter.js +10 -2
- package/dest/services/reqresp/rate-limiter/rate_limits.d.ts +1 -1
- package/dest/services/reqresp/rate-limiter/rate_limits.d.ts.map +1 -1
- package/dest/services/reqresp/rate-limiter/rate_limits.js +21 -1
- package/dest/services/reqresp/reqresp.d.ts +29 -66
- package/dest/services/reqresp/reqresp.d.ts.map +1 -1
- package/dest/services/reqresp/reqresp.js +753 -248
- package/dest/services/reqresp/status.d.ts +10 -4
- package/dest/services/reqresp/status.d.ts.map +1 -1
- package/dest/services/reqresp/status.js +9 -2
- package/dest/services/service.d.ts +40 -20
- package/dest/services/service.d.ts.map +1 -1
- package/dest/services/tx_collection/config.d.ts +28 -0
- package/dest/services/tx_collection/config.d.ts.map +1 -0
- package/dest/services/tx_collection/config.js +66 -0
- package/dest/services/tx_collection/fast_tx_collection.d.ts +53 -0
- package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -0
- package/dest/services/tx_collection/fast_tx_collection.js +311 -0
- package/dest/services/tx_collection/index.d.ts +4 -0
- package/dest/services/tx_collection/index.d.ts.map +1 -0
- package/dest/services/tx_collection/index.js +3 -0
- package/dest/services/tx_collection/instrumentation.d.ts +10 -0
- package/dest/services/tx_collection/instrumentation.d.ts.map +1 -0
- package/dest/services/tx_collection/instrumentation.js +31 -0
- package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
- package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
- package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
- package/dest/services/tx_collection/slow_tx_collection.d.ts +53 -0
- package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -0
- package/dest/services/tx_collection/slow_tx_collection.js +177 -0
- package/dest/services/tx_collection/tx_collection.d.ts +110 -0
- package/dest/services/tx_collection/tx_collection.d.ts.map +1 -0
- package/dest/services/tx_collection/tx_collection.js +128 -0
- package/dest/services/tx_collection/tx_collection_sink.d.ts +30 -0
- package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -0
- package/dest/services/tx_collection/tx_collection_sink.js +111 -0
- package/dest/services/tx_collection/tx_source.d.ts +18 -0
- package/dest/services/tx_collection/tx_source.d.ts.map +1 -0
- package/dest/services/tx_collection/tx_source.js +31 -0
- package/dest/services/tx_provider.d.ts +51 -0
- package/dest/services/tx_provider.d.ts.map +1 -0
- package/dest/services/tx_provider.js +219 -0
- package/dest/services/tx_provider_instrumentation.d.ts +16 -0
- package/dest/services/tx_provider_instrumentation.d.ts.map +1 -0
- package/dest/services/tx_provider_instrumentation.js +34 -0
- package/dest/test-helpers/generate-peer-id-private-keys.d.ts +1 -1
- package/dest/test-helpers/get-ports.d.ts +1 -1
- package/dest/test-helpers/get-ports.d.ts.map +1 -1
- package/dest/test-helpers/index.d.ts +4 -1
- package/dest/test-helpers/index.d.ts.map +1 -1
- package/dest/test-helpers/index.js +3 -0
- package/dest/test-helpers/make-enrs.d.ts +1 -1
- package/dest/test-helpers/make-enrs.d.ts.map +1 -1
- package/dest/test-helpers/make-enrs.js +4 -5
- package/dest/test-helpers/make-test-p2p-clients.d.ts +33 -5
- package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
- package/dest/test-helpers/make-test-p2p-clients.js +86 -16
- package/dest/test-helpers/mock-pubsub.d.ts +59 -0
- package/dest/test-helpers/mock-pubsub.d.ts.map +1 -0
- package/dest/test-helpers/mock-pubsub.js +130 -0
- package/dest/test-helpers/mock-tx-helpers.d.ts +12 -0
- package/dest/test-helpers/mock-tx-helpers.d.ts.map +1 -0
- package/dest/test-helpers/mock-tx-helpers.js +19 -0
- package/dest/test-helpers/reqresp-nodes.d.ts +15 -11
- package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
- package/dest/test-helpers/reqresp-nodes.js +62 -28
- package/dest/test-helpers/test_tx_provider.d.ts +40 -0
- package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
- package/dest/test-helpers/test_tx_provider.js +41 -0
- package/dest/test-helpers/testbench-utils.d.ts +158 -0
- package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
- package/dest/test-helpers/testbench-utils.js +297 -0
- package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
- package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
- package/dest/testbench/p2p_client_testbench_worker.js +259 -90
- package/dest/testbench/parse_log_file.d.ts +1 -1
- package/dest/testbench/parse_log_file.js +4 -4
- package/dest/testbench/testbench.d.ts +1 -1
- package/dest/testbench/testbench.js +4 -4
- package/dest/testbench/worker_client_manager.d.ts +51 -11
- package/dest/testbench/worker_client_manager.d.ts.map +1 -1
- package/dest/testbench/worker_client_manager.js +232 -53
- package/dest/types/index.d.ts +4 -2
- package/dest/types/index.d.ts.map +1 -1
- package/dest/types/index.js +2 -0
- package/dest/util.d.ts +24 -16
- package/dest/util.d.ts.map +1 -1
- package/dest/util.js +75 -69
- package/dest/versioning.d.ts +4 -4
- package/dest/versioning.d.ts.map +1 -1
- package/dest/versioning.js +8 -3
- package/package.json +32 -27
- package/src/bootstrap/bootstrap.ts +34 -15
- package/src/client/factory.ts +135 -53
- package/src/client/index.ts +1 -0
- package/src/client/interface.ts +213 -0
- package/src/client/p2p_client.ts +476 -383
- package/src/client/test/tx_proposal_collector/README.md +227 -0
- package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +336 -0
- package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
- package/src/config.ts +304 -134
- package/src/enr/generate-enr.ts +39 -6
- package/src/errors/attestation-pool.error.ts +13 -0
- package/src/index.ts +4 -0
- package/src/mem_pools/attestation_pool/attestation_pool.ts +119 -24
- package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +352 -201
- package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +233 -72
- package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +199 -96
- package/src/mem_pools/attestation_pool/mocks.ts +24 -17
- package/src/mem_pools/instrumentation.ts +72 -48
- package/src/mem_pools/interface.ts +2 -4
- package/src/mem_pools/tx_pool/README.md +270 -0
- package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +580 -143
- package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +132 -0
- package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +208 -0
- package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +162 -0
- package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +104 -0
- package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +93 -0
- package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +106 -0
- package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
- package/src/mem_pools/tx_pool/index.ts +0 -1
- package/src/mem_pools/tx_pool/priority.ts +9 -2
- package/src/mem_pools/tx_pool/tx_pool.ts +75 -10
- package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +225 -36
- package/src/msg_validators/attestation_validator/attestation_validator.ts +72 -14
- package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +94 -0
- package/src/msg_validators/attestation_validator/index.ts +1 -0
- package/src/msg_validators/clock_tolerance.ts +51 -0
- package/src/msg_validators/index.ts +1 -1
- package/src/msg_validators/msg_seen_validator/msg_seen_validator.ts +36 -0
- package/src/msg_validators/proposal_validator/block_proposal_validator.ts +10 -0
- package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +13 -0
- package/src/msg_validators/proposal_validator/index.ts +3 -0
- package/src/msg_validators/proposal_validator/proposal_validator.ts +92 -0
- package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +230 -0
- package/src/msg_validators/tx_validator/allowed_public_setup.ts +35 -0
- package/src/msg_validators/tx_validator/archive_cache.ts +28 -0
- package/src/msg_validators/tx_validator/block_header_validator.ts +10 -9
- package/src/msg_validators/tx_validator/data_validator.ts +95 -71
- package/src/msg_validators/tx_validator/double_spend_validator.ts +23 -20
- package/src/msg_validators/tx_validator/factory.ts +151 -0
- package/src/msg_validators/tx_validator/fee_payer_balance.ts +40 -0
- package/src/msg_validators/tx_validator/gas_validator.ts +123 -0
- package/src/msg_validators/tx_validator/index.ts +8 -0
- package/src/msg_validators/tx_validator/metadata_validator.ts +72 -24
- package/src/msg_validators/tx_validator/phases_validator.ts +118 -0
- package/src/msg_validators/tx_validator/size_validator.ts +22 -0
- package/src/msg_validators/tx_validator/test_utils.ts +43 -0
- package/src/msg_validators/tx_validator/timestamp_validator.ts +52 -0
- package/src/msg_validators/tx_validator/tx_permitted_validator.ts +22 -0
- package/src/msg_validators/tx_validator/tx_proof_validator.ts +14 -8
- package/src/services/data_store.ts +10 -7
- package/src/services/discv5/discV5_service.ts +85 -39
- package/src/services/dummy_service.ts +198 -9
- package/src/services/encoding.ts +82 -6
- package/src/services/index.ts +4 -0
- package/src/services/libp2p/instrumentation.ts +126 -0
- package/src/services/libp2p/libp2p_service.ts +1170 -353
- package/src/services/peer-manager/interface.ts +29 -0
- package/src/services/peer-manager/metrics.ts +55 -12
- package/src/services/peer-manager/peer_manager.ts +657 -80
- package/src/services/peer-manager/peer_scoring.ts +45 -3
- package/src/services/reqresp/batch-tx-requester/README.md +305 -0
- package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +706 -0
- package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
- package/src/services/reqresp/batch-tx-requester/interface.ts +57 -0
- package/src/services/reqresp/batch-tx-requester/missing_txs.ts +209 -0
- package/src/services/reqresp/batch-tx-requester/peer_collection.ts +205 -0
- package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
- package/src/services/reqresp/config.ts +26 -9
- package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +77 -10
- package/src/services/reqresp/connection-sampler/connection_sampler.ts +166 -95
- package/src/services/reqresp/constants.ts +14 -0
- package/src/services/reqresp/index.ts +2 -0
- package/src/services/reqresp/interface.ts +95 -37
- package/src/services/reqresp/metrics.ts +40 -28
- package/src/services/reqresp/protocols/auth.ts +83 -0
- package/src/services/reqresp/protocols/block.ts +26 -4
- package/src/services/reqresp/protocols/block_txs/bitvector.ts +106 -0
- package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +67 -0
- package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +121 -0
- package/src/services/reqresp/protocols/block_txs/index.ts +3 -0
- package/src/services/reqresp/protocols/goodbye.ts +9 -7
- package/src/services/reqresp/protocols/index.ts +2 -0
- package/src/services/reqresp/protocols/status.ts +121 -5
- package/src/services/reqresp/protocols/tx.ts +36 -8
- package/src/services/reqresp/rate-limiter/rate_limiter.ts +12 -3
- package/src/services/reqresp/rate-limiter/rate_limits.ts +21 -1
- package/src/services/reqresp/reqresp.ts +449 -271
- package/src/services/reqresp/status.ts +12 -3
- package/src/services/service.ts +65 -22
- package/src/services/tx_collection/config.ts +98 -0
- package/src/services/tx_collection/fast_tx_collection.ts +364 -0
- package/src/services/tx_collection/index.ts +7 -0
- package/src/services/tx_collection/instrumentation.ts +35 -0
- package/src/services/tx_collection/proposal_tx_collector.ts +114 -0
- package/src/services/tx_collection/slow_tx_collection.ts +233 -0
- package/src/services/tx_collection/tx_collection.ts +216 -0
- package/src/services/tx_collection/tx_collection_sink.ts +129 -0
- package/src/services/tx_collection/tx_source.ts +37 -0
- package/src/services/tx_provider.ts +232 -0
- package/src/services/tx_provider_instrumentation.ts +54 -0
- package/src/test-helpers/index.ts +3 -0
- package/src/test-helpers/make-enrs.ts +4 -5
- package/src/test-helpers/make-test-p2p-clients.ts +111 -21
- package/src/test-helpers/mock-pubsub.ts +188 -0
- package/src/test-helpers/mock-tx-helpers.ts +24 -0
- package/src/test-helpers/reqresp-nodes.ts +87 -36
- package/src/test-helpers/test_tx_provider.ts +64 -0
- package/src/test-helpers/testbench-utils.ts +374 -0
- package/src/testbench/p2p_client_testbench_worker.ts +434 -89
- package/src/testbench/parse_log_file.ts +4 -4
- package/src/testbench/testbench.ts +4 -4
- package/src/testbench/worker_client_manager.ts +315 -59
- package/src/types/index.ts +2 -0
- package/src/util.ts +105 -91
- package/src/versioning.ts +11 -4
- package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -56
- package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
- package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -141
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -8
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +0 -21
- package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
- package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
- package/dest/msg_validators/block_proposal_validator/index.js +0 -1
- package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -174
- package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +0 -29
- package/src/msg_validators/block_proposal_validator/index.ts +0 -1
|
@@ -18,11 +18,18 @@ import type { ConnectionSampler } from './connection_sampler.js';
|
|
|
18
18
|
* If a peer fails, it is replaced while maintaining the same bucket.
|
|
19
19
|
*/
|
|
20
20
|
export class BatchConnectionSampler {
|
|
21
|
-
private readonly logger = createLogger('p2p:reqresp:batch-connection-sampler');
|
|
22
21
|
private readonly batch: PeerId[] = [];
|
|
23
22
|
private readonly requestsPerPeer: number;
|
|
23
|
+
/** Tracks peer-index combinations that returned empty/invalid responses */
|
|
24
|
+
private readonly failedPeerIndices: Map<string, Set<number>> = new Map();
|
|
24
25
|
|
|
25
|
-
constructor(
|
|
26
|
+
constructor(
|
|
27
|
+
private readonly connectionSampler: ConnectionSampler,
|
|
28
|
+
batchSize: number,
|
|
29
|
+
maxPeers: number,
|
|
30
|
+
exclude?: PeerId[],
|
|
31
|
+
private readonly logger = createLogger('p2p:reqresp:batch-connection-sampler'),
|
|
32
|
+
) {
|
|
26
33
|
if (maxPeers <= 0) {
|
|
27
34
|
throw new Error('Max peers cannot be 0');
|
|
28
35
|
}
|
|
@@ -34,14 +41,17 @@ export class BatchConnectionSampler {
|
|
|
34
41
|
this.requestsPerPeer = Math.max(1, Math.floor(batchSize / maxPeers));
|
|
35
42
|
|
|
36
43
|
// Sample initial peers
|
|
37
|
-
|
|
44
|
+
const excluding = exclude && new Map(exclude.map(peerId => [peerId.toString(), true] as const));
|
|
45
|
+
this.batch = this.connectionSampler.samplePeersBatch(maxPeers, excluding);
|
|
38
46
|
}
|
|
39
47
|
|
|
40
48
|
/**
|
|
41
|
-
* Gets the peer responsible for handling a specific request index
|
|
49
|
+
* Gets the peer responsible for handling a specific request index.
|
|
50
|
+
* If the primary peer has previously failed for this index, tries other peers.
|
|
51
|
+
* If all batch peers have failed, attempts to sample a new peer.
|
|
42
52
|
*
|
|
43
53
|
* @param index - The request index
|
|
44
|
-
* @returns The peer assigned to handle this request
|
|
54
|
+
* @returns The peer assigned to handle this request, or undefined if no peer available
|
|
45
55
|
*/
|
|
46
56
|
getPeerForRequest(index: number): PeerId | undefined {
|
|
47
57
|
if (this.batch.length === 0) {
|
|
@@ -49,8 +59,65 @@ export class BatchConnectionSampler {
|
|
|
49
59
|
}
|
|
50
60
|
|
|
51
61
|
// Calculate which peer bucket this index belongs to
|
|
52
|
-
const
|
|
53
|
-
|
|
62
|
+
const primaryPeerIndex = Math.floor(index / this.requestsPerPeer) % this.batch.length;
|
|
63
|
+
|
|
64
|
+
// Try peers starting from primary, wrapping around
|
|
65
|
+
for (let offset = 0; offset < this.batch.length; offset++) {
|
|
66
|
+
const peerIndex = (primaryPeerIndex + offset) % this.batch.length;
|
|
67
|
+
const peer = this.batch[peerIndex];
|
|
68
|
+
const peerKey = peer.toString();
|
|
69
|
+
|
|
70
|
+
const failedIndices = this.failedPeerIndices.get(peerKey);
|
|
71
|
+
if (!failedIndices || !failedIndices.has(index)) {
|
|
72
|
+
return peer;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// All batch peers have failed for this index - try to sample a new peer
|
|
77
|
+
const newPeer = this.sampleNewPeer();
|
|
78
|
+
if (newPeer) {
|
|
79
|
+
return newPeer;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
return undefined;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* Attempts to sample a new peer that isn't already in the batch.
|
|
87
|
+
* If successful, adds the peer to the batch.
|
|
88
|
+
*
|
|
89
|
+
* @returns The new peer if one was sampled, undefined otherwise
|
|
90
|
+
*/
|
|
91
|
+
private sampleNewPeer(): PeerId | undefined {
|
|
92
|
+
// Exclude all current batch peers
|
|
93
|
+
const excluding = new Map(this.batch.map(p => [p.toString(), true] as const));
|
|
94
|
+
const newPeer = this.connectionSampler.getPeer(excluding);
|
|
95
|
+
|
|
96
|
+
if (newPeer) {
|
|
97
|
+
this.batch.push(newPeer);
|
|
98
|
+
this.logger.trace('Sampled new peer for exhausted index', { newPeer: newPeer.toString() });
|
|
99
|
+
return newPeer;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
return undefined;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Marks that a peer returned an empty/invalid response for a specific request index.
|
|
107
|
+
* The peer will not be assigned this index again.
|
|
108
|
+
*
|
|
109
|
+
* @param peerId - The peer that failed
|
|
110
|
+
* @param index - The request index that failed
|
|
111
|
+
*/
|
|
112
|
+
markPeerFailedForIndex(peerId: PeerId, index: number): void {
|
|
113
|
+
const peerKey = peerId.toString();
|
|
114
|
+
let failedIndices = this.failedPeerIndices.get(peerKey);
|
|
115
|
+
if (!failedIndices) {
|
|
116
|
+
failedIndices = new Set();
|
|
117
|
+
this.failedPeerIndices.set(peerKey, failedIndices);
|
|
118
|
+
}
|
|
119
|
+
failedIndices.add(index);
|
|
120
|
+
this.logger.trace('Marked peer failed for index', { peerId: peerKey, index });
|
|
54
121
|
}
|
|
55
122
|
|
|
56
123
|
/**
|
|
@@ -66,15 +133,15 @@ export class BatchConnectionSampler {
|
|
|
66
133
|
}
|
|
67
134
|
|
|
68
135
|
const excluding = new Map([[peerId.toString(), true]]);
|
|
69
|
-
const newPeer = this.connectionSampler.getPeer(excluding);
|
|
136
|
+
const newPeer = this.connectionSampler.getPeer(excluding); // Q: Shouldn't we accumulate all excluded peers? Otherwise the sampler could return us a previously excluded peer?
|
|
70
137
|
|
|
71
138
|
if (newPeer) {
|
|
72
139
|
this.batch[index] = newPeer;
|
|
73
|
-
this.logger.trace(
|
|
140
|
+
this.logger.trace('Replaced peer', { peerId, newPeer });
|
|
74
141
|
} else {
|
|
75
142
|
// If we couldn't get a replacement, remove the peer and compact the array
|
|
76
143
|
this.batch.splice(index, 1);
|
|
77
|
-
this.logger.trace(
|
|
144
|
+
this.logger.trace('Removed peer', { peerId });
|
|
78
145
|
}
|
|
79
146
|
}
|
|
80
147
|
|
|
@@ -1,15 +1,10 @@
|
|
|
1
|
+
import { AbortError } from '@aztec/foundation/error';
|
|
1
2
|
import { createLogger } from '@aztec/foundation/log';
|
|
2
|
-
import { SerialQueue } from '@aztec/foundation/queue';
|
|
3
3
|
|
|
4
4
|
import type { Libp2p, PeerId, Stream } from '@libp2p/interface';
|
|
5
5
|
|
|
6
6
|
const MAX_SAMPLE_ATTEMPTS = 4;
|
|
7
7
|
|
|
8
|
-
interface StreamAndPeerId {
|
|
9
|
-
stream: Stream;
|
|
10
|
-
peerId: PeerId;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
8
|
export class RandomSampler {
|
|
14
9
|
random(max: number) {
|
|
15
10
|
return Math.floor(Math.random() * max);
|
|
@@ -17,31 +12,33 @@ export class RandomSampler {
|
|
|
17
12
|
}
|
|
18
13
|
|
|
19
14
|
/**
|
|
20
|
-
* A class that samples peers from the libp2p node and returns a peer that we don't already have a connection open to.
|
|
15
|
+
* A class that samples peers from the libp2p node and returns a peer that we don't already have a reqresp connection open to.
|
|
21
16
|
* If we already have a connection open, we try to sample a different peer.
|
|
22
17
|
* We do this MAX_SAMPLE_ATTEMPTS times, if we still don't find a peer we just go for it.
|
|
23
18
|
*
|
|
24
19
|
* @dev Close must always be called on connections, else memory leak
|
|
25
20
|
*/
|
|
26
21
|
export class ConnectionSampler {
|
|
27
|
-
private readonly logger = createLogger('p2p:reqresp:connection-sampler');
|
|
28
22
|
private cleanupInterval: NodeJS.Timeout;
|
|
29
|
-
private abortController: AbortController = new AbortController();
|
|
30
23
|
|
|
31
|
-
|
|
32
|
-
|
|
24
|
+
// Map from stringified peer id to number of active connections
|
|
25
|
+
protected readonly activeConnectionsCount: Map<string, number> = new Map();
|
|
26
|
+
|
|
27
|
+
// eslint-disable-next-line aztec-custom/no-non-primitive-in-collections
|
|
28
|
+
protected readonly streams: Set<Stream> = new Set();
|
|
33
29
|
|
|
34
|
-
|
|
35
|
-
private dialQueue: SerialQueue = new SerialQueue();
|
|
30
|
+
private abortOnStop: AbortController = new AbortController();
|
|
36
31
|
|
|
37
32
|
constructor(
|
|
38
33
|
private readonly libp2p: Libp2p,
|
|
39
|
-
private readonly
|
|
40
|
-
private readonly
|
|
34
|
+
private readonly sampler: RandomSampler,
|
|
35
|
+
private readonly logger = createLogger('p2p:reqresp:connection-sampler'),
|
|
36
|
+
private readonly opts: { cleanupIntervalMs?: number; p2pOptimisticNegotiation?: boolean } = {},
|
|
41
37
|
) {
|
|
42
|
-
this.cleanupInterval = setInterval(
|
|
43
|
-
|
|
44
|
-
|
|
38
|
+
this.cleanupInterval = setInterval(
|
|
39
|
+
() => void this.cleanupStaleConnections(),
|
|
40
|
+
this.opts.cleanupIntervalMs ?? 60_000,
|
|
41
|
+
);
|
|
45
42
|
}
|
|
46
43
|
|
|
47
44
|
/**
|
|
@@ -49,13 +46,11 @@ export class ConnectionSampler {
|
|
|
49
46
|
*/
|
|
50
47
|
async stop() {
|
|
51
48
|
this.logger.info('Stopping connection sampler');
|
|
49
|
+
this.abortOnStop.abort(new AbortError('Connection sampler stopped'));
|
|
52
50
|
clearInterval(this.cleanupInterval);
|
|
53
51
|
|
|
54
|
-
this.abortController.abort();
|
|
55
|
-
await this.dialQueue.end();
|
|
56
|
-
|
|
57
52
|
// Close all active streams
|
|
58
|
-
const closePromises = Array.from(this.streams.
|
|
53
|
+
const closePromises = Array.from(this.streams.values()).map(stream => this.close(stream));
|
|
59
54
|
await Promise.all(closePromises);
|
|
60
55
|
this.logger.info('Connection sampler stopped');
|
|
61
56
|
}
|
|
@@ -69,70 +64,128 @@ export class ConnectionSampler {
|
|
|
69
64
|
getPeer(excluding?: Map<string, boolean>): PeerId | undefined {
|
|
70
65
|
// In libp2p getPeers performs a shallow copy, so this array can be sliced from safetly
|
|
71
66
|
const peers = this.libp2p.getPeers();
|
|
67
|
+
const { peer } = this.getPeerFromList(peers, excluding);
|
|
68
|
+
return peer;
|
|
69
|
+
}
|
|
72
70
|
|
|
71
|
+
/**
|
|
72
|
+
* Samples a peer from a list of peers, excluding those that have active (reqresp) connections or are in the exclusion list
|
|
73
|
+
*
|
|
74
|
+
* @param peers - The list of peers to sample from
|
|
75
|
+
* @param excluding - The peers to exclude from the sampling
|
|
76
|
+
* @returns - A peer from the list, or undefined if no peers are available,
|
|
77
|
+
* - a boolean indicating if the peer has active connections, and
|
|
78
|
+
* - all sampled peers - to enable optional resampling
|
|
79
|
+
*
|
|
80
|
+
* @dev The provided list peers, should be mutated by this function. This allows batch sampling
|
|
81
|
+
* to be performed without making extra copies of the list.
|
|
82
|
+
*/
|
|
83
|
+
getPeerFromList(
|
|
84
|
+
peers: PeerId[],
|
|
85
|
+
excluding?: Map<string, boolean>,
|
|
86
|
+
): {
|
|
87
|
+
peer: PeerId | undefined;
|
|
88
|
+
sampledPeers: PeerId[];
|
|
89
|
+
} {
|
|
73
90
|
if (peers.length === 0) {
|
|
74
|
-
return undefined;
|
|
91
|
+
return { peer: undefined, sampledPeers: [] };
|
|
75
92
|
}
|
|
76
93
|
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
(excluding?.get(peers[randomIndex]?.toString()) ?? false))
|
|
87
|
-
) {
|
|
94
|
+
const sampledPeers: PeerId[] = [];
|
|
95
|
+
// Try to find a peer that has no active connections and is not in the exclusion list
|
|
96
|
+
for (let attempts = 0; attempts < MAX_SAMPLE_ATTEMPTS && peers.length > 0; attempts++) {
|
|
97
|
+
const randomIndex = this.sampler.random(peers.length);
|
|
98
|
+
const peer = peers[randomIndex];
|
|
99
|
+
const hasActiveConnections = (this.activeConnectionsCount.get(peer.toString()) ?? 0) > 0;
|
|
100
|
+
const isExcluded = excluding?.get(peer.toString()) ?? false;
|
|
101
|
+
|
|
102
|
+
// Remove this peer from consideration
|
|
88
103
|
peers.splice(randomIndex, 1);
|
|
89
|
-
|
|
90
|
-
|
|
104
|
+
|
|
105
|
+
// If peer is suitable (no active connections and not excluded), return it
|
|
106
|
+
if (!hasActiveConnections && !isExcluded) {
|
|
107
|
+
this.logger.trace('Sampled peer', {
|
|
108
|
+
attempts,
|
|
109
|
+
peer,
|
|
110
|
+
});
|
|
111
|
+
return { peer, sampledPeers };
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
// Keep track of peers that have active reqresp channels, batch sampling will use these to resample
|
|
115
|
+
sampledPeers.push(peer);
|
|
91
116
|
}
|
|
92
117
|
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
118
|
+
// If we've exhausted our attempts or peers list is empty, return the last peer if available
|
|
119
|
+
const lastPeer = peers.length > 0 ? peers[this.sampler.random(peers.length)] : undefined;
|
|
120
|
+
|
|
121
|
+
this.logger.trace('Sampled peer', {
|
|
122
|
+
attempts: MAX_SAMPLE_ATTEMPTS,
|
|
123
|
+
peer: lastPeer?.toString(),
|
|
96
124
|
});
|
|
97
|
-
return
|
|
125
|
+
return { peer: lastPeer, sampledPeers };
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
/*
|
|
129
|
+
* Returns all peers sorted by connection count ascending,
|
|
130
|
+
* meaning that the peers with the least number of active connections are earlier in an array
|
|
131
|
+
*
|
|
132
|
+
* @param: excluding - peers to exclude
|
|
133
|
+
* @return: list of peer ids
|
|
134
|
+
* */
|
|
135
|
+
public getPeerListSortedByConnectionCountAsc(excluding?: Set<string>): PeerId[] {
|
|
136
|
+
return this.libp2p
|
|
137
|
+
.getPeers()
|
|
138
|
+
.filter(id => !excluding?.has(id.toString()))
|
|
139
|
+
.map(id => ({ id, count: this.activeConnectionsCount.get(id.toString()) ?? 0 }))
|
|
140
|
+
.sort((a, b) => a.count - b.count)
|
|
141
|
+
.map(p => p.id);
|
|
98
142
|
}
|
|
99
143
|
|
|
100
144
|
/**
|
|
101
145
|
* Samples a batch of unique peers from the libp2p node, prioritizing peers without active connections
|
|
102
146
|
*
|
|
103
147
|
* @param numberToSample - The number of peers to sample
|
|
148
|
+
* @param excluding - The peers to exclude from the sampling
|
|
104
149
|
* @returns Array of unique sampled peers, prioritizing those without active connections
|
|
105
150
|
*/
|
|
106
|
-
samplePeersBatch(numberToSample: number): PeerId[] {
|
|
151
|
+
samplePeersBatch(numberToSample: number, excluding?: Map<string, boolean>): PeerId[] {
|
|
107
152
|
const peers = this.libp2p.getPeers();
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
}
|
|
118
|
-
|
|
153
|
+
this.logger.debug('Sampling peers batch', { numberToSample, peers });
|
|
154
|
+
|
|
155
|
+
// Only sample as many peers as we have available
|
|
156
|
+
numberToSample = Math.min(numberToSample, peers.length);
|
|
157
|
+
|
|
158
|
+
const batch: PeerId[] = [];
|
|
159
|
+
// eslint-disable-next-line aztec-custom/no-non-primitive-in-collections
|
|
160
|
+
const withActiveConnections: Set<PeerId> = new Set();
|
|
161
|
+
for (let i = 0; i < numberToSample; i++) {
|
|
162
|
+
const { peer, sampledPeers } = this.getPeerFromList(peers, excluding);
|
|
163
|
+
if (peer) {
|
|
164
|
+
batch.push(peer);
|
|
165
|
+
}
|
|
166
|
+
if (sampledPeers.length > 0) {
|
|
167
|
+
sampledPeers.forEach(peer => withActiveConnections.add(peer));
|
|
119
168
|
}
|
|
120
169
|
}
|
|
170
|
+
const lengthWithoutConnections = batch.length;
|
|
121
171
|
|
|
122
172
|
// If we still need more peers, sample from those with connections
|
|
123
|
-
while (
|
|
124
|
-
const randomIndex = this.sampler.random(
|
|
125
|
-
|
|
126
|
-
|
|
173
|
+
while (batch.length < numberToSample && withActiveConnections.size > 0) {
|
|
174
|
+
const randomIndex = this.sampler.random(withActiveConnections.size);
|
|
175
|
+
|
|
176
|
+
const peer = Array.from(withActiveConnections)[randomIndex];
|
|
177
|
+
withActiveConnections.delete(peer);
|
|
178
|
+
batch.push(peer);
|
|
127
179
|
}
|
|
128
180
|
|
|
129
|
-
this.logger.trace(
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
181
|
+
this.logger.trace('Batch sampled peers', {
|
|
182
|
+
length: batch.length,
|
|
183
|
+
peers: batch,
|
|
184
|
+
withoutConnections: lengthWithoutConnections,
|
|
185
|
+
withConnections: numberToSample - lengthWithoutConnections,
|
|
133
186
|
});
|
|
134
187
|
|
|
135
|
-
return
|
|
188
|
+
return batch;
|
|
136
189
|
}
|
|
137
190
|
|
|
138
191
|
// Set of passthrough functions to keep track of active connections
|
|
@@ -142,22 +195,27 @@ export class ConnectionSampler {
|
|
|
142
195
|
*
|
|
143
196
|
* @param peerId - The peer id
|
|
144
197
|
* @param protocol - The protocol
|
|
198
|
+
* @param timeout - Abort connection if it takes too long
|
|
145
199
|
* @returns The stream
|
|
146
200
|
*/
|
|
147
|
-
async dialProtocol(peerId: PeerId, protocol: string): Promise<Stream> {
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
201
|
+
async dialProtocol(peerId: PeerId, protocol: string, timeout?: number): Promise<Stream> {
|
|
202
|
+
const stream = await this.libp2p.dialProtocol(peerId, protocol, {
|
|
203
|
+
signal: AbortSignal.any(
|
|
204
|
+
timeout ? [this.abortOnStop.signal, AbortSignal.timeout(timeout!)] : [this.abortOnStop.signal],
|
|
205
|
+
),
|
|
206
|
+
negotiateFully: !this.opts.p2pOptimisticNegotiation,
|
|
207
|
+
});
|
|
208
|
+
stream.metadata.peerId = peerId;
|
|
209
|
+
this.streams.add(stream);
|
|
153
210
|
|
|
154
|
-
|
|
155
|
-
const updatedActiveConnectionsCount = (this.activeConnectionsCount.get(
|
|
156
|
-
this.activeConnectionsCount.set(
|
|
211
|
+
const peerIdString = peerId.toString();
|
|
212
|
+
const updatedActiveConnectionsCount = (this.activeConnectionsCount.get(peerIdString) ?? 0) + 1;
|
|
213
|
+
this.activeConnectionsCount.set(peerIdString, updatedActiveConnectionsCount);
|
|
157
214
|
|
|
158
|
-
this.logger.trace(
|
|
215
|
+
this.logger.trace('Dialed protocol', {
|
|
159
216
|
streamId: stream.id,
|
|
160
|
-
|
|
217
|
+
protocol,
|
|
218
|
+
peerId: peerIdString,
|
|
161
219
|
activeConnectionsCount: updatedActiveConnectionsCount,
|
|
162
220
|
});
|
|
163
221
|
return stream;
|
|
@@ -165,34 +223,39 @@ export class ConnectionSampler {
|
|
|
165
223
|
|
|
166
224
|
/**
|
|
167
225
|
* Closes a stream and updates the active connections count
|
|
168
|
-
*
|
|
169
|
-
* @param streamId - The stream id
|
|
170
226
|
*/
|
|
171
|
-
async close(
|
|
172
|
-
|
|
173
|
-
const streamAndPeerId = this.streams.get(streamId);
|
|
174
|
-
if (!streamAndPeerId) {
|
|
175
|
-
this.logger.warn(`Stream ${streamId} not found`);
|
|
176
|
-
return;
|
|
177
|
-
}
|
|
227
|
+
async close(stream: Stream): Promise<void> {
|
|
228
|
+
let peerId: PeerId | undefined = undefined;
|
|
178
229
|
|
|
179
|
-
|
|
230
|
+
try {
|
|
231
|
+
peerId = stream.metadata.peerId;
|
|
232
|
+
let updatedActiveConnectionsCount = undefined;
|
|
180
233
|
|
|
181
|
-
|
|
182
|
-
|
|
234
|
+
if (!peerId) {
|
|
235
|
+
this.logger.warn(`Stream ${stream.id} does not have a peerId set`);
|
|
236
|
+
} else {
|
|
237
|
+
updatedActiveConnectionsCount = (this.activeConnectionsCount.get(peerId.toString()) ?? 1) - 1;
|
|
238
|
+
this.activeConnectionsCount.set(peerId.toString(), updatedActiveConnectionsCount);
|
|
239
|
+
}
|
|
183
240
|
|
|
184
|
-
this.logger.trace(
|
|
185
|
-
streamId,
|
|
186
|
-
peerId: peerId
|
|
241
|
+
this.logger.trace('Closing connection', {
|
|
242
|
+
streamId: stream.id,
|
|
243
|
+
peerId: peerId?.toString(),
|
|
187
244
|
protocol: stream.protocol,
|
|
188
245
|
activeConnectionsCount: updatedActiveConnectionsCount,
|
|
189
246
|
});
|
|
190
247
|
|
|
191
|
-
|
|
248
|
+
if (!this.streams.has(stream)) {
|
|
249
|
+
this.logger.debug(`Stream ${stream.id} is not in the active streams set`);
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
await stream.close();
|
|
192
253
|
} catch (error) {
|
|
193
|
-
this.logger.error(`Failed to close connection to peer with stream id ${
|
|
254
|
+
this.logger.error(`Failed to close connection to peer ${peerId ?? 'unknown'} with stream id ${stream.id}`, error);
|
|
255
|
+
// graceful close failed, abort the stream
|
|
256
|
+
stream.abort(new AbortError('Failed to close stream gracefully'));
|
|
194
257
|
} finally {
|
|
195
|
-
this.streams.delete(
|
|
258
|
+
this.streams.delete(stream);
|
|
196
259
|
}
|
|
197
260
|
}
|
|
198
261
|
|
|
@@ -202,15 +265,23 @@ export class ConnectionSampler {
|
|
|
202
265
|
private async cleanupStaleConnections() {
|
|
203
266
|
// Look for streams without anything in the activeConnectionsCount
|
|
204
267
|
// If we find anything, close the stream
|
|
205
|
-
for (const
|
|
268
|
+
for (const stream of this.streams.values()) {
|
|
206
269
|
try {
|
|
207
270
|
// Check if we have lost track of accounting
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
this.logger.
|
|
271
|
+
const peerId: PeerId = stream.metadata.peerId;
|
|
272
|
+
if (!peerId) {
|
|
273
|
+
this.logger.warn(`Stream ${stream.id} does not have a peerId set`);
|
|
274
|
+
} else if (this.activeConnectionsCount.get(peerId.toString()) === 0) {
|
|
275
|
+
await this.close(stream);
|
|
276
|
+
this.logger.debug('Cleaned up stale connection', { streamId: stream.id, peerId: peerId.toString() });
|
|
211
277
|
}
|
|
212
278
|
} catch (error) {
|
|
213
|
-
this.logger.error(
|
|
279
|
+
this.logger.error(
|
|
280
|
+
`Error cleaning up stale connection to peer ${stream.metadata.peerId?.toString() ?? 'unknown'} stream ${
|
|
281
|
+
stream.id
|
|
282
|
+
}`,
|
|
283
|
+
{ error },
|
|
284
|
+
);
|
|
214
285
|
}
|
|
215
286
|
}
|
|
216
287
|
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Constants for P2P message deserialization bounds checking.
|
|
3
|
+
* These constants define maximum allowed sizes during deserialization
|
|
4
|
+
* to prevent DoS attacks via maliciously crafted messages.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
/** Max transactions per block for deserialization validation (~300x default of 32) */
|
|
8
|
+
export { MAX_TXS_PER_BLOCK } from '@aztec/stdlib/deserialization';
|
|
9
|
+
|
|
10
|
+
/** Max version string length (e.g., "1.0.0-alpha.123") */
|
|
11
|
+
export const MAX_VERSION_STRING_LENGTH = 64;
|
|
12
|
+
|
|
13
|
+
/** Max block hash string length (hex: 0x + 64 chars, with generous headroom) */
|
|
14
|
+
export const MAX_BLOCK_HASH_STRING_LENGTH = 128;
|