@aztec/p2p 0.0.0-test.1 → 0.0.1-commit.0208eb9
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 +63 -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 +77 -193
- package/dest/client/p2p_client.d.ts.map +1 -1
- package/dest/client/p2p_client.js +769 -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 +160 -125
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +184 -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 +6 -1
- package/dest/services/index.d.ts.map +1 -1
- package/dest/services/index.js +5 -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_file_store/config.d.ts +18 -0
- package/dest/services/tx_file_store/config.d.ts.map +1 -0
- package/dest/services/tx_file_store/config.js +26 -0
- package/dest/services/tx_file_store/index.d.ts +4 -0
- package/dest/services/tx_file_store/index.d.ts.map +1 -0
- package/dest/services/tx_file_store/index.js +3 -0
- package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
- package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
- package/dest/services/tx_file_store/instrumentation.js +29 -0
- package/dest/services/tx_file_store/tx_file_store.d.ts +47 -0
- package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
- package/dest/services/tx_file_store/tx_file_store.js +149 -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 +139 -53
- package/src/client/index.ts +1 -0
- package/src/client/interface.ts +213 -0
- package/src/client/p2p_client.ts +481 -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 +311 -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 +5 -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_file_store/config.ts +43 -0
- package/src/services/tx_file_store/index.ts +3 -0
- package/src/services/tx_file_store/instrumentation.ts +36 -0
- package/src/services/tx_file_store/tx_file_store.ts +173 -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
|
@@ -1,113 +1,509 @@
|
|
|
1
|
-
function
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
function applyDecs2203RFactory() {
|
|
2
|
+
function createAddInitializerMethod(initializers, decoratorFinishedRef) {
|
|
3
|
+
return function addInitializer(initializer) {
|
|
4
|
+
assertNotFinished(decoratorFinishedRef, "addInitializer");
|
|
5
|
+
assertCallable(initializer, "An initializer");
|
|
6
|
+
initializers.push(initializer);
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
function memberDec(dec, name, desc, initializers, kind, isStatic, isPrivate, metadata, value) {
|
|
10
|
+
var kindStr;
|
|
11
|
+
switch(kind){
|
|
12
|
+
case 1:
|
|
13
|
+
kindStr = "accessor";
|
|
14
|
+
break;
|
|
15
|
+
case 2:
|
|
16
|
+
kindStr = "method";
|
|
17
|
+
break;
|
|
18
|
+
case 3:
|
|
19
|
+
kindStr = "getter";
|
|
20
|
+
break;
|
|
21
|
+
case 4:
|
|
22
|
+
kindStr = "setter";
|
|
23
|
+
break;
|
|
24
|
+
default:
|
|
25
|
+
kindStr = "field";
|
|
26
|
+
}
|
|
27
|
+
var ctx = {
|
|
28
|
+
kind: kindStr,
|
|
29
|
+
name: isPrivate ? "#" + name : name,
|
|
30
|
+
static: isStatic,
|
|
31
|
+
private: isPrivate,
|
|
32
|
+
metadata: metadata
|
|
33
|
+
};
|
|
34
|
+
var decoratorFinishedRef = {
|
|
35
|
+
v: false
|
|
36
|
+
};
|
|
37
|
+
ctx.addInitializer = createAddInitializerMethod(initializers, decoratorFinishedRef);
|
|
38
|
+
var get, set;
|
|
39
|
+
if (kind === 0) {
|
|
40
|
+
if (isPrivate) {
|
|
41
|
+
get = desc.get;
|
|
42
|
+
set = desc.set;
|
|
43
|
+
} else {
|
|
44
|
+
get = function() {
|
|
45
|
+
return this[name];
|
|
46
|
+
};
|
|
47
|
+
set = function(v) {
|
|
48
|
+
this[name] = v;
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
} else if (kind === 2) {
|
|
52
|
+
get = function() {
|
|
53
|
+
return desc.value;
|
|
54
|
+
};
|
|
55
|
+
} else {
|
|
56
|
+
if (kind === 1 || kind === 3) {
|
|
57
|
+
get = function() {
|
|
58
|
+
return desc.get.call(this);
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
if (kind === 1 || kind === 4) {
|
|
62
|
+
set = function(v) {
|
|
63
|
+
desc.set.call(this, v);
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
ctx.access = get && set ? {
|
|
68
|
+
get: get,
|
|
69
|
+
set: set
|
|
70
|
+
} : get ? {
|
|
71
|
+
get: get
|
|
72
|
+
} : {
|
|
73
|
+
set: set
|
|
74
|
+
};
|
|
75
|
+
try {
|
|
76
|
+
return dec(value, ctx);
|
|
77
|
+
} finally{
|
|
78
|
+
decoratorFinishedRef.v = true;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
function assertNotFinished(decoratorFinishedRef, fnName) {
|
|
82
|
+
if (decoratorFinishedRef.v) {
|
|
83
|
+
throw new Error("attempted to call " + fnName + " after decoration was finished");
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
function assertCallable(fn, hint) {
|
|
87
|
+
if (typeof fn !== "function") {
|
|
88
|
+
throw new TypeError(hint + " must be a function");
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
function assertValidReturnValue(kind, value) {
|
|
92
|
+
var type = typeof value;
|
|
93
|
+
if (kind === 1) {
|
|
94
|
+
if (type !== "object" || value === null) {
|
|
95
|
+
throw new TypeError("accessor decorators must return an object with get, set, or init properties or void 0");
|
|
96
|
+
}
|
|
97
|
+
if (value.get !== undefined) {
|
|
98
|
+
assertCallable(value.get, "accessor.get");
|
|
99
|
+
}
|
|
100
|
+
if (value.set !== undefined) {
|
|
101
|
+
assertCallable(value.set, "accessor.set");
|
|
102
|
+
}
|
|
103
|
+
if (value.init !== undefined) {
|
|
104
|
+
assertCallable(value.init, "accessor.init");
|
|
105
|
+
}
|
|
106
|
+
} else if (type !== "function") {
|
|
107
|
+
var hint;
|
|
108
|
+
if (kind === 0) {
|
|
109
|
+
hint = "field";
|
|
110
|
+
} else if (kind === 10) {
|
|
111
|
+
hint = "class";
|
|
112
|
+
} else {
|
|
113
|
+
hint = "method";
|
|
114
|
+
}
|
|
115
|
+
throw new TypeError(hint + " decorators must return a function or void 0");
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
function applyMemberDec(ret, base, decInfo, name, kind, isStatic, isPrivate, initializers, metadata) {
|
|
119
|
+
var decs = decInfo[0];
|
|
120
|
+
var desc, init, value;
|
|
121
|
+
if (isPrivate) {
|
|
122
|
+
if (kind === 0 || kind === 1) {
|
|
123
|
+
desc = {
|
|
124
|
+
get: decInfo[3],
|
|
125
|
+
set: decInfo[4]
|
|
126
|
+
};
|
|
127
|
+
} else if (kind === 3) {
|
|
128
|
+
desc = {
|
|
129
|
+
get: decInfo[3]
|
|
130
|
+
};
|
|
131
|
+
} else if (kind === 4) {
|
|
132
|
+
desc = {
|
|
133
|
+
set: decInfo[3]
|
|
134
|
+
};
|
|
135
|
+
} else {
|
|
136
|
+
desc = {
|
|
137
|
+
value: decInfo[3]
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
} else if (kind !== 0) {
|
|
141
|
+
desc = Object.getOwnPropertyDescriptor(base, name);
|
|
142
|
+
}
|
|
143
|
+
if (kind === 1) {
|
|
144
|
+
value = {
|
|
145
|
+
get: desc.get,
|
|
146
|
+
set: desc.set
|
|
147
|
+
};
|
|
148
|
+
} else if (kind === 2) {
|
|
149
|
+
value = desc.value;
|
|
150
|
+
} else if (kind === 3) {
|
|
151
|
+
value = desc.get;
|
|
152
|
+
} else if (kind === 4) {
|
|
153
|
+
value = desc.set;
|
|
154
|
+
}
|
|
155
|
+
var newValue, get, set;
|
|
156
|
+
if (typeof decs === "function") {
|
|
157
|
+
newValue = memberDec(decs, name, desc, initializers, kind, isStatic, isPrivate, metadata, value);
|
|
158
|
+
if (newValue !== void 0) {
|
|
159
|
+
assertValidReturnValue(kind, newValue);
|
|
160
|
+
if (kind === 0) {
|
|
161
|
+
init = newValue;
|
|
162
|
+
} else if (kind === 1) {
|
|
163
|
+
init = newValue.init;
|
|
164
|
+
get = newValue.get || value.get;
|
|
165
|
+
set = newValue.set || value.set;
|
|
166
|
+
value = {
|
|
167
|
+
get: get,
|
|
168
|
+
set: set
|
|
169
|
+
};
|
|
170
|
+
} else {
|
|
171
|
+
value = newValue;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
} else {
|
|
175
|
+
for(var i = decs.length - 1; i >= 0; i--){
|
|
176
|
+
var dec = decs[i];
|
|
177
|
+
newValue = memberDec(dec, name, desc, initializers, kind, isStatic, isPrivate, metadata, value);
|
|
178
|
+
if (newValue !== void 0) {
|
|
179
|
+
assertValidReturnValue(kind, newValue);
|
|
180
|
+
var newInit;
|
|
181
|
+
if (kind === 0) {
|
|
182
|
+
newInit = newValue;
|
|
183
|
+
} else if (kind === 1) {
|
|
184
|
+
newInit = newValue.init;
|
|
185
|
+
get = newValue.get || value.get;
|
|
186
|
+
set = newValue.set || value.set;
|
|
187
|
+
value = {
|
|
188
|
+
get: get,
|
|
189
|
+
set: set
|
|
190
|
+
};
|
|
191
|
+
} else {
|
|
192
|
+
value = newValue;
|
|
193
|
+
}
|
|
194
|
+
if (newInit !== void 0) {
|
|
195
|
+
if (init === void 0) {
|
|
196
|
+
init = newInit;
|
|
197
|
+
} else if (typeof init === "function") {
|
|
198
|
+
init = [
|
|
199
|
+
init,
|
|
200
|
+
newInit
|
|
201
|
+
];
|
|
202
|
+
} else {
|
|
203
|
+
init.push(newInit);
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
if (kind === 0 || kind === 1) {
|
|
210
|
+
if (init === void 0) {
|
|
211
|
+
init = function(instance, init) {
|
|
212
|
+
return init;
|
|
213
|
+
};
|
|
214
|
+
} else if (typeof init !== "function") {
|
|
215
|
+
var ownInitializers = init;
|
|
216
|
+
init = function(instance, init) {
|
|
217
|
+
var value = init;
|
|
218
|
+
for(var i = 0; i < ownInitializers.length; i++){
|
|
219
|
+
value = ownInitializers[i].call(instance, value);
|
|
220
|
+
}
|
|
221
|
+
return value;
|
|
222
|
+
};
|
|
223
|
+
} else {
|
|
224
|
+
var originalInitializer = init;
|
|
225
|
+
init = function(instance, init) {
|
|
226
|
+
return originalInitializer.call(instance, init);
|
|
227
|
+
};
|
|
228
|
+
}
|
|
229
|
+
ret.push(init);
|
|
230
|
+
}
|
|
231
|
+
if (kind !== 0) {
|
|
232
|
+
if (kind === 1) {
|
|
233
|
+
desc.get = value.get;
|
|
234
|
+
desc.set = value.set;
|
|
235
|
+
} else if (kind === 2) {
|
|
236
|
+
desc.value = value;
|
|
237
|
+
} else if (kind === 3) {
|
|
238
|
+
desc.get = value;
|
|
239
|
+
} else if (kind === 4) {
|
|
240
|
+
desc.set = value;
|
|
241
|
+
}
|
|
242
|
+
if (isPrivate) {
|
|
243
|
+
if (kind === 1) {
|
|
244
|
+
ret.push(function(instance, args) {
|
|
245
|
+
return value.get.call(instance, args);
|
|
246
|
+
});
|
|
247
|
+
ret.push(function(instance, args) {
|
|
248
|
+
return value.set.call(instance, args);
|
|
249
|
+
});
|
|
250
|
+
} else if (kind === 2) {
|
|
251
|
+
ret.push(value);
|
|
252
|
+
} else {
|
|
253
|
+
ret.push(function(instance, args) {
|
|
254
|
+
return value.call(instance, args);
|
|
255
|
+
});
|
|
256
|
+
}
|
|
257
|
+
} else {
|
|
258
|
+
Object.defineProperty(base, name, desc);
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
function applyMemberDecs(Class, decInfos, metadata) {
|
|
263
|
+
var ret = [];
|
|
264
|
+
var protoInitializers;
|
|
265
|
+
var staticInitializers;
|
|
266
|
+
var existingProtoNonFields = new Map();
|
|
267
|
+
var existingStaticNonFields = new Map();
|
|
268
|
+
for(var i = 0; i < decInfos.length; i++){
|
|
269
|
+
var decInfo = decInfos[i];
|
|
270
|
+
if (!Array.isArray(decInfo)) continue;
|
|
271
|
+
var kind = decInfo[1];
|
|
272
|
+
var name = decInfo[2];
|
|
273
|
+
var isPrivate = decInfo.length > 3;
|
|
274
|
+
var isStatic = kind >= 5;
|
|
275
|
+
var base;
|
|
276
|
+
var initializers;
|
|
277
|
+
if (isStatic) {
|
|
278
|
+
base = Class;
|
|
279
|
+
kind = kind - 5;
|
|
280
|
+
staticInitializers = staticInitializers || [];
|
|
281
|
+
initializers = staticInitializers;
|
|
282
|
+
} else {
|
|
283
|
+
base = Class.prototype;
|
|
284
|
+
protoInitializers = protoInitializers || [];
|
|
285
|
+
initializers = protoInitializers;
|
|
286
|
+
}
|
|
287
|
+
if (kind !== 0 && !isPrivate) {
|
|
288
|
+
var existingNonFields = isStatic ? existingStaticNonFields : existingProtoNonFields;
|
|
289
|
+
var existingKind = existingNonFields.get(name) || 0;
|
|
290
|
+
if (existingKind === true || existingKind === 3 && kind !== 4 || existingKind === 4 && kind !== 3) {
|
|
291
|
+
throw new Error("Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: " + name);
|
|
292
|
+
} else if (!existingKind && kind > 2) {
|
|
293
|
+
existingNonFields.set(name, kind);
|
|
294
|
+
} else {
|
|
295
|
+
existingNonFields.set(name, true);
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
applyMemberDec(ret, base, decInfo, name, kind, isStatic, isPrivate, initializers, metadata);
|
|
299
|
+
}
|
|
300
|
+
pushInitializers(ret, protoInitializers);
|
|
301
|
+
pushInitializers(ret, staticInitializers);
|
|
302
|
+
return ret;
|
|
303
|
+
}
|
|
304
|
+
function pushInitializers(ret, initializers) {
|
|
305
|
+
if (initializers) {
|
|
306
|
+
ret.push(function(instance) {
|
|
307
|
+
for(var i = 0; i < initializers.length; i++){
|
|
308
|
+
initializers[i].call(instance);
|
|
309
|
+
}
|
|
310
|
+
return instance;
|
|
311
|
+
});
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
function applyClassDecs(targetClass, classDecs, metadata) {
|
|
315
|
+
if (classDecs.length > 0) {
|
|
316
|
+
var initializers = [];
|
|
317
|
+
var newClass = targetClass;
|
|
318
|
+
var name = targetClass.name;
|
|
319
|
+
for(var i = classDecs.length - 1; i >= 0; i--){
|
|
320
|
+
var decoratorFinishedRef = {
|
|
321
|
+
v: false
|
|
322
|
+
};
|
|
323
|
+
try {
|
|
324
|
+
var nextNewClass = classDecs[i](newClass, {
|
|
325
|
+
kind: "class",
|
|
326
|
+
name: name,
|
|
327
|
+
addInitializer: createAddInitializerMethod(initializers, decoratorFinishedRef),
|
|
328
|
+
metadata
|
|
329
|
+
});
|
|
330
|
+
} finally{
|
|
331
|
+
decoratorFinishedRef.v = true;
|
|
332
|
+
}
|
|
333
|
+
if (nextNewClass !== undefined) {
|
|
334
|
+
assertValidReturnValue(10, nextNewClass);
|
|
335
|
+
newClass = nextNewClass;
|
|
336
|
+
}
|
|
337
|
+
}
|
|
338
|
+
return [
|
|
339
|
+
defineMetadata(newClass, metadata),
|
|
340
|
+
function() {
|
|
341
|
+
for(var i = 0; i < initializers.length; i++){
|
|
342
|
+
initializers[i].call(newClass);
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
];
|
|
346
|
+
}
|
|
347
|
+
}
|
|
348
|
+
function defineMetadata(Class, metadata) {
|
|
349
|
+
return Object.defineProperty(Class, Symbol.metadata || Symbol.for("Symbol.metadata"), {
|
|
350
|
+
configurable: true,
|
|
351
|
+
enumerable: true,
|
|
352
|
+
value: metadata
|
|
353
|
+
});
|
|
354
|
+
}
|
|
355
|
+
return function applyDecs2203R(targetClass, memberDecs, classDecs, parentClass) {
|
|
356
|
+
if (parentClass !== void 0) {
|
|
357
|
+
var parentMetadata = parentClass[Symbol.metadata || Symbol.for("Symbol.metadata")];
|
|
358
|
+
}
|
|
359
|
+
var metadata = Object.create(parentMetadata === void 0 ? null : parentMetadata);
|
|
360
|
+
var e = applyMemberDecs(targetClass, memberDecs, metadata);
|
|
361
|
+
if (!classDecs.length) defineMetadata(targetClass, metadata);
|
|
362
|
+
return {
|
|
363
|
+
e: e,
|
|
364
|
+
get c () {
|
|
365
|
+
return applyClassDecs(targetClass, classDecs, metadata);
|
|
366
|
+
}
|
|
367
|
+
};
|
|
368
|
+
};
|
|
369
|
+
}
|
|
370
|
+
function _apply_decs_2203_r(targetClass, memberDecs, classDecs, parentClass) {
|
|
371
|
+
return (_apply_decs_2203_r = applyDecs2203RFactory())(targetClass, memberDecs, classDecs, parentClass);
|
|
6
372
|
}
|
|
7
|
-
|
|
373
|
+
var _dec, _dec1, _initProto;
|
|
374
|
+
import { GENESIS_BLOCK_HEADER_HASH } from '@aztec/constants';
|
|
375
|
+
import { BlockNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
8
376
|
import { createLogger } from '@aztec/foundation/log';
|
|
9
|
-
import {
|
|
377
|
+
import { DateProvider } from '@aztec/foundation/timer';
|
|
378
|
+
import { L2TipsKVStore } from '@aztec/kv-store/stores';
|
|
379
|
+
import { L2BlockStream } from '@aztec/stdlib/block';
|
|
380
|
+
import { getTimestampForSlot } from '@aztec/stdlib/epoch-helpers';
|
|
381
|
+
import { tryStop } from '@aztec/stdlib/interfaces/server';
|
|
382
|
+
import { Attributes, WithTracer, getTelemetryClient, trackSpan } from '@aztec/telemetry-client';
|
|
10
383
|
import { getP2PDefaultConfig } from '../config.js';
|
|
11
384
|
import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
385
|
+
import { chunkTxHashesRequest } from '../services/reqresp/protocols/tx.js';
|
|
386
|
+
import { TxProvider } from '../services/tx_provider.js';
|
|
387
|
+
import { P2PClientState } from './interface.js';
|
|
388
|
+
_dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
|
|
389
|
+
[Attributes.SLOT_NUMBER]: proposal.slotNumber,
|
|
390
|
+
[Attributes.BLOCK_ARCHIVE]: proposal.archive.toString(),
|
|
391
|
+
[Attributes.P2P_ID]: (await proposal.p2pMessageLoggingIdentifier()).toString()
|
|
392
|
+
})), _dec1 = trackSpan('p2pClient.broadcastCheckpointProposal', async (proposal)=>({
|
|
393
|
+
[Attributes.SLOT_NUMBER]: proposal.slotNumber,
|
|
394
|
+
[Attributes.BLOCK_ARCHIVE]: proposal.archive.toString(),
|
|
395
|
+
[Attributes.P2P_ID]: (await proposal.p2pMessageLoggingIdentifier()).toString()
|
|
396
|
+
}));
|
|
21
397
|
/**
|
|
22
398
|
* The P2P client implementation.
|
|
23
399
|
*/ export class P2PClient extends WithTracer {
|
|
400
|
+
store;
|
|
24
401
|
l2BlockSource;
|
|
25
402
|
p2pService;
|
|
403
|
+
txCollection;
|
|
404
|
+
txFileStore;
|
|
405
|
+
_dateProvider;
|
|
406
|
+
telemetry;
|
|
26
407
|
log;
|
|
408
|
+
static{
|
|
409
|
+
({ e: [_initProto] } = _apply_decs_2203_r(this, [
|
|
410
|
+
[
|
|
411
|
+
_dec,
|
|
412
|
+
2,
|
|
413
|
+
"broadcastProposal"
|
|
414
|
+
],
|
|
415
|
+
[
|
|
416
|
+
_dec1,
|
|
417
|
+
2,
|
|
418
|
+
"broadcastCheckpointProposal"
|
|
419
|
+
]
|
|
420
|
+
], []));
|
|
421
|
+
}
|
|
27
422
|
/** The JS promise that will be running to keep the client's data in sync. Can be interrupted if the client is stopped. */ runningPromise;
|
|
28
423
|
currentState;
|
|
29
424
|
syncPromise;
|
|
30
425
|
syncResolve;
|
|
31
426
|
latestBlockNumberAtStart;
|
|
32
427
|
provenBlockNumberAtStart;
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
428
|
+
finalizedBlockNumberAtStart;
|
|
429
|
+
l2Tips;
|
|
430
|
+
synchedLatestSlot;
|
|
36
431
|
txPool;
|
|
37
432
|
attestationPool;
|
|
38
|
-
|
|
39
|
-
/** How many slots to keep proven txs for. */ keepProvenTxsFor;
|
|
433
|
+
config;
|
|
40
434
|
blockStream;
|
|
435
|
+
txProvider;
|
|
436
|
+
validatorAddresses;
|
|
41
437
|
/**
|
|
42
438
|
* In-memory P2P client constructor.
|
|
43
439
|
* @param store - The client's instance of the KV store.
|
|
44
440
|
* @param l2BlockSource - P2P client's source for fetching existing blocks.
|
|
45
441
|
* @param txPool - The client's instance of a transaction pool. Defaults to in-memory implementation.
|
|
46
442
|
* @param p2pService - The concrete instance of p2p networking to use.
|
|
47
|
-
* @param keepProvenTxsFor - How many blocks have to pass after a block is proven before its txs are deleted (zero to delete immediately once proven).
|
|
48
443
|
* @param log - A logger.
|
|
49
|
-
*/ constructor(_clientType, store, l2BlockSource, mempools, p2pService, config = {}, telemetry = getTelemetryClient(), log = createLogger('p2p')){
|
|
50
|
-
super(telemetry, 'P2PClient'), this.l2BlockSource = l2BlockSource, this.p2pService = p2pService, this.log = log, this.currentState =
|
|
51
|
-
|
|
444
|
+
*/ constructor(_clientType, store, l2BlockSource, mempools, p2pService, txCollection, txFileStore, config = {}, _dateProvider = new DateProvider(), telemetry = getTelemetryClient(), log = createLogger('p2p')){
|
|
445
|
+
super(telemetry, 'P2PClient'), this.store = store, this.l2BlockSource = l2BlockSource, this.p2pService = p2pService, this.txCollection = txCollection, this.txFileStore = txFileStore, this._dateProvider = _dateProvider, this.telemetry = telemetry, this.log = log, this.currentState = (_initProto(this), P2PClientState.IDLE), this.syncPromise = Promise.resolve(), this.syncResolve = undefined, this.latestBlockNumberAtStart = -1, this.provenBlockNumberAtStart = -1, this.finalizedBlockNumberAtStart = -1, this.validatorAddresses = [];
|
|
446
|
+
this.config = {
|
|
52
447
|
...getP2PDefaultConfig(),
|
|
53
448
|
...config
|
|
54
449
|
};
|
|
55
|
-
this.keepProvenTxsFor = keepProvenTxsInPoolFor;
|
|
56
|
-
this.keepAttestationsInPoolFor = keepAttestationsInPoolFor;
|
|
57
|
-
const tracer = telemetry.getTracer('P2PL2BlockStream');
|
|
58
|
-
const logger = createLogger('p2p:l2-block-stream');
|
|
59
|
-
this.blockStream = new TraceableL2BlockStream(l2BlockSource, this, this, tracer, 'P2PL2BlockStream', logger, {
|
|
60
|
-
batchSize: blockRequestBatchSize,
|
|
61
|
-
pollIntervalMS: blockCheckIntervalMS
|
|
62
|
-
});
|
|
63
|
-
this.synchedBlockHashes = store.openMap('p2p_pool_block_hashes');
|
|
64
|
-
this.synchedLatestBlockNumber = store.openSingleton('p2p_pool_last_l2_block');
|
|
65
|
-
this.synchedProvenBlockNumber = store.openSingleton('p2p_pool_last_proven_l2_block');
|
|
66
450
|
this.txPool = mempools.txPool;
|
|
67
451
|
this.attestationPool = mempools.attestationPool;
|
|
452
|
+
this.txProvider = new TxProvider(this.txCollection, this.txPool, this, this.log.createChild('tx-provider'), this.telemetry);
|
|
453
|
+
// Default to collecting all txs when we see a valid proposal
|
|
454
|
+
// This can be overridden by the validator client to validate, and it will call getTxsForBlockProposal on its own
|
|
455
|
+
// Note: Validators do NOT attest to individual blocks - attestations are only for checkpoint proposals.
|
|
456
|
+
// TODO(palla/txs): We should not trigger a request for txs on a proposal before fully validating it. We need to bring
|
|
457
|
+
// validator-client code into here so we can validate a proposal is reasonable.
|
|
458
|
+
this.registerBlockProposalHandler(async (block, sender)=>{
|
|
459
|
+
this.log.debug(`Received block proposal from ${sender.toString()}`);
|
|
460
|
+
// TODO(palla/txs): Need to subtract validatorReexecuteDeadlineMs from this deadline (see ValidatorClient.getReexecutionDeadline)
|
|
461
|
+
const constants = this.txCollection.getConstants();
|
|
462
|
+
const nextSlotTimestampSeconds = Number(getTimestampForSlot(SlotNumber(block.slotNumber + 1), constants));
|
|
463
|
+
const deadline = new Date(nextSlotTimestampSeconds * 1000);
|
|
464
|
+
const parentBlock = await this.l2BlockSource.getBlockHeaderByArchive(block.blockHeader.lastArchive.root);
|
|
465
|
+
if (!parentBlock) {
|
|
466
|
+
this.log.debug(`Cannot collect txs for proposal as parent block not found`);
|
|
467
|
+
return false;
|
|
468
|
+
}
|
|
469
|
+
const blockNumber = BlockNumber(parentBlock.getBlockNumber() + 1);
|
|
470
|
+
await this.txProvider.getTxsForBlockProposal(block, blockNumber, {
|
|
471
|
+
pinnedPeer: sender,
|
|
472
|
+
deadline
|
|
473
|
+
});
|
|
474
|
+
return true;
|
|
475
|
+
});
|
|
476
|
+
this.l2Tips = new L2TipsKVStore(store, 'p2p_client');
|
|
477
|
+
this.synchedLatestSlot = store.openSingleton('p2p_pool_last_l2_slot');
|
|
478
|
+
}
|
|
479
|
+
registerThisValidatorAddresses(addresses) {
|
|
480
|
+
this.validatorAddresses = [
|
|
481
|
+
...addresses
|
|
482
|
+
];
|
|
483
|
+
this.p2pService.registerThisValidatorAddresses(this.validatorAddresses);
|
|
484
|
+
}
|
|
485
|
+
clear() {
|
|
486
|
+
return this.store.clear();
|
|
68
487
|
}
|
|
69
488
|
isP2PClient() {
|
|
70
489
|
return true;
|
|
71
490
|
}
|
|
491
|
+
getTxProvider() {
|
|
492
|
+
return this.txProvider;
|
|
493
|
+
}
|
|
72
494
|
getPeers(includePending) {
|
|
73
495
|
return Promise.resolve(this.p2pService.getPeers(includePending));
|
|
74
496
|
}
|
|
75
497
|
getL2BlockHash(number) {
|
|
76
|
-
return this.
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
if (typeof latestBlockHash === 'undefined') {
|
|
86
|
-
this.log.warn(`Block hash for latest block ${latestBlockNumber} not found`);
|
|
87
|
-
throw new Error();
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
if (provenBlockNumber > 0) {
|
|
91
|
-
provenBlockHash = await this.synchedBlockHashes.getAsync(provenBlockNumber);
|
|
92
|
-
if (typeof provenBlockHash === 'undefined') {
|
|
93
|
-
this.log.warn(`Block hash for proven block ${provenBlockNumber} not found`);
|
|
94
|
-
throw new Error();
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
return Promise.resolve({
|
|
98
|
-
latest: {
|
|
99
|
-
hash: latestBlockHash,
|
|
100
|
-
number: latestBlockNumber
|
|
101
|
-
},
|
|
102
|
-
proven: {
|
|
103
|
-
hash: provenBlockHash,
|
|
104
|
-
number: provenBlockNumber
|
|
105
|
-
},
|
|
106
|
-
finalized: {
|
|
107
|
-
hash: provenBlockHash,
|
|
108
|
-
number: provenBlockNumber
|
|
109
|
-
}
|
|
110
|
-
});
|
|
498
|
+
return this.l2Tips.getL2BlockHash(number);
|
|
499
|
+
}
|
|
500
|
+
updateP2PConfig(config) {
|
|
501
|
+
this.txPool.updateConfig(config);
|
|
502
|
+
this.p2pService.updateConfig(config);
|
|
503
|
+
return Promise.resolve();
|
|
504
|
+
}
|
|
505
|
+
getL2Tips() {
|
|
506
|
+
return this.l2Tips.getL2Tips();
|
|
111
507
|
}
|
|
112
508
|
async handleBlockStreamEvent(event) {
|
|
113
509
|
this.log.debug(`Handling block stream event ${event.type}`);
|
|
@@ -116,16 +512,24 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
116
512
|
await this.handleLatestL2Blocks(event.blocks);
|
|
117
513
|
break;
|
|
118
514
|
case 'chain-finalized':
|
|
119
|
-
break;
|
|
120
|
-
case 'chain-proven':
|
|
121
515
|
{
|
|
122
|
-
const
|
|
123
|
-
const
|
|
124
|
-
|
|
516
|
+
const oldFinalizedBlockNum = await this.getSyncedFinalizedBlockNum();
|
|
517
|
+
const from = BlockNumber(oldFinalizedBlockNum + 1);
|
|
518
|
+
const limit = event.block.number - from + 1;
|
|
519
|
+
if (limit > 0) {
|
|
520
|
+
const oldBlocks = await this.l2BlockSource.getBlocks(from, limit);
|
|
521
|
+
await this.handleFinalizedL2Blocks(oldBlocks);
|
|
522
|
+
}
|
|
125
523
|
break;
|
|
126
524
|
}
|
|
525
|
+
case 'chain-proven':
|
|
526
|
+
this.txCollection.stopCollectingForBlocksUpTo(event.block.number);
|
|
527
|
+
break;
|
|
127
528
|
case 'chain-pruned':
|
|
128
|
-
|
|
529
|
+
this.txCollection.stopCollectingForBlocksAfter(event.block.number);
|
|
530
|
+
await this.handlePruneL2Blocks(event.block.number);
|
|
531
|
+
break;
|
|
532
|
+
case 'chain-checkpointed':
|
|
129
533
|
break;
|
|
130
534
|
default:
|
|
131
535
|
{
|
|
@@ -133,6 +537,9 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
133
537
|
break;
|
|
134
538
|
}
|
|
135
539
|
}
|
|
540
|
+
// Pass the event through to our l2 tips store
|
|
541
|
+
await this.l2Tips.handleBlockStreamEvent(event);
|
|
542
|
+
await this.startServiceIfSynched();
|
|
136
543
|
}
|
|
137
544
|
#assertIsReady() {
|
|
138
545
|
// this.log.info('Checking if p2p client is ready, current state: ', this.currentState);
|
|
@@ -144,107 +551,146 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
144
551
|
* Starts the P2P client.
|
|
145
552
|
* @returns An empty promise signalling the synching process.
|
|
146
553
|
*/ async start() {
|
|
147
|
-
if (this.currentState ===
|
|
554
|
+
if (this.currentState === P2PClientState.STOPPED) {
|
|
148
555
|
throw new Error('P2P client already stopped');
|
|
149
556
|
}
|
|
150
|
-
if (this.currentState !==
|
|
557
|
+
if (this.currentState !== P2PClientState.IDLE) {
|
|
151
558
|
return this.syncPromise;
|
|
152
559
|
}
|
|
153
560
|
// get the current latest block numbers
|
|
154
|
-
|
|
155
|
-
this.
|
|
561
|
+
const latestBlockNumbers = await this.l2BlockSource.getL2Tips();
|
|
562
|
+
this.latestBlockNumberAtStart = latestBlockNumbers.proposed.number;
|
|
563
|
+
this.provenBlockNumberAtStart = latestBlockNumbers.proven.block.number;
|
|
564
|
+
this.finalizedBlockNumberAtStart = latestBlockNumbers.finalized.block.number;
|
|
156
565
|
const syncedLatestBlock = await this.getSyncedLatestBlockNum() + 1;
|
|
157
566
|
const syncedProvenBlock = await this.getSyncedProvenBlockNum() + 1;
|
|
158
|
-
|
|
159
|
-
if (
|
|
160
|
-
|
|
567
|
+
const syncedFinalizedBlock = await this.getSyncedFinalizedBlockNum() + 1;
|
|
568
|
+
if (await this.txPool.isEmpty() && await this.attestationPool.isEmpty()) {
|
|
569
|
+
// if mempools are empty, we don't care about syncing prior blocks
|
|
570
|
+
this.initBlockStream(BlockNumber(this.latestBlockNumberAtStart));
|
|
571
|
+
this.setCurrentState(P2PClientState.RUNNING);
|
|
572
|
+
this.syncPromise = Promise.resolve();
|
|
573
|
+
await this.p2pService.start();
|
|
574
|
+
this.log.info(`Starting p2p client from block ${this.latestBlockNumberAtStart} with empty mempools`);
|
|
575
|
+
} else if (syncedLatestBlock <= this.latestBlockNumberAtStart || syncedProvenBlock <= this.provenBlockNumberAtStart || syncedFinalizedBlock <= this.finalizedBlockNumberAtStart) {
|
|
576
|
+
// if there are blocks to be retrieved, go to a synching state
|
|
577
|
+
// this gets resolved on `startServiceIfSynched`
|
|
578
|
+
this.initBlockStream();
|
|
579
|
+
this.setCurrentState(P2PClientState.SYNCHING);
|
|
161
580
|
this.syncPromise = new Promise((resolve)=>{
|
|
162
581
|
this.syncResolve = resolve;
|
|
163
582
|
});
|
|
164
|
-
this.log.
|
|
583
|
+
this.log.info(`Initiating p2p sync from ${syncedLatestBlock}`, {
|
|
584
|
+
syncedLatestBlock,
|
|
585
|
+
syncedProvenBlock,
|
|
586
|
+
syncedFinalizedBlock
|
|
587
|
+
});
|
|
165
588
|
} else {
|
|
166
589
|
// if no blocks to be retrieved, go straight to running
|
|
167
|
-
this.
|
|
590
|
+
this.initBlockStream();
|
|
591
|
+
this.setCurrentState(P2PClientState.RUNNING);
|
|
168
592
|
this.syncPromise = Promise.resolve();
|
|
169
593
|
await this.p2pService.start();
|
|
170
|
-
this.log.
|
|
594
|
+
this.log.info(`Starting P2P client synced to ${syncedLatestBlock}`, {
|
|
595
|
+
syncedLatestBlock,
|
|
596
|
+
syncedProvenBlock,
|
|
597
|
+
syncedFinalizedBlock
|
|
598
|
+
});
|
|
171
599
|
}
|
|
172
600
|
this.blockStream.start();
|
|
173
|
-
this.
|
|
601
|
+
await this.txCollection.start();
|
|
602
|
+
this.txFileStore?.start();
|
|
174
603
|
return this.syncPromise;
|
|
175
604
|
}
|
|
605
|
+
addReqRespSubProtocol(subProtocol, handler, validator) {
|
|
606
|
+
return this.p2pService.addReqRespSubProtocol(subProtocol, handler, validator);
|
|
607
|
+
}
|
|
608
|
+
initBlockStream(startingBlock) {
|
|
609
|
+
if (!this.blockStream) {
|
|
610
|
+
const { blockRequestBatchSize: batchSize, blockCheckIntervalMS: pollIntervalMS } = this.config;
|
|
611
|
+
this.blockStream = new L2BlockStream(this.l2BlockSource, this, this, createLogger(`${this.log.module}:l2-block-stream`), {
|
|
612
|
+
batchSize,
|
|
613
|
+
pollIntervalMS,
|
|
614
|
+
startingBlock
|
|
615
|
+
});
|
|
616
|
+
}
|
|
617
|
+
}
|
|
176
618
|
/**
|
|
177
619
|
* Allows consumers to stop the instance of the P2P client.
|
|
178
620
|
* 'ready' will now return 'false' and the running promise that keeps the client synced is interrupted.
|
|
179
621
|
*/ async stop() {
|
|
180
622
|
this.log.debug('Stopping p2p client...');
|
|
623
|
+
await tryStop(this.txCollection);
|
|
624
|
+
this.log.debug('Stopped tx collection service');
|
|
625
|
+
await this.txFileStore?.stop();
|
|
626
|
+
this.log.debug('Stopped tx file store');
|
|
181
627
|
await this.p2pService.stop();
|
|
182
628
|
this.log.debug('Stopped p2p service');
|
|
183
|
-
await this.blockStream
|
|
629
|
+
await this.blockStream?.stop();
|
|
184
630
|
this.log.debug('Stopped block downloader');
|
|
185
631
|
await this.runningPromise;
|
|
186
|
-
this.setCurrentState(
|
|
187
|
-
this.log.info('P2P client stopped
|
|
632
|
+
this.setCurrentState(P2PClientState.STOPPED);
|
|
633
|
+
this.log.info('P2P client stopped');
|
|
634
|
+
}
|
|
635
|
+
/** Triggers a sync to the archiver. Used for testing. */ async sync() {
|
|
636
|
+
this.initBlockStream();
|
|
637
|
+
await this.blockStream.sync();
|
|
638
|
+
}
|
|
639
|
+
async broadcastProposal(proposal) {
|
|
640
|
+
this.log.verbose(`Broadcasting proposal for slot ${proposal.slotNumber} to peers`);
|
|
641
|
+
// Store our own proposal so we can respond to req/resp requests for it
|
|
642
|
+
await this.attestationPool.addBlockProposal(proposal);
|
|
643
|
+
return this.p2pService.propagate(proposal);
|
|
188
644
|
}
|
|
189
|
-
|
|
190
|
-
this.log.verbose(`Broadcasting proposal for slot ${proposal.slotNumber
|
|
645
|
+
async broadcastCheckpointProposal(proposal) {
|
|
646
|
+
this.log.verbose(`Broadcasting checkpoint proposal for slot ${proposal.slotNumber} to peers`);
|
|
647
|
+
const blockProposal = proposal.getBlockProposal();
|
|
648
|
+
if (blockProposal) {
|
|
649
|
+
// Store our own last-block proposal so we can respond to req/resp requests for it.
|
|
650
|
+
await this.attestationPool.addBlockProposal(blockProposal);
|
|
651
|
+
}
|
|
191
652
|
return this.p2pService.propagate(proposal);
|
|
192
653
|
}
|
|
193
|
-
async
|
|
194
|
-
|
|
654
|
+
async broadcastCheckpointAttestations(attestations) {
|
|
655
|
+
this.log.verbose(`Broadcasting ${attestations.length} checkpoint attestations to peers`);
|
|
656
|
+
await Promise.all(attestations.map((att)=>this.p2pService.propagate(att)));
|
|
657
|
+
}
|
|
658
|
+
async getCheckpointAttestationsForSlot(slot, proposalId) {
|
|
659
|
+
return await (proposalId ? this.attestationPool.getCheckpointAttestationsForSlotAndProposal(slot, proposalId) : this.attestationPool.getCheckpointAttestationsForSlot(slot));
|
|
660
|
+
}
|
|
661
|
+
addCheckpointAttestations(attestations) {
|
|
662
|
+
return this.attestationPool.addCheckpointAttestations(attestations);
|
|
195
663
|
}
|
|
196
664
|
// REVIEW: https://github.com/AztecProtocol/aztec-packages/issues/7963
|
|
197
665
|
// ^ This pattern is not my favorite (md)
|
|
198
666
|
registerBlockProposalHandler(handler) {
|
|
199
667
|
this.p2pService.registerBlockReceivedCallback(handler);
|
|
200
668
|
}
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
*
|
|
204
|
-
* If a transaction can be retrieved, it will be returned, if not an undefined
|
|
205
|
-
* will be returned. In place.
|
|
206
|
-
*
|
|
207
|
-
* @param txHashes - The hashes of the transactions to request.
|
|
208
|
-
* @returns A promise that resolves to an array of transactions or undefined.
|
|
209
|
-
*/ async requestTxs(txHashes) {
|
|
210
|
-
const res = await this.p2pService.sendBatchRequest(ReqRespSubProtocol.TX, txHashes);
|
|
211
|
-
return Promise.resolve(res ?? []);
|
|
212
|
-
}
|
|
213
|
-
/**
|
|
214
|
-
* Uses the Request Response protocol to request a transaction from the network.
|
|
215
|
-
*
|
|
216
|
-
* If the underlying request response protocol fails, then we return undefined.
|
|
217
|
-
* If it succeeds then we add the transaction to our transaction pool and return.
|
|
218
|
-
*
|
|
219
|
-
* @param txHash - The hash of the transaction to request.
|
|
220
|
-
* @returns A promise that resolves to a transaction or undefined.
|
|
221
|
-
*/ async requestTxByHash(txHash) {
|
|
222
|
-
const tx = await this.p2pService.sendRequest(ReqRespSubProtocol.TX, txHash);
|
|
223
|
-
if (tx) {
|
|
224
|
-
this.log.debug(`Received tx ${txHash.toString()} from peer`);
|
|
225
|
-
await this.txPool.addTxs([
|
|
226
|
-
tx
|
|
227
|
-
]);
|
|
228
|
-
} else {
|
|
229
|
-
this.log.debug(`Failed to receive tx ${txHash.toString()} from peer`);
|
|
230
|
-
}
|
|
231
|
-
return tx;
|
|
669
|
+
registerCheckpointProposalHandler(handler) {
|
|
670
|
+
this.p2pService.registerCheckpointReceivedCallback(handler);
|
|
232
671
|
}
|
|
233
672
|
/**
|
|
234
673
|
* Uses the batched Request Response protocol to request a set of transactions from the network.
|
|
235
|
-
*/ async requestTxsByHash(txHashes) {
|
|
236
|
-
const
|
|
237
|
-
|
|
674
|
+
*/ async requestTxsByHash(txHashes, pinnedPeerId) {
|
|
675
|
+
const timeoutMs = 8000; // Longer timeout for now
|
|
676
|
+
const maxRetryAttempts = 10; // Keep retrying within the timeout
|
|
677
|
+
const requests = chunkTxHashesRequest(txHashes);
|
|
678
|
+
const maxPeers = Math.min(Math.ceil(requests.length / 3), 10);
|
|
679
|
+
const txBatches = await this.p2pService.sendBatchRequest(ReqRespSubProtocol.TX, requests, pinnedPeerId, timeoutMs, maxPeers, maxRetryAttempts);
|
|
680
|
+
const txs = txBatches.flat();
|
|
681
|
+
if (txs.length > 0) {
|
|
682
|
+
await this.txPool.addTxs(txs);
|
|
683
|
+
}
|
|
238
684
|
const txHashesStr = txHashes.map((tx)=>tx.toString()).join(', ');
|
|
239
|
-
this.log.debug(`
|
|
685
|
+
this.log.debug(`Requested txs ${txHashesStr} (${txs.length} / ${txHashes.length}) from peers`);
|
|
686
|
+
// We return all transactions, even the not found ones to the caller, such they can handle missing items themselves.
|
|
240
687
|
return txs;
|
|
241
688
|
}
|
|
242
|
-
getPendingTxs() {
|
|
243
|
-
return
|
|
689
|
+
getPendingTxs(limit, after) {
|
|
690
|
+
return this.getTxs('pending', limit, after);
|
|
244
691
|
}
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
return pendingTxs.length;
|
|
692
|
+
getPendingTxCount() {
|
|
693
|
+
return this.txPool.getPendingTxCount();
|
|
248
694
|
}
|
|
249
695
|
async *iteratePendingTxs() {
|
|
250
696
|
for (const txHash of (await this.txPool.getPendingTxHashes())){
|
|
@@ -256,22 +702,50 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
256
702
|
}
|
|
257
703
|
/**
|
|
258
704
|
* Returns all transactions in the transaction pool.
|
|
705
|
+
* @param filter - The type of txs to return
|
|
706
|
+
* @param limit - How many txs to return
|
|
707
|
+
* @param after - If paginating, the last known tx hash. Will return txs after this hash
|
|
259
708
|
* @returns An array of Txs.
|
|
260
|
-
*/ async getTxs(filter) {
|
|
709
|
+
*/ async getTxs(filter, limit, after) {
|
|
710
|
+
if (limit !== undefined && limit <= 0) {
|
|
711
|
+
throw new TypeError('limit must be greater than 0');
|
|
712
|
+
}
|
|
713
|
+
let txs = undefined;
|
|
714
|
+
let txHashes;
|
|
261
715
|
if (filter === 'all') {
|
|
262
|
-
|
|
716
|
+
txs = await this.txPool.getAllTxs();
|
|
717
|
+
txHashes = await Promise.all(txs.map((tx)=>tx.getTxHash()));
|
|
263
718
|
} else if (filter === 'mined') {
|
|
264
|
-
const
|
|
265
|
-
|
|
266
|
-
return minedTx.filter((tx)=>!!tx);
|
|
719
|
+
const minedTxHashes = await this.txPool.getMinedTxHashes();
|
|
720
|
+
txHashes = minedTxHashes.map(([txHash])=>txHash);
|
|
267
721
|
} else if (filter === 'pending') {
|
|
268
|
-
|
|
269
|
-
const pendingTxs = await Promise.all(pendingHashses.map((txHash)=>this.txPool.getTxByHash(txHash)));
|
|
270
|
-
return pendingTxs.filter((tx)=>!!tx);
|
|
722
|
+
txHashes = await this.txPool.getPendingTxHashes();
|
|
271
723
|
} else {
|
|
272
724
|
const _ = filter;
|
|
273
725
|
throw new Error(`Unknown filter ${filter}`);
|
|
274
726
|
}
|
|
727
|
+
let startIndex = 0;
|
|
728
|
+
let endIndex = undefined;
|
|
729
|
+
if (after) {
|
|
730
|
+
startIndex = txHashes.findIndex((txHash)=>after.equals(txHash));
|
|
731
|
+
// if we can't find the last tx in our set then return an empty array as pagination is no longer valid.
|
|
732
|
+
if (startIndex === -1) {
|
|
733
|
+
return [];
|
|
734
|
+
}
|
|
735
|
+
// increment by one because we don't want to return the same tx again
|
|
736
|
+
startIndex++;
|
|
737
|
+
}
|
|
738
|
+
if (limit !== undefined) {
|
|
739
|
+
endIndex = startIndex + limit;
|
|
740
|
+
}
|
|
741
|
+
txHashes = txHashes.slice(startIndex, endIndex);
|
|
742
|
+
if (txs) {
|
|
743
|
+
txs = txs.slice(startIndex, endIndex);
|
|
744
|
+
} else {
|
|
745
|
+
const maybeTxs = await Promise.all(txHashes.map((txHash)=>this.txPool.getTxByHash(txHash)));
|
|
746
|
+
txs = maybeTxs.filter((tx)=>!!tx);
|
|
747
|
+
}
|
|
748
|
+
return txs;
|
|
275
749
|
}
|
|
276
750
|
/**
|
|
277
751
|
* Returns a transaction in the transaction pool by its hash.
|
|
@@ -281,23 +755,21 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
281
755
|
return this.txPool.getTxByHash(txHash);
|
|
282
756
|
}
|
|
283
757
|
/**
|
|
284
|
-
* Returns
|
|
285
|
-
*
|
|
286
|
-
* @
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
}
|
|
293
|
-
return this.requestTxByHash(txHash);
|
|
758
|
+
* Returns transactions in the transaction pool by hash.
|
|
759
|
+
* @param txHashes - Hashes of the transactions to look for.
|
|
760
|
+
* @returns The txs found, in the same order as the requested hashes. If a tx is not found, it will be undefined.
|
|
761
|
+
*/ getTxsByHashFromPool(txHashes) {
|
|
762
|
+
return this.txPool.getTxsByHash(txHashes);
|
|
763
|
+
}
|
|
764
|
+
hasTxsInPool(txHashes) {
|
|
765
|
+
return this.txPool.hasTxs(txHashes);
|
|
294
766
|
}
|
|
295
767
|
/**
|
|
296
768
|
* Returns transactions in the transaction pool by hash.
|
|
297
769
|
* If a transaction is not in the pool, it will be requested from the network.
|
|
298
770
|
* @param txHashes - Hashes of the transactions to look for.
|
|
299
|
-
* @returns The txs found, not
|
|
300
|
-
*/ async getTxsByHash(txHashes) {
|
|
771
|
+
* @returns The txs found, or undefined if not found in the order requested.
|
|
772
|
+
*/ async getTxsByHash(txHashes, pinnedPeerId) {
|
|
301
773
|
const txs = await Promise.all(txHashes.map((txHash)=>this.txPool.getTxByHash(txHash)));
|
|
302
774
|
const missingTxHashes = txs.map((tx, index)=>[
|
|
303
775
|
tx,
|
|
@@ -306,8 +778,27 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
306
778
|
if (missingTxHashes.length === 0) {
|
|
307
779
|
return txs;
|
|
308
780
|
}
|
|
309
|
-
const missingTxs = await this.requestTxsByHash(missingTxHashes);
|
|
310
|
-
|
|
781
|
+
const missingTxs = await this.requestTxsByHash(missingTxHashes, pinnedPeerId);
|
|
782
|
+
// TODO: optimize
|
|
783
|
+
// Merge the found txs in order
|
|
784
|
+
const mergingTxs = txHashes.map((txHash)=>{
|
|
785
|
+
// Is it in the txs list from the mempool?
|
|
786
|
+
for (const tx of txs){
|
|
787
|
+
if (tx !== undefined && tx.getTxHash().equals(txHash)) {
|
|
788
|
+
return tx;
|
|
789
|
+
}
|
|
790
|
+
}
|
|
791
|
+
// Is it in the fetched missing txs?
|
|
792
|
+
// Note: this is an O(n^2) operation, but we expect the number of missing txs to be small.
|
|
793
|
+
for (const tx of missingTxs){
|
|
794
|
+
if (tx.getTxHash().equals(txHash)) {
|
|
795
|
+
return tx;
|
|
796
|
+
}
|
|
797
|
+
}
|
|
798
|
+
// Otherwise return undefined
|
|
799
|
+
return undefined;
|
|
800
|
+
});
|
|
801
|
+
return mergingTxs;
|
|
311
802
|
}
|
|
312
803
|
/**
|
|
313
804
|
* Returns an archived transaction in the transaction pool by its hash.
|
|
@@ -321,11 +812,20 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
321
812
|
* @param tx - The tx to verify.
|
|
322
813
|
* @returns Empty promise.
|
|
323
814
|
**/ async sendTx(tx) {
|
|
324
|
-
this
|
|
325
|
-
await this.txPool.addTxs([
|
|
815
|
+
const addedCount = await this.addTxsToPool([
|
|
326
816
|
tx
|
|
327
817
|
]);
|
|
328
|
-
|
|
818
|
+
const txAddedSuccessfully = addedCount === 1;
|
|
819
|
+
if (txAddedSuccessfully) {
|
|
820
|
+
await this.p2pService.propagate(tx);
|
|
821
|
+
}
|
|
822
|
+
}
|
|
823
|
+
/**
|
|
824
|
+
* Adds transactions to the pool. Does not send to peers or validate the txs.
|
|
825
|
+
* @param txs - The transactions.
|
|
826
|
+
**/ async addTxsToPool(txs) {
|
|
827
|
+
this.#assertIsReady();
|
|
828
|
+
return await this.txPool.addTxs(txs);
|
|
329
829
|
}
|
|
330
830
|
/**
|
|
331
831
|
* Returns whether the given tx hash is flagged as pending or mined.
|
|
@@ -353,26 +853,35 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
353
853
|
* Public function to check if the p2p client is fully synced and ready to receive txs.
|
|
354
854
|
* @returns True if the P2P client is ready to receive txs.
|
|
355
855
|
*/ isReady() {
|
|
356
|
-
return this.currentState ===
|
|
856
|
+
return this.currentState === P2PClientState.RUNNING;
|
|
357
857
|
}
|
|
358
858
|
/**
|
|
359
859
|
* Public function to check the latest block number that the P2P client is synced to.
|
|
360
860
|
* @returns Block number of latest L2 Block we've synced with.
|
|
361
861
|
*/ async getSyncedLatestBlockNum() {
|
|
362
|
-
|
|
862
|
+
const tips = await this.l2Tips.getL2Tips();
|
|
863
|
+
return tips.proposed.number;
|
|
363
864
|
}
|
|
364
865
|
/**
|
|
365
866
|
* Public function to check the latest proven block number that the P2P client is synced to.
|
|
366
867
|
* @returns Block number of latest proven L2 Block we've synced with.
|
|
367
868
|
*/ async getSyncedProvenBlockNum() {
|
|
368
|
-
|
|
869
|
+
const tips = await this.l2Tips.getL2Tips();
|
|
870
|
+
return tips.proven.block.number;
|
|
871
|
+
}
|
|
872
|
+
async getSyncedFinalizedBlockNum() {
|
|
873
|
+
const tips = await this.l2Tips.getL2Tips();
|
|
874
|
+
return tips.finalized.block.number;
|
|
875
|
+
}
|
|
876
|
+
/** Returns latest L2 slot for which we have seen an L2 block. */ async getSyncedLatestSlot() {
|
|
877
|
+
return await this.synchedLatestSlot.getAsync() ?? BigInt(0);
|
|
369
878
|
}
|
|
370
879
|
/**
|
|
371
880
|
* Method to check the status the p2p client.
|
|
372
881
|
* @returns Information about p2p client status: state & syncedToBlockNum.
|
|
373
882
|
*/ async getStatus() {
|
|
374
883
|
const blockNumber = await this.getSyncedLatestBlockNum();
|
|
375
|
-
const blockHash = blockNumber === 0 ?
|
|
884
|
+
const blockHash = blockNumber === 0 ? GENESIS_BLOCK_HEADER_HASH.toString() : await this.l2BlockSource.getBlockHeader(blockNumber).then((header)=>header?.hash()).then((hash)=>hash?.toString());
|
|
376
885
|
return {
|
|
377
886
|
state: this.currentState,
|
|
378
887
|
syncedToL2Block: {
|
|
@@ -388,18 +897,7 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
388
897
|
*/ async markTxsAsMinedFromBlocks(blocks) {
|
|
389
898
|
for (const block of blocks){
|
|
390
899
|
const txHashes = block.body.txEffects.map((txEffect)=>txEffect.txHash);
|
|
391
|
-
await this.txPool.markAsMined(txHashes, block.
|
|
392
|
-
}
|
|
393
|
-
}
|
|
394
|
-
/**
|
|
395
|
-
* Deletes txs from these blocks.
|
|
396
|
-
* @param blocks - A list of existing blocks with txs that the P2P client needs to ensure the tx pool is reconciled with.
|
|
397
|
-
* @returns Empty promise.
|
|
398
|
-
*/ async deleteTxsFromBlocks(blocks) {
|
|
399
|
-
this.log.debug(`Deleting txs from blocks ${blocks[0].number} to ${blocks[blocks.length - 1].number}`);
|
|
400
|
-
for (const block of blocks){
|
|
401
|
-
const txHashes = block.body.txEffects.map((txEffect)=>txEffect.txHash);
|
|
402
|
-
await this.txPool.deleteTxs(txHashes);
|
|
900
|
+
await this.txPool.markAsMined(txHashes, block.header);
|
|
403
901
|
}
|
|
404
902
|
}
|
|
405
903
|
/**
|
|
@@ -411,75 +909,113 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
411
909
|
return Promise.resolve();
|
|
412
910
|
}
|
|
413
911
|
await this.markTxsAsMinedFromBlocks(blocks);
|
|
414
|
-
|
|
415
|
-
await
|
|
416
|
-
|
|
417
|
-
this.
|
|
418
|
-
|
|
912
|
+
await this.txPool.clearNonEvictableTxs();
|
|
913
|
+
await this.startCollectingMissingTxs(blocks);
|
|
914
|
+
const lastBlock = blocks.at(-1);
|
|
915
|
+
await this.synchedLatestSlot.set(BigInt(lastBlock.header.getSlot()));
|
|
916
|
+
this.log.verbose(`Synched to latest block ${lastBlock.number}`);
|
|
917
|
+
}
|
|
918
|
+
/** Request txs for unproven blocks so the prover node has more chances to get them. */ async startCollectingMissingTxs(blocks) {
|
|
919
|
+
try {
|
|
920
|
+
// TODO(#15435): If the archiver has lagged behind L1, the reported proven block number may
|
|
921
|
+
// be much lower than the actual one, and it does not update until the pending chain is
|
|
922
|
+
// fully synced. This could lead to a ton of tx collection requests for blocks that
|
|
923
|
+
// are already proven, but the archiver has not yet updated its state. Until this is properly
|
|
924
|
+
// fixed, it is mitigated by the expiration date of collection requests, which depends on
|
|
925
|
+
// the slot number of the block.
|
|
926
|
+
const provenBlockNumber = await this.l2BlockSource.getProvenBlockNumber();
|
|
927
|
+
const unprovenBlocks = blocks.filter((block)=>block.number > provenBlockNumber);
|
|
928
|
+
for (const block of unprovenBlocks){
|
|
929
|
+
const txHashes = block.body.txEffects.map((txEffect)=>txEffect.txHash);
|
|
930
|
+
const missingTxHashes = await this.txPool.hasTxs(txHashes).then((availability)=>txHashes.filter((_, index)=>!availability[index]));
|
|
931
|
+
if (missingTxHashes.length > 0) {
|
|
932
|
+
this.log.verbose(`Starting collection of ${missingTxHashes.length} missing txs for unproven mined block ${block.number}`, {
|
|
933
|
+
missingTxHashes,
|
|
934
|
+
blockNumber: block.number,
|
|
935
|
+
blockHash: await block.hash().then((h)=>h.toString())
|
|
936
|
+
});
|
|
937
|
+
this.txCollection.startCollecting(block, missingTxHashes);
|
|
938
|
+
}
|
|
939
|
+
}
|
|
940
|
+
} catch (err) {
|
|
941
|
+
this.log.error(`Error while starting collection of missing txs for unproven blocks`, err);
|
|
942
|
+
}
|
|
419
943
|
}
|
|
420
944
|
/**
|
|
421
|
-
* Handles new
|
|
422
|
-
* @param blocks - A list of
|
|
945
|
+
* Handles new finalized blocks by deleting the txs and attestations in them.
|
|
946
|
+
* @param blocks - A list of finalized L2 blocks.
|
|
423
947
|
* @returns Empty promise.
|
|
424
|
-
*/ async
|
|
948
|
+
*/ async handleFinalizedL2Blocks(blocks) {
|
|
425
949
|
if (!blocks.length) {
|
|
426
950
|
return Promise.resolve();
|
|
427
951
|
}
|
|
428
|
-
|
|
952
|
+
this.log.debug(`Handling finalized blocks ${blocks.length} up to ${blocks.at(-1)?.number}`);
|
|
429
953
|
const lastBlockNum = blocks[blocks.length - 1].number;
|
|
430
|
-
const lastBlockSlot = blocks[blocks.length - 1].header.
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
await this.deleteTxsFromBlocks(blocksToDeleteTxsFrom);
|
|
440
|
-
}
|
|
441
|
-
// We delete attestations older than the last block slot minus the number of slots we want to keep in the pool.
|
|
442
|
-
const lastBlockSlotMinusKeepAttestationsInPoolFor = lastBlockSlot - BigInt(this.keepAttestationsInPoolFor);
|
|
443
|
-
if (lastBlockSlotMinusKeepAttestationsInPoolFor >= BigInt(INITIAL_L2_BLOCK_NUM)) {
|
|
444
|
-
await this.attestationPool?.deleteAttestationsOlderThan(lastBlockSlotMinusKeepAttestationsInPoolFor);
|
|
445
|
-
}
|
|
446
|
-
await this.synchedProvenBlockNumber.set(lastBlockNum);
|
|
447
|
-
this.log.debug(`Synched to proven block ${lastBlockNum}`);
|
|
448
|
-
await this.startServiceIfSynched();
|
|
954
|
+
const lastBlockSlot = blocks[blocks.length - 1].header.getSlot();
|
|
955
|
+
const txHashes = blocks.flatMap((block)=>block.body.txEffects.map((txEffect)=>txEffect.txHash));
|
|
956
|
+
this.log.debug(`Deleting ${txHashes.length} txs from pool from finalized blocks up to ${lastBlockNum}`);
|
|
957
|
+
await this.txPool.deleteTxs(txHashes, {
|
|
958
|
+
permanently: true
|
|
959
|
+
});
|
|
960
|
+
await this.txPool.cleanupDeletedMinedTxs(lastBlockNum);
|
|
961
|
+
await this.attestationPool.deleteCheckpointAttestationsOlderThan(lastBlockSlot);
|
|
962
|
+
this.log.debug(`Synched to finalized block ${lastBlockNum} at slot ${lastBlockSlot}`);
|
|
449
963
|
}
|
|
450
964
|
/**
|
|
451
965
|
* Updates the tx pool after a chain prune.
|
|
452
966
|
* @param latestBlock - The block number the chain was pruned to.
|
|
453
967
|
*/ async handlePruneL2Blocks(latestBlock) {
|
|
454
|
-
const txsToDelete =
|
|
968
|
+
const txsToDelete = new Map();
|
|
969
|
+
const minedTxs = await this.txPool.getMinedTxHashes();
|
|
970
|
+
// Find transactions that reference pruned blocks in their historical header
|
|
455
971
|
for (const tx of (await this.txPool.getAllTxs())){
|
|
456
972
|
// every tx that's been generated against a block that has now been pruned is no longer valid
|
|
457
|
-
if (tx.data.constants.
|
|
458
|
-
|
|
973
|
+
if (tx.data.constants.anchorBlockHeader.globalVariables.blockNumber > latestBlock) {
|
|
974
|
+
const txHash = tx.getTxHash();
|
|
975
|
+
txsToDelete.set(txHash.toString(), txHash);
|
|
459
976
|
}
|
|
460
977
|
}
|
|
461
|
-
this.log.info(`Detected chain prune. Removing
|
|
978
|
+
this.log.info(`Detected chain prune. Removing ${txsToDelete.size} txs built against pruned blocks.`, {
|
|
979
|
+
newLatestBlock: latestBlock,
|
|
980
|
+
previousLatestBlock: await this.getSyncedLatestBlockNum(),
|
|
981
|
+
txsToDelete: Array.from(txsToDelete.keys())
|
|
982
|
+
});
|
|
462
983
|
// delete invalid txs (both pending and mined)
|
|
463
|
-
await this.txPool.deleteTxs(txsToDelete);
|
|
984
|
+
await this.txPool.deleteTxs(Array.from(txsToDelete.values()));
|
|
464
985
|
// everything left in the mined set was built against a block on the proven chain so its still valid
|
|
465
|
-
// move back to pending the txs that were reorged out of the chain
|
|
986
|
+
// move back to pending the txs that were reorged out of the chain, unless txPoolDeleteTxsAfterReorg is set,
|
|
987
|
+
// in which case we clean them up to avoid potential reorg loops
|
|
466
988
|
// NOTE: we can't move _all_ txs back to pending because the tx pool could keep hold of mined txs for longer
|
|
467
989
|
// (see this.keepProvenTxsFor)
|
|
468
|
-
const
|
|
469
|
-
for (const [txHash, blockNumber] of
|
|
470
|
-
|
|
471
|
-
|
|
990
|
+
const minedTxsFromReorg = [];
|
|
991
|
+
for (const [txHash, blockNumber] of minedTxs){
|
|
992
|
+
// We keep the txsToDelete out of this list as they have already been deleted above
|
|
993
|
+
if (blockNumber > latestBlock && !txsToDelete.has(txHash.toString())) {
|
|
994
|
+
minedTxsFromReorg.push(txHash);
|
|
472
995
|
}
|
|
473
996
|
}
|
|
474
|
-
this.
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
997
|
+
if (this.config.txPoolDeleteTxsAfterReorg) {
|
|
998
|
+
this.log.info(`Deleting ${minedTxsFromReorg.length} mined txs from reorg`);
|
|
999
|
+
await this.txPool.deleteTxs(minedTxsFromReorg);
|
|
1000
|
+
} else {
|
|
1001
|
+
await this.txPool.markMinedAsPending(minedTxsFromReorg, latestBlock);
|
|
1002
|
+
}
|
|
478
1003
|
}
|
|
479
1004
|
async startServiceIfSynched() {
|
|
480
|
-
if (this.currentState
|
|
481
|
-
|
|
482
|
-
|
|
1005
|
+
if (this.currentState !== P2PClientState.SYNCHING) {
|
|
1006
|
+
return;
|
|
1007
|
+
}
|
|
1008
|
+
const tips = await this.l2Tips.getL2Tips();
|
|
1009
|
+
const syncedFinalizedBlock = tips.finalized.block.number;
|
|
1010
|
+
const syncedProvenBlock = tips.proven.block.number;
|
|
1011
|
+
const syncedLatestBlock = tips.proposed.number;
|
|
1012
|
+
if (syncedLatestBlock >= this.latestBlockNumberAtStart && syncedProvenBlock >= this.provenBlockNumberAtStart && syncedFinalizedBlock >= this.finalizedBlockNumberAtStart) {
|
|
1013
|
+
this.log.info(`Completed P2P client sync to block ${syncedLatestBlock}. Starting service.`, {
|
|
1014
|
+
syncedLatestBlock,
|
|
1015
|
+
syncedProvenBlock,
|
|
1016
|
+
syncedFinalizedBlock
|
|
1017
|
+
});
|
|
1018
|
+
this.setCurrentState(P2PClientState.RUNNING);
|
|
483
1019
|
if (this.syncResolve !== undefined) {
|
|
484
1020
|
this.syncResolve();
|
|
485
1021
|
await this.p2pService.start();
|
|
@@ -494,12 +1030,16 @@ import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
|
|
|
494
1030
|
this.currentState = newState;
|
|
495
1031
|
this.log.debug(`Moved from state ${P2PClientState[oldState]} to ${P2PClientState[this.currentState]}`);
|
|
496
1032
|
}
|
|
1033
|
+
validate(txs) {
|
|
1034
|
+
return this.p2pService.validate(txs);
|
|
1035
|
+
}
|
|
1036
|
+
/**
|
|
1037
|
+
* Marks transactions as non-evictable in the pool.
|
|
1038
|
+
* @param txHashes - Hashes of the transactions to mark as non-evictable.
|
|
1039
|
+
*/ markTxsAsNonEvictable(txHashes) {
|
|
1040
|
+
return this.txPool.markTxsAsNonEvictable(txHashes);
|
|
1041
|
+
}
|
|
1042
|
+
handleAuthRequestFromPeer(authRequest, peerId) {
|
|
1043
|
+
return this.p2pService.handleAuthRequestFromPeer(authRequest, peerId);
|
|
1044
|
+
}
|
|
497
1045
|
}
|
|
498
|
-
_ts_decorate([
|
|
499
|
-
trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
|
|
500
|
-
[Attributes.BLOCK_NUMBER]: proposal.blockNumber.toNumber(),
|
|
501
|
-
[Attributes.SLOT_NUMBER]: proposal.slotNumber.toNumber(),
|
|
502
|
-
[Attributes.BLOCK_ARCHIVE]: proposal.archive.toString(),
|
|
503
|
-
[Attributes.P2P_ID]: (await proposal.p2pMessageIdentifier()).toString()
|
|
504
|
-
}))
|
|
505
|
-
], P2PClient.prototype, "broadcastProposal", null);
|