@aztec/p2p 0.76.4 → 0.77.0-testnet-ignition.21
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 +2 -2
- package/dest/bootstrap/bootstrap.d.ts.map +1 -1
- package/dest/bootstrap/bootstrap.js +55 -41
- package/dest/client/factory.d.ts +8 -6
- package/dest/client/factory.d.ts.map +1 -1
- package/dest/client/factory.js +8 -10
- package/dest/client/index.js +0 -1
- package/dest/client/p2p_client.d.ts +7 -4
- package/dest/client/p2p_client.d.ts.map +1 -1
- package/dest/client/p2p_client.js +492 -514
- package/dest/config.d.ts +8 -10
- package/dest/config.d.ts.map +1 -1
- package/dest/config.js +54 -47
- package/dest/enr/generate-enr.d.ts +9 -0
- package/dest/enr/generate-enr.d.ts.map +1 -0
- package/dest/enr/generate-enr.js +30 -0
- package/dest/enr/index.d.ts +2 -0
- package/dest/enr/index.d.ts.map +1 -0
- package/dest/enr/index.js +1 -0
- package/dest/errors/reqresp.error.js +6 -10
- package/dest/index.js +0 -1
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +1 -1
- package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/attestation_pool.js +6 -2
- 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 +65 -33
- package/dest/mem_pools/attestation_pool/index.js +0 -1
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +3 -3
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +23 -20
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +2 -2
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +22 -26
- package/dest/mem_pools/attestation_pool/mocks.d.ts +3 -2
- package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
- package/dest/mem_pools/attestation_pool/mocks.js +12 -7
- package/dest/mem_pools/index.d.ts +2 -2
- package/dest/mem_pools/index.d.ts.map +1 -1
- package/dest/mem_pools/index.js +1 -2
- package/dest/mem_pools/instrumentation.d.ts +1 -1
- package/dest/mem_pools/instrumentation.d.ts.map +1 -1
- package/dest/mem_pools/instrumentation.js +35 -39
- package/dest/mem_pools/interface.d.ts +3 -3
- package/dest/mem_pools/interface.d.ts.map +1 -1
- package/dest/mem_pools/interface.js +3 -2
- package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +2 -2
- 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 +129 -136
- package/dest/mem_pools/tx_pool/index.js +0 -1
- package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +2 -2
- package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/memory_tx_pool.js +46 -44
- package/dest/mem_pools/tx_pool/priority.d.ts +1 -1
- package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/priority.js +1 -3
- package/dest/mem_pools/tx_pool/tx_pool.d.ts +1 -1
- package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -1
- package/dest/mem_pools/tx_pool/tx_pool.js +3 -2
- 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 +109 -39
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +2 -2
- package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
- package/dest/msg_validators/attestation_validator/attestation_validator.js +4 -4
- package/dest/msg_validators/attestation_validator/index.js +0 -1
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +2 -2
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +1 -1
- package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +3 -3
- package/dest/msg_validators/block_proposal_validator/index.js +0 -1
- package/dest/msg_validators/index.js +0 -1
- package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +1 -1
- package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +9 -11
- 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/block_header_validator.js +18 -13
- 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/data_validator.js +102 -33
- package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +1 -1
- package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/double_spend_validator.js +34 -20
- package/dest/msg_validators/tx_validator/index.js +0 -1
- 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/metadata_validator.js +30 -27
- package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +2 -1
- package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
- package/dest/msg_validators/tx_validator/tx_proof_validator.js +17 -12
- package/dest/services/data_store.js +57 -57
- package/dest/services/discv5/discV5_service.d.ts +2 -0
- package/dest/services/discv5/discV5_service.d.ts.map +1 -1
- package/dest/services/discv5/discV5_service.js +64 -36
- package/dest/services/dummy_service.d.ts +4 -2
- package/dest/services/dummy_service.d.ts.map +1 -1
- package/dest/services/dummy_service.js +41 -59
- package/dest/services/encoding.d.ts +3 -3
- package/dest/services/encoding.d.ts.map +1 -1
- package/dest/services/encoding.js +10 -9
- package/dest/services/gossipsub/scoring.d.ts +7 -0
- package/dest/services/gossipsub/scoring.d.ts.map +1 -0
- package/dest/services/gossipsub/scoring.js +10 -0
- package/dest/services/index.js +0 -1
- package/dest/services/libp2p/libp2p_service.d.ts +10 -33
- package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
- package/dest/services/libp2p/libp2p_service.js +682 -673
- package/dest/services/peer-manager/metrics.js +14 -7
- package/dest/services/peer-manager/peer_manager.d.ts +24 -6
- package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
- package/dest/services/peer-manager/peer_manager.js +390 -340
- package/dest/services/peer-manager/peer_scoring.d.ts +3 -3
- package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
- package/dest/services/peer-manager/peer_scoring.js +21 -19
- package/dest/services/reqresp/config.js +4 -5
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +2 -2
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
- package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +35 -28
- 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/connection-sampler/connection_sampler.js +67 -61
- package/dest/services/reqresp/index.js +1 -3
- package/dest/services/reqresp/interface.d.ts +2 -2
- package/dest/services/reqresp/interface.d.ts.map +1 -1
- package/dest/services/reqresp/interface.js +27 -31
- 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 +23 -10
- package/dest/services/reqresp/protocols/block.d.ts +2 -2
- package/dest/services/reqresp/protocols/block.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/block.js +1 -2
- package/dest/services/reqresp/protocols/goodbye.d.ts +5 -5
- package/dest/services/reqresp/protocols/goodbye.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/goodbye.js +36 -41
- package/dest/services/reqresp/protocols/index.js +1 -3
- package/dest/services/reqresp/protocols/ping.js +1 -3
- package/dest/services/reqresp/protocols/status.js +1 -3
- package/dest/services/reqresp/protocols/tx.d.ts +3 -3
- package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
- package/dest/services/reqresp/protocols/tx.js +6 -9
- package/dest/services/reqresp/rate-limiter/index.js +0 -1
- package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +9 -9
- package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -1
- package/dest/services/reqresp/rate-limiter/rate_limiter.js +53 -46
- package/dest/services/reqresp/rate-limiter/rate_limits.js +16 -17
- package/dest/services/reqresp/reqresp.d.ts +4 -4
- package/dest/services/reqresp/reqresp.d.ts.map +1 -1
- package/dest/services/reqresp/reqresp.js +467 -464
- package/dest/services/reqresp/status.js +16 -17
- package/dest/services/service.d.ts +3 -2
- package/dest/services/service.d.ts.map +1 -1
- package/dest/services/service.js +3 -4
- package/dest/test-helpers/generate-peer-id-private-keys.js +2 -4
- package/dest/test-helpers/get-ports.js +3 -3
- package/dest/test-helpers/index.js +0 -1
- package/dest/test-helpers/make-enrs.d.ts +1 -1
- package/dest/test-helpers/make-enrs.d.ts.map +1 -1
- package/dest/test-helpers/make-enrs.js +3 -6
- package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -6
- package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
- package/dest/test-helpers/make-test-p2p-clients.js +10 -12
- package/dest/test-helpers/reqresp-nodes.d.ts +18 -7
- package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
- package/dest/test-helpers/reqresp-nodes.js +64 -40
- package/dest/testbench/p2p_client_testbench_worker.js +61 -45
- package/dest/testbench/parse_log_file.d.ts +2 -0
- package/dest/testbench/parse_log_file.d.ts.map +1 -0
- package/dest/testbench/parse_log_file.js +131 -0
- package/dest/testbench/testbench.d.ts +2 -0
- package/dest/testbench/testbench.d.ts.map +1 -0
- package/dest/testbench/testbench.js +141 -0
- package/dest/{services/types.d.ts → types/index.d.ts} +1 -1
- package/dest/types/index.d.ts.map +1 -0
- package/dest/types/index.js +28 -0
- package/dest/util.d.ts +5 -5
- package/dest/util.d.ts.map +1 -1
- package/dest/util.js +23 -34
- package/dest/versioning.d.ts +3 -3
- package/dest/versioning.d.ts.map +1 -1
- package/dest/versioning.js +7 -12
- package/package.json +15 -13
- package/src/bootstrap/bootstrap.ts +30 -17
- package/src/client/factory.ts +9 -12
- package/src/client/p2p_client.ts +13 -24
- package/src/config.ts +14 -15
- package/src/enr/generate-enr.ts +39 -0
- package/src/enr/index.ts +1 -0
- package/src/mem_pools/attestation_pool/attestation_pool.ts +1 -1
- package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +4 -3
- package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +3 -3
- package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +2 -2
- package/src/mem_pools/attestation_pool/mocks.ts +5 -5
- package/src/mem_pools/index.ts +2 -2
- package/src/mem_pools/instrumentation.ts +4 -3
- package/src/mem_pools/interface.ts +3 -3
- package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +4 -4
- package/src/mem_pools/tx_pool/memory_tx_pool.ts +3 -3
- package/src/mem_pools/tx_pool/priority.ts +1 -1
- package/src/mem_pools/tx_pool/tx_pool.ts +1 -1
- package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +4 -3
- package/src/msg_validators/attestation_validator/attestation_validator.ts +2 -2
- package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +2 -2
- package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +1 -1
- package/src/msg_validators/tx_validator/block_header_validator.ts +2 -2
- package/src/msg_validators/tx_validator/data_validator.ts +57 -4
- package/src/msg_validators/tx_validator/double_spend_validator.ts +17 -12
- package/src/msg_validators/tx_validator/metadata_validator.ts +2 -2
- package/src/msg_validators/tx_validator/tx_proof_validator.ts +2 -6
- package/src/services/discv5/discV5_service.ts +33 -8
- package/src/services/dummy_service.ts +4 -2
- package/src/services/encoding.ts +3 -3
- package/src/services/gossipsub/scoring.ts +13 -0
- package/src/services/libp2p/libp2p_service.ts +124 -146
- package/src/services/peer-manager/peer_manager.ts +71 -13
- package/src/services/peer-manager/peer_scoring.ts +3 -3
- package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +2 -2
- package/src/services/reqresp/connection-sampler/connection_sampler.ts +9 -3
- package/src/services/reqresp/interface.ts +4 -3
- package/src/services/reqresp/metrics.ts +1 -1
- package/src/services/reqresp/protocols/block.ts +3 -3
- package/src/services/reqresp/protocols/goodbye.ts +7 -7
- package/src/services/reqresp/protocols/tx.ts +5 -5
- package/src/services/reqresp/rate-limiter/rate_limiter.ts +22 -18
- package/src/services/reqresp/reqresp.ts +18 -11
- package/src/services/service.ts +3 -2
- package/src/test-helpers/make-enrs.ts +1 -1
- package/src/test-helpers/make-test-p2p-clients.ts +9 -7
- package/src/test-helpers/reqresp-nodes.ts +32 -18
- package/src/testbench/p2p_client_testbench_worker.ts +16 -9
- package/src/testbench/parse_log_file.ts +175 -0
- package/src/testbench/testbench.ts +157 -0
- package/src/util.ts +5 -5
- package/src/versioning.ts +7 -7
- package/dest/services/libp2p/libp2p_logger.d.ts +0 -7
- package/dest/services/libp2p/libp2p_logger.d.ts.map +0 -1
- package/dest/services/libp2p/libp2p_logger.js +0 -67
- package/dest/services/types.d.ts.map +0 -1
- package/dest/services/types.js +0 -35
- package/src/services/libp2p/libp2p_logger.ts +0 -78
- package/src/testbench/scripts/run_testbench.sh +0 -7
- /package/src/{services/types.ts → types/index.ts} +0 -0
|
@@ -1,33 +1,35 @@
|
|
|
1
|
-
var _AztecDatastore_memoryDatastore, _AztecDatastore_dbDatastore, _AztecDatastore_batchOps;
|
|
2
|
-
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
1
|
import { filter, map, sort, take } from '@aztec/foundation/iterable';
|
|
4
2
|
import { Key } from 'interface-datastore';
|
|
5
3
|
class KeyNotFoundError extends Error {
|
|
6
|
-
|
|
4
|
+
code;
|
|
5
|
+
constructor(message){
|
|
7
6
|
super(message);
|
|
8
7
|
this.code = 'ERR_NOT_FOUND';
|
|
9
8
|
}
|
|
10
9
|
}
|
|
11
10
|
export class AztecDatastore {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
11
|
+
#memoryDatastore;
|
|
12
|
+
#dbDatastore;
|
|
13
|
+
#batchOps = [];
|
|
14
|
+
maxMemoryItems;
|
|
15
|
+
constructor(db, { maxMemoryItems } = {
|
|
16
|
+
maxMemoryItems: 50
|
|
17
|
+
}){
|
|
18
|
+
this.#memoryDatastore = new Map();
|
|
19
|
+
this.#dbDatastore = db.openMap('p2p_datastore');
|
|
18
20
|
this.maxMemoryItems = maxMemoryItems;
|
|
19
21
|
}
|
|
20
22
|
async has(key) {
|
|
21
|
-
return
|
|
23
|
+
return this.#memoryDatastore.has(key.toString()) || await this.#dbDatastore.hasAsync(key.toString());
|
|
22
24
|
}
|
|
23
25
|
async get(key) {
|
|
24
26
|
const keyStr = key.toString();
|
|
25
|
-
const memoryItem =
|
|
27
|
+
const memoryItem = this.#memoryDatastore.get(keyStr);
|
|
26
28
|
if (memoryItem) {
|
|
27
29
|
memoryItem.lastAccessedMs = Date.now();
|
|
28
30
|
return memoryItem.data;
|
|
29
31
|
}
|
|
30
|
-
const dbItem = await
|
|
32
|
+
const dbItem = await this.#dbDatastore.getAsync(keyStr);
|
|
31
33
|
if (!dbItem) {
|
|
32
34
|
throw new KeyNotFoundError(`Key not found`);
|
|
33
35
|
}
|
|
@@ -37,72 +39,71 @@ export class AztecDatastore {
|
|
|
37
39
|
return this._put(key, val);
|
|
38
40
|
}
|
|
39
41
|
async *putMany(source) {
|
|
40
|
-
for await (const { key, value } of source)
|
|
42
|
+
for await (const { key, value } of source){
|
|
41
43
|
await this.put(key, value);
|
|
42
44
|
yield key;
|
|
43
45
|
}
|
|
44
46
|
}
|
|
45
47
|
async *getMany(source) {
|
|
46
|
-
for await (const key of source)
|
|
48
|
+
for await (const key of source){
|
|
47
49
|
yield {
|
|
48
50
|
key,
|
|
49
|
-
value: await this.get(key)
|
|
51
|
+
value: await this.get(key)
|
|
50
52
|
};
|
|
51
53
|
}
|
|
52
54
|
}
|
|
53
55
|
async *deleteMany(source) {
|
|
54
|
-
for await (const key of source)
|
|
56
|
+
for await (const key of source){
|
|
55
57
|
await this.delete(key);
|
|
56
58
|
yield key;
|
|
57
59
|
}
|
|
58
60
|
}
|
|
59
61
|
async delete(key) {
|
|
60
|
-
|
|
61
|
-
await
|
|
62
|
+
this.#memoryDatastore.delete(key.toString());
|
|
63
|
+
await this.#dbDatastore.delete(key.toString());
|
|
62
64
|
}
|
|
63
65
|
batch() {
|
|
64
66
|
return {
|
|
65
|
-
put: (key, value)
|
|
66
|
-
|
|
67
|
+
put: (key, value)=>{
|
|
68
|
+
this.#batchOps.push({
|
|
67
69
|
type: 'put',
|
|
68
70
|
key,
|
|
69
|
-
value
|
|
71
|
+
value
|
|
70
72
|
});
|
|
71
73
|
},
|
|
72
|
-
delete: key
|
|
73
|
-
|
|
74
|
+
delete: (key)=>{
|
|
75
|
+
this.#batchOps.push({
|
|
74
76
|
type: 'del',
|
|
75
|
-
key
|
|
77
|
+
key
|
|
76
78
|
});
|
|
77
79
|
},
|
|
78
|
-
commit: async ()
|
|
79
|
-
for (const op of
|
|
80
|
+
commit: async ()=>{
|
|
81
|
+
for (const op of this.#batchOps){
|
|
80
82
|
if (op.type === 'put' && op.value) {
|
|
81
83
|
await this.put(op.key, op.value);
|
|
82
|
-
}
|
|
83
|
-
else if (op.type === 'del') {
|
|
84
|
+
} else if (op.type === 'del') {
|
|
84
85
|
await this.delete(op.key);
|
|
85
86
|
}
|
|
86
87
|
}
|
|
87
|
-
|
|
88
|
-
}
|
|
88
|
+
this.#batchOps = []; // Clear operations after commit
|
|
89
|
+
}
|
|
89
90
|
};
|
|
90
91
|
}
|
|
91
92
|
query(q) {
|
|
92
93
|
let it = this.all(); //
|
|
93
94
|
const { prefix, filters, orders, offset, limit } = q;
|
|
94
95
|
if (prefix != null) {
|
|
95
|
-
it = filter(it, e
|
|
96
|
+
it = filter(it, (e)=>e.key.toString().startsWith(`${prefix}`));
|
|
96
97
|
}
|
|
97
98
|
if (Array.isArray(filters)) {
|
|
98
|
-
it = filters.reduce((it, f)
|
|
99
|
+
it = filters.reduce((it, f)=>filter(it, f), it);
|
|
99
100
|
}
|
|
100
101
|
if (Array.isArray(orders)) {
|
|
101
|
-
it = orders.reduce((it, f)
|
|
102
|
+
it = orders.reduce((it, f)=>sort(it, f), it);
|
|
102
103
|
}
|
|
103
104
|
if (offset != null) {
|
|
104
105
|
let i = 0;
|
|
105
|
-
it = filter(it, ()
|
|
106
|
+
it = filter(it, ()=>i++ >= offset);
|
|
106
107
|
}
|
|
107
108
|
if (limit != null) {
|
|
108
109
|
it = take(it, limit);
|
|
@@ -110,20 +111,20 @@ export class AztecDatastore {
|
|
|
110
111
|
return it;
|
|
111
112
|
}
|
|
112
113
|
queryKeys(q) {
|
|
113
|
-
let it = map(this.all(), ({ key })
|
|
114
|
+
let it = map(this.all(), ({ key })=>key);
|
|
114
115
|
const { prefix, filters, orders, offset, limit } = q;
|
|
115
116
|
if (prefix != null) {
|
|
116
|
-
it = filter(it, e
|
|
117
|
+
it = filter(it, (e)=>e.toString().startsWith(`${prefix}`));
|
|
117
118
|
}
|
|
118
119
|
if (Array.isArray(filters)) {
|
|
119
|
-
it = filters.reduce((it, f)
|
|
120
|
+
it = filters.reduce((it, f)=>filter(it, f), it);
|
|
120
121
|
}
|
|
121
122
|
if (Array.isArray(orders)) {
|
|
122
|
-
it = orders.reduce((it, f)
|
|
123
|
+
it = orders.reduce((it, f)=>sort(it, f), it);
|
|
123
124
|
}
|
|
124
125
|
if (offset != null) {
|
|
125
126
|
let i = 0;
|
|
126
|
-
it = filter(it, ()
|
|
127
|
+
it = filter(it, ()=>i++ >= offset);
|
|
127
128
|
}
|
|
128
129
|
if (limit != null) {
|
|
129
130
|
it = take(it, limit);
|
|
@@ -132,47 +133,48 @@ export class AztecDatastore {
|
|
|
132
133
|
}
|
|
133
134
|
async _put(key, val) {
|
|
134
135
|
const keyStr = key.toString();
|
|
135
|
-
while
|
|
136
|
+
while(this.#memoryDatastore.size >= this.maxMemoryItems){
|
|
136
137
|
this.pruneMemoryDatastore();
|
|
137
138
|
}
|
|
138
|
-
const memoryItem =
|
|
139
|
+
const memoryItem = this.#memoryDatastore.get(keyStr);
|
|
139
140
|
if (memoryItem) {
|
|
140
141
|
// update existing
|
|
141
142
|
memoryItem.lastAccessedMs = Date.now();
|
|
142
143
|
memoryItem.data = val;
|
|
143
|
-
}
|
|
144
|
-
else {
|
|
144
|
+
} else {
|
|
145
145
|
// new entry
|
|
146
|
-
|
|
146
|
+
this.#memoryDatastore.set(keyStr, {
|
|
147
|
+
data: val,
|
|
148
|
+
lastAccessedMs: Date.now()
|
|
149
|
+
});
|
|
147
150
|
}
|
|
148
151
|
// Always add to DB
|
|
149
|
-
await
|
|
152
|
+
await this.#dbDatastore.set(keyStr, val);
|
|
150
153
|
return key;
|
|
151
154
|
}
|
|
152
155
|
async *all() {
|
|
153
|
-
for (const [key, value] of
|
|
156
|
+
for (const [key, value] of this.#memoryDatastore.entries()){
|
|
154
157
|
yield {
|
|
155
158
|
key: new Key(key),
|
|
156
|
-
value: value.data
|
|
159
|
+
value: value.data
|
|
157
160
|
};
|
|
158
161
|
}
|
|
159
|
-
for await (const [key, value] of
|
|
160
|
-
if (!
|
|
162
|
+
for await (const [key, value] of this.#dbDatastore.entriesAsync()){
|
|
163
|
+
if (!this.#memoryDatastore.has(key)) {
|
|
161
164
|
yield {
|
|
162
165
|
key: new Key(key),
|
|
163
|
-
value
|
|
166
|
+
value
|
|
164
167
|
};
|
|
165
168
|
}
|
|
166
169
|
}
|
|
167
170
|
}
|
|
168
171
|
/**
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
pruneMemoryDatastore() {
|
|
172
|
+
* Prune memory store
|
|
173
|
+
*/ pruneMemoryDatastore() {
|
|
172
174
|
let oldestAccessedMs = Date.now() + 1000;
|
|
173
175
|
let oldestKey = undefined;
|
|
174
176
|
let oldestValue = undefined;
|
|
175
|
-
for (const [key, value] of
|
|
177
|
+
for (const [key, value] of this.#memoryDatastore){
|
|
176
178
|
if (value.lastAccessedMs < oldestAccessedMs) {
|
|
177
179
|
oldestAccessedMs = value.lastAccessedMs;
|
|
178
180
|
oldestKey = key;
|
|
@@ -180,9 +182,7 @@ export class AztecDatastore {
|
|
|
180
182
|
}
|
|
181
183
|
}
|
|
182
184
|
if (oldestKey && oldestValue) {
|
|
183
|
-
|
|
185
|
+
this.#memoryDatastore.delete(oldestKey);
|
|
184
186
|
}
|
|
185
187
|
}
|
|
186
188
|
}
|
|
187
|
-
_AztecDatastore_memoryDatastore = new WeakMap(), _AztecDatastore_dbDatastore = new WeakMap(), _AztecDatastore_batchOps = new WeakMap();
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data_store.js","sourceRoot":"","sources":["../../src/services/data_store.ts"],"names":[],"mappings":"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"}
|
|
@@ -23,6 +23,7 @@ export declare class DiscV5Service extends EventEmitter implements PeerDiscovery
|
|
|
23
23
|
private currentState;
|
|
24
24
|
readonly bootstrapNodes: string[];
|
|
25
25
|
private bootstrapNodePeerIds;
|
|
26
|
+
private bootstrapNodeEnrs;
|
|
26
27
|
private startTime;
|
|
27
28
|
constructor(peerId: PeerId, config: P2PConfig, telemetry?: TelemetryClient, logger?: import("@aztec/foundation/log").Logger);
|
|
28
29
|
start(): Promise<void>;
|
|
@@ -34,6 +35,7 @@ export declare class DiscV5Service extends EventEmitter implements PeerDiscovery
|
|
|
34
35
|
isBootstrapPeer(peerId: PeerId): boolean;
|
|
35
36
|
stop(): Promise<void>;
|
|
36
37
|
private onEnrAdded;
|
|
38
|
+
private isOurBootnode;
|
|
37
39
|
private onDiscovered;
|
|
38
40
|
private validateEnr;
|
|
39
41
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"discV5_service.d.ts","sourceRoot":"","sources":["../../../src/services/discv5/discV5_service.ts"],"names":[],"mappings":";AAGA,OAAO,EAAsB,KAAK,eAAe,EAAsB,MAAM,yBAAyB,CAAC;AAGvG,OAAO,EAAE,GAAG,EAAe,MAAM,gBAAgB,CAAC;AAClD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,YAAY,MAAM,QAAQ,CAAC;AAElC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"discV5_service.d.ts","sourceRoot":"","sources":["../../../src/services/discv5/discV5_service.ts"],"names":[],"mappings":";AAGA,OAAO,EAAsB,KAAK,eAAe,EAAsB,MAAM,yBAAyB,CAAC;AAGvG,OAAO,EAAE,GAAG,EAAe,MAAM,gBAAgB,CAAC;AAClD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,YAAY,MAAM,QAAQ,CAAC;AAElC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAIjD,OAAO,EAAE,KAAK,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAI9E;;GAEG;AACH,qBAAa,aAAc,SAAQ,YAAa,YAAW,oBAAoB;IAsB3E,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,MAAM;IAEd,OAAO,CAAC,MAAM;IAxBhB,0BAA0B;IAC1B,OAAO,CAAC,MAAM,CAA8B;IAE5C,0BAA0B;IAC1B,OAAO,CAAC,GAAG,CAAc;IAEzB,2BAA2B;IAC3B,OAAO,CAAC,QAAQ,CAAqB;IAErC,sBAAsB;IACtB,OAAO,CAAC,kBAAkB,CAAY;IAEtC,OAAO,CAAC,YAAY,CAA8B;IAElD,SAAgB,cAAc,EAAE,MAAM,EAAE,CAAM;IAC9C,OAAO,CAAC,oBAAoB,CAAgB;IAC5C,OAAO,CAAC,iBAAiB,CAAa;IAEtC,OAAO,CAAC,SAAS,CAAK;gBAGZ,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,SAAS,EACzB,SAAS,GAAE,eAAsC,EACzC,MAAM,yCAAqC;IA+DxC,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAuCtB,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;IAmB1C,WAAW,IAAI,GAAG,EAAE;IAIpB,MAAM,IAAI,GAAG;IAIb,SAAS,IAAI,MAAM;IAInB,SAAS,IAAI,kBAAkB;IAI/B,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAIlC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;YASpB,UAAU;IAOxB,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,YAAY;IAqBpB,OAAO,CAAC,WAAW;CA0BpB"}
|
|
@@ -1,31 +1,36 @@
|
|
|
1
|
-
import { checkCompressedComponentVersion } from '@aztec/circuit-types';
|
|
2
1
|
import { createLogger } from '@aztec/foundation/log';
|
|
3
2
|
import { sleep } from '@aztec/foundation/sleep';
|
|
3
|
+
import { checkCompressedComponentVersion } from '@aztec/stdlib/versioning';
|
|
4
4
|
import { OtelMetricsAdapter, getTelemetryClient } from '@aztec/telemetry-client';
|
|
5
5
|
import { Discv5 } from '@chainsafe/discv5';
|
|
6
6
|
import { ENR, SignableENR } from '@chainsafe/enr';
|
|
7
7
|
import { multiaddr } from '@multiformats/multiaddr';
|
|
8
8
|
import EventEmitter from 'events';
|
|
9
|
+
import { AZTEC_ENR_KEY, Discv5Event, PeerEvent } from '../../types/index.js';
|
|
9
10
|
import { convertToMultiaddr } from '../../util.js';
|
|
10
11
|
import { setAztecEnrKey } from '../../versioning.js';
|
|
11
12
|
import { PeerDiscoveryState } from '../service.js';
|
|
12
|
-
import { AZTEC_ENR_KEY, Discv5Event, PeerEvent } from '../types.js';
|
|
13
13
|
const delayBeforeStart = 2000; // 2sec
|
|
14
14
|
/**
|
|
15
15
|
* Peer discovery service using Discv5.
|
|
16
|
-
*/
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
16
|
+
*/ export class DiscV5Service extends EventEmitter {
|
|
17
|
+
peerId;
|
|
18
|
+
config;
|
|
19
|
+
logger;
|
|
20
|
+
/** The Discv5 instance */ discv5;
|
|
21
|
+
/** This instance's ENR */ enr;
|
|
22
|
+
/** Version identifiers. */ versions;
|
|
23
|
+
/** UDP listen addr */ listenMultiAddrUdp;
|
|
24
|
+
currentState;
|
|
25
|
+
bootstrapNodes;
|
|
26
|
+
bootstrapNodePeerIds;
|
|
27
|
+
bootstrapNodeEnrs;
|
|
28
|
+
startTime;
|
|
29
|
+
constructor(peerId, config, telemetry = getTelemetryClient(), logger = createLogger('p2p:discv5_service')){
|
|
30
|
+
super(), this.peerId = peerId, this.config = config, this.logger = logger, this.currentState = PeerDiscoveryState.STOPPED, this.bootstrapNodes = [], this.bootstrapNodePeerIds = [], this.bootstrapNodeEnrs = [], this.startTime = 0;
|
|
27
31
|
const { tcpAnnounceAddress, udpAnnounceAddress, udpListenAddress, bootstrapNodes } = config;
|
|
28
32
|
this.bootstrapNodes = bootstrapNodes ?? [];
|
|
33
|
+
this.bootstrapNodeEnrs = this.bootstrapNodes.map((x)=>ENR.decodeTxt(x));
|
|
29
34
|
// create ENR from PeerId
|
|
30
35
|
this.enr = SignableENR.createFromPeerId(peerId);
|
|
31
36
|
// Add aztec identification to ENR
|
|
@@ -44,13 +49,15 @@ export class DiscV5Service extends EventEmitter {
|
|
|
44
49
|
this.discv5 = Discv5.create({
|
|
45
50
|
enr: this.enr,
|
|
46
51
|
peerId,
|
|
47
|
-
bindAddrs: {
|
|
52
|
+
bindAddrs: {
|
|
53
|
+
ip4: this.listenMultiAddrUdp
|
|
54
|
+
},
|
|
48
55
|
config: {
|
|
49
56
|
lookupTimeout: 2000,
|
|
50
57
|
requestTimeout: 2000,
|
|
51
|
-
allowUnverifiedSessions: true
|
|
58
|
+
allowUnverifiedSessions: true
|
|
52
59
|
},
|
|
53
|
-
metricsRegistry
|
|
60
|
+
metricsRegistry
|
|
54
61
|
});
|
|
55
62
|
// Hook onto the onEstablished method to check the peer's version from the ENR,
|
|
56
63
|
// so we don't add it to our dht if it doesn't have the correct version.
|
|
@@ -59,8 +66,13 @@ export class DiscV5Service extends EventEmitter {
|
|
|
59
66
|
// being "readded" constantly, we'll need to keep an eye on whether this
|
|
60
67
|
// turns out to be a problem or not.
|
|
61
68
|
const origOnEstablished = this.discv5.onEstablished.bind(this.discv5);
|
|
62
|
-
this.discv5.onEstablished = (...args)
|
|
69
|
+
this.discv5.onEstablished = (...args)=>{
|
|
63
70
|
const enr = args[1];
|
|
71
|
+
// A special case is for bootnodes. If this is a bootnode and we have been told to skip version checks
|
|
72
|
+
// then proceed straight to handling the event
|
|
73
|
+
if (!this.config.bootstrapNodeEnrVersionCheck && this.isOurBootnode(enr)) {
|
|
74
|
+
return origOnEstablished(...args);
|
|
75
|
+
}
|
|
64
76
|
if (this.validateEnr(enr)) {
|
|
65
77
|
return origOnEstablished(...args);
|
|
66
78
|
}
|
|
@@ -80,16 +92,15 @@ export class DiscV5Service extends EventEmitter {
|
|
|
80
92
|
peerId: this.peerId,
|
|
81
93
|
enrUdp: await this.enr.getFullMultiaddr('udp'),
|
|
82
94
|
enrTcp: await this.enr.getFullMultiaddr('tcp'),
|
|
83
|
-
versions: this.versions
|
|
95
|
+
versions: this.versions
|
|
84
96
|
});
|
|
85
97
|
this.currentState = PeerDiscoveryState.RUNNING;
|
|
86
98
|
// Add bootnode ENR if provided
|
|
87
99
|
if (this.bootstrapNodes?.length) {
|
|
88
100
|
// Do this conversion once since it involves an async function call
|
|
89
|
-
|
|
90
|
-
this.bootstrapNodePeerIds = await Promise.all(bootstrapNodesEnrs.map(enr => enr.peerId()));
|
|
101
|
+
this.bootstrapNodePeerIds = await Promise.all(this.bootstrapNodeEnrs.map((enr)=>enr.peerId()));
|
|
91
102
|
this.logger.info(`Adding ${this.bootstrapNodes} bootstrap nodes ENRs: ${this.bootstrapNodes.join(', ')}`);
|
|
92
|
-
for (const enr of
|
|
103
|
+
for (const enr of this.bootstrapNodeEnrs){
|
|
93
104
|
try {
|
|
94
105
|
if (this.config.bootstrapNodeEnrVersionCheck) {
|
|
95
106
|
const value = enr.kvs.get(AZTEC_ENR_KEY);
|
|
@@ -99,8 +110,7 @@ export class DiscV5Service extends EventEmitter {
|
|
|
99
110
|
checkCompressedComponentVersion(Buffer.from(value).toString(), this.versions);
|
|
100
111
|
}
|
|
101
112
|
this.discv5.addEnr(enr);
|
|
102
|
-
}
|
|
103
|
-
catch (e) {
|
|
113
|
+
} catch (e) {
|
|
104
114
|
this.logger.error(`Error adding bootratrap node ${enr.encodeTxt()}`, e);
|
|
105
115
|
}
|
|
106
116
|
}
|
|
@@ -118,8 +128,7 @@ export class DiscV5Service extends EventEmitter {
|
|
|
118
128
|
}
|
|
119
129
|
try {
|
|
120
130
|
await this.discv5.findRandomNode();
|
|
121
|
-
}
|
|
122
|
-
catch (err) {
|
|
131
|
+
} catch (err) {
|
|
123
132
|
this.logger.error(`Error running discV5 random node query: ${err}`);
|
|
124
133
|
}
|
|
125
134
|
}
|
|
@@ -136,7 +145,7 @@ export class DiscV5Service extends EventEmitter {
|
|
|
136
145
|
return this.currentState;
|
|
137
146
|
}
|
|
138
147
|
isBootstrapPeer(peerId) {
|
|
139
|
-
return this.bootstrapNodePeerIds.some(node
|
|
148
|
+
return this.bootstrapNodePeerIds.some((node)=>node.equals(peerId));
|
|
140
149
|
}
|
|
141
150
|
async stop() {
|
|
142
151
|
await this.discv5.off(Discv5Event.DISCOVERED, this.onDiscovered);
|
|
@@ -147,10 +156,32 @@ export class DiscV5Service extends EventEmitter {
|
|
|
147
156
|
async onEnrAdded(enr) {
|
|
148
157
|
const multiAddrTcp = await enr.getFullMultiaddr('tcp');
|
|
149
158
|
const multiAddrUdp = await enr.getFullMultiaddr('udp');
|
|
150
|
-
this.logger.debug(`Added ENR ${enr.encodeTxt()}`, {
|
|
159
|
+
this.logger.debug(`Added ENR ${enr.encodeTxt()}`, {
|
|
160
|
+
multiAddrTcp,
|
|
161
|
+
multiAddrUdp,
|
|
162
|
+
nodeId: enr.nodeId
|
|
163
|
+
});
|
|
151
164
|
this.onDiscovered(enr);
|
|
152
165
|
}
|
|
166
|
+
isOurBootnode(enr) {
|
|
167
|
+
return this.bootstrapNodeEnrs.some((x)=>x.nodeId === enr.nodeId);
|
|
168
|
+
}
|
|
153
169
|
onDiscovered(enr) {
|
|
170
|
+
// Find out if this is one of our bootnodes
|
|
171
|
+
if (this.isOurBootnode(enr)) {
|
|
172
|
+
// it is, what we do here depends
|
|
173
|
+
if (!this.config.bootstrapNodesAsFullPeers) {
|
|
174
|
+
// we don't consider bootnodes as full peers, don't perform any checks and don't emit anything
|
|
175
|
+
return;
|
|
176
|
+
}
|
|
177
|
+
if (!this.config.bootstrapNodeEnrVersionCheck) {
|
|
178
|
+
// we do consider bootnodes to be full peers and we have been told to NOT version check them, so emit
|
|
179
|
+
this.logger.trace(`Skipping version check for bootnode ${enr.nodeId}`);
|
|
180
|
+
this.emit(PeerEvent.DISCOVERED, enr);
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
// here, we do consider bootnodes as full peers and we must version check so we continue to regular validation
|
|
184
|
+
}
|
|
154
185
|
if (this.validateEnr(enr)) {
|
|
155
186
|
this.emit(PeerEvent.DISCOVERED, enr);
|
|
156
187
|
}
|
|
@@ -159,28 +190,25 @@ export class DiscV5Service extends EventEmitter {
|
|
|
159
190
|
// Check the peer is an aztec peer
|
|
160
191
|
const value = enr.kvs.get(AZTEC_ENR_KEY);
|
|
161
192
|
if (!value) {
|
|
162
|
-
this.logger.warn(`Peer ${enr.nodeId} does not have aztec key in ENR`);
|
|
193
|
+
this.logger.warn(`Peer node ${enr.nodeId} does not have aztec key in ENR`);
|
|
163
194
|
return false;
|
|
164
195
|
}
|
|
196
|
+
// And check it has the correct version
|
|
165
197
|
let compressedVersion;
|
|
166
198
|
try {
|
|
167
|
-
// And check it has the correct version
|
|
168
199
|
compressedVersion = Buffer.from(value).toString();
|
|
169
200
|
checkCompressedComponentVersion(compressedVersion, this.versions);
|
|
170
201
|
return true;
|
|
171
|
-
}
|
|
172
|
-
catch (err) {
|
|
202
|
+
} catch (err) {
|
|
173
203
|
if (err.name === 'ComponentsVersionsError') {
|
|
174
|
-
this.logger.warn(`Peer ${enr.nodeId} has incorrect version: ${err.message}`, {
|
|
204
|
+
this.logger.warn(`Peer node ${enr.nodeId} has incorrect version: ${err.message}`, {
|
|
175
205
|
compressedVersion,
|
|
176
|
-
expected: this.versions
|
|
206
|
+
expected: this.versions
|
|
177
207
|
});
|
|
178
|
-
}
|
|
179
|
-
else {
|
|
208
|
+
} else {
|
|
180
209
|
this.logger.error(`Error checking peer version`, err);
|
|
181
210
|
}
|
|
182
211
|
}
|
|
183
212
|
return false;
|
|
184
213
|
}
|
|
185
214
|
}
|
|
186
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"discV5_service.js","sourceRoot":"","sources":["../../../src/services/discv5/discV5_service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
/// <reference types="node" resolution-mode="require"/>
|
|
2
|
-
import type {
|
|
2
|
+
import type { PeerInfo } from '@aztec/stdlib/interfaces/server';
|
|
3
|
+
import type { BlockAttestation, BlockProposal, Gossipable } from '@aztec/stdlib/p2p';
|
|
4
|
+
import { TxHash } from '@aztec/stdlib/tx';
|
|
3
5
|
import type { PeerId } from '@libp2p/interface';
|
|
4
6
|
import EventEmitter from 'events';
|
|
5
|
-
import {
|
|
7
|
+
import type { ReqRespSubProtocol, SubProtocolMap } from './reqresp/interface.js';
|
|
6
8
|
import { type P2PService, type PeerDiscoveryService, PeerDiscoveryState } from './service.js';
|
|
7
9
|
/**
|
|
8
10
|
* A dummy implementation of the P2P Service.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dummy_service.d.ts","sourceRoot":"","sources":["../../src/services/dummy_service.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,UAAU,EAAE,
|
|
1
|
+
{"version":3,"file":"dummy_service.d.ts","sourceRoot":"","sources":["../../src/services/dummy_service.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAChE,OAAO,KAAK,EAAE,gBAAgB,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AACrF,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAE1C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,YAAY,MAAM,QAAQ,CAAC;AAElC,OAAO,KAAK,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACjF,OAAO,EAAE,KAAK,UAAU,EAAE,KAAK,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAE9F;;GAEG;AACH,qBAAa,eAAgB,YAAW,UAAU;IAChD,wCAAwC;IACxC,QAAQ,IAAI,QAAQ,EAAE;IAItB;;;OAGG;IACI,KAAK;IAIZ;;;OAGG;IACI,IAAI;IAIX;;;OAGG;IACI,SAAS,CAAC,CAAC,SAAS,UAAU,EAAE,CAAC,EAAE,CAAC;IAE3C;;;OAGG;IACI,UAAU,CAAC,CAAC,EAAE,MAAM,EAAE;IAE7B;;OAEG;IACI,6BAA6B,CAAC,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,OAAO,CAAC,gBAAgB,CAAC;IAE3F;;;;;OAKG;IACI,WAAW,CAAC,QAAQ,SAAS,kBAAkB,EACpD,SAAS,EAAE,QAAQ,EACnB,QAAQ,EAAE,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,GAC1D,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,GAAG,SAAS,CAAC;IAI1E;;;;;OAKG;IACI,gBAAgB,CAAC,QAAQ,SAAS,kBAAkB,EACzD,SAAS,EAAE,QAAQ,EACnB,SAAS,EAAE,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,GAC7D,OAAO,CAAC,YAAY,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC;IAIhE;;;OAGG;IACI,MAAM,IAAI,SAAS;CAG3B;AAED;;GAEG;AACH,qBAAa,yBAA0B,SAAQ,YAAa,YAAW,oBAAoB;IACzF,OAAO,CAAC,YAAY,CAA8B;IAC3C,cAAc,EAAE,MAAM,EAAE,CAAM;IAErC;;;OAGG;IACI,KAAK;IAIZ;;;OAGG;IACI,IAAI;IAIX;;;OAGG;IACI,WAAW;IAIX,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;IAIpC,eAAe,CAAC,CAAC,EAAE,MAAM,GAAG,OAAO;IAInC,SAAS,IAAI,kBAAkB;IAI/B,MAAM,IAAI,SAAS;CAG3B"}
|