@aztec/p2p 0.0.1-commit.d3ec352c → 0.0.1-commit.f295ac2
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/client/factory.d.ts +2 -2
- package/dest/client/factory.d.ts.map +1 -1
- package/dest/client/factory.js +2 -3
- package/dest/client/interface.d.ts +18 -5
- package/dest/client/interface.d.ts.map +1 -1
- package/dest/client/p2p_client.d.ts +11 -14
- package/dest/client/p2p_client.d.ts.map +1 -1
- package/dest/client/p2p_client.js +456 -124
- package/dest/config.d.ts +4 -7
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +10 -13
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +61 -42
- 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 +239 -265
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +21 -18
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +114 -109
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +17 -16
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +89 -128
- package/dest/mem_pools/attestation_pool/mocks.d.ts +11 -8
- package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/mocks.js +17 -13
- package/dest/mem_pools/instrumentation.d.ts +7 -1
- package/dest/mem_pools/instrumentation.d.ts.map +1 -1
- package/dest/mem_pools/instrumentation.js +30 -12
- 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 +36 -27
- 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 +314 -335
- package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +31 -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 +156 -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 +115 -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 +76 -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 +6 -1
- package/dest/mem_pools/tx_pool/tx_pool.d.ts +8 -4
- 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 +25 -20
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +4 -4
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
- package/dest/msg_validators/attestation_validator/attestation_validator.js +13 -11
- package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +5 -5
- package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
- package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +7 -10
- 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/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/{block_proposal_validator/block_proposal_validator.js → proposal_validator/proposal_validator.js} +20 -22
- 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 +183 -0
- package/dest/msg_validators/tx_validator/archive_cache.d.ts +2 -2
- package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/block_header_validator.d.ts +2 -2
- package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/data_validator.d.ts +1 -1
- package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/factory.d.ts +2 -2
- package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/factory.js +1 -1
- 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 +1 -1
- package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/gas_validator.js +8 -14
- package/dest/msg_validators/tx_validator/metadata_validator.d.ts +2 -2
- package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/test_utils.d.ts +2 -2
- package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +1 -1
- package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
- package/dest/services/dummy_service.d.ts +6 -2
- package/dest/services/dummy_service.d.ts.map +1 -1
- package/dest/services/dummy_service.js +3 -0
- package/dest/services/encoding.d.ts +1 -1
- package/dest/services/encoding.d.ts.map +1 -1
- package/dest/services/encoding.js +5 -3
- package/dest/services/libp2p/instrumentation.d.ts +1 -1
- package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
- package/dest/services/libp2p/instrumentation.js +20 -73
- package/dest/services/libp2p/libp2p_service.d.ts +30 -13
- package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
- package/dest/services/libp2p/libp2p_service.js +703 -149
- package/dest/services/peer-manager/metrics.d.ts +6 -1
- package/dest/services/peer-manager/metrics.d.ts.map +1 -1
- package/dest/services/peer-manager/metrics.js +18 -21
- package/dest/services/peer-manager/peer_manager.d.ts +2 -2
- package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
- package/dest/services/peer-manager/peer_manager.js +4 -12
- package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
- package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
- package/dest/services/peer-manager/peer_scoring.js +2 -5
- package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +1 -1
- package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
- 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/interface.d.ts +4 -4
- package/dest/services/reqresp/interface.d.ts.map +1 -1
- package/dest/services/reqresp/interface.js +3 -3
- package/dest/services/reqresp/metrics.d.ts +1 -1
- package/dest/services/reqresp/metrics.d.ts.map +1 -1
- package/dest/services/reqresp/metrics.js +5 -21
- package/dest/services/reqresp/protocols/auth.d.ts +2 -2
- package/dest/services/reqresp/protocols/auth.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/auth.js +2 -2
- package/dest/services/reqresp/protocols/block.js +1 -1
- package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +1 -1
- package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/block_txs/bitvector.js +7 -0
- package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +2 -2
- package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +1 -1
- package/dest/services/reqresp/protocols/status.d.ts +1 -1
- package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/status.js +4 -1
- package/dest/services/reqresp/protocols/tx.d.ts +2 -3
- package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
- package/dest/services/reqresp/reqresp.js +402 -24
- package/dest/services/service.d.ts +16 -3
- package/dest/services/service.d.ts.map +1 -1
- package/dest/services/tx_collection/config.js +1 -1
- package/dest/services/tx_collection/instrumentation.d.ts +1 -1
- package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
- package/dest/services/tx_collection/instrumentation.js +4 -14
- package/dest/services/tx_collection/slow_tx_collection.d.ts +3 -3
- package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
- package/dest/services/tx_collection/tx_collection.d.ts +4 -4
- package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
- package/dest/services/tx_collection/tx_collection.js +1 -1
- package/dest/services/tx_provider.d.ts +2 -1
- package/dest/services/tx_provider.d.ts.map +1 -1
- package/dest/services/tx_provider.js +11 -2
- package/dest/services/tx_provider_instrumentation.d.ts +5 -2
- package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
- package/dest/services/tx_provider_instrumentation.js +13 -13
- package/dest/test-helpers/mock-tx-helpers.js +1 -1
- package/dest/test-helpers/reqresp-nodes.d.ts +2 -2
- package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
- package/dest/testbench/p2p_client_testbench_worker.js +28 -12
- package/dest/testbench/worker_client_manager.d.ts +1 -1
- package/dest/testbench/worker_client_manager.d.ts.map +1 -1
- package/dest/testbench/worker_client_manager.js +6 -1
- package/package.json +16 -16
- package/src/client/factory.ts +5 -10
- package/src/client/interface.ts +19 -4
- package/src/client/p2p_client.ts +92 -147
- package/src/config.ts +12 -18
- package/src/mem_pools/attestation_pool/attestation_pool.ts +68 -41
- package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +241 -289
- package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +163 -141
- package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +141 -164
- package/src/mem_pools/attestation_pool/mocks.ts +21 -15
- package/src/mem_pools/instrumentation.ts +38 -14
- 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 +363 -368
- package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +131 -0
- package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +207 -0
- package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +159 -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 +91 -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 +8 -1
- package/src/mem_pools/tx_pool/tx_pool.ts +8 -3
- package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +18 -13
- package/src/msg_validators/attestation_validator/attestation_validator.ts +17 -14
- package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +9 -12
- package/src/msg_validators/index.ts +1 -1
- 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/{block_proposal_validator/block_proposal_validator.ts → proposal_validator/proposal_validator.ts} +24 -29
- package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +206 -0
- package/src/msg_validators/tx_validator/archive_cache.ts +1 -1
- package/src/msg_validators/tx_validator/block_header_validator.ts +1 -1
- package/src/msg_validators/tx_validator/data_validator.ts +12 -4
- package/src/msg_validators/tx_validator/factory.ts +1 -1
- package/src/msg_validators/tx_validator/fee_payer_balance.ts +40 -0
- package/src/msg_validators/tx_validator/gas_validator.ts +8 -25
- package/src/msg_validators/tx_validator/metadata_validator.ts +13 -5
- package/src/msg_validators/tx_validator/test_utils.ts +1 -1
- package/src/msg_validators/tx_validator/timestamp_validator.ts +3 -1
- package/src/services/dummy_service.ts +6 -0
- package/src/services/encoding.ts +4 -2
- package/src/services/libp2p/instrumentation.ts +19 -73
- package/src/services/libp2p/libp2p_service.ts +336 -117
- package/src/services/peer-manager/metrics.ts +22 -21
- package/src/services/peer-manager/peer_manager.ts +5 -4
- package/src/services/peer-manager/peer_scoring.ts +1 -5
- package/src/services/reqresp/connection-sampler/connection_sampler.ts +3 -1
- package/src/services/reqresp/constants.ts +14 -0
- package/src/services/reqresp/interface.ts +3 -3
- package/src/services/reqresp/metrics.ts +7 -23
- package/src/services/reqresp/protocols/auth.ts +2 -2
- package/src/services/reqresp/protocols/block.ts +1 -1
- package/src/services/reqresp/protocols/block_txs/bitvector.ts +9 -0
- package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +1 -1
- package/src/services/reqresp/protocols/status.ts +7 -4
- package/src/services/reqresp/protocols/tx.ts +1 -2
- package/src/services/service.ts +19 -4
- package/src/services/tx_collection/config.ts +1 -1
- package/src/services/tx_collection/instrumentation.ts +4 -21
- package/src/services/tx_collection/slow_tx_collection.ts +2 -2
- package/src/services/tx_collection/tx_collection.ts +4 -4
- package/src/services/tx_provider.ts +17 -2
- package/src/services/tx_provider_instrumentation.ts +18 -14
- package/src/test-helpers/mock-pubsub.ts +1 -1
- package/src/test-helpers/mock-tx-helpers.ts +1 -1
- package/src/test-helpers/reqresp-nodes.ts +1 -1
- package/src/testbench/p2p_client_testbench_worker.ts +37 -13
- package/src/testbench/worker_client_manager.ts +6 -1
- package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -81
- 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 -239
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -12
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
- 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 -285
- package/src/msg_validators/block_proposal_validator/index.ts +0 -1
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
import { MockL2BlockSource } from '@aztec/archiver/test';
|
|
7
7
|
import type { EpochCacheInterface } from '@aztec/epoch-cache';
|
|
8
8
|
import { EpochNumber, SlotNumber } from '@aztec/foundation/branded-types';
|
|
9
|
+
import { SecretValue } from '@aztec/foundation/config';
|
|
9
10
|
import { EthAddress } from '@aztec/foundation/eth-address';
|
|
10
11
|
import { createLogger } from '@aztec/foundation/log';
|
|
11
12
|
import { sleep } from '@aztec/foundation/sleep';
|
|
@@ -56,6 +57,7 @@ function mockTxPool(): TxPool {
|
|
|
56
57
|
hasTx: () => Promise.resolve(false),
|
|
57
58
|
updateConfig: () => {},
|
|
58
59
|
markTxsAsNonEvictable: () => Promise.resolve(),
|
|
60
|
+
clearNonEvictableTxs: () => Promise.resolve(),
|
|
59
61
|
cleanupDeletedMinedTxs: () => Promise.resolve(0),
|
|
60
62
|
};
|
|
61
63
|
return Object.assign(new EventEmitter(), pool);
|
|
@@ -64,25 +66,29 @@ function mockTxPool(): TxPool {
|
|
|
64
66
|
function mockAttestationPool(): AttestationPool {
|
|
65
67
|
return {
|
|
66
68
|
isEmpty: () => Promise.resolve(false),
|
|
67
|
-
addAttestations: () => Promise.resolve(),
|
|
68
|
-
deleteAttestations: () => Promise.resolve(),
|
|
69
|
-
deleteAttestationsOlderThan: () => Promise.resolve(),
|
|
70
|
-
deleteAttestationsForSlot: () => Promise.resolve(),
|
|
71
|
-
deleteAttestationsForSlotAndProposal: () => Promise.resolve(),
|
|
72
|
-
getAttestationsForSlot: () => Promise.resolve([]),
|
|
73
|
-
getAttestationsForSlotAndProposal: () => Promise.resolve([]),
|
|
74
69
|
addBlockProposal: () => Promise.resolve(),
|
|
75
70
|
getBlockProposal: () => Promise.resolve(undefined),
|
|
76
71
|
hasBlockProposal: () => Promise.resolve(false),
|
|
77
|
-
hasAttestation: () => Promise.resolve(false),
|
|
78
72
|
canAddProposal: () => Promise.resolve(true),
|
|
79
|
-
|
|
73
|
+
// Checkpoint attestation methods
|
|
74
|
+
addCheckpointProposal: () => Promise.resolve(),
|
|
75
|
+
getCheckpointProposal: () => Promise.resolve(undefined),
|
|
76
|
+
hasCheckpointProposal: () => Promise.resolve(false),
|
|
77
|
+
addCheckpointAttestations: () => Promise.resolve(),
|
|
78
|
+
getCheckpointAttestationsForSlot: () => Promise.resolve([]),
|
|
79
|
+
getCheckpointAttestationsForSlotAndProposal: () => Promise.resolve([]),
|
|
80
|
+
deleteCheckpointAttestationsOlderThan: () => Promise.resolve(),
|
|
81
|
+
hasReachedCheckpointProposalCap: () => Promise.resolve(false),
|
|
82
|
+
hasReachedCheckpointAttestationCap: () => Promise.resolve(false),
|
|
83
|
+
canAddCheckpointProposal: () => Promise.resolve(true),
|
|
84
|
+
canAddCheckpointAttestation: () => Promise.resolve(true),
|
|
85
|
+
hasCheckpointAttestation: () => Promise.resolve(false),
|
|
80
86
|
};
|
|
81
87
|
}
|
|
82
88
|
|
|
83
89
|
function mockEpochCache(): EpochCacheInterface {
|
|
84
90
|
return {
|
|
85
|
-
getCommittee: () => Promise.resolve({ committee: [], seed: 1n, epoch: EpochNumber.ZERO }),
|
|
91
|
+
getCommittee: () => Promise.resolve({ committee: [], seed: 1n, epoch: EpochNumber.ZERO, isEscapeHatchOpen: false }),
|
|
86
92
|
getProposerIndexEncoding: () => '0x' as `0x${string}`,
|
|
87
93
|
getEpochAndSlotNow: () => ({ epoch: EpochNumber.ZERO, slot: SlotNumber.ZERO, ts: 0n }),
|
|
88
94
|
computeProposerIndex: () => 0n,
|
|
@@ -93,6 +99,7 @@ function mockEpochCache(): EpochCacheInterface {
|
|
|
93
99
|
currentSlot: SlotNumber.ZERO,
|
|
94
100
|
nextSlot: SlotNumber.ZERO,
|
|
95
101
|
}),
|
|
102
|
+
getProposerAttesterAddressInSlot: () => Promise.resolve(undefined),
|
|
96
103
|
getEpochAndSlotInNextL1Slot: () => ({ epoch: EpochNumber.ZERO, slot: SlotNumber.ZERO, ts: 0n, now: 0n }),
|
|
97
104
|
isInCommittee: () => Promise.resolve(false),
|
|
98
105
|
getRegisteredValidators: () => Promise.resolve([]),
|
|
@@ -126,7 +133,7 @@ class TestLibP2PService<T extends P2PClientType = P2PClientType.Full> extends Li
|
|
|
126
133
|
peerDiscoveryService: PeerDiscoveryService,
|
|
127
134
|
reqresp: ReqResp,
|
|
128
135
|
peerManager: PeerManager,
|
|
129
|
-
mempools: MemPools
|
|
136
|
+
mempools: MemPools,
|
|
130
137
|
archiver: L2BlockSource & ContractDataSource,
|
|
131
138
|
epochCache: EpochCacheInterface,
|
|
132
139
|
proofVerifier: ClientProtocolCircuitVerifier,
|
|
@@ -188,9 +195,25 @@ class TestLibP2PService<T extends P2PClientType = P2PClientType.Full> extends Li
|
|
|
188
195
|
|
|
189
196
|
// eslint-disable-next-line @typescript-eslint/no-misused-promises
|
|
190
197
|
process.on('message', async msg => {
|
|
191
|
-
|
|
198
|
+
// Note: peerIdPrivateKey comes as a raw string (not SecretValue) because
|
|
199
|
+
// SecretValue's private fields can't be serialized via IPC
|
|
200
|
+
const {
|
|
201
|
+
type,
|
|
202
|
+
config: rawConfig,
|
|
203
|
+
clientIndex,
|
|
204
|
+
} = msg as {
|
|
205
|
+
type: string;
|
|
206
|
+
config: Omit<P2PConfig, 'peerIdPrivateKey'> & { peerIdPrivateKey?: string };
|
|
207
|
+
clientIndex: number;
|
|
208
|
+
};
|
|
192
209
|
try {
|
|
193
210
|
if (type === 'START') {
|
|
211
|
+
// Re-wrap the peerIdPrivateKey with SecretValue
|
|
212
|
+
const config: P2PConfig = {
|
|
213
|
+
...rawConfig,
|
|
214
|
+
peerIdPrivateKey: rawConfig.peerIdPrivateKey ? new SecretValue(rawConfig.peerIdPrivateKey) : undefined,
|
|
215
|
+
} as P2PConfig;
|
|
216
|
+
|
|
194
217
|
const txPool = mockTxPool();
|
|
195
218
|
const attestationPool = mockAttestationPool();
|
|
196
219
|
const epochCache = mockEpochCache();
|
|
@@ -223,14 +246,15 @@ process.on('message', async msg => {
|
|
|
223
246
|
);
|
|
224
247
|
|
|
225
248
|
// Create test service with validation disabled
|
|
249
|
+
// Note: Parameter order must match LibP2PService constructor
|
|
226
250
|
const testService = new TestLibP2PService(
|
|
227
251
|
P2PClientType.Full,
|
|
228
252
|
config,
|
|
229
253
|
(client as any).p2pService.node,
|
|
230
254
|
(client as any).p2pService.peerDiscoveryService,
|
|
231
|
-
(client as any).p2pService.mempools,
|
|
232
255
|
(client as any).p2pService.reqresp,
|
|
233
256
|
(client as any).p2pService.peerManager,
|
|
257
|
+
(client as any).p2pService.mempools,
|
|
234
258
|
(client as any).p2pService.archiver,
|
|
235
259
|
epochCache,
|
|
236
260
|
proofVerifier,
|
|
@@ -73,7 +73,12 @@ class WorkerClientManager {
|
|
|
73
73
|
clientIndex: number,
|
|
74
74
|
): [ChildProcess, Promise<void>] {
|
|
75
75
|
const childProcess = fork(workerPath);
|
|
76
|
-
|
|
76
|
+
// Extract the raw peerIdPrivateKey value since SecretValue can't be serialized via IPC
|
|
77
|
+
const serializedConfig = {
|
|
78
|
+
...config,
|
|
79
|
+
peerIdPrivateKey: config.peerIdPrivateKey?.getValue(),
|
|
80
|
+
};
|
|
81
|
+
childProcess.send({ type: 'START', config: serializedConfig, clientIndex });
|
|
77
82
|
|
|
78
83
|
// Handle unexpected child process exit
|
|
79
84
|
childProcess.on('exit', (code, signal) => {
|
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import { BlockNumber } from '@aztec/foundation/branded-types';
|
|
2
|
-
import type { TypedEventEmitter } from '@aztec/foundation/types';
|
|
3
|
-
import { BlockHeader, Tx, TxHash } from '@aztec/stdlib/tx';
|
|
4
|
-
import { type TelemetryClient } from '@aztec/telemetry-client';
|
|
5
|
-
import type { TxPool, TxPoolEvents, TxPoolOptions } from './tx_pool.js';
|
|
6
|
-
declare const InMemoryTxPool_base: new () => TypedEventEmitter<TxPoolEvents>;
|
|
7
|
-
/**
|
|
8
|
-
* In-memory implementation of the Transaction Pool.
|
|
9
|
-
*/
|
|
10
|
-
export declare class InMemoryTxPool extends InMemoryTxPool_base implements TxPool {
|
|
11
|
-
private log;
|
|
12
|
-
/**
|
|
13
|
-
* Our tx pool, stored as a Map in-memory, with K: tx hash and V: the transaction.
|
|
14
|
-
*/
|
|
15
|
-
private txs;
|
|
16
|
-
private minedTxs;
|
|
17
|
-
private pendingTxs;
|
|
18
|
-
private deletedMinedTxHashes;
|
|
19
|
-
private blockToDeletedMinedTxHash;
|
|
20
|
-
private metrics;
|
|
21
|
-
/**
|
|
22
|
-
* Class constructor for in-memory TxPool. Initiates our transaction pool as a JS Map.
|
|
23
|
-
* @param log - A logger.
|
|
24
|
-
*/
|
|
25
|
-
constructor(telemetry?: TelemetryClient, log?: import("@aztec/foundation/log").Logger);
|
|
26
|
-
private countTx;
|
|
27
|
-
isEmpty(): Promise<boolean>;
|
|
28
|
-
markAsMined(txHashes: TxHash[], blockHeader: BlockHeader): Promise<void>;
|
|
29
|
-
markMinedAsPending(txHashes: TxHash[]): Promise<void>;
|
|
30
|
-
getPendingTxHashes(): Promise<TxHash[]>;
|
|
31
|
-
getMinedTxHashes(): Promise<[TxHash, BlockNumber][]>;
|
|
32
|
-
getPendingTxCount(): Promise<number>;
|
|
33
|
-
getTxStatus(txHash: TxHash): Promise<'pending' | 'mined' | 'deleted' | undefined>;
|
|
34
|
-
/**
|
|
35
|
-
* Checks if a transaction exists in the pool and returns it.
|
|
36
|
-
* @param txHash - The generated tx hash.
|
|
37
|
-
* @returns The transaction, if found, 'undefined' otherwise.
|
|
38
|
-
*/
|
|
39
|
-
getTxByHash(txHash: TxHash): Promise<Tx | undefined>;
|
|
40
|
-
getTxsByHash(txHashes: TxHash[]): Promise<(Tx | undefined)[]>;
|
|
41
|
-
hasTxs(txHashes: TxHash[]): Promise<boolean[]>;
|
|
42
|
-
hasTx(txHash: TxHash): Promise<boolean>;
|
|
43
|
-
getArchivedTxByHash(): Promise<Tx | undefined>;
|
|
44
|
-
/**
|
|
45
|
-
* Adds a list of transactions to the pool. Duplicates are ignored.
|
|
46
|
-
* @param txs - An array of txs to be added to the pool.
|
|
47
|
-
* @returns Empty promise.
|
|
48
|
-
*/
|
|
49
|
-
addTxs(txs: Tx[], opts?: {
|
|
50
|
-
source?: string;
|
|
51
|
-
}): Promise<number>;
|
|
52
|
-
/**
|
|
53
|
-
* Deletes transactions from the pool. Tx hashes that are not present are ignored.
|
|
54
|
-
* Mined transactions are soft-deleted with a timestamp, pending transactions are permanently deleted.
|
|
55
|
-
* @param txHashes - An array of tx hashes to be deleted from the tx pool.
|
|
56
|
-
* @returns Empty promise.
|
|
57
|
-
*/
|
|
58
|
-
deleteTxs(txHashes: TxHash[], opts?: {
|
|
59
|
-
permanently?: boolean;
|
|
60
|
-
}): Promise<void>;
|
|
61
|
-
/**
|
|
62
|
-
* Gets all the transactions stored in the pool.
|
|
63
|
-
* @returns Array of tx objects in the order they were added to the pool.
|
|
64
|
-
*/
|
|
65
|
-
getAllTxs(): Promise<Tx[]>;
|
|
66
|
-
/**
|
|
67
|
-
* Gets the hashes of all transactions currently in the tx pool.
|
|
68
|
-
* @returns An array of transaction hashes found in the tx pool.
|
|
69
|
-
*/
|
|
70
|
-
getAllTxHashes(): Promise<TxHash[]>;
|
|
71
|
-
updateConfig(_config: TxPoolOptions): void;
|
|
72
|
-
markTxsAsNonEvictable(_: TxHash[]): Promise<void>;
|
|
73
|
-
/**
|
|
74
|
-
* Permanently deletes deleted mined transactions from blocks up to and including the specified block number.
|
|
75
|
-
* @param blockNumber - Block number threshold. Deleted mined txs from this block or earlier will be permanently deleted.
|
|
76
|
-
* @returns The number of transactions permanently deleted.
|
|
77
|
-
*/
|
|
78
|
-
cleanupDeletedMinedTxs(blockNumber: BlockNumber): Promise<number>;
|
|
79
|
-
}
|
|
80
|
-
export {};
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVtb3J5X3R4X3Bvb2wuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tZW1fcG9vbHMvdHhfcG9vbC9tZW1vcnlfdHhfcG9vbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFFOUQsT0FBTyxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUVqRSxPQUFPLEVBQUUsV0FBVyxFQUFFLEVBQUUsRUFBRSxNQUFNLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUMzRCxPQUFPLEVBQUUsS0FBSyxlQUFlLEVBQXNCLE1BQU0seUJBQXlCLENBQUM7QUFNbkYsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsTUFBTSxjQUFjLENBQUM7O0FBRXhFOztHQUVHO0FBQ0gscUJBQWEsY0FBZSxTQUFRLG1CQUE0RCxZQUFXLE1BQU07SUFtQjdHLE9BQU8sQ0FBQyxHQUFHO0lBbEJiOztPQUVHO0lBQ0gsT0FBTyxDQUFDLEdBQUcsQ0FBa0I7SUFDN0IsT0FBTyxDQUFDLFFBQVEsQ0FBMkI7SUFDM0MsT0FBTyxDQUFDLFVBQVUsQ0FBYztJQUNoQyxPQUFPLENBQUMsb0JBQW9CLENBQTJCO0lBRXZELE9BQU8sQ0FBQyx5QkFBeUIsQ0FBZ0M7SUFFakUsT0FBTyxDQUFDLE9BQU8sQ0FBMEI7SUFFekM7OztPQUdHO0lBQ0gsWUFDRSxTQUFTLEdBQUUsZUFBc0MsRUFDekMsR0FBRyx5Q0FBOEIsRUFTMUM7SUFFRCxPQUFPLENBQUMsT0FBTyxDQU9iO0lBRUssT0FBTyxJQUFJLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FFakM7SUFFTSxXQUFXLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxFQUFFLFdBQVcsRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQW9COUU7SUFFTSxrQkFBa0IsQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQWdCM0Q7SUFFWSxrQkFBa0IsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FXbkQ7SUFFTSxnQkFBZ0IsSUFBSSxPQUFPLENBQUMsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUkxRDtJQUVNLGlCQUFpQixJQUFJLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FHMUM7SUFFTSxXQUFXLENBQUMsTUFBTSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsU0FBUyxHQUFHLE9BQU8sR0FBRyxTQUFTLEdBQUcsU0FBUyxDQUFDLENBYXZGO0lBRUQ7Ozs7T0FJRztJQUNJLFdBQVcsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxFQUFFLEdBQUcsU0FBUyxDQUFDLENBRzFEO0lBRUQsWUFBWSxDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsR0FBRyxPQUFPLENBQUMsQ0FBQyxFQUFFLEdBQUcsU0FBUyxDQUFDLEVBQUUsQ0FBQyxDQUU1RDtJQUNELE1BQU0sQ0FBQyxRQUFRLEVBQUUsTUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBRTdDO0lBRUssS0FBSyxDQUFDLE1BQU0sRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUc1QztJQUVNLG1CQUFtQixJQUFJLE9BQU8sQ0FBQyxFQUFFLEdBQUcsU0FBUyxDQUFDLENBRXBEO0lBRUQ7Ozs7T0FJRztJQUNJLE1BQU0sQ0FBQyxHQUFHLEVBQUUsRUFBRSxFQUFFLEVBQUUsSUFBSSxHQUFFO1FBQUUsTUFBTSxDQUFDLEVBQUUsTUFBTSxDQUFBO0tBQU8sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBd0J4RTtJQUVEOzs7OztPQUtHO0lBQ0ksU0FBUyxDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsRUFBRSxJQUFJLENBQUMsRUFBRTtRQUFFLFdBQVcsQ0FBQyxFQUFFLE9BQU8sQ0FBQTtLQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQTJCcEY7SUFFRDs7O09BR0c7SUFDSSxTQUFTLElBQUksT0FBTyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBRWhDO0lBRUQ7OztPQUdHO0lBQ0ksY0FBYyxJQUFJLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUV6QztJQUVELFlBQVksQ0FBQyxPQUFPLEVBQUUsYUFBYSxHQUFHLElBQUksQ0FBRztJQUU3QyxxQkFBcUIsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUVoRDtJQUVEOzs7O09BSUc7SUFDSSxzQkFBc0IsQ0FBQyxXQUFXLEVBQUUsV0FBVyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0EwQnZFO0NBQ0YifQ==
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"memory_tx_pool.d.ts","sourceRoot":"","sources":["../../../src/mem_pools/tx_pool/memory_tx_pool.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAE9D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAC;AAEjE,OAAO,EAAE,WAAW,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAE,KAAK,eAAe,EAAsB,MAAM,yBAAyB,CAAC;AAMnF,OAAO,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;;AAExE;;GAEG;AACH,qBAAa,cAAe,SAAQ,mBAA4D,YAAW,MAAM;IAmB7G,OAAO,CAAC,GAAG;IAlBb;;OAEG;IACH,OAAO,CAAC,GAAG,CAAkB;IAC7B,OAAO,CAAC,QAAQ,CAA2B;IAC3C,OAAO,CAAC,UAAU,CAAc;IAChC,OAAO,CAAC,oBAAoB,CAA2B;IAEvD,OAAO,CAAC,yBAAyB,CAAgC;IAEjE,OAAO,CAAC,OAAO,CAA0B;IAEzC;;;OAGG;IACH,YACE,SAAS,GAAE,eAAsC,EACzC,GAAG,yCAA8B,EAS1C;IAED,OAAO,CAAC,OAAO,CAOb;IAEK,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,CAEjC;IAEM,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAoB9E;IAEM,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAgB3D;IAEY,kBAAkB,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,CAWnD;IAEM,gBAAgB,IAAI,OAAO,CAAC,CAAC,MAAM,EAAE,WAAW,CAAC,EAAE,CAAC,CAI1D;IAEM,iBAAiB,IAAI,OAAO,CAAC,MAAM,CAAC,CAG1C;IAEM,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,OAAO,GAAG,SAAS,GAAG,SAAS,CAAC,CAavF;IAED;;;;OAIG;IACI,WAAW,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,EAAE,GAAG,SAAS,CAAC,CAG1D;IAED,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC,EAAE,GAAG,SAAS,CAAC,EAAE,CAAC,CAE5D;IACD,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,CAE7C;IAEK,KAAK,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAG5C;IAEM,mBAAmB,IAAI,OAAO,CAAC,EAAE,GAAG,SAAS,CAAC,CAEpD;IAED;;;;OAIG;IACI,MAAM,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,IAAI,GAAE;QAAE,MAAM,CAAC,EAAE,MAAM,CAAA;KAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAwBxE;IAED;;;;;OAKG;IACI,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE,IAAI,CAAC,EAAE;QAAE,WAAW,CAAC,EAAE,OAAO,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CA2BpF;IAED;;;OAGG;IACI,SAAS,IAAI,OAAO,CAAC,EAAE,EAAE,CAAC,CAEhC;IAED;;;OAGG;IACI,cAAc,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC,CAEzC;IAED,YAAY,CAAC,OAAO,EAAE,aAAa,GAAG,IAAI,CAAG;IAE7C,qBAAqB,CAAC,CAAC,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAEhD;IAED;;;;OAIG;IACI,sBAAsB,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CA0BvE;CACF"}
|
|
@@ -1,239 +0,0 @@
|
|
|
1
|
-
import { createLogger } from '@aztec/foundation/log';
|
|
2
|
-
import { Tx, TxHash } from '@aztec/stdlib/tx';
|
|
3
|
-
import { getTelemetryClient } from '@aztec/telemetry-client';
|
|
4
|
-
import EventEmitter from 'node:events';
|
|
5
|
-
import { PoolInstrumentation, PoolName } from '../instrumentation.js';
|
|
6
|
-
import { getPendingTxPriority } from './priority.js';
|
|
7
|
-
/**
|
|
8
|
-
* In-memory implementation of the Transaction Pool.
|
|
9
|
-
*/ export class InMemoryTxPool extends EventEmitter {
|
|
10
|
-
log;
|
|
11
|
-
/**
|
|
12
|
-
* Our tx pool, stored as a Map in-memory, with K: tx hash and V: the transaction.
|
|
13
|
-
*/ txs;
|
|
14
|
-
minedTxs;
|
|
15
|
-
pendingTxs;
|
|
16
|
-
deletedMinedTxHashes;
|
|
17
|
-
// eslint-disable-next-line aztec-custom/no-non-primitive-in-collections
|
|
18
|
-
blockToDeletedMinedTxHash;
|
|
19
|
-
metrics;
|
|
20
|
-
/**
|
|
21
|
-
* Class constructor for in-memory TxPool. Initiates our transaction pool as a JS Map.
|
|
22
|
-
* @param log - A logger.
|
|
23
|
-
*/ constructor(telemetry = getTelemetryClient(), log = createLogger('p2p:tx_pool')){
|
|
24
|
-
super(), this.log = log, this.countTx = ()=>{
|
|
25
|
-
return Promise.resolve({
|
|
26
|
-
itemCount: {
|
|
27
|
-
mined: this.minedTxs.size,
|
|
28
|
-
pending: this.pendingTxs.size
|
|
29
|
-
}
|
|
30
|
-
});
|
|
31
|
-
};
|
|
32
|
-
this.txs = new Map();
|
|
33
|
-
this.minedTxs = new Map();
|
|
34
|
-
this.pendingTxs = new Set();
|
|
35
|
-
this.deletedMinedTxHashes = new Map();
|
|
36
|
-
this.blockToDeletedMinedTxHash = new Map();
|
|
37
|
-
this.metrics = new PoolInstrumentation(telemetry, PoolName.TX_POOL, this.countTx);
|
|
38
|
-
}
|
|
39
|
-
countTx;
|
|
40
|
-
isEmpty() {
|
|
41
|
-
return Promise.resolve(this.txs.size === 0);
|
|
42
|
-
}
|
|
43
|
-
markAsMined(txHashes, blockHeader) {
|
|
44
|
-
const keys = txHashes.map((x)=>x.toBigInt());
|
|
45
|
-
for (const key of keys){
|
|
46
|
-
// If this tx was previously soft-deleted, remove it from the deleted sets
|
|
47
|
-
if (this.deletedMinedTxHashes.has(key)) {
|
|
48
|
-
const originalBlock = this.deletedMinedTxHashes.get(key);
|
|
49
|
-
this.deletedMinedTxHashes.delete(key);
|
|
50
|
-
// Remove from block-to-hash mapping
|
|
51
|
-
const txHashesForBlock = this.blockToDeletedMinedTxHash.get(originalBlock);
|
|
52
|
-
if (txHashesForBlock) {
|
|
53
|
-
txHashesForBlock.delete(key);
|
|
54
|
-
if (txHashesForBlock.size === 0) {
|
|
55
|
-
this.blockToDeletedMinedTxHash.delete(originalBlock);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
this.minedTxs.set(key, blockHeader.globalVariables.blockNumber);
|
|
60
|
-
this.pendingTxs.delete(key);
|
|
61
|
-
}
|
|
62
|
-
return Promise.resolve();
|
|
63
|
-
}
|
|
64
|
-
markMinedAsPending(txHashes) {
|
|
65
|
-
if (txHashes.length === 0) {
|
|
66
|
-
return Promise.resolve();
|
|
67
|
-
}
|
|
68
|
-
const keys = txHashes.map((x)=>x.toBigInt());
|
|
69
|
-
for (const key of keys){
|
|
70
|
-
this.minedTxs.delete(key);
|
|
71
|
-
// only add back to the pending set if we have the tx object
|
|
72
|
-
if (this.txs.has(key)) {
|
|
73
|
-
this.pendingTxs.add(key);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
return Promise.resolve();
|
|
77
|
-
}
|
|
78
|
-
async getPendingTxHashes() {
|
|
79
|
-
const txs = (await this.getAllTxs()).sort((tx1, tx2)=>-getPendingTxPriority(tx1).localeCompare(getPendingTxPriority(tx2)));
|
|
80
|
-
const txHashes = await Promise.all(txs.map((tx)=>tx.getTxHash()));
|
|
81
|
-
// No need to check deleted since pending txs are never soft-deleted
|
|
82
|
-
return txHashes.filter((txHash)=>{
|
|
83
|
-
const key = txHash.toBigInt();
|
|
84
|
-
return this.pendingTxs.has(key);
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
getMinedTxHashes() {
|
|
88
|
-
return Promise.resolve(Array.from(this.minedTxs.entries()).map(([txHash, blockNumber])=>[
|
|
89
|
-
TxHash.fromBigInt(txHash),
|
|
90
|
-
blockNumber
|
|
91
|
-
]));
|
|
92
|
-
}
|
|
93
|
-
getPendingTxCount() {
|
|
94
|
-
// Soft-deleted transactions are always mined, never pending
|
|
95
|
-
return Promise.resolve(this.pendingTxs.size);
|
|
96
|
-
}
|
|
97
|
-
getTxStatus(txHash) {
|
|
98
|
-
const key = txHash.toBigInt();
|
|
99
|
-
if (this.deletedMinedTxHashes.has(key)) {
|
|
100
|
-
return Promise.resolve('deleted');
|
|
101
|
-
}
|
|
102
|
-
if (this.minedTxs.has(key)) {
|
|
103
|
-
return Promise.resolve('mined');
|
|
104
|
-
}
|
|
105
|
-
if (this.pendingTxs.has(key)) {
|
|
106
|
-
return Promise.resolve('pending');
|
|
107
|
-
}
|
|
108
|
-
return Promise.resolve(undefined);
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Checks if a transaction exists in the pool and returns it.
|
|
112
|
-
* @param txHash - The generated tx hash.
|
|
113
|
-
* @returns The transaction, if found, 'undefined' otherwise.
|
|
114
|
-
*/ getTxByHash(txHash) {
|
|
115
|
-
const result = this.txs.get(txHash.toBigInt());
|
|
116
|
-
return Promise.resolve(result === undefined ? undefined : Tx.clone(result));
|
|
117
|
-
}
|
|
118
|
-
getTxsByHash(txHashes) {
|
|
119
|
-
return Promise.all(txHashes.map((txHash)=>this.getTxByHash(txHash)));
|
|
120
|
-
}
|
|
121
|
-
hasTxs(txHashes) {
|
|
122
|
-
return Promise.resolve(txHashes.map((txHash)=>this.txs.has(txHash.toBigInt())));
|
|
123
|
-
}
|
|
124
|
-
async hasTx(txHash) {
|
|
125
|
-
const result = await this.hasTxs([
|
|
126
|
-
txHash
|
|
127
|
-
]);
|
|
128
|
-
return result[0];
|
|
129
|
-
}
|
|
130
|
-
getArchivedTxByHash() {
|
|
131
|
-
return Promise.resolve(undefined);
|
|
132
|
-
}
|
|
133
|
-
/**
|
|
134
|
-
* Adds a list of transactions to the pool. Duplicates are ignored.
|
|
135
|
-
* @param txs - An array of txs to be added to the pool.
|
|
136
|
-
* @returns Empty promise.
|
|
137
|
-
*/ addTxs(txs, opts = {}) {
|
|
138
|
-
const added = [];
|
|
139
|
-
for (const tx of txs){
|
|
140
|
-
const txHash = tx.getTxHash();
|
|
141
|
-
this.log.verbose(`Adding tx ${txHash.toString()} to pool`, {
|
|
142
|
-
eventName: 'tx-added-to-pool',
|
|
143
|
-
...tx.getStats()
|
|
144
|
-
});
|
|
145
|
-
const key = txHash.toBigInt();
|
|
146
|
-
if (!this.txs.has(key)) {
|
|
147
|
-
added.push(tx);
|
|
148
|
-
this.txs.set(key, tx);
|
|
149
|
-
}
|
|
150
|
-
if (!this.minedTxs.has(key)) {
|
|
151
|
-
this.metrics.recordSize(tx);
|
|
152
|
-
this.pendingTxs.add(key);
|
|
153
|
-
}
|
|
154
|
-
}
|
|
155
|
-
if (added.length > 0) {
|
|
156
|
-
this.emit('txs-added', {
|
|
157
|
-
...opts,
|
|
158
|
-
txs: added
|
|
159
|
-
});
|
|
160
|
-
}
|
|
161
|
-
return Promise.resolve(added.length);
|
|
162
|
-
}
|
|
163
|
-
/**
|
|
164
|
-
* Deletes transactions from the pool. Tx hashes that are not present are ignored.
|
|
165
|
-
* Mined transactions are soft-deleted with a timestamp, pending transactions are permanently deleted.
|
|
166
|
-
* @param txHashes - An array of tx hashes to be deleted from the tx pool.
|
|
167
|
-
* @returns Empty promise.
|
|
168
|
-
*/ deleteTxs(txHashes, opts) {
|
|
169
|
-
for (const txHash of txHashes){
|
|
170
|
-
const key = txHash.toBigInt();
|
|
171
|
-
if (this.txs.has(key)) {
|
|
172
|
-
if (this.minedTxs.has(key)) {
|
|
173
|
-
const blockNumber = this.minedTxs.get(key);
|
|
174
|
-
this.minedTxs.delete(key);
|
|
175
|
-
// Soft-delete mined transactions: remove from mined set but keep in storage
|
|
176
|
-
if (opts?.permanently) {
|
|
177
|
-
// Permanently delete mined transactions if specified
|
|
178
|
-
this.txs.delete(key);
|
|
179
|
-
} else {
|
|
180
|
-
this.deletedMinedTxHashes.set(key, blockNumber);
|
|
181
|
-
if (!this.blockToDeletedMinedTxHash.has(blockNumber)) {
|
|
182
|
-
this.blockToDeletedMinedTxHash.set(blockNumber, new Set());
|
|
183
|
-
}
|
|
184
|
-
this.blockToDeletedMinedTxHash.get(blockNumber).add(key);
|
|
185
|
-
}
|
|
186
|
-
} else {
|
|
187
|
-
// Permanently delete pending transactions
|
|
188
|
-
this.txs.delete(key);
|
|
189
|
-
this.pendingTxs.delete(key);
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
return Promise.resolve();
|
|
194
|
-
}
|
|
195
|
-
/**
|
|
196
|
-
* Gets all the transactions stored in the pool.
|
|
197
|
-
* @returns Array of tx objects in the order they were added to the pool.
|
|
198
|
-
*/ getAllTxs() {
|
|
199
|
-
return Promise.resolve(Array.from(this.txs.values()).map((x)=>Tx.clone(x)));
|
|
200
|
-
}
|
|
201
|
-
/**
|
|
202
|
-
* Gets the hashes of all transactions currently in the tx pool.
|
|
203
|
-
* @returns An array of transaction hashes found in the tx pool.
|
|
204
|
-
*/ getAllTxHashes() {
|
|
205
|
-
return Promise.resolve(Array.from(this.txs.keys()).map((x)=>TxHash.fromBigInt(x)));
|
|
206
|
-
}
|
|
207
|
-
updateConfig(_config) {}
|
|
208
|
-
markTxsAsNonEvictable(_) {
|
|
209
|
-
return Promise.resolve();
|
|
210
|
-
}
|
|
211
|
-
/**
|
|
212
|
-
* Permanently deletes deleted mined transactions from blocks up to and including the specified block number.
|
|
213
|
-
* @param blockNumber - Block number threshold. Deleted mined txs from this block or earlier will be permanently deleted.
|
|
214
|
-
* @returns The number of transactions permanently deleted.
|
|
215
|
-
*/ cleanupDeletedMinedTxs(blockNumber) {
|
|
216
|
-
let deletedCount = 0;
|
|
217
|
-
const blocksToDelete = [];
|
|
218
|
-
// Find all blocks up to the specified block number
|
|
219
|
-
for (const [block, txHashes] of this.blockToDeletedMinedTxHash.entries()){
|
|
220
|
-
if (block <= blockNumber) {
|
|
221
|
-
// Permanently delete all transactions from this block
|
|
222
|
-
for (const txHash of txHashes){
|
|
223
|
-
this.txs.delete(txHash);
|
|
224
|
-
this.deletedMinedTxHashes.delete(txHash);
|
|
225
|
-
deletedCount++;
|
|
226
|
-
}
|
|
227
|
-
blocksToDelete.push(block);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
// Clean up block-to-hash mapping
|
|
231
|
-
for (const block of blocksToDelete){
|
|
232
|
-
this.blockToDeletedMinedTxHash.delete(block);
|
|
233
|
-
}
|
|
234
|
-
if (deletedCount > 0) {
|
|
235
|
-
this.log.debug(`Permanently deleted ${deletedCount} deleted mined txs from blocks up to ${blockNumber}`);
|
|
236
|
-
}
|
|
237
|
-
return Promise.resolve(deletedCount);
|
|
238
|
-
}
|
|
239
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { EpochCacheInterface } from '@aztec/epoch-cache';
|
|
2
|
-
import { type BlockProposal, type P2PValidator, PeerErrorSeverity } from '@aztec/stdlib/p2p';
|
|
3
|
-
export declare class BlockProposalValidator implements P2PValidator<BlockProposal> {
|
|
4
|
-
private epochCache;
|
|
5
|
-
private logger;
|
|
6
|
-
private txsPermitted;
|
|
7
|
-
constructor(epochCache: EpochCacheInterface, opts: {
|
|
8
|
-
txsPermitted: boolean;
|
|
9
|
-
});
|
|
10
|
-
validate(block: BlockProposal): Promise<PeerErrorSeverity | undefined>;
|
|
11
|
-
}
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2tfcHJvcG9zYWxfdmFsaWRhdG9yLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbXNnX3ZhbGlkYXRvcnMvYmxvY2tfcHJvcG9zYWxfdmFsaWRhdG9yL2Jsb2NrX3Byb3Bvc2FsX3ZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRzlELE9BQU8sRUFBRSxLQUFLLGFBQWEsRUFBRSxLQUFLLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRTdGLHFCQUFhLHNCQUF1QixZQUFXLFlBQVksQ0FBQyxhQUFhLENBQUM7SUFDeEUsT0FBTyxDQUFDLFVBQVUsQ0FBc0I7SUFDeEMsT0FBTyxDQUFDLE1BQU0sQ0FBUztJQUN2QixPQUFPLENBQUMsWUFBWSxDQUFVO0lBRTlCLFlBQVksVUFBVSxFQUFFLG1CQUFtQixFQUFFLElBQUksRUFBRTtRQUFFLFlBQVksRUFBRSxPQUFPLENBQUE7S0FBRSxFQUkzRTtJQUVLLFFBQVEsQ0FBQyxLQUFLLEVBQUUsYUFBYSxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsR0FBRyxTQUFTLENBQUMsQ0ErRTNFO0NBQ0YifQ==
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"block_proposal_validator.d.ts","sourceRoot":"","sources":["../../../src/msg_validators/block_proposal_validator/block_proposal_validator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAG9D,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,YAAY,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAE7F,qBAAa,sBAAuB,YAAW,YAAY,CAAC,aAAa,CAAC;IACxE,OAAO,CAAC,UAAU,CAAsB;IACxC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,YAAY,CAAU;IAE9B,YAAY,UAAU,EAAE,mBAAmB,EAAE,IAAI,EAAE;QAAE,YAAY,EAAE,OAAO,CAAA;KAAE,EAI3E;IAEK,QAAQ,CAAC,KAAK,EAAE,aAAa,GAAG,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CA+E3E;CACF"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export * from './block_proposal_validator.js';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tc2dfdmFsaWRhdG9ycy9ibG9ja19wcm9wb3NhbF92YWxpZGF0b3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQyJ9
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/msg_validators/block_proposal_validator/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from './block_proposal_validator.js';
|