@aztec/p2p 0.75.0-commit.c03ba01a2a4122e43e90d5133ba017e54b90e9d2 → 0.76.0
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 +38 -0
- package/dest/bootstrap/bootstrap.d.ts.map +1 -0
- package/dest/bootstrap/bootstrap.js +31 -38
- package/dest/client/factory.d.ts +21 -0
- package/dest/client/factory.d.ts.map +1 -0
- package/dest/client/factory.js +13 -11
- package/dest/client/index.d.ts +3 -0
- package/dest/client/index.d.ts.map +1 -0
- package/dest/client/index.js +1 -0
- package/dest/client/p2p_client.d.ts +332 -0
- package/dest/client/p2p_client.d.ts.map +1 -0
- package/dest/client/p2p_client.js +535 -513
- package/dest/config.d.ts +187 -0
- package/dest/config.d.ts.map +1 -0
- package/dest/config.js +64 -53
- package/dest/errors/reqresp.error.d.ts +28 -0
- package/dest/errors/reqresp.error.d.ts.map +1 -0
- package/dest/errors/reqresp.error.js +10 -6
- package/dest/index.d.ts +9 -0
- package/dest/index.d.ts.map +1 -0
- package/dest/index.js +1 -0
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +57 -0
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -0
- package/dest/mem_pools/attestation_pool/attestation_pool.js +2 -6
- package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +3 -0
- package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -0
- package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +32 -64
- package/dest/mem_pools/attestation_pool/index.d.ts +3 -0
- package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -0
- package/dest/mem_pools/attestation_pool/index.js +1 -0
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +22 -0
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -0
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +19 -22
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +17 -0
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +1 -0
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +26 -22
- package/dest/mem_pools/attestation_pool/mocks.d.ts +18 -0
- package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -0
- package/dest/mem_pools/attestation_pool/mocks.js +6 -10
- package/dest/mem_pools/epoch_proof_quote_pool/epoch_proof_quote_pool.d.ts +7 -0
- package/dest/mem_pools/epoch_proof_quote_pool/epoch_proof_quote_pool.d.ts.map +1 -0
- package/dest/mem_pools/epoch_proof_quote_pool/epoch_proof_quote_pool.js +2 -1
- package/dest/mem_pools/epoch_proof_quote_pool/index.d.ts +4 -0
- package/dest/mem_pools/epoch_proof_quote_pool/index.d.ts.map +1 -0
- package/dest/mem_pools/epoch_proof_quote_pool/index.js +1 -0
- package/dest/mem_pools/epoch_proof_quote_pool/memory_epoch_proof_quote_pool.d.ts +12 -0
- package/dest/mem_pools/epoch_proof_quote_pool/memory_epoch_proof_quote_pool.d.ts.map +1 -0
- package/dest/mem_pools/epoch_proof_quote_pool/memory_epoch_proof_quote_pool.js +4 -5
- package/dest/mem_pools/epoch_proof_quote_pool/test_utils.d.ts +8 -0
- package/dest/mem_pools/epoch_proof_quote_pool/test_utils.d.ts.map +1 -0
- package/dest/mem_pools/epoch_proof_quote_pool/test_utils.js +3 -2
- package/dest/mem_pools/index.d.ts +5 -0
- package/dest/mem_pools/index.d.ts.map +1 -0
- package/dest/mem_pools/index.js +2 -1
- package/dest/mem_pools/instrumentation.d.ts +31 -0
- package/dest/mem_pools/instrumentation.d.ts.map +1 -0
- package/dest/mem_pools/instrumentation.js +42 -37
- package/dest/mem_pools/interface.d.ts +13 -0
- package/dest/mem_pools/interface.d.ts.map +1 -0
- package/dest/mem_pools/interface.js +2 -3
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +66 -0
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +134 -127
- package/dest/mem_pools/tx_pool/index.d.ts +4 -0
- package/dest/mem_pools/tx_pool/index.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/index.js +1 -0
- package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +56 -0
- package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/memory_tx_pool.js +43 -45
- package/dest/mem_pools/tx_pool/priority.d.ts +8 -0
- package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/priority.js +3 -1
- package/dest/mem_pools/tx_pool/tx_pool.d.ts +66 -0
- package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/tx_pool.js +2 -3
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +7 -0
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -0
- package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +37 -107
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +8 -0
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -0
- package/dest/msg_validators/attestation_validator/attestation_validator.js +3 -3
- package/dest/msg_validators/attestation_validator/index.d.ts +2 -0
- package/dest/msg_validators/attestation_validator/index.d.ts.map +1 -0
- package/dest/msg_validators/attestation_validator/index.js +1 -0
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +8 -0
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +1 -0
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +2 -2
- package/dest/msg_validators/block_proposal_validator/index.d.ts +2 -0
- package/dest/msg_validators/block_proposal_validator/index.d.ts.map +1 -0
- package/dest/msg_validators/block_proposal_validator/index.js +1 -0
- package/dest/msg_validators/epoch_proof_quote_validator/epoch_proof_quote_validator.d.ts +8 -0
- package/dest/msg_validators/epoch_proof_quote_validator/epoch_proof_quote_validator.d.ts.map +1 -0
- package/dest/msg_validators/epoch_proof_quote_validator/epoch_proof_quote_validator.js +2 -2
- package/dest/msg_validators/epoch_proof_quote_validator/index.d.ts +2 -0
- package/dest/msg_validators/epoch_proof_quote_validator/index.d.ts.map +1 -0
- package/dest/msg_validators/epoch_proof_quote_validator/index.js +1 -0
- package/dest/msg_validators/index.d.ts +4 -0
- package/dest/msg_validators/index.d.ts.map +1 -0
- package/dest/msg_validators/index.js +1 -0
- package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +7 -0
- package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +11 -9
- package/dest/msg_validators/tx_validator/block_header_validator.d.ts +11 -0
- package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/block_header_validator.js +12 -17
- package/dest/msg_validators/tx_validator/data_validator.d.ts +6 -0
- package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/data_validator.js +32 -41
- package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +12 -0
- package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/double_spend_validator.js +14 -22
- package/dest/msg_validators/tx_validator/index.d.ts +7 -0
- package/dest/msg_validators/tx_validator/index.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/index.js +1 -0
- package/dest/msg_validators/tx_validator/metadata_validator.d.ts +10 -0
- package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/metadata_validator.js +26 -29
- package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +8 -0
- package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -0
- package/dest/msg_validators/tx_validator/tx_proof_validator.js +12 -17
- package/dest/services/data_store.d.ts +27 -0
- package/dest/services/data_store.d.ts.map +1 -0
- package/dest/services/data_store.js +57 -57
- package/dest/services/discv5/discV5_service.d.ts +40 -0
- package/dest/services/discv5/discV5_service.d.ts.map +1 -0
- package/dest/services/discv5/discV5_service.js +82 -43
- package/dest/services/dummy_service.d.ts +83 -0
- package/dest/services/dummy_service.d.ts.map +1 -0
- package/dest/services/dummy_service.js +59 -40
- package/dest/services/encoding.d.ts +31 -0
- package/dest/services/encoding.d.ts.map +1 -0
- package/dest/services/encoding.js +9 -10
- package/dest/services/index.d.ts +3 -0
- package/dest/services/index.d.ts.map +1 -0
- package/dest/services/index.js +1 -0
- package/dest/services/libp2p/libp2p_logger.d.ts +7 -0
- package/dest/services/libp2p/libp2p_logger.d.ts.map +1 -0
- package/dest/services/libp2p/libp2p_logger.js +67 -0
- package/dest/services/libp2p/libp2p_service.d.ts +225 -0
- package/dest/services/libp2p/libp2p_service.d.ts.map +1 -0
- package/dest/services/libp2p/libp2p_service.js +727 -709
- package/dest/services/peer-manager/metrics.d.ts +12 -0
- package/dest/services/peer-manager/metrics.d.ts.map +1 -0
- package/dest/services/peer-manager/metrics.js +7 -14
- package/dest/services/peer-manager/peer_manager.d.ts +76 -0
- package/dest/services/peer-manager/peer_manager.d.ts.map +1 -0
- package/dest/services/peer-manager/peer_manager.js +342 -340
- package/dest/services/peer-manager/peer_scoring.d.ts +28 -0
- package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -0
- package/dest/services/peer-manager/peer_scoring.js +18 -20
- package/dest/services/reqresp/config.d.ts +16 -0
- package/dest/services/reqresp/config.d.ts.map +1 -0
- package/dest/services/reqresp/config.js +5 -4
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +45 -0
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -0
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +28 -35
- package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +61 -0
- package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -0
- package/dest/services/reqresp/connection-sampler/connection_sampler.js +59 -60
- package/dest/services/reqresp/index.d.ts +6 -0
- package/dest/services/reqresp/index.d.ts.map +1 -0
- package/dest/services/reqresp/index.js +3 -1
- package/dest/services/reqresp/interface.d.ts +116 -0
- package/dest/services/reqresp/interface.d.ts.map +1 -0
- package/dest/services/reqresp/interface.js +30 -25
- package/dest/services/reqresp/metrics.d.ts +15 -0
- package/dest/services/reqresp/metrics.d.ts.map +1 -0
- package/dest/services/reqresp/metrics.js +10 -23
- package/dest/services/reqresp/protocols/block.d.ts +4 -0
- package/dest/services/reqresp/protocols/block.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/block.js +2 -1
- package/dest/services/reqresp/protocols/goodbye.d.ts +51 -0
- package/dest/services/reqresp/protocols/goodbye.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/goodbye.js +41 -36
- package/dest/services/reqresp/protocols/index.d.ts +9 -0
- package/dest/services/reqresp/protocols/index.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/index.js +3 -1
- package/dest/services/reqresp/protocols/ping.d.ts +9 -0
- package/dest/services/reqresp/protocols/ping.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/ping.js +3 -1
- package/dest/services/reqresp/protocols/status.d.ts +9 -0
- package/dest/services/reqresp/protocols/status.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/status.js +3 -1
- package/dest/services/reqresp/protocols/tx.d.ts +13 -0
- package/dest/services/reqresp/protocols/tx.d.ts.map +1 -0
- package/dest/services/reqresp/protocols/tx.js +8 -5
- package/dest/services/reqresp/rate-limiter/index.d.ts +2 -0
- package/dest/services/reqresp/rate-limiter/index.d.ts.map +1 -0
- package/dest/services/reqresp/rate-limiter/index.js +1 -0
- package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +102 -0
- package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -0
- package/dest/services/reqresp/rate-limiter/rate_limiter.js +35 -39
- package/dest/services/reqresp/rate-limiter/rate_limits.d.ts +3 -0
- package/dest/services/reqresp/rate-limiter/rate_limits.d.ts.map +1 -0
- package/dest/services/reqresp/rate-limiter/rate_limits.js +17 -16
- package/dest/services/reqresp/reqresp.d.ts +166 -0
- package/dest/services/reqresp/reqresp.d.ts.map +1 -0
- package/dest/services/reqresp/reqresp.js +463 -460
- package/dest/services/reqresp/status.d.ts +31 -0
- package/dest/services/reqresp/status.d.ts.map +1 -0
- package/dest/services/reqresp/status.js +17 -16
- package/dest/services/service.d.ts +86 -0
- package/dest/services/service.d.ts.map +1 -0
- package/dest/services/service.js +4 -3
- package/dest/services/types.d.ts +32 -0
- package/dest/services/types.d.ts.map +1 -0
- package/dest/services/types.js +19 -20
- package/dest/test-helpers/generate-peer-id-private-keys.d.ts +7 -0
- package/dest/test-helpers/generate-peer-id-private-keys.d.ts.map +1 -0
- package/dest/test-helpers/generate-peer-id-private-keys.js +15 -0
- package/dest/test-helpers/get-ports.d.ts +7 -0
- package/dest/test-helpers/get-ports.d.ts.map +1 -0
- package/dest/test-helpers/get-ports.js +8 -0
- package/dest/test-helpers/index.d.ts +6 -0
- package/dest/test-helpers/index.d.ts.map +1 -0
- package/dest/test-helpers/index.js +6 -0
- package/dest/test-helpers/make-enrs.d.ts +16 -0
- package/dest/test-helpers/make-enrs.d.ts.map +1 -0
- package/dest/test-helpers/make-enrs.js +35 -0
- package/dest/test-helpers/make-test-p2p-clients.d.ts +37 -0
- package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -0
- package/dest/test-helpers/make-test-p2p-clients.js +71 -0
- package/dest/test-helpers/reqresp-nodes.d.ts +55 -0
- package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -0
- package/dest/test-helpers/reqresp-nodes.js +183 -0
- package/dest/testbench/p2p_client_testbench_worker.d.ts +2 -0
- package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -0
- package/dest/testbench/p2p_client_testbench_worker.js +125 -0
- package/dest/util.d.ts +53 -0
- package/dest/util.d.ts.map +1 -0
- package/dest/util.js +34 -23
- package/dest/versioning.d.ts +12 -0
- package/dest/versioning.d.ts.map +1 -0
- package/dest/versioning.js +38 -0
- package/package.json +11 -9
- package/src/bootstrap/bootstrap.ts +9 -3
- package/src/client/factory.ts +12 -5
- package/src/config.ts +56 -29
- package/src/mem_pools/index.ts +3 -3
- package/src/mem_pools/instrumentation.ts +2 -3
- package/src/msg_validators/attestation_validator/attestation_validator.ts +3 -3
- package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +3 -3
- package/src/msg_validators/epoch_proof_quote_validator/epoch_proof_quote_validator.ts +3 -3
- package/src/services/discv5/discV5_service.ts +67 -18
- package/src/services/dummy_service.ts +2 -0
- package/src/services/libp2p/libp2p_logger.ts +78 -0
- package/src/services/libp2p/libp2p_service.ts +47 -10
- package/src/services/reqresp/protocols/goodbye.ts +1 -1
- package/src/services/reqresp/reqresp.ts +9 -1
- package/src/services/service.ts +2 -0
- package/src/services/types.ts +2 -10
- package/src/test-helpers/generate-peer-id-private-keys.ts +15 -0
- package/src/test-helpers/get-ports.ts +8 -0
- package/src/test-helpers/index.ts +5 -0
- package/src/test-helpers/make-enrs.ts +44 -0
- package/src/test-helpers/make-test-p2p-clients.ts +124 -0
- package/src/{mocks/index.ts → test-helpers/reqresp-nodes.ts} +10 -5
- package/src/testbench/README.md +20 -0
- package/src/testbench/p2p_client_testbench_worker.ts +156 -0
- package/src/testbench/scripts/run_testbench.sh +7 -0
- package/src/versioning.ts +50 -0
- package/dest/mocks/index.js +0 -190
|
@@ -2,78 +2,96 @@ import EventEmitter from 'events';
|
|
|
2
2
|
import { PeerDiscoveryState } from './service.js';
|
|
3
3
|
/**
|
|
4
4
|
* A dummy implementation of the P2P Service.
|
|
5
|
-
*/
|
|
6
|
-
|
|
5
|
+
*/
|
|
6
|
+
export class DummyP2PService {
|
|
7
|
+
/** Returns an empty array for peers. */
|
|
8
|
+
getPeers() {
|
|
7
9
|
return [];
|
|
8
10
|
}
|
|
9
11
|
/**
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
12
|
+
* Starts the dummy implementation.
|
|
13
|
+
* @returns A resolved promise.
|
|
14
|
+
*/
|
|
15
|
+
start() {
|
|
13
16
|
return Promise.resolve();
|
|
14
17
|
}
|
|
15
18
|
/**
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
+
* Stops the dummy implementation.
|
|
20
|
+
* @returns A resolved promise.
|
|
21
|
+
*/
|
|
22
|
+
stop() {
|
|
19
23
|
return Promise.resolve();
|
|
20
24
|
}
|
|
21
25
|
/**
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
26
|
+
* Called to have the given message propagated through the P2P network.
|
|
27
|
+
* @param _ - The message to be propagated.
|
|
28
|
+
*/
|
|
29
|
+
propagate(_) { }
|
|
25
30
|
/**
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
31
|
+
* Called upon receipt of settled transactions.
|
|
32
|
+
* @param _ - The hashes of the settled transactions.
|
|
33
|
+
*/
|
|
34
|
+
settledTxs(_) { }
|
|
29
35
|
/**
|
|
30
|
-
|
|
31
|
-
|
|
36
|
+
* Register a callback into the validator client for when a block proposal is received
|
|
37
|
+
*/
|
|
38
|
+
registerBlockReceivedCallback(_) { }
|
|
32
39
|
/**
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
40
|
+
* Sends a request to a peer.
|
|
41
|
+
* @param _protocol - The protocol to send the request on.
|
|
42
|
+
* @param _request - The request to send.
|
|
43
|
+
* @returns The response from the peer, otherwise undefined.
|
|
44
|
+
*/
|
|
45
|
+
sendRequest(_protocol, _request) {
|
|
38
46
|
return Promise.resolve(undefined);
|
|
39
47
|
}
|
|
40
48
|
/**
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
49
|
+
* Sends a batch request to a peer.
|
|
50
|
+
* @param _protocol - The protocol to send the request on.
|
|
51
|
+
* @param _requests - The requests to send.
|
|
52
|
+
* @returns The responses from the peer, otherwise undefined.
|
|
53
|
+
*/
|
|
54
|
+
sendBatchRequest(_protocol, _requests) {
|
|
46
55
|
return Promise.resolve([]);
|
|
47
56
|
}
|
|
48
57
|
/**
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
58
|
+
* Returns the ENR of the peer.
|
|
59
|
+
* @returns The ENR of the peer, otherwise undefined.
|
|
60
|
+
*/
|
|
61
|
+
getEnr() {
|
|
52
62
|
return undefined;
|
|
53
63
|
}
|
|
54
64
|
}
|
|
55
65
|
/**
|
|
56
66
|
* A dummy implementation of the Peer Discovery Service.
|
|
57
|
-
*/
|
|
58
|
-
|
|
67
|
+
*/
|
|
68
|
+
export class DummyPeerDiscoveryService extends EventEmitter {
|
|
69
|
+
constructor() {
|
|
70
|
+
super(...arguments);
|
|
71
|
+
this.currentState = PeerDiscoveryState.STOPPED;
|
|
72
|
+
this.bootstrapNodes = [];
|
|
73
|
+
}
|
|
59
74
|
/**
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
75
|
+
* Starts the dummy implementation.
|
|
76
|
+
* @returns A resolved promise.
|
|
77
|
+
*/
|
|
78
|
+
start() {
|
|
63
79
|
this.currentState = PeerDiscoveryState.RUNNING;
|
|
64
80
|
return Promise.resolve();
|
|
65
81
|
}
|
|
66
82
|
/**
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
83
|
+
* Stops the dummy implementation.
|
|
84
|
+
* @returns A resolved promise.
|
|
85
|
+
*/
|
|
86
|
+
stop() {
|
|
70
87
|
this.currentState = PeerDiscoveryState.STOPPED;
|
|
71
88
|
return Promise.resolve();
|
|
72
89
|
}
|
|
73
90
|
/**
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
91
|
+
* Called to discover peers in the network.
|
|
92
|
+
* @returns An array of discovered peer addresses.
|
|
93
|
+
*/
|
|
94
|
+
getAllPeers() {
|
|
77
95
|
return [];
|
|
78
96
|
}
|
|
79
97
|
runRandomNodesQuery() {
|
|
@@ -89,3 +107,4 @@ import { PeerDiscoveryState } from './service.js';
|
|
|
89
107
|
return undefined;
|
|
90
108
|
}
|
|
91
109
|
}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHVtbXlfc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXJ2aWNlcy9kdW1teV9zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sWUFBWSxNQUFNLFFBQVEsQ0FBQztBQUdsQyxPQUFPLEVBQThDLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRTlGOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGVBQWU7SUFDMUIsd0NBQXdDO0lBQ3hDLFFBQVE7UUFDTixPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRDs7O09BR0c7SUFDSSxLQUFLO1FBQ1YsT0FBTyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVEOzs7T0FHRztJQUNJLElBQUk7UUFDVCxPQUFPLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksU0FBUyxDQUF1QixDQUFJLElBQUcsQ0FBQztJQUUvQzs7O09BR0c7SUFDSSxVQUFVLENBQUMsQ0FBVyxJQUFHLENBQUM7SUFFakM7O09BRUc7SUFDSSw2QkFBNkIsQ0FBQyxDQUFzRCxJQUFHLENBQUM7SUFFL0Y7Ozs7O09BS0c7SUFDSSxXQUFXLENBQ2hCLFNBQW1CLEVBQ25CLFFBQTJEO1FBRTNELE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxnQkFBZ0IsQ0FDckIsU0FBbUIsRUFDbkIsU0FBOEQ7UUFFOUQsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRDs7O09BR0c7SUFDSSxNQUFNO1FBQ1gsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztDQUNGO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8seUJBQTBCLFNBQVEsWUFBWTtJQUEzRDs7UUFDVSxpQkFBWSxHQUFHLGtCQUFrQixDQUFDLE9BQU8sQ0FBQztRQUMzQyxtQkFBYyxHQUFhLEVBQUUsQ0FBQztJQXlDdkMsQ0FBQztJQXZDQzs7O09BR0c7SUFDSSxLQUFLO1FBQ1YsSUFBSSxDQUFDLFlBQVksR0FBRyxrQkFBa0IsQ0FBQyxPQUFPLENBQUM7UUFDL0MsT0FBTyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUNEOzs7T0FHRztJQUNJLElBQUk7UUFDVCxJQUFJLENBQUMsWUFBWSxHQUFHLGtCQUFrQixDQUFDLE9BQU8sQ0FBQztRQUMvQyxPQUFPLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBQ0Q7OztPQUdHO0lBQ0ksV0FBVztRQUNoQixPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFTSxtQkFBbUI7UUFDeEIsT0FBTyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVNLGVBQWUsQ0FBQyxDQUFTO1FBQzlCLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVNLFNBQVM7UUFDZCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDM0IsQ0FBQztJQUVNLE1BQU07UUFDWCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0NBQ0YifQ==
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
+
/// <reference types="node" resolution-mode="require"/>
|
|
3
|
+
import { type RPC } from '@chainsafe/libp2p-gossipsub/message';
|
|
4
|
+
import { type DataTransform } from '@chainsafe/libp2p-gossipsub/types';
|
|
5
|
+
import { type Message } from '@libp2p/interface';
|
|
6
|
+
/**
|
|
7
|
+
* The function used to generate a gossipsub message id
|
|
8
|
+
* We use the first 8 bytes of SHA256(data) for content addressing
|
|
9
|
+
*/
|
|
10
|
+
export declare function fastMsgIdFn(rpcMsg: RPC.Message): string;
|
|
11
|
+
export declare function msgIdToStrFn(msgId: Uint8Array): string;
|
|
12
|
+
/**
|
|
13
|
+
* Get the message identifier from a libp2p message
|
|
14
|
+
*
|
|
15
|
+
* Follows similarly to:
|
|
16
|
+
* https://github.com/ethereum/consensus-specs/blob/v1.1.0-alpha.7/specs/altair/p2p-interface.md#topics-and-messages
|
|
17
|
+
*
|
|
18
|
+
* @param message - The libp2p message
|
|
19
|
+
* @returns The message identifier
|
|
20
|
+
*/
|
|
21
|
+
export declare function getMsgIdFn(message: Message): Buffer;
|
|
22
|
+
/**
|
|
23
|
+
* Snappy transform for libp2p gossipsub
|
|
24
|
+
*/
|
|
25
|
+
export declare class SnappyTransform implements DataTransform {
|
|
26
|
+
inboundTransform(_topicStr: string, data: Uint8Array): Uint8Array;
|
|
27
|
+
inboundTransformNoTopic(data: Buffer): Buffer;
|
|
28
|
+
outboundTransform(_topicStr: string, data: Uint8Array): Uint8Array;
|
|
29
|
+
outboundTransformNoTopic(data: Buffer): Buffer;
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=encoding.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encoding.d.ts","sourceRoot":"","sources":["../../src/services/encoding.ts"],"names":[],"mappings":";;AAGA,OAAO,EAAE,KAAK,GAAG,EAAE,MAAM,qCAAqC,CAAC;AAC/D,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAajD;;;GAGG;AACH,wBAAgB,WAAW,CAAC,MAAM,EAAE,GAAG,CAAC,OAAO,GAAG,MAAM,CAKvD;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,UAAU,GAAG,MAAM,CAItD;AAED;;;;;;;;GAQG;AACH,wBAAgB,UAAU,CAAC,OAAO,EAAE,OAAO,UAK1C;AAED;;GAEG;AACH,qBAAa,eAAgB,YAAW,aAAa;IAEnD,gBAAgB,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,UAAU;IAI1D,uBAAuB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAQpD,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,UAAU;IAI3D,wBAAwB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;CAMtD"}
|
|
@@ -11,7 +11,8 @@ const sharedMsgIdBuf = Buffer.alloc(20);
|
|
|
11
11
|
/**
|
|
12
12
|
* The function used to generate a gossipsub message id
|
|
13
13
|
* We use the first 8 bytes of SHA256(data) for content addressing
|
|
14
|
-
*/
|
|
14
|
+
*/
|
|
15
|
+
export function fastMsgIdFn(rpcMsg) {
|
|
15
16
|
if (rpcMsg.data) {
|
|
16
17
|
return xxhash.h64Raw(rpcMsg.data, h64Seed).toString(16);
|
|
17
18
|
}
|
|
@@ -30,17 +31,16 @@ export function msgIdToStrFn(msgId) {
|
|
|
30
31
|
*
|
|
31
32
|
* @param message - The libp2p message
|
|
32
33
|
* @returns The message identifier
|
|
33
|
-
*/
|
|
34
|
+
*/
|
|
35
|
+
export function getMsgIdFn(message) {
|
|
34
36
|
const { topic } = message;
|
|
35
|
-
const vec = [
|
|
36
|
-
Buffer.from(topic),
|
|
37
|
-
message.data
|
|
38
|
-
];
|
|
37
|
+
const vec = [Buffer.from(topic), message.data];
|
|
39
38
|
return sha256(Buffer.concat(vec)).subarray(0, 20);
|
|
40
39
|
}
|
|
41
40
|
/**
|
|
42
41
|
* Snappy transform for libp2p gossipsub
|
|
43
|
-
*/
|
|
42
|
+
*/
|
|
43
|
+
export class SnappyTransform {
|
|
44
44
|
// Topic string included to satisfy DataTransform interface
|
|
45
45
|
inboundTransform(_topicStr, data) {
|
|
46
46
|
return this.inboundTransformNoTopic(Buffer.from(data));
|
|
@@ -49,9 +49,7 @@ export function msgIdToStrFn(msgId) {
|
|
|
49
49
|
if (data.length === 0) {
|
|
50
50
|
return data;
|
|
51
51
|
}
|
|
52
|
-
return Buffer.from(uncompressSync(data, {
|
|
53
|
-
asBuffer: true
|
|
54
|
-
}));
|
|
52
|
+
return Buffer.from(uncompressSync(data, { asBuffer: true }));
|
|
55
53
|
}
|
|
56
54
|
// Topic string included to satisfy DataTransform interface
|
|
57
55
|
outboundTransform(_topicStr, data) {
|
|
@@ -64,3 +62,4 @@ export function msgIdToStrFn(msgId) {
|
|
|
64
62
|
return Buffer.from(compressSync(data));
|
|
65
63
|
}
|
|
66
64
|
}
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5jb2RpbmcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VydmljZXMvZW5jb2RpbmcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsNkRBQTZEO0FBQzdELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUtsRCxPQUFPLEVBQUUsWUFBWSxFQUFFLGNBQWMsRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUN0RCxPQUFPLGFBQWEsTUFBTSxhQUFhLENBQUM7QUFFeEMsWUFBWTtBQUNaLE1BQU0sTUFBTSxHQUFHLE1BQU0sYUFBYSxFQUFFLENBQUM7QUFFckMsNERBQTREO0FBQzVELE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDO0FBRXhELDJDQUEyQztBQUMzQyxNQUFNLGNBQWMsR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBRXhDOzs7R0FHRztBQUNILE1BQU0sVUFBVSxXQUFXLENBQUMsTUFBbUI7SUFDN0MsSUFBSSxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDaEIsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUMsUUFBUSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFDRCxPQUFPLGtCQUFrQixDQUFDO0FBQzVCLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLEtBQWlCO0lBQzVDLDBEQUEwRDtJQUMxRCxjQUFjLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzFCLE9BQU8sS0FBSyxjQUFjLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7QUFDL0MsQ0FBQztBQUVEOzs7Ozs7OztHQVFHO0FBQ0gsTUFBTSxVQUFVLFVBQVUsQ0FBQyxPQUFnQjtJQUN6QyxNQUFNLEVBQUUsS0FBSyxFQUFFLEdBQUcsT0FBTyxDQUFDO0lBRTFCLE1BQU0sR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0MsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDcEQsQ0FBQztBQUVEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGVBQWU7SUFDMUIsMkRBQTJEO0lBQzNELGdCQUFnQixDQUFDLFNBQWlCLEVBQUUsSUFBZ0I7UUFDbEQsT0FBTyxJQUFJLENBQUMsdUJBQXVCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ3pELENBQUM7SUFFTSx1QkFBdUIsQ0FBQyxJQUFZO1FBQ3pDLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUN0QixPQUFPLElBQUksQ0FBQztRQUNkLENBQUM7UUFDRCxPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDL0QsQ0FBQztJQUVELDJEQUEyRDtJQUMzRCxpQkFBaUIsQ0FBQyxTQUFpQixFQUFFLElBQWdCO1FBQ25ELE9BQU8sSUFBSSxDQUFDLHdCQUF3QixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUMxRCxDQUFDO0lBRU0sd0JBQXdCLENBQUMsSUFBWTtRQUMxQyxJQUFJLElBQUksQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdEIsT0FBTyxJQUFJLENBQUM7UUFDZCxDQUFDO1FBQ0QsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7Q0FDRiJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/services/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,cAAc,4BAA4B,CAAC"}
|
package/dest/services/index.js
CHANGED
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
export * from './service.js';
|
|
2
2
|
export * from './libp2p/libp2p_service.js';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VydmljZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyw0QkFBNEIsQ0FBQyJ9
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { type ComponentLogger } from '@libp2p/interface';
|
|
2
|
+
/**
|
|
3
|
+
* Creates a libp2p compatible logger that wraps our pino logger.
|
|
4
|
+
* This adapter implements the ComponentLogger interface required by libp2p.
|
|
5
|
+
*/
|
|
6
|
+
export declare function createLibp2pComponentLogger(namespace: string, fixedTerms?: {}): ComponentLogger;
|
|
7
|
+
//# sourceMappingURL=libp2p_logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"libp2p_logger.d.ts","sourceRoot":"","sources":["../../../src/services/libp2p/libp2p_logger.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,eAAe,EAAe,MAAM,mBAAmB,CAAC;AAEtE;;;GAGG;AACH,wBAAgB,2BAA2B,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,KAAK,GAAG,eAAe,CAI/F"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { createLogger } from '@aztec/foundation/log';
|
|
2
|
+
/**
|
|
3
|
+
* Creates a libp2p compatible logger that wraps our pino logger.
|
|
4
|
+
* This adapter implements the ComponentLogger interface required by libp2p.
|
|
5
|
+
*/
|
|
6
|
+
export function createLibp2pComponentLogger(namespace, fixedTerms = {}) {
|
|
7
|
+
return {
|
|
8
|
+
forComponent: (component) => createLibp2pLogger(`${namespace}:${component}`, fixedTerms),
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
function createLibp2pLogger(component, fixedTerms = {}) {
|
|
12
|
+
const logger = createLogger(component, fixedTerms);
|
|
13
|
+
// Default log level is trace as this is super super noisy
|
|
14
|
+
const logFn = (formatter, ...args) => {
|
|
15
|
+
// Handle %p format specifier by manually replacing with args
|
|
16
|
+
if (typeof formatter === 'string' && args.length > 0) {
|
|
17
|
+
// Handle %p, %a, %s and %d format specifiers
|
|
18
|
+
const parts = formatter.split(/(%p|%a|%s|%d)/);
|
|
19
|
+
let result = parts[0];
|
|
20
|
+
let argIndex = 0;
|
|
21
|
+
for (let i = 1; i < parts.length; i += 2) {
|
|
22
|
+
if (argIndex < args.length) {
|
|
23
|
+
result += String(args[argIndex]) + (parts[i + 1] || '');
|
|
24
|
+
argIndex++;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
formatter = result;
|
|
28
|
+
// Only keep non-format args as data
|
|
29
|
+
args = args.slice(argIndex);
|
|
30
|
+
}
|
|
31
|
+
// Handle object args by spreading them, but only if they weren't used in formatting
|
|
32
|
+
if (args.length === 1 && typeof args[0] === 'object') {
|
|
33
|
+
logger.trace(formatter, args[0]);
|
|
34
|
+
}
|
|
35
|
+
else if (args.length > 0) {
|
|
36
|
+
// If we have remaining args after formatting, pass them as data
|
|
37
|
+
logger.trace(formatter, { _args: args });
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
logger.trace(formatter);
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
return Object.assign(logFn, {
|
|
44
|
+
enabled: logger.isLevelEnabled('debug'),
|
|
45
|
+
error(...args) {
|
|
46
|
+
const [msg, ...rest] = args;
|
|
47
|
+
logger.error(msg, ...rest);
|
|
48
|
+
},
|
|
49
|
+
debug(...args) {
|
|
50
|
+
const [msg, ...rest] = args;
|
|
51
|
+
logger.debug(msg, ...rest);
|
|
52
|
+
},
|
|
53
|
+
info(...args) {
|
|
54
|
+
const [msg, ...rest] = args;
|
|
55
|
+
logger.info(msg, ...rest);
|
|
56
|
+
},
|
|
57
|
+
warn(...args) {
|
|
58
|
+
const [msg, ...rest] = args;
|
|
59
|
+
logger.warn(msg, ...rest);
|
|
60
|
+
},
|
|
61
|
+
trace(...args) {
|
|
62
|
+
const [msg, ...rest] = args;
|
|
63
|
+
logger.trace(msg, ...rest);
|
|
64
|
+
},
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicDJwX2xvZ2dlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZXJ2aWNlcy9saWJwMnAvbGlicDJwX2xvZ2dlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFJckQ7OztHQUdHO0FBQ0gsTUFBTSxVQUFVLDJCQUEyQixDQUFDLFNBQWlCLEVBQUUsVUFBVSxHQUFHLEVBQUU7SUFDNUUsT0FBTztRQUNMLFlBQVksRUFBRSxDQUFDLFNBQWlCLEVBQUUsRUFBRSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsU0FBUyxJQUFJLFNBQVMsRUFBRSxFQUFFLFVBQVUsQ0FBQztLQUNqRyxDQUFDO0FBQ0osQ0FBQztBQUVELFNBQVMsa0JBQWtCLENBQUMsU0FBaUIsRUFBRSxVQUFVLEdBQUcsRUFBRTtJQUM1RCxNQUFNLE1BQU0sR0FBRyxZQUFZLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBRW5ELDBEQUEwRDtJQUMxRCxNQUFNLEtBQUssR0FBRyxDQUFDLFNBQWMsRUFBRSxHQUFHLElBQVcsRUFBRSxFQUFFO1FBQy9DLDZEQUE2RDtRQUM3RCxJQUFJLE9BQU8sU0FBUyxLQUFLLFFBQVEsSUFBSSxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ3JELDZDQUE2QztZQUM3QyxNQUFNLEtBQUssR0FBRyxTQUFTLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQy9DLElBQUksTUFBTSxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN0QixJQUFJLFFBQVEsR0FBRyxDQUFDLENBQUM7WUFFakIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO2dCQUN6QyxJQUFJLFFBQVEsR0FBRyxJQUFJLENBQUMsTUFB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
|
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
import { BlockAttestation, BlockProposal, type ClientProtocolCircuitVerifier, EpochProofQuote, type Gossipable, type L2BlockSource, P2PClientType, type PeerInfo, type WorldStateSynchronizer } from '@aztec/circuit-types';
|
|
2
|
+
import { type EpochCacheInterface } from '@aztec/epoch-cache';
|
|
3
|
+
import type { AztecAsyncKVStore } from '@aztec/kv-store';
|
|
4
|
+
import { type TelemetryClient, WithTracer } from '@aztec/telemetry-client';
|
|
5
|
+
import { type ENR } from '@chainsafe/enr';
|
|
6
|
+
import { type PeerId } from '@libp2p/interface';
|
|
7
|
+
import '@libp2p/kad-dht';
|
|
8
|
+
import { type P2PConfig } from '../../config.js';
|
|
9
|
+
import { type MemPools } from '../../mem_pools/interface.js';
|
|
10
|
+
import { type PubSubLibp2p } from '../../util.js';
|
|
11
|
+
import { ReqRespSubProtocol, type SubProtocolMap } from '../reqresp/interface.js';
|
|
12
|
+
import { ReqResp } from '../reqresp/reqresp.js';
|
|
13
|
+
import type { P2PService, PeerDiscoveryService } from '../service.js';
|
|
14
|
+
/**
|
|
15
|
+
* Lib P2P implementation of the P2PService interface.
|
|
16
|
+
*/
|
|
17
|
+
export declare class LibP2PService<T extends P2PClientType> extends WithTracer implements P2PService {
|
|
18
|
+
private clientType;
|
|
19
|
+
private config;
|
|
20
|
+
private node;
|
|
21
|
+
private peerDiscoveryService;
|
|
22
|
+
private mempools;
|
|
23
|
+
private l2BlockSource;
|
|
24
|
+
private proofVerifier;
|
|
25
|
+
private worldStateSynchronizer;
|
|
26
|
+
private logger;
|
|
27
|
+
private jobQueue;
|
|
28
|
+
private peerManager;
|
|
29
|
+
private discoveryRunningPromise?;
|
|
30
|
+
private attestationValidator;
|
|
31
|
+
private blockProposalValidator;
|
|
32
|
+
private epochProofQuoteValidator;
|
|
33
|
+
reqresp: ReqResp;
|
|
34
|
+
/**
|
|
35
|
+
* Callback for when a block is received from a peer.
|
|
36
|
+
* @param block - The block received from the peer.
|
|
37
|
+
* @returns The attestation for the block, if any.
|
|
38
|
+
*/
|
|
39
|
+
private blockReceivedCallback;
|
|
40
|
+
constructor(clientType: T, config: P2PConfig, node: PubSubLibp2p, peerDiscoveryService: PeerDiscoveryService, mempools: MemPools<T>, l2BlockSource: L2BlockSource, epochCache: EpochCacheInterface, proofVerifier: ClientProtocolCircuitVerifier, worldStateSynchronizer: WorldStateSynchronizer, telemetry: TelemetryClient, logger?: import("@aztec/foundation/log").Logger);
|
|
41
|
+
/**
|
|
42
|
+
* Creates an instance of the LibP2P service.
|
|
43
|
+
* @param config - The configuration to use when creating the service.
|
|
44
|
+
* @param txPool - The transaction pool to be accessed by the service.
|
|
45
|
+
* @returns The new service.
|
|
46
|
+
*/
|
|
47
|
+
static new<T extends P2PClientType>(clientType: T, config: P2PConfig, peerDiscoveryService: PeerDiscoveryService, peerId: PeerId, mempools: MemPools<T>, l2BlockSource: L2BlockSource, epochCache: EpochCacheInterface, proofVerifier: ClientProtocolCircuitVerifier, worldStateSynchronizer: WorldStateSynchronizer, store: AztecAsyncKVStore, telemetry: TelemetryClient, logger?: import("@aztec/foundation/log").Logger): Promise<LibP2PService<T>>;
|
|
48
|
+
/**
|
|
49
|
+
* Starts the LibP2P service.
|
|
50
|
+
* @returns An empty promise.
|
|
51
|
+
*/
|
|
52
|
+
start(): Promise<void>;
|
|
53
|
+
/**
|
|
54
|
+
* Stops the LibP2P service.
|
|
55
|
+
* @returns An empty promise.
|
|
56
|
+
*/
|
|
57
|
+
stop(): Promise<void>;
|
|
58
|
+
getPeers(includePending?: boolean): PeerInfo[];
|
|
59
|
+
private handleGossipSubEvent;
|
|
60
|
+
/**
|
|
61
|
+
* Send Request via the ReqResp service
|
|
62
|
+
* The subprotocol defined will determine the request and response types
|
|
63
|
+
*
|
|
64
|
+
* See the subProtocolMap for the mapping of subprotocols to request/response types in `interface.ts`
|
|
65
|
+
*
|
|
66
|
+
* @param protocol The request response protocol to use
|
|
67
|
+
* @param request The request type to send
|
|
68
|
+
* @returns
|
|
69
|
+
*/
|
|
70
|
+
sendRequest<SubProtocol extends ReqRespSubProtocol>(protocol: SubProtocol, request: InstanceType<SubProtocolMap[SubProtocol]['request']>): Promise<InstanceType<SubProtocolMap[SubProtocol]['response']> | undefined>;
|
|
71
|
+
/**
|
|
72
|
+
* Send a batch of requests to peers, and return the responses
|
|
73
|
+
* @param protocol - The request response protocol to use
|
|
74
|
+
* @param requests - The requests to send to the peers
|
|
75
|
+
* @returns The responses to the requests
|
|
76
|
+
*/
|
|
77
|
+
sendBatchRequest<SubProtocol extends ReqRespSubProtocol>(protocol: SubProtocol, requests: InstanceType<SubProtocolMap[SubProtocol]['request']>[]): Promise<InstanceType<SubProtocolMap[SubProtocol]['response']>[] | undefined>;
|
|
78
|
+
/**
|
|
79
|
+
* Get the ENR of the node
|
|
80
|
+
* @returns The ENR of the node
|
|
81
|
+
*/
|
|
82
|
+
getEnr(): ENR | undefined;
|
|
83
|
+
registerBlockReceivedCallback(callback: (block: BlockProposal) => Promise<BlockAttestation | undefined>): void;
|
|
84
|
+
/**
|
|
85
|
+
* Subscribes to a topic.
|
|
86
|
+
* @param topic - The topic to subscribe to.
|
|
87
|
+
*/
|
|
88
|
+
private subscribeToTopic;
|
|
89
|
+
/**
|
|
90
|
+
* Publishes data to a topic.
|
|
91
|
+
* @param topic - The topic to publish to.
|
|
92
|
+
* @param data - The data to publish.
|
|
93
|
+
* @returns The number of recipients the data was sent to.
|
|
94
|
+
*/
|
|
95
|
+
private publishToTopic;
|
|
96
|
+
/**
|
|
97
|
+
* Handles a new gossip message that was received by the client.
|
|
98
|
+
* @param topic - The message's topic.
|
|
99
|
+
* @param data - The message data
|
|
100
|
+
*/
|
|
101
|
+
private handleNewGossipMessage;
|
|
102
|
+
/**Process Attestation From Peer
|
|
103
|
+
* When a proposal is received from a peer, we add it to the attestation pool, so it can be accessed by other services.
|
|
104
|
+
*
|
|
105
|
+
* @param attestation - The attestation to process.
|
|
106
|
+
*/
|
|
107
|
+
private processAttestationFromPeer;
|
|
108
|
+
/**Process block from peer
|
|
109
|
+
*
|
|
110
|
+
* Pass the received block to the validator client
|
|
111
|
+
*
|
|
112
|
+
* @param block - The block to process.
|
|
113
|
+
*/
|
|
114
|
+
private processBlockFromPeer;
|
|
115
|
+
/**
|
|
116
|
+
* Broadcast an attestation to all peers.
|
|
117
|
+
* @param attestation - The attestation to broadcast.
|
|
118
|
+
*/
|
|
119
|
+
private broadcastAttestation;
|
|
120
|
+
private processEpochProofQuoteFromPeer;
|
|
121
|
+
/**
|
|
122
|
+
* Propagates provided message to peers.
|
|
123
|
+
* @param message - The message to propagate.
|
|
124
|
+
*/
|
|
125
|
+
propagate<T extends Gossipable>(message: T): Promise<void>;
|
|
126
|
+
private processTxFromPeer;
|
|
127
|
+
/**
|
|
128
|
+
* Validate a tx that has been requested from a peer.
|
|
129
|
+
*
|
|
130
|
+
* The core component of this validator is that the tx hash MUST match the requested tx hash,
|
|
131
|
+
* In order to perform this check, the tx proof must be verified.
|
|
132
|
+
*
|
|
133
|
+
* Note: This function is called from within `ReqResp.sendRequest` as part of the
|
|
134
|
+
* ReqRespSubProtocol.TX subprotocol validation.
|
|
135
|
+
*
|
|
136
|
+
* @param requestedTxHash - The hash of the tx that was requested.
|
|
137
|
+
* @param responseTx - The tx that was received as a response to the request.
|
|
138
|
+
* @param peerId - The peer ID of the peer that sent the tx.
|
|
139
|
+
* @returns True if the tx is valid, false otherwise.
|
|
140
|
+
*/
|
|
141
|
+
private validateRequestedTx;
|
|
142
|
+
/**
|
|
143
|
+
* Validate a tx from a peer.
|
|
144
|
+
* @param propagationSource - The peer ID of the peer that sent the tx.
|
|
145
|
+
* @param msg - The tx message.
|
|
146
|
+
* @returns True if the tx is valid, false otherwise.
|
|
147
|
+
*/
|
|
148
|
+
private validatePropagatedTxFromMessage;
|
|
149
|
+
/**
|
|
150
|
+
* Validate an attestation from a peer.
|
|
151
|
+
* @param propagationSource - The peer ID of the peer that sent the attestation.
|
|
152
|
+
* @param msg - The attestation message.
|
|
153
|
+
* @returns True if the attestation is valid, false otherwise.
|
|
154
|
+
*/
|
|
155
|
+
private validatePropagatedAttestationFromMessage;
|
|
156
|
+
/**
|
|
157
|
+
* Validate a block proposal from a peer.
|
|
158
|
+
* @param propagationSource - The peer ID of the peer that sent the block.
|
|
159
|
+
* @param msg - The block proposal message.
|
|
160
|
+
* @returns True if the block proposal is valid, false otherwise.
|
|
161
|
+
*/
|
|
162
|
+
private validatePropagatedBlockFromMessage;
|
|
163
|
+
/**
|
|
164
|
+
* Validate an epoch proof quote from a peer.
|
|
165
|
+
* @param propagationSource - The peer ID of the peer that sent the epoch proof quote.
|
|
166
|
+
* @param msg - The epoch proof quote message.
|
|
167
|
+
* @returns True if the epoch proof quote is valid, false otherwise.
|
|
168
|
+
*/
|
|
169
|
+
private validatePropagatedEpochProofQuoteFromMessage;
|
|
170
|
+
private validatePropagatedTx;
|
|
171
|
+
/**
|
|
172
|
+
* Create message validators for the given block number.
|
|
173
|
+
*
|
|
174
|
+
* Each validator is a pair of a validator and a severity.
|
|
175
|
+
* If a validator fails, the peer is penalized with the severity of the validator.
|
|
176
|
+
*
|
|
177
|
+
* @param blockNumber - The block number to create validators for.
|
|
178
|
+
* @returns The message validators.
|
|
179
|
+
*/
|
|
180
|
+
private createMessageValidators;
|
|
181
|
+
/**
|
|
182
|
+
* Run validations on a tx.
|
|
183
|
+
* @param tx - The tx to validate.
|
|
184
|
+
* @param messageValidators - The message validators to run.
|
|
185
|
+
* @returns The validation outcome.
|
|
186
|
+
*/
|
|
187
|
+
private runValidations;
|
|
188
|
+
/**
|
|
189
|
+
* Handle a double spend failure.
|
|
190
|
+
*
|
|
191
|
+
* Double spend failures are managed on their own because they are a special case.
|
|
192
|
+
* We must check if the double spend is recent or old, if it is past a threshold, then we heavily penalize the peer.
|
|
193
|
+
*
|
|
194
|
+
* @param tx - The tx that failed the double spend validator.
|
|
195
|
+
* @param blockNumber - The block number of the tx.
|
|
196
|
+
* @param peerId - The peer ID of the peer that sent the tx.
|
|
197
|
+
* @returns True if the tx is valid, false otherwise.
|
|
198
|
+
*/
|
|
199
|
+
private handleDoubleSpendFailure;
|
|
200
|
+
/**
|
|
201
|
+
* Validate an attestation.
|
|
202
|
+
*
|
|
203
|
+
* @param attestation - The attestation to validate.
|
|
204
|
+
* @returns True if the attestation is valid, false otherwise.
|
|
205
|
+
*/
|
|
206
|
+
validateAttestation(peerId: PeerId, attestation: BlockAttestation): Promise<boolean>;
|
|
207
|
+
/**
|
|
208
|
+
* Validate a block proposal.
|
|
209
|
+
*
|
|
210
|
+
* @param block - The block proposal to validate.
|
|
211
|
+
* @returns True if the block proposal is valid, false otherwise.
|
|
212
|
+
*/
|
|
213
|
+
validateBlockProposal(peerId: PeerId, block: BlockProposal): Promise<boolean>;
|
|
214
|
+
/**
|
|
215
|
+
* Validate an epoch proof quote.
|
|
216
|
+
*
|
|
217
|
+
* @param epochProofQuote - The epoch proof quote to validate.
|
|
218
|
+
* @returns True if the epoch proof quote is valid, false otherwise.
|
|
219
|
+
*/
|
|
220
|
+
validateEpochProofQuote(peerId: PeerId, epochProofQuote: EpochProofQuote): Promise<boolean>;
|
|
221
|
+
getPeerScore(peerId: PeerId): number;
|
|
222
|
+
private sendToPeers;
|
|
223
|
+
private stopLibP2P;
|
|
224
|
+
}
|
|
225
|
+
//# sourceMappingURL=libp2p_service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"libp2p_service.d.ts","sourceRoot":"","sources":["../../../src/services/libp2p/libp2p_service.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,aAAa,EACb,KAAK,6BAA6B,EAClC,eAAe,EACf,KAAK,UAAU,EACf,KAAK,aAAa,EAElB,aAAa,EAEb,KAAK,QAAQ,EAMb,KAAK,sBAAsB,EAG5B,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAI9D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAkC,KAAK,eAAe,EAAE,UAAU,EAAa,MAAM,yBAAyB,CAAC;AAEtH,OAAO,EAAE,KAAK,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAa1C,OAAO,EAAgB,KAAK,MAAM,EAAwB,MAAM,mBAAmB,CAAC;AAEpF,OAAO,iBAAiB,CAAC;AAKzB,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,KAAK,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AAS7D,OAAO,EAAE,KAAK,YAAY,EAAsB,MAAM,eAAe,CAAC;AAKtE,OAAO,EAAmC,kBAAkB,EAAE,KAAK,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAGnH,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AAChD,OAAO,KAAK,EAAE,UAAU,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAmBtE;;GAEG;AACH,qBAAa,aAAa,CAAC,CAAC,SAAS,aAAa,CAAE,SAAQ,UAAW,YAAW,UAAU;IAqBxF,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,IAAI;IACZ,OAAO,CAAC,oBAAoB;IAC5B,OAAO,CAAC,QAAQ;IAChB,OAAO,CAAC,aAAa;IAErB,OAAO,CAAC,aAAa;IACrB,OAAO,CAAC,sBAAsB;IAE9B,OAAO,CAAC,MAAM;IA9BhB,OAAO,CAAC,QAAQ,CAAkC;IAClD,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,uBAAuB,CAAC,CAAiB;IAGjD,OAAO,CAAC,oBAAoB,CAAuB;IACnD,OAAO,CAAC,sBAAsB,CAAyB;IACvD,OAAO,CAAC,wBAAwB,CAA2B;IAGpD,OAAO,EAAE,OAAO,CAAC;IAExB;;;;OAIG;IACH,OAAO,CAAC,qBAAqB,CAAkE;gBAGrF,UAAU,EAAE,CAAC,EACb,MAAM,EAAE,SAAS,EACjB,IAAI,EAAE,YAAY,EAClB,oBAAoB,EAAE,oBAAoB,EAC1C,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EACrB,aAAa,EAAE,aAAa,EACpC,UAAU,EAAE,mBAAmB,EACvB,aAAa,EAAE,6BAA6B,EAC5C,sBAAsB,EAAE,sBAAsB,EACtD,SAAS,EAAE,eAAe,EAClB,MAAM,yCAAqC;IAoCrD;;;;;OAKG;WACiB,GAAG,CAAC,CAAC,SAAS,aAAa,EAC7C,UAAU,EAAE,CAAC,EACb,MAAM,EAAE,SAAS,EACjB,oBAAoB,EAAE,oBAAoB,EAC1C,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EACrB,aAAa,EAAE,aAAa,EAC5B,UAAU,EAAE,mBAAmB,EAC/B,aAAa,EAAE,6BAA6B,EAC5C,sBAAsB,EAAE,sBAAsB,EAC9C,KAAK,EAAE,iBAAiB,EACxB,SAAS,EAAE,eAAe,EAC1B,MAAM,yCAAqC;IA4H7C;;;OAGG;IACU,KAAK;IAkFlB;;;OAGG;IACU,IAAI;IAqBV,QAAQ,CAAC,cAAc,CAAC,EAAE,OAAO,GAAG,QAAQ,EAAE;IAIrD,OAAO,CAAC,oBAAoB;IAS5B;;;;;;;;;OASG;IACH,WAAW,CAAC,WAAW,SAAS,kBAAkB,EAChD,QAAQ,EAAE,WAAW,EACrB,OAAO,EAAE,YAAY,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,GAC5D,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC;IAI7E;;;;;OAKG;IACH,gBAAgB,CAAC,WAAW,SAAS,kBAAkB,EACrD,QAAQ,EAAE,WAAW,EACrB,QAAQ,EAAE,YAAY,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,GAC/D,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,SAAS,CAAC;IAI/E;;;OAGG;IACI,MAAM,IAAI,GAAG,GAAG,SAAS;IAIzB,6BAA6B,CAAC,QAAQ,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,OAAO,CAAC,gBAAgB,GAAG,SAAS,CAAC;IAK9G;;;OAGG;IACH,OAAO,CAAC,gBAAgB;IAOxB;;;;;OAKG;YACW,cAAc;IAS5B;;;;OAIG;YACW,sBAAsB;IAqBpC;;;;OAIG;YAOW,0BAA0B;IAaxC;;;;;OAKG;YAQW,oBAAoB;IA4BlC;;;OAGG;YAOW,oBAAoB;YAIpB,8BAA8B;IAW5C;;;OAGG;IACU,SAAS,CAAC,CAAC,SAAS,UAAU,EAAE,OAAO,EAAE,CAAC;YAQzC,iBAAiB;IAO/B;;;;;;;;;;;;;OAaG;YAIW,mBAAmB;IAoBjC;;;;;OAKG;YACW,+BAA+B;IAa7C;;;;;OAKG;YACW,wCAAwC;IAatD;;;;;OAKG;YACW,kCAAkC;IAahD;;;;;OAKG;YACW,4CAA4C;YAgB5C,oBAAoB;IAuBlC;;;;;;;;OAQG;IACH,OAAO,CAAC,uBAAuB;IA2B/B;;;;;OAKG;YACW,cAAc;IA8B5B;;;;;;;;;;OAUG;YACW,wBAAwB;IAwBtC;;;;;OAKG;IAIU,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;IAUjG;;;;;OAKG;IAIU,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC;IAU1F;;;;;OAKG;IAIU,uBAAuB,CAAC,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,eAAe,GAAG,OAAO,CAAC,OAAO,CAAC;IAUjG,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;YAI7B,WAAW;YAcX,UAAU;CAYzB"}
|