@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
|
@@ -1,17 +1,22 @@
|
|
|
1
1
|
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
2
2
|
import { sleep } from '@aztec/foundation/sleep';
|
|
3
3
|
import { fork } from 'child_process';
|
|
4
|
+
import { existsSync } from 'fs';
|
|
4
5
|
import path from 'path';
|
|
5
6
|
import { fileURLToPath } from 'url';
|
|
6
7
|
import { getP2PDefaultConfig } from '../config.js';
|
|
7
8
|
import { generatePeerIdPrivateKeys } from '../test-helpers/generate-peer-id-private-keys.js';
|
|
8
9
|
import { getPorts } from '../test-helpers/get-ports.js';
|
|
9
10
|
import { makeEnr, makeEnrs } from '../test-helpers/make-enrs.js';
|
|
11
|
+
import { BENCHMARK_CONSTANTS } from '../test-helpers/testbench-utils.js';
|
|
10
12
|
const __dirname = path.dirname(fileURLToPath(import.meta.url));
|
|
11
|
-
const
|
|
13
|
+
const p2pRoot = path.resolve(__dirname, '../..');
|
|
14
|
+
const workerTsPath = path.join(__dirname, 'p2p_client_testbench_worker.ts');
|
|
15
|
+
const workerJsPath = path.join(p2pRoot, 'dest/testbench/p2p_client_testbench_worker.js');
|
|
16
|
+
const tsconfigPath = path.join(p2pRoot, 'tsconfig.json');
|
|
12
17
|
const testChainConfig = {
|
|
13
18
|
l1ChainId: 31337,
|
|
14
|
-
|
|
19
|
+
rollupVersion: 1,
|
|
15
20
|
l1Contracts: {
|
|
16
21
|
rollupAddress: EthAddress.random()
|
|
17
22
|
}
|
|
@@ -21,6 +26,7 @@ class WorkerClientManager {
|
|
|
21
26
|
peerIdPrivateKeys = [];
|
|
22
27
|
peerEnrs = [];
|
|
23
28
|
ports = [];
|
|
29
|
+
peerIds = [];
|
|
24
30
|
p2pConfig;
|
|
25
31
|
logger;
|
|
26
32
|
messageReceivedByClient = [];
|
|
@@ -35,25 +41,18 @@ class WorkerClientManager {
|
|
|
35
41
|
});
|
|
36
42
|
}
|
|
37
43
|
/**
|
|
38
|
-
* Creates
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
listenAddr: `0.0.0.0:${port}`
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
/**
|
|
46
|
-
* Creates a client configuration object
|
|
44
|
+
* Creates a client configuration object for IPC.
|
|
45
|
+
* Note: We send the raw peerIdPrivateKey string instead of SecretValue
|
|
46
|
+
* because SecretValue.toJSON() returns '[Redacted]', losing the value.
|
|
47
|
+
* The worker must re-wrap it in SecretValue.
|
|
47
48
|
*/ createClientConfig(clientIndex, port, otherNodes) {
|
|
48
|
-
const { addr, listenAddr } = this.getAddresses(port);
|
|
49
49
|
return {
|
|
50
50
|
...getP2PDefaultConfig(),
|
|
51
51
|
p2pEnabled: true,
|
|
52
52
|
peerIdPrivateKey: this.peerIdPrivateKeys[clientIndex],
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
udpAnnounceAddress: addr,
|
|
53
|
+
listenAddress: '127.0.0.1',
|
|
54
|
+
p2pIp: '127.0.0.1',
|
|
55
|
+
p2pPort: port,
|
|
57
56
|
bootstrapNodes: [
|
|
58
57
|
...otherNodes
|
|
59
58
|
],
|
|
@@ -61,9 +60,26 @@ class WorkerClientManager {
|
|
|
61
60
|
};
|
|
62
61
|
}
|
|
63
62
|
/**
|
|
64
|
-
* Spawns a worker process and returns a promise that resolves when the worker is ready
|
|
63
|
+
* Spawns a worker process and returns a promise that resolves when the worker is ready.
|
|
64
|
+
* Config uses raw string for peerIdPrivateKey (not SecretValue) for IPC serialization.
|
|
65
65
|
*/ spawnWorkerProcess(config, clientIndex) {
|
|
66
|
-
const
|
|
66
|
+
const useCompiled = existsSync(workerJsPath);
|
|
67
|
+
const workerPath = useCompiled ? workerJsPath : workerTsPath;
|
|
68
|
+
const execArgv = [
|
|
69
|
+
...process.execArgv
|
|
70
|
+
];
|
|
71
|
+
if (!useCompiled && !execArgv.includes('ts-node/esm')) {
|
|
72
|
+
execArgv.push('--loader', 'ts-node/esm');
|
|
73
|
+
}
|
|
74
|
+
const env = {
|
|
75
|
+
...process.env,
|
|
76
|
+
TS_NODE_PROJECT: tsconfigPath
|
|
77
|
+
};
|
|
78
|
+
const childProcess = fork(workerPath, {
|
|
79
|
+
cwd: p2pRoot,
|
|
80
|
+
execArgv,
|
|
81
|
+
env
|
|
82
|
+
});
|
|
67
83
|
childProcess.send({
|
|
68
84
|
type: 'START',
|
|
69
85
|
config,
|
|
@@ -82,29 +98,54 @@ class WorkerClientManager {
|
|
|
82
98
|
});
|
|
83
99
|
// Create ready signal promise
|
|
84
100
|
const readySignal = new Promise((resolve, reject)=>{
|
|
85
|
-
|
|
101
|
+
let resolved = false;
|
|
86
102
|
const timeout = setTimeout(()=>{
|
|
103
|
+
if (resolved) {
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
resolved = true;
|
|
107
|
+
childProcess.off('message', messageHandler);
|
|
108
|
+
childProcess.off('exit', exitHandler);
|
|
87
109
|
reject(new Error(`Timeout waiting for worker ${clientIndex} to be ready`));
|
|
88
|
-
},
|
|
89
|
-
|
|
90
|
-
|
|
110
|
+
}, BENCHMARK_CONSTANTS.WORKER_READY_TIMEOUT_MS);
|
|
111
|
+
const messageHandler = (msg)=>{
|
|
112
|
+
if (resolved) {
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
// Only handle READY or ERROR messages; ignore others (e.g., GOSSIP_RECEIVED)
|
|
91
116
|
if (msg.type === 'READY') {
|
|
117
|
+
resolved = true;
|
|
118
|
+
clearTimeout(timeout);
|
|
119
|
+
childProcess.off('message', messageHandler);
|
|
120
|
+
childProcess.off('exit', exitHandler);
|
|
121
|
+
if (typeof msg.peerId === 'string') {
|
|
122
|
+
this.peerIds[clientIndex] = msg.peerId;
|
|
123
|
+
}
|
|
92
124
|
resolve();
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
|
|
125
|
+
} else if (msg.type === 'ERROR') {
|
|
126
|
+
resolved = true;
|
|
127
|
+
clearTimeout(timeout);
|
|
128
|
+
childProcess.off('message', messageHandler);
|
|
129
|
+
childProcess.off('exit', exitHandler);
|
|
96
130
|
reject(new Error(msg.error));
|
|
97
131
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
132
|
+
// Ignore other message types and keep waiting for READY/ERROR
|
|
133
|
+
};
|
|
134
|
+
const exitHandler = (code)=>{
|
|
135
|
+
if (resolved) {
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
resolved = true;
|
|
101
139
|
clearTimeout(timeout);
|
|
140
|
+
childProcess.off('message', messageHandler);
|
|
102
141
|
if (code === 0) {
|
|
103
142
|
resolve();
|
|
104
143
|
} else {
|
|
105
144
|
reject(new Error(`Worker ${clientIndex} exited with code ${code} before becoming ready`));
|
|
106
145
|
}
|
|
107
|
-
}
|
|
146
|
+
};
|
|
147
|
+
childProcess.on('message', messageHandler);
|
|
148
|
+
childProcess.once('exit', exitHandler);
|
|
108
149
|
});
|
|
109
150
|
return [
|
|
110
151
|
childProcess,
|
|
@@ -112,34 +153,46 @@ class WorkerClientManager {
|
|
|
112
153
|
];
|
|
113
154
|
}
|
|
114
155
|
/**
|
|
115
|
-
* Creates a number of worker clients in separate processes
|
|
116
|
-
* All are configured to connect to each other and
|
|
156
|
+
* Creates a number of worker clients in separate processes.
|
|
157
|
+
* All are configured to connect to each other and overridden with the test-specific config.
|
|
117
158
|
*
|
|
118
159
|
* @param numberOfClients - The number of clients to create
|
|
160
|
+
* @param options - Optional overrides for seeding/bootstrapping strategy
|
|
119
161
|
* @returns The ENRs of the created clients
|
|
120
|
-
*/ async makeWorkerClients(numberOfClients) {
|
|
162
|
+
*/ async makeWorkerClients(numberOfClients, options = {}) {
|
|
121
163
|
try {
|
|
164
|
+
const bootstrapMode = options.bootstrapMode ?? (this.p2pConfig.bootstrapNodesAsFullPeers ? 'all' : 'subset');
|
|
165
|
+
const seedPeerLimit = options.seedPeerLimit ?? 10;
|
|
166
|
+
const batchSize = options.batchSize ?? (bootstrapMode === 'all' ? Math.min(5, numberOfClients) : numberOfClients);
|
|
167
|
+
const batchDelayMs = options.batchDelayMs ?? (bootstrapMode === 'all' ? 500 : 0);
|
|
122
168
|
this.messageReceivedByClient = new Array(numberOfClients).fill(0);
|
|
123
169
|
this.peerIdPrivateKeys = generatePeerIdPrivateKeys(numberOfClients);
|
|
124
170
|
this.ports = await getPorts(numberOfClients);
|
|
125
171
|
this.peerEnrs = await makeEnrs(this.peerIdPrivateKeys, this.ports, testChainConfig);
|
|
172
|
+
this.peerIds = new Array(numberOfClients);
|
|
126
173
|
this.processes = [];
|
|
127
174
|
const readySignals = [];
|
|
128
|
-
for(let
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
175
|
+
for(let batchStart = 0; batchStart < numberOfClients; batchStart += batchSize){
|
|
176
|
+
const batchEnd = Math.min(batchStart + batchSize, numberOfClients);
|
|
177
|
+
const batchPromises = [];
|
|
178
|
+
for(let i = batchStart; i < batchEnd; i++){
|
|
179
|
+
this.logger.info(`Creating client ${i}`);
|
|
180
|
+
const otherNodes = bootstrapMode === 'all' ? this.peerEnrs.filter((_, ind)=>ind !== i) : this.peerEnrs.filter((_, ind)=>ind < Math.min(i, seedPeerLimit));
|
|
181
|
+
const config = this.createClientConfig(i, this.ports[i], otherNodes);
|
|
182
|
+
const [childProcess, readySignal] = this.spawnWorkerProcess(config, i);
|
|
183
|
+
readySignals.push(readySignal);
|
|
184
|
+
batchPromises.push(readySignal);
|
|
185
|
+
this.processes.push(childProcess);
|
|
186
|
+
}
|
|
187
|
+
await Promise.all(batchPromises);
|
|
188
|
+
if (batchEnd < numberOfClients && batchDelayMs > 0) {
|
|
189
|
+
await sleep(batchDelayMs);
|
|
190
|
+
}
|
|
136
191
|
}
|
|
137
|
-
|
|
138
|
-
await sleep(10000);
|
|
139
|
-
// Wait for all peers to be booted up with timeout
|
|
192
|
+
await sleep(BENCHMARK_CONSTANTS.PEER_DISCOVERY_WAIT_MS);
|
|
140
193
|
await Promise.race([
|
|
141
194
|
Promise.all(readySignals),
|
|
142
|
-
new Promise((_, reject)=>setTimeout(()=>reject(new Error('Timeout waiting for all workers to be ready')),
|
|
195
|
+
new Promise((_, reject)=>setTimeout(()=>reject(new Error('Timeout waiting for all workers to be ready')), BENCHMARK_CONSTANTS.WORKER_READY_TIMEOUT_MS))
|
|
143
196
|
]);
|
|
144
197
|
return this.peerEnrs;
|
|
145
198
|
} catch (error) {
|
|
@@ -177,13 +230,13 @@ class WorkerClientManager {
|
|
|
177
230
|
this.peerEnrs[clientIndex] = await makeEnr(this.peerIdPrivateKeys[clientIndex], newPort, testChainConfig);
|
|
178
231
|
// Maximum seed with 10 other peers to allow peer discovery to connect them at a smoother rate
|
|
179
232
|
const otherNodes = this.peerEnrs.filter((_, ind)=>ind !== clientIndex && ind < Math.min(this.peerEnrs.length, 10));
|
|
233
|
+
this.logger.info(`Changing port for client ${clientIndex} to ${newPort} with other nodes `, otherNodes);
|
|
180
234
|
const config = this.createClientConfig(clientIndex, newPort, otherNodes);
|
|
181
235
|
const [childProcess, readySignal] = this.spawnWorkerProcess(config, clientIndex);
|
|
182
236
|
this.processes[clientIndex] = childProcess;
|
|
183
|
-
// Wait for the process to be ready with a timeout
|
|
184
237
|
await Promise.race([
|
|
185
238
|
readySignal,
|
|
186
|
-
new Promise((_, reject)=>setTimeout(()=>reject(new Error(`Timeout waiting for client ${clientIndex} to be ready`)),
|
|
239
|
+
new Promise((_, reject)=>setTimeout(()=>reject(new Error(`Timeout waiting for client ${clientIndex} to be ready`)), BENCHMARK_CONSTANTS.WORKER_READY_TIMEOUT_MS))
|
|
187
240
|
]);
|
|
188
241
|
} catch (error) {
|
|
189
242
|
this.logger.error(`Error during changePort for client ${clientIndex}:`, error);
|
|
@@ -199,15 +252,14 @@ class WorkerClientManager {
|
|
|
199
252
|
return Promise.resolve();
|
|
200
253
|
}
|
|
201
254
|
return new Promise((resolve)=>{
|
|
202
|
-
// Set a timeout for the graceful exit
|
|
203
255
|
const forceKillTimeout = setTimeout(()=>{
|
|
204
256
|
this.logger.warn(`Process ${index} didn't exit gracefully, force killing...`);
|
|
205
257
|
try {
|
|
206
|
-
process1.kill('SIGKILL');
|
|
258
|
+
process1.kill('SIGKILL');
|
|
207
259
|
} catch (e) {
|
|
208
260
|
this.logger.error(`Error force killing process ${index}:`, e);
|
|
209
261
|
}
|
|
210
|
-
},
|
|
262
|
+
}, BENCHMARK_CONSTANTS.GRACEFUL_SHUTDOWN_TIMEOUT_MS);
|
|
211
263
|
// Listen for process exit
|
|
212
264
|
process1.once('exit', ()=>{
|
|
213
265
|
clearTimeout(forceKillTimeout);
|
|
@@ -218,7 +270,7 @@ class WorkerClientManager {
|
|
|
218
270
|
process1.send({
|
|
219
271
|
type: 'STOP'
|
|
220
272
|
});
|
|
221
|
-
} catch
|
|
273
|
+
} catch {
|
|
222
274
|
// If sending the message fails, force kill immediately
|
|
223
275
|
clearTimeout(forceKillTimeout);
|
|
224
276
|
try {
|
|
@@ -236,7 +288,6 @@ class WorkerClientManager {
|
|
|
236
288
|
this.logger.info(`Cleaning up ${this.processes.length} worker processes`);
|
|
237
289
|
// Create array of promises for each process termination
|
|
238
290
|
const terminationPromises = this.processes.map((process1, index)=>this.terminateProcess(process1, index));
|
|
239
|
-
// Wait for all processes to terminate with a timeout
|
|
240
291
|
try {
|
|
241
292
|
await Promise.race([
|
|
242
293
|
Promise.all(terminationPromises),
|
|
@@ -248,19 +299,147 @@ class WorkerClientManager {
|
|
|
248
299
|
if (!p.killed) {
|
|
249
300
|
p.kill('SIGKILL');
|
|
250
301
|
}
|
|
251
|
-
} catch
|
|
302
|
+
} catch {
|
|
252
303
|
// Ignore errors when force killing
|
|
253
304
|
}
|
|
254
305
|
});
|
|
255
306
|
resolve();
|
|
256
|
-
},
|
|
307
|
+
}, BENCHMARK_CONSTANTS.CLEANUP_TIMEOUT_MS);
|
|
257
308
|
})
|
|
258
309
|
]);
|
|
259
310
|
} catch (error) {
|
|
260
311
|
this.logger.error('Error during cleanup:', error);
|
|
261
312
|
}
|
|
262
313
|
this.processes = [];
|
|
314
|
+
this.peerIds = [];
|
|
263
315
|
this.logger.info('All worker processes cleaned up');
|
|
264
316
|
}
|
|
317
|
+
/**
|
|
318
|
+
* Run a req/resp benchmark across all worker clients.
|
|
319
|
+
*
|
|
320
|
+
* This sends a BENCH_REQRESP command to all workers:
|
|
321
|
+
* - Aggregator (client 0) runs the collector and returns timing results
|
|
322
|
+
* - Responders (clients 1..N) populate their tx pools based on distribution
|
|
323
|
+
*
|
|
324
|
+
* All workers generate the same txs deterministically from a shared seed,
|
|
325
|
+
* then filter based on their peerIndex and distribution pattern.
|
|
326
|
+
*/ async runReqRespBenchmark(config) {
|
|
327
|
+
const peerCount = this.processes.length;
|
|
328
|
+
if (peerCount < 2) {
|
|
329
|
+
throw new Error('Need at least 2 peers to run req/resp benchmark');
|
|
330
|
+
}
|
|
331
|
+
const seed = config.seed ?? Date.now();
|
|
332
|
+
const blockNumber = config.blockNumber ?? 1;
|
|
333
|
+
const pinnedPeerId = config.pinnedPeerIndex !== undefined ? this.peerIds[config.pinnedPeerIndex] : undefined;
|
|
334
|
+
this.logger.info(`Starting req/resp benchmark: txCount=${config.txCount}, distribution=${config.distribution}, collector=${config.collectorType}`);
|
|
335
|
+
const readyPromises = [];
|
|
336
|
+
for(let i = 1; i < peerCount; i++){
|
|
337
|
+
const cmd = {
|
|
338
|
+
type: 'BENCH_REQRESP',
|
|
339
|
+
txCount: config.txCount,
|
|
340
|
+
peerCount,
|
|
341
|
+
distribution: config.distribution,
|
|
342
|
+
collectorType: config.collectorType,
|
|
343
|
+
timeoutMs: config.timeoutMs,
|
|
344
|
+
isAggregator: false,
|
|
345
|
+
peerIndex: i,
|
|
346
|
+
pinnedPeerIndex: config.pinnedPeerIndex,
|
|
347
|
+
pinnedPeerId,
|
|
348
|
+
blockNumber,
|
|
349
|
+
seed
|
|
350
|
+
};
|
|
351
|
+
this.processes[i].send(cmd);
|
|
352
|
+
readyPromises.push(this.waitForBenchReady(i, 30000));
|
|
353
|
+
}
|
|
354
|
+
await Promise.all(readyPromises);
|
|
355
|
+
this.logger.info('All responder peers ready, starting aggregator benchmark...');
|
|
356
|
+
const aggregatorCmd = {
|
|
357
|
+
type: 'BENCH_REQRESP',
|
|
358
|
+
txCount: config.txCount,
|
|
359
|
+
peerCount,
|
|
360
|
+
distribution: config.distribution,
|
|
361
|
+
collectorType: config.collectorType,
|
|
362
|
+
timeoutMs: config.timeoutMs,
|
|
363
|
+
isAggregator: true,
|
|
364
|
+
peerIndex: 0,
|
|
365
|
+
pinnedPeerIndex: config.pinnedPeerIndex,
|
|
366
|
+
pinnedPeerId,
|
|
367
|
+
blockNumber,
|
|
368
|
+
seed
|
|
369
|
+
};
|
|
370
|
+
this.processes[0].send(aggregatorCmd);
|
|
371
|
+
const result = await this.waitForBenchResult(0, config.timeoutMs + 30000);
|
|
372
|
+
this.logger.info(`Benchmark complete: fetched=${result.fetchedCount}/${config.txCount}, duration=${result.durationMs.toFixed(0)}ms, success=${result.success}`);
|
|
373
|
+
return {
|
|
374
|
+
txCount: config.txCount,
|
|
375
|
+
distribution: config.distribution,
|
|
376
|
+
collector: config.collectorType,
|
|
377
|
+
durationMs: result.durationMs,
|
|
378
|
+
fetchedCount: result.fetchedCount,
|
|
379
|
+
success: result.success,
|
|
380
|
+
error: result.error
|
|
381
|
+
};
|
|
382
|
+
}
|
|
383
|
+
waitForBenchReady(clientIndex, timeoutMs) {
|
|
384
|
+
return new Promise((resolve, reject)=>{
|
|
385
|
+
let resolved = false;
|
|
386
|
+
const handler = (msg)=>{
|
|
387
|
+
if (resolved) {
|
|
388
|
+
return;
|
|
389
|
+
}
|
|
390
|
+
if (msg.type === 'BENCH_READY') {
|
|
391
|
+
resolved = true;
|
|
392
|
+
clearTimeout(timeout);
|
|
393
|
+
this.processes[clientIndex].off('message', handler);
|
|
394
|
+
resolve();
|
|
395
|
+
} else if (msg.type === 'ERROR') {
|
|
396
|
+
resolved = true;
|
|
397
|
+
clearTimeout(timeout);
|
|
398
|
+
this.processes[clientIndex].off('message', handler);
|
|
399
|
+
reject(new Error(`Client ${clientIndex} error: ${msg.error}`));
|
|
400
|
+
}
|
|
401
|
+
};
|
|
402
|
+
const timeout = setTimeout(()=>{
|
|
403
|
+
if (resolved) {
|
|
404
|
+
return;
|
|
405
|
+
}
|
|
406
|
+
resolved = true;
|
|
407
|
+
this.processes[clientIndex].off('message', handler);
|
|
408
|
+
reject(new Error(`Timeout waiting for BENCH_READY from client ${clientIndex}`));
|
|
409
|
+
}, timeoutMs);
|
|
410
|
+
this.processes[clientIndex].on('message', handler);
|
|
411
|
+
});
|
|
412
|
+
}
|
|
413
|
+
waitForBenchResult(clientIndex, timeoutMs) {
|
|
414
|
+
return new Promise((resolve, reject)=>{
|
|
415
|
+
let resolved = false;
|
|
416
|
+
const handler = (msg)=>{
|
|
417
|
+
if (resolved) {
|
|
418
|
+
return;
|
|
419
|
+
}
|
|
420
|
+
if (msg.type === 'BENCH_RESULT') {
|
|
421
|
+
resolved = true;
|
|
422
|
+
clearTimeout(timeout);
|
|
423
|
+
this.processes[clientIndex].off('message', handler);
|
|
424
|
+
resolve(msg);
|
|
425
|
+
} else if (msg.type === 'ERROR') {
|
|
426
|
+
resolved = true;
|
|
427
|
+
clearTimeout(timeout);
|
|
428
|
+
this.processes[clientIndex].off('message', handler);
|
|
429
|
+
reject(new Error(`Client ${clientIndex} error: ${msg.error}`));
|
|
430
|
+
}
|
|
431
|
+
};
|
|
432
|
+
const timeout = setTimeout(()=>{
|
|
433
|
+
if (resolved) {
|
|
434
|
+
return;
|
|
435
|
+
}
|
|
436
|
+
resolved = true;
|
|
437
|
+
this.processes[clientIndex].off('message', handler);
|
|
438
|
+
reject(new Error(`Timeout waiting for BENCH_RESULT from client ${clientIndex}`));
|
|
439
|
+
}, timeoutMs);
|
|
440
|
+
this.processes[clientIndex].on('message', handler);
|
|
441
|
+
});
|
|
442
|
+
}
|
|
265
443
|
}
|
|
266
444
|
export { WorkerClientManager, testChainConfig };
|
|
445
|
+
export { COLLECTOR_DISPLAY_NAMES } from './p2p_client_testbench_worker.js';
|
package/dest/types/index.d.ts
CHANGED
|
@@ -14,7 +14,8 @@ export declare enum PeerEvent {
|
|
|
14
14
|
*/
|
|
15
15
|
export declare enum Discv5Event {
|
|
16
16
|
DISCOVERED = "discovered",
|
|
17
|
-
ENR_ADDED = "enrAdded"
|
|
17
|
+
ENR_ADDED = "enrAdded",
|
|
18
|
+
MULTIADDR_UPDATED = "multiaddrUpdated"
|
|
18
19
|
}
|
|
19
20
|
/**
|
|
20
21
|
* Events emitted from the GossipSub protocol.
|
|
@@ -29,4 +30,5 @@ export declare enum GossipSubEvent {
|
|
|
29
30
|
* Aztec network specific types
|
|
30
31
|
*/
|
|
31
32
|
export declare const AZTEC_ENR_KEY = "aztec";
|
|
32
|
-
|
|
33
|
+
export declare const AZTEC_ENR_CLIENT_VERSION_KEY = "ver";
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7cURBRXFEO0FBRXJEOztHQUVHO0FBQ0gsb0JBQVksU0FBUztJQUNuQixVQUFVLG9CQUFvQjtJQUM5QixTQUFTLGlCQUFpQjtJQUMxQixZQUFZLG9CQUFvQjtDQUNqQztBQUVEOztHQUVHO0FBQ0gsb0JBQVksV0FBVztJQUNyQixVQUFVLGVBQWU7SUFDekIsU0FBUyxhQUFhO0lBQ3RCLGlCQUFpQixxQkFBcUI7Q0FDdkM7QUFFRDs7R0FFRztBQUNILG9CQUFZLGNBQWM7SUFDeEIsT0FBTyxzQkFBc0I7Q0FDOUI7QUFFRDs7cURBRXFEO0FBRXJEOztHQUVHO0FBQ0gsZUFBTyxNQUFNLGFBQWEsVUFBVSxDQUFDO0FBQ3JDLGVBQU8sTUFBTSw0QkFBNEIsUUFBUSxDQUFDIn0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA;;qDAEqD;AAErD;;GAEG;AACH,oBAAY,SAAS;IACnB,UAAU,oBAAoB;IAC9B,SAAS,iBAAiB;IAC1B,YAAY,oBAAoB;CACjC;AAED;;GAEG;AACH,oBAAY,WAAW;IACrB,UAAU,eAAe;IACzB,SAAS,aAAa;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA;;qDAEqD;AAErD;;GAEG;AACH,oBAAY,SAAS;IACnB,UAAU,oBAAoB;IAC9B,SAAS,iBAAiB;IAC1B,YAAY,oBAAoB;CACjC;AAED;;GAEG;AACH,oBAAY,WAAW;IACrB,UAAU,eAAe;IACzB,SAAS,aAAa;IACtB,iBAAiB,qBAAqB;CACvC;AAED;;GAEG;AACH,oBAAY,cAAc;IACxB,OAAO,sBAAsB;CAC9B;AAED;;qDAEqD;AAErD;;GAEG;AACH,eAAO,MAAM,aAAa,UAAU,CAAC;AACrC,eAAO,MAAM,4BAA4B,QAAQ,CAAC"}
|
package/dest/types/index.js
CHANGED
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
*/ export var Discv5Event = /*#__PURE__*/ function(Discv5Event) {
|
|
14
14
|
Discv5Event["DISCOVERED"] = "discovered";
|
|
15
15
|
Discv5Event["ENR_ADDED"] = "enrAdded";
|
|
16
|
+
Discv5Event["MULTIADDR_UPDATED"] = "multiaddrUpdated";
|
|
16
17
|
return Discv5Event;
|
|
17
18
|
}({});
|
|
18
19
|
/**
|
|
@@ -26,3 +27,4 @@
|
|
|
26
27
|
***************************************************/ /**
|
|
27
28
|
* Aztec network specific types
|
|
28
29
|
*/ export const AZTEC_ENR_KEY = 'aztec';
|
|
30
|
+
export const AZTEC_ENR_CLIENT_VERSION_KEY = 'ver';
|
package/dest/util.d.ts
CHANGED
|
@@ -1,18 +1,27 @@
|
|
|
1
|
+
import { SecretValue } from '@aztec/foundation/config';
|
|
2
|
+
import type { Logger } from '@aztec/foundation/log';
|
|
1
3
|
import type { AztecAsyncKVStore } from '@aztec/kv-store';
|
|
2
4
|
import type { DataStoreConfig } from '@aztec/kv-store/config';
|
|
3
5
|
import type { GossipSub } from '@chainsafe/libp2p-gossipsub';
|
|
6
|
+
import type { Identify } from '@libp2p/identify';
|
|
4
7
|
import type { PeerId } from '@libp2p/interface';
|
|
5
8
|
import type { ConnectionManager } from '@libp2p/interface-internal';
|
|
6
9
|
import type { Libp2p } from 'libp2p';
|
|
7
10
|
import type { P2PConfig } from './config.js';
|
|
8
|
-
export interface PubSubLibp2p extends Libp2p {
|
|
11
|
+
export interface PubSubLibp2p extends Pick<Libp2p, 'status' | 'start' | 'stop' | 'peerId'> {
|
|
9
12
|
services: {
|
|
10
|
-
pubsub: GossipSub
|
|
11
|
-
|
|
12
|
-
connectionManager: ConnectionManager;
|
|
13
|
+
pubsub: Pick<GossipSub, 'addEventListener' | 'removeEventListener' | 'publish' | 'subscribe' | 'reportMessageValidationResult' | 'direct'> & {
|
|
14
|
+
score: Pick<GossipSub['score'], 'score'>;
|
|
13
15
|
};
|
|
14
16
|
};
|
|
15
17
|
}
|
|
18
|
+
export type FullLibp2p = Libp2p<{
|
|
19
|
+
identify: Identify;
|
|
20
|
+
pubsub: GossipSub;
|
|
21
|
+
components: {
|
|
22
|
+
connectionManager: ConnectionManager;
|
|
23
|
+
};
|
|
24
|
+
}>;
|
|
16
25
|
/**
|
|
17
26
|
* Converts an address string to a multiaddr string.
|
|
18
27
|
* Example usage:
|
|
@@ -21,33 +30,32 @@ export interface PubSubLibp2p extends Libp2p {
|
|
|
21
30
|
* @param address - The address string to convert. Has to be in the format <addr>:<port>.
|
|
22
31
|
* @param protocol - The protocol to use in the multiaddr string.
|
|
23
32
|
* @returns A multiaddr compliant string. */
|
|
24
|
-
export declare function convertToMultiaddr(address: string, protocol: 'tcp' | 'udp'): string;
|
|
25
|
-
/**
|
|
26
|
-
* Splits an <address>:<port> string into its components.
|
|
27
|
-
* @returns The ip6 or ip4 address & port separately
|
|
28
|
-
*/
|
|
29
|
-
export declare function splitAddressPort(address: string, allowEmptyAddress: boolean): [string, string];
|
|
33
|
+
export declare function convertToMultiaddr(address: string, port: number, protocol: 'tcp' | 'udp'): string;
|
|
30
34
|
/**
|
|
31
35
|
* Queries the public IP address of the machine.
|
|
32
36
|
*/
|
|
33
37
|
export declare function getPublicIp(): Promise<string>;
|
|
34
|
-
export declare function
|
|
38
|
+
export declare function isValidIpAddress(address: string): boolean;
|
|
39
|
+
export declare function resolveAddressIfNecessary(address: string, port: string): Promise<string>;
|
|
35
40
|
export declare function configureP2PClientAddresses(_config: P2PConfig & DataStoreConfig): Promise<P2PConfig & DataStoreConfig>;
|
|
36
41
|
/**
|
|
37
42
|
* Get the peer id private key
|
|
38
43
|
*
|
|
39
44
|
* 1. Check if we have a peer id private key in the config
|
|
40
|
-
* 2. If not, check we have a peer id private key persisted in
|
|
41
|
-
* 3. If
|
|
45
|
+
* 2. If not, check if we have a peer id private key persisted in a file
|
|
46
|
+
* 3. If no file path or data directory is provided, check if we have a peer id private key in the node's store
|
|
47
|
+
* 4. If not, create a new one, then persist it in a file if a file path or data directory is provided or in the node's store otherwise
|
|
42
48
|
*
|
|
43
49
|
*/
|
|
44
50
|
export declare function getPeerIdPrivateKey(config: {
|
|
45
|
-
peerIdPrivateKey?: string
|
|
46
|
-
|
|
51
|
+
peerIdPrivateKey?: SecretValue<string>;
|
|
52
|
+
peerIdPrivateKeyPath?: string;
|
|
53
|
+
dataDirectory?: string;
|
|
54
|
+
}, store: AztecAsyncKVStore, logger: Logger): Promise<SecretValue<string>>;
|
|
47
55
|
/**
|
|
48
56
|
* Create a libp2p peer ID from the private key.
|
|
49
57
|
* @param privateKey - peer ID private key as hex string
|
|
50
58
|
* @returns The peer ID.
|
|
51
59
|
*/
|
|
52
60
|
export declare function createLibP2PPeerIdFromPrivateKey(privateKey: string): Promise<PeerId>;
|
|
53
|
-
//# sourceMappingURL=
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3ZELE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3BELE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUF1QixNQUFNLGlCQUFpQixDQUFDO0FBQzlFLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTlELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRTdELE9BQU8sS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBYyxNQUFNLG1CQUFtQixDQUFDO0FBQzVELE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFJcEUsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBSXJDLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUk3QyxNQUFNLFdBQVcsWUFBYSxTQUFRLElBQUksQ0FBQyxNQUFNLEVBQUUsUUFBUSxHQUFHLE9BQU8sR0FBRyxNQUFNLEdBQUcsUUFBUSxDQUFDO0lBQ3hGLFFBQVEsRUFBRTtRQUNSLE1BQU0sRUFBRSxJQUFJLENBQ1YsU0FBUyxFQUNULGtCQUFrQixHQUFHLHFCQUFxQixHQUFHLFNBQVMsR0FBRyxXQUFXLEdBQUcsK0JBQStCLEdBQUcsUUFBUSxDQUNsSCxHQUFHO1lBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUE7U0FBRSxDQUFDO0tBQ2xELENBQUM7Q0FDSDtBQUVELE1BQU0sTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDO0lBQzlCLFFBQVEsRUFBRSxRQUFRLENBQUM7SUFDbkIsTUFBTSxFQUFFLFNBQVMsQ0FBQztJQUNsQixVQUFVLEVBQUU7UUFDVixpQkFBaUIsRUFBRSxpQkFBaUIsQ0FBQztLQUN0QyxDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUg7Ozs7Ozs7NkNBTzZDO0FBQzdDLHdCQUFnQixrQkFBa0IsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEtBQUssR0FBRyxLQUFLLEdBQUcsTUFBTSxDQU9qRztBQUVEOztHQUVHO0FBQ0gsd0JBQXNCLFdBQVcsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLENBUW5EO0FBRUQsd0JBQWdCLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUd6RDtBQUVELHdCQUFzQix5QkFBeUIsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQVc5RjtBQWNELHdCQUFzQiwyQkFBMkIsQ0FDL0MsT0FBTyxFQUFFLFNBQVMsR0FBRyxlQUFlLEdBQ25DLE9BQU8sQ0FBQyxTQUFTLEdBQUcsZUFBZSxDQUFDLENBbUJ0QztBQUVEOzs7Ozs7OztHQVFHO0FBQ0gsd0JBQXNCLG1CQUFtQixDQUN2QyxNQUFNLEVBQUU7SUFBRSxnQkFBZ0IsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUFDLG9CQUFvQixDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQUMsYUFBYSxDQUFDLEVBQUUsTUFBTSxDQUFBO0NBQUUsRUFDekcsS0FBSyxFQUFFLGlCQUFpQixFQUN4QixNQUFNLEVBQUUsTUFBTSxHQUNiLE9BQU8sQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsQ0EyRDlCO0FBRUQ7Ozs7R0FJRztBQUNILHdCQUFzQixnQ0FBZ0MsQ0FBQyxVQUFVLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FTMUYifQ==
|
package/dest/util.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,KAAK,EAAE,iBAAiB,EAAuB,MAAM,iBAAiB,CAAC;AAC9E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAE7D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EAAE,MAAM,EAAc,MAAM,mBAAmB,CAAC;AAC5D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAIpE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAIrC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAI7C,MAAM,WAAW,YAAa,SAAQ,IAAI,CAAC,MAAM,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAC;IACxF,QAAQ,EAAE;QACR,MAAM,EAAE,IAAI,CACV,SAAS,EACT,kBAAkB,GAAG,qBAAqB,GAAG,SAAS,GAAG,WAAW,GAAG,+BAA+B,GAAG,QAAQ,CAClH,GAAG;YAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,CAAA;SAAE,CAAC;KAClD,CAAC;CACH;AAED,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC;IAC9B,QAAQ,EAAE,QAAQ,CAAC;IACnB,MAAM,EAAE,SAAS,CAAC;IAClB,UAAU,EAAE;QACV,iBAAiB,EAAE,iBAAiB,CAAC;KACtC,CAAC;CACH,CAAC,CAAC;AAEH;;;;;;;6CAO6C;AAC7C,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,GAAG,KAAK,GAAG,MAAM,CAOjG;AAED;;GAEG;AACH,wBAAsB,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC,CAQnD;AAED,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAGzD;AAED,wBAAsB,yBAAyB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAW9F;AAcD,wBAAsB,2BAA2B,CAC/C,OAAO,EAAE,SAAS,GAAG,eAAe,GACnC,OAAO,CAAC,SAAS,GAAG,eAAe,CAAC,CAmBtC;AAED;;;;;;;;GAQG;AACH,wBAAsB,mBAAmB,CACvC,MAAM,EAAE;IAAE,gBAAgB,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;IAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAAC,aAAa,CAAC,EAAE,MAAM,CAAA;CAAE,EACzG,KAAK,EAAE,iBAAiB,EACxB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CA2D9B;AAED;;;;GAIG;AACH,wBAAsB,gCAAgC,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAS1F"}
|