@waku/core 0.0.33 → 0.0.34-00f2e75.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/bundle/base_protocol-Bp5a9PNG.js +152 -0
- package/bundle/{index-BIW3qNYx.js → index-G1eRBjeI.js} +118 -204
- package/bundle/index.js +1895 -179
- package/bundle/lib/base_protocol.js +2 -2
- package/bundle/lib/message/version_0.js +2 -2
- package/bundle/{version_0-CdmZMfkQ.js → version_0-DJZG2fB2.js} +283 -45
- package/dist/.tsbuildinfo +1 -1
- package/dist/index.d.ts +1 -3
- package/dist/index.js +1 -3
- package/dist/index.js.map +1 -1
- package/dist/lib/base_protocol.d.ts +3 -23
- package/dist/lib/base_protocol.js +3 -47
- package/dist/lib/base_protocol.js.map +1 -1
- package/dist/lib/connection_manager/connection_manager.d.ts +118 -0
- package/dist/lib/{connection_manager.js → connection_manager/connection_manager.js} +136 -36
- package/dist/lib/connection_manager/connection_manager.js.map +1 -0
- package/dist/lib/connection_manager/index.d.ts +1 -0
- package/dist/lib/connection_manager/index.js +2 -0
- package/dist/lib/connection_manager/index.js.map +1 -0
- package/dist/lib/{keep_alive_manager.d.ts → connection_manager/keep_alive_manager.d.ts} +4 -2
- package/dist/lib/{keep_alive_manager.js → connection_manager/keep_alive_manager.js} +2 -2
- package/dist/lib/connection_manager/keep_alive_manager.js.map +1 -0
- package/dist/lib/connection_manager/utils.d.ts +7 -0
- package/dist/lib/connection_manager/utils.js +22 -0
- package/dist/lib/connection_manager/utils.js.map +1 -0
- package/dist/lib/filter/filter.d.ts +18 -0
- package/dist/lib/filter/filter.js +209 -0
- package/dist/lib/filter/filter.js.map +1 -0
- package/dist/lib/filter/index.d.ts +1 -18
- package/dist/lib/filter/index.js +1 -208
- package/dist/lib/filter/index.js.map +1 -1
- package/dist/lib/light_push/index.d.ts +1 -15
- package/dist/lib/light_push/index.js +1 -143
- package/dist/lib/light_push/index.js.map +1 -1
- package/dist/lib/light_push/light_push.d.ts +15 -0
- package/dist/lib/light_push/light_push.js +144 -0
- package/dist/lib/light_push/light_push.js.map +1 -0
- package/dist/lib/light_push/utils.d.ts +0 -2
- package/dist/lib/light_push/utils.js +9 -17
- package/dist/lib/light_push/utils.js.map +1 -1
- package/dist/lib/metadata/index.d.ts +1 -3
- package/dist/lib/metadata/index.js +1 -118
- package/dist/lib/metadata/index.js.map +1 -1
- package/dist/lib/metadata/metadata.d.ts +3 -0
- package/dist/lib/metadata/metadata.js +119 -0
- package/dist/lib/metadata/metadata.js.map +1 -0
- package/dist/lib/store/index.d.ts +1 -9
- package/dist/lib/store/index.js +1 -82
- package/dist/lib/store/index.js.map +1 -1
- package/dist/lib/store/store.d.ts +9 -0
- package/dist/lib/store/store.js +83 -0
- package/dist/lib/store/store.js.map +1 -0
- package/dist/lib/stream_manager/stream_manager.d.ts +2 -2
- package/dist/lib/stream_manager/stream_manager.js +16 -17
- package/dist/lib/stream_manager/stream_manager.js.map +1 -1
- package/package.json +1 -126
- package/src/index.ts +1 -4
- package/src/lib/base_protocol.ts +3 -76
- package/src/lib/{connection_manager.ts → connection_manager/connection_manager.ts} +168 -63
- package/src/lib/connection_manager/index.ts +1 -0
- package/src/lib/{keep_alive_manager.ts → connection_manager/keep_alive_manager.ts} +7 -3
- package/src/lib/connection_manager/utils.ts +25 -0
- package/src/lib/filter/filter.ts +315 -0
- package/src/lib/filter/index.ts +1 -315
- package/src/lib/light_push/index.ts +1 -188
- package/src/lib/light_push/light_push.ts +188 -0
- package/src/lib/light_push/utils.ts +13 -21
- package/src/lib/metadata/index.ts +1 -182
- package/src/lib/metadata/metadata.ts +182 -0
- package/src/lib/store/index.ts +1 -136
- package/src/lib/store/store.ts +136 -0
- package/src/lib/stream_manager/stream_manager.ts +16 -18
- package/bundle/base_protocol-Dzv-QHPR.js +0 -275
- package/dist/lib/connection_manager.d.ts +0 -62
- package/dist/lib/connection_manager.js.map +0 -1
- package/dist/lib/filterPeers.d.ts +0 -13
- package/dist/lib/filterPeers.js +0 -38
- package/dist/lib/filterPeers.js.map +0 -1
- package/dist/lib/health_manager.d.ts +0 -14
- package/dist/lib/health_manager.js +0 -70
- package/dist/lib/health_manager.js.map +0 -1
- package/dist/lib/keep_alive_manager.js.map +0 -1
- package/src/lib/filterPeers.ts +0 -51
- package/src/lib/health_manager.ts +0 -90
@@ -0,0 +1,83 @@
|
|
1
|
+
import { Logger } from "@waku/utils";
|
2
|
+
import all from "it-all";
|
3
|
+
import * as lp from "it-length-prefixed";
|
4
|
+
import { pipe } from "it-pipe";
|
5
|
+
import { Uint8ArrayList } from "uint8arraylist";
|
6
|
+
import { BaseProtocol } from "../base_protocol.js";
|
7
|
+
import { toProtoMessage } from "../to_proto_message.js";
|
8
|
+
import { DEFAULT_PAGE_SIZE, MAX_PAGE_SIZE, StoreQueryRequest, StoreQueryResponse } from "./rpc.js";
|
9
|
+
const log = new Logger("store");
|
10
|
+
export const StoreCodec = "/vac/waku/store-query/3.0.0";
|
11
|
+
export class StoreCore extends BaseProtocol {
|
12
|
+
pubsubTopics;
|
13
|
+
constructor(pubsubTopics, libp2p) {
|
14
|
+
super(StoreCodec, libp2p.components, pubsubTopics);
|
15
|
+
this.pubsubTopics = pubsubTopics;
|
16
|
+
}
|
17
|
+
async *queryPerPage(queryOpts, decoders, peerId) {
|
18
|
+
if (queryOpts.contentTopics.toString() !==
|
19
|
+
Array.from(decoders.keys()).toString()) {
|
20
|
+
throw new Error("Internal error, the decoders should match the query's content topics");
|
21
|
+
}
|
22
|
+
let currentCursor = queryOpts.paginationCursor;
|
23
|
+
while (true) {
|
24
|
+
const storeQueryRequest = StoreQueryRequest.create({
|
25
|
+
...queryOpts,
|
26
|
+
paginationCursor: currentCursor
|
27
|
+
});
|
28
|
+
let stream;
|
29
|
+
try {
|
30
|
+
stream = await this.getStream(peerId);
|
31
|
+
}
|
32
|
+
catch (e) {
|
33
|
+
log.error("Failed to get stream", e);
|
34
|
+
break;
|
35
|
+
}
|
36
|
+
const res = await pipe([storeQueryRequest.encode()], lp.encode, stream, lp.decode, async (source) => await all(source));
|
37
|
+
const bytes = new Uint8ArrayList();
|
38
|
+
res.forEach((chunk) => {
|
39
|
+
bytes.append(chunk);
|
40
|
+
});
|
41
|
+
const storeQueryResponse = StoreQueryResponse.decode(bytes);
|
42
|
+
if (!storeQueryResponse.statusCode ||
|
43
|
+
storeQueryResponse.statusCode >= 300) {
|
44
|
+
const errorMessage = `Store query failed with status code: ${storeQueryResponse.statusCode}, description: ${storeQueryResponse.statusDesc}`;
|
45
|
+
log.error(errorMessage);
|
46
|
+
throw new Error(errorMessage);
|
47
|
+
}
|
48
|
+
if (!storeQueryResponse.messages || !storeQueryResponse.messages.length) {
|
49
|
+
log.warn("Stopping pagination due to empty messages in response");
|
50
|
+
break;
|
51
|
+
}
|
52
|
+
log.info(`${storeQueryResponse.messages.length} messages retrieved from store`);
|
53
|
+
const decodedMessages = storeQueryResponse.messages.map((protoMsg) => {
|
54
|
+
if (!protoMsg.message) {
|
55
|
+
return Promise.resolve(undefined);
|
56
|
+
}
|
57
|
+
const contentTopic = protoMsg.message.contentTopic;
|
58
|
+
if (contentTopic) {
|
59
|
+
const decoder = decoders.get(contentTopic);
|
60
|
+
if (decoder) {
|
61
|
+
return decoder.fromProtoObj(protoMsg.pubsubTopic || "", toProtoMessage(protoMsg.message));
|
62
|
+
}
|
63
|
+
}
|
64
|
+
return Promise.resolve(undefined);
|
65
|
+
});
|
66
|
+
yield decodedMessages;
|
67
|
+
if (queryOpts.paginationForward) {
|
68
|
+
currentCursor =
|
69
|
+
storeQueryResponse.messages[storeQueryResponse.messages.length - 1]
|
70
|
+
.messageHash;
|
71
|
+
}
|
72
|
+
else {
|
73
|
+
currentCursor = storeQueryResponse.messages[0].messageHash;
|
74
|
+
}
|
75
|
+
if (storeQueryResponse.messages.length > MAX_PAGE_SIZE &&
|
76
|
+
storeQueryResponse.messages.length <
|
77
|
+
(queryOpts.paginationLimit || DEFAULT_PAGE_SIZE)) {
|
78
|
+
break;
|
79
|
+
}
|
80
|
+
}
|
81
|
+
}
|
82
|
+
}
|
83
|
+
//# sourceMappingURL=store.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/lib/store/store.ts"],"names":[],"mappings":"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"}
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import type {
|
1
|
+
import type { PeerId, Stream } from "@libp2p/interface";
|
2
2
|
import type { Libp2p } from "@waku/interfaces";
|
3
3
|
export declare class StreamManager {
|
4
4
|
private multicodec;
|
@@ -8,7 +8,7 @@ export declare class StreamManager {
|
|
8
8
|
private ongoingCreation;
|
9
9
|
private streamPool;
|
10
10
|
constructor(multicodec: string, getConnections: Libp2p["getConnections"], addEventListener: Libp2p["addEventListener"]);
|
11
|
-
getStream(
|
11
|
+
getStream(peerId: PeerId): Promise<Stream>;
|
12
12
|
private createStream;
|
13
13
|
private createStreamWithLock;
|
14
14
|
private handlePeerUpdateStreamPool;
|
@@ -15,36 +15,36 @@ export class StreamManager {
|
|
15
15
|
this.log = new Logger(`stream-manager:${multicodec}`);
|
16
16
|
this.addEventListener("peer:update", this.handlePeerUpdateStreamPool);
|
17
17
|
}
|
18
|
-
async getStream(
|
19
|
-
const
|
20
|
-
const scheduledStream = this.streamPool.get(
|
18
|
+
async getStream(peerId) {
|
19
|
+
const peerIdStr = peerId.toString();
|
20
|
+
const scheduledStream = this.streamPool.get(peerIdStr);
|
21
21
|
if (scheduledStream) {
|
22
|
-
this.streamPool.delete(
|
22
|
+
this.streamPool.delete(peerIdStr);
|
23
23
|
await scheduledStream;
|
24
24
|
}
|
25
|
-
let stream = this.getOpenStreamForCodec(
|
25
|
+
let stream = this.getOpenStreamForCodec(peerId);
|
26
26
|
if (stream) {
|
27
|
-
this.log.info(`Found existing stream peerId=${
|
28
|
-
this.lockStream(
|
27
|
+
this.log.info(`Found existing stream peerId=${peerIdStr} multicodec=${this.multicodec}`);
|
28
|
+
this.lockStream(peerIdStr, stream);
|
29
29
|
return stream;
|
30
30
|
}
|
31
|
-
stream = await this.createStream(
|
32
|
-
this.lockStream(
|
31
|
+
stream = await this.createStream(peerId);
|
32
|
+
this.lockStream(peerIdStr, stream);
|
33
33
|
return stream;
|
34
34
|
}
|
35
|
-
async createStream(
|
36
|
-
const connections = this.getConnections(
|
35
|
+
async createStream(peerId, retries = 0) {
|
36
|
+
const connections = this.getConnections(peerId);
|
37
37
|
const connection = selectOpenConnection(connections);
|
38
38
|
if (!connection) {
|
39
|
-
throw new Error(`Failed to get a connection to the peer peerId=${
|
39
|
+
throw new Error(`Failed to get a connection to the peer peerId=${peerId.toString()} multicodec=${this.multicodec}`);
|
40
40
|
}
|
41
41
|
let lastError;
|
42
42
|
let stream;
|
43
43
|
for (let i = 0; i < retries + 1; i++) {
|
44
44
|
try {
|
45
|
-
this.log.info(`Attempting to create a stream for peerId=${
|
45
|
+
this.log.info(`Attempting to create a stream for peerId=${peerId.toString()} multicodec=${this.multicodec}`);
|
46
46
|
stream = await connection.newStream(this.multicodec);
|
47
|
-
this.log.info(`Created stream for peerId=${
|
47
|
+
this.log.info(`Created stream for peerId=${peerId.toString()} multicodec=${this.multicodec}`);
|
48
48
|
break;
|
49
49
|
}
|
50
50
|
catch (error) {
|
@@ -52,8 +52,7 @@ export class StreamManager {
|
|
52
52
|
}
|
53
53
|
}
|
54
54
|
if (!stream) {
|
55
|
-
throw new Error(`Failed to create a new stream for ${
|
56
|
-
lastError);
|
55
|
+
throw new Error(`Failed to create a new stream for ${peerId.toString()} -- ` + lastError);
|
57
56
|
}
|
58
57
|
return stream;
|
59
58
|
}
|
@@ -65,7 +64,7 @@ export class StreamManager {
|
|
65
64
|
}
|
66
65
|
try {
|
67
66
|
this.ongoingCreation.add(peerId);
|
68
|
-
await this.createStream(peer);
|
67
|
+
await this.createStream(peer.id);
|
69
68
|
}
|
70
69
|
catch (error) {
|
71
70
|
this.log.error(`Failed to createStreamWithLock:`, error);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"stream_manager.js","sourceRoot":"","sources":["../../../src/lib/stream_manager/stream_manager.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErC,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAElD,MAAM,eAAe,GAAG,UAAU,CAAC;AAEnC,MAAM,OAAO,aAAa;IAOd;IACA;IACA;IARO,GAAG,CAAS;IAErB,eAAe,GAAgB,IAAI,GAAG,EAAE,CAAC;IACzC,UAAU,GAA+B,IAAI,GAAG,EAAE,CAAC;IAE3D,YACU,UAAkB,EAClB,cAAwC,EACxC,gBAA4C;QAF5C,eAAU,GAAV,UAAU,CAAQ;QAClB,mBAAc,GAAd,cAAc,CAA0B;QACxC,qBAAgB,GAAhB,gBAAgB,CAA4B;QAEpD,IAAI,CAAC,GAAG,GAAG,IAAI,MAAM,CAAC,kBAAkB,UAAU,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,0BAA0B,CAAC,CAAC;IACxE,CAAC;IAEM,KAAK,CAAC,SAAS,CAAC,
|
1
|
+
{"version":3,"file":"stream_manager.js","sourceRoot":"","sources":["../../../src/lib/stream_manager/stream_manager.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
@@ -1,126 +1 @@
|
|
1
|
-
{
|
2
|
-
"name": "@waku/core",
|
3
|
-
"version": "0.0.33",
|
4
|
-
"description": "TypeScript implementation of the Waku v2 protocol",
|
5
|
-
"types": "./dist/index.d.ts",
|
6
|
-
"module": "./dist/index.js",
|
7
|
-
"exports": {
|
8
|
-
".": {
|
9
|
-
"types": "./dist/index.d.ts",
|
10
|
-
"import": "./dist/index.js"
|
11
|
-
},
|
12
|
-
"./lib/message/version_0": {
|
13
|
-
"types": "./dist/lib/message/version_0.d.ts",
|
14
|
-
"import": "./dist/lib/message/version_0.js"
|
15
|
-
},
|
16
|
-
"./lib/base_protocol": {
|
17
|
-
"types": "./dist/lib/base_protocol.d.ts",
|
18
|
-
"import": "./dist/lib/base_protocol.js"
|
19
|
-
}
|
20
|
-
},
|
21
|
-
"typesVersions": {
|
22
|
-
"*": {
|
23
|
-
"lib/*": [
|
24
|
-
"dist/lib/*"
|
25
|
-
],
|
26
|
-
"constants/*": [
|
27
|
-
"dist/constants/*"
|
28
|
-
]
|
29
|
-
}
|
30
|
-
},
|
31
|
-
"type": "module",
|
32
|
-
"homepage": "https://github.com/waku-org/js-waku/tree/master/packages/core#readme",
|
33
|
-
"repository": {
|
34
|
-
"type": "git",
|
35
|
-
"url": "https://github.com/waku-org/js-waku.git"
|
36
|
-
},
|
37
|
-
"bugs": {
|
38
|
-
"url": "https://github.com/waku-org/js-waku/issues"
|
39
|
-
},
|
40
|
-
"license": "MIT OR Apache-2.0",
|
41
|
-
"keywords": [
|
42
|
-
"waku",
|
43
|
-
"decentralised",
|
44
|
-
"communication",
|
45
|
-
"web3",
|
46
|
-
"ethereum",
|
47
|
-
"dapps"
|
48
|
-
],
|
49
|
-
"scripts": {
|
50
|
-
"build": "run-s build:**",
|
51
|
-
"build:esm": "tsc",
|
52
|
-
"build:bundle": "rollup --config rollup.config.js",
|
53
|
-
"fix": "run-s fix:*",
|
54
|
-
"fix:lint": "eslint src *.js --fix",
|
55
|
-
"check": "run-s check:*",
|
56
|
-
"check:tsc": "tsc -p tsconfig.dev.json",
|
57
|
-
"check:lint": "eslint src *.js",
|
58
|
-
"check:spelling": "cspell \"{README.md,src/**/*.ts}\"",
|
59
|
-
"test": "NODE_ENV=test run-s test:*",
|
60
|
-
"test:node": "NODE_ENV=test TS_NODE_PROJECT=./tsconfig.dev.json mocha",
|
61
|
-
"test:browser": "NODE_ENV=test karma start karma.conf.cjs",
|
62
|
-
"watch:build": "tsc -p tsconfig.json -w",
|
63
|
-
"watch:test": "mocha --watch",
|
64
|
-
"prepublish": "npm run build",
|
65
|
-
"reset-hard": "git clean -dfx -e .idea && git reset --hard && npm i && npm run build"
|
66
|
-
},
|
67
|
-
"engines": {
|
68
|
-
"node": ">=20"
|
69
|
-
},
|
70
|
-
"dependencies": {
|
71
|
-
"@libp2p/ping": "^1.1.2",
|
72
|
-
"@waku/enr": "^0.0.27",
|
73
|
-
"@waku/interfaces": "0.0.28",
|
74
|
-
"@waku/proto": "0.0.8",
|
75
|
-
"@waku/utils": "0.0.21",
|
76
|
-
"debug": "^4.3.4",
|
77
|
-
"it-all": "^3.0.4",
|
78
|
-
"it-length-prefixed": "^9.0.4",
|
79
|
-
"it-pipe": "^3.0.1",
|
80
|
-
"uint8arraylist": "^2.4.3",
|
81
|
-
"uuid": "^9.0.0"
|
82
|
-
},
|
83
|
-
"devDependencies": {
|
84
|
-
"@multiformats/multiaddr": "^12.0.0",
|
85
|
-
"@rollup/plugin-commonjs": "^25.0.7",
|
86
|
-
"@rollup/plugin-json": "^6.0.0",
|
87
|
-
"@rollup/plugin-node-resolve": "^15.2.3",
|
88
|
-
"@types/chai": "^4.3.11",
|
89
|
-
"@types/debug": "^4.1.12",
|
90
|
-
"@types/mocha": "^10.0.6",
|
91
|
-
"@types/uuid": "^9.0.8",
|
92
|
-
"@waku/build-utils": "*",
|
93
|
-
"chai": "^4.3.10",
|
94
|
-
"sinon": "^18.0.0",
|
95
|
-
"cspell": "^8.6.1",
|
96
|
-
"fast-check": "^3.19.0",
|
97
|
-
"ignore-loader": "^0.1.2",
|
98
|
-
"isomorphic-fetch": "^3.0.0",
|
99
|
-
"mocha": "^10.3.0",
|
100
|
-
"npm-run-all": "^4.1.5",
|
101
|
-
"process": "^0.11.10",
|
102
|
-
"rollup": "^4.12.0"
|
103
|
-
},
|
104
|
-
"peerDependencies": {
|
105
|
-
"@multiformats/multiaddr": "^12.0.0",
|
106
|
-
"libp2p": "^1.8.1"
|
107
|
-
},
|
108
|
-
"peerDependenciesMeta": {
|
109
|
-
"@multiformats/multiaddr": {
|
110
|
-
"optional": true
|
111
|
-
},
|
112
|
-
"libp2p": {
|
113
|
-
"optional": true
|
114
|
-
}
|
115
|
-
},
|
116
|
-
"files": [
|
117
|
-
"dist",
|
118
|
-
"bundle",
|
119
|
-
"src/**/*.ts",
|
120
|
-
"!**/*.spec.*",
|
121
|
-
"!**/*.json",
|
122
|
-
"CHANGELOG.md",
|
123
|
-
"LICENSE",
|
124
|
-
"README.md"
|
125
|
-
]
|
126
|
-
}
|
1
|
+
{"name":"@waku/core","version":"0.0.34-00f2e75.0","description":"TypeScript implementation of the Waku v2 protocol","types":"./dist/index.d.ts","module":"./dist/index.js","exports":{".":{"types":"./dist/index.d.ts","import":"./dist/index.js"},"./lib/message/version_0":{"types":"./dist/lib/message/version_0.d.ts","import":"./dist/lib/message/version_0.js"},"./lib/base_protocol":{"types":"./dist/lib/base_protocol.d.ts","import":"./dist/lib/base_protocol.js"}},"typesVersions":{"*":{"lib/*":["dist/lib/*"],"constants/*":["dist/constants/*"]}},"type":"module","homepage":"https://github.com/waku-org/js-waku/tree/master/packages/core#readme","repository":{"type":"git","url":"https://github.com/waku-org/js-waku.git"},"bugs":{"url":"https://github.com/waku-org/js-waku/issues"},"license":"MIT OR Apache-2.0","keywords":["waku","decentralised","communication","web3","ethereum","dapps"],"scripts":{"build":"run-s build:**","build:esm":"tsc","build:bundle":"rollup --config rollup.config.js","fix":"run-s fix:*","fix:lint":"eslint src *.js --fix","check":"run-s check:*","check:tsc":"tsc -p tsconfig.dev.json","check:lint":"eslint src *.js","check:spelling":"cspell \"{README.md,src/**/*.ts}\"","test":"NODE_ENV=test run-s test:*","test:node":"NODE_ENV=test TS_NODE_PROJECT=./tsconfig.dev.json mocha","test:browser":"NODE_ENV=test karma start karma.conf.cjs","watch:build":"tsc -p tsconfig.json -w","watch:test":"mocha --watch","prepublish":"npm run build","reset-hard":"git clean -dfx -e .idea && git reset --hard && npm i && npm run build"},"engines":{"node":">=20"},"dependencies":{"@waku/enr":"0.0.28-00f2e75.0","@waku/interfaces":"0.0.29-00f2e75.0","@libp2p/ping":"2.0.1","@waku/proto":"0.0.9-00f2e75.0","@waku/utils":"0.0.22-00f2e75.0","debug":"^4.3.4","it-all":"^3.0.4","it-length-prefixed":"^9.0.4","it-pipe":"^3.0.1","uint8arraylist":"^2.4.3","uuid":"^9.0.0"},"devDependencies":{"@libp2p/peer-id":"^5.0.1","@libp2p/interface":"^2.1.3","@multiformats/multiaddr":"^12.0.0","@rollup/plugin-commonjs":"^25.0.7","@rollup/plugin-json":"^6.0.0","@rollup/plugin-node-resolve":"^15.2.3","@types/chai":"^4.3.11","@types/debug":"^4.1.12","@types/mocha":"^10.0.6","@types/uuid":"^9.0.8","@waku/build-utils":"*","chai":"^4.3.10","sinon":"^18.0.0","cspell":"^8.6.1","fast-check":"^3.19.0","ignore-loader":"^0.1.2","isomorphic-fetch":"^3.0.0","mocha":"^10.3.0","npm-run-all":"^4.1.5","process":"^0.11.10","rollup":"^4.12.0"},"peerDependencies":{"@multiformats/multiaddr":"^12.0.0","libp2p":"2.1.8"},"peerDependenciesMeta":{"@multiformats/multiaddr":{"optional":true},"libp2p":{"optional":true}},"files":["dist","bundle","src/**/*.ts","!**/*.spec.*","!**/*.json","CHANGELOG.md","LICENSE","README.md"]}
|
package/src/index.ts
CHANGED
@@ -15,11 +15,8 @@ export { LightPushCodec, LightPushCore } from "./lib/light_push/index.js";
|
|
15
15
|
export * as waku_store from "./lib/store/index.js";
|
16
16
|
export { StoreCore, StoreCodec } from "./lib/store/index.js";
|
17
17
|
|
18
|
-
export { ConnectionManager } from "./lib/connection_manager.js";
|
18
|
+
export { ConnectionManager } from "./lib/connection_manager/index.js";
|
19
19
|
|
20
|
-
export { getHealthManager } from "./lib/health_manager.js";
|
21
|
-
|
22
|
-
export { KeepAliveManager } from "./lib/keep_alive_manager.js";
|
23
20
|
export { StreamManager } from "./lib/stream_manager/index.js";
|
24
21
|
|
25
22
|
export { MetadataCodec, wakuMetadata } from "./lib/metadata/index.js";
|
package/src/lib/base_protocol.ts
CHANGED
@@ -1,14 +1,11 @@
|
|
1
1
|
import type { Libp2p } from "@libp2p/interface";
|
2
|
-
import type {
|
2
|
+
import type { PeerId, Stream } from "@libp2p/interface";
|
3
3
|
import type {
|
4
4
|
IBaseProtocolCore,
|
5
5
|
Libp2pComponents,
|
6
6
|
PubsubTopic
|
7
7
|
} from "@waku/interfaces";
|
8
|
-
import { Logger } from "@waku/utils";
|
9
|
-
import { getPeersForProtocol, sortPeersByLatency } from "@waku/utils/libp2p";
|
10
8
|
|
11
|
-
import { filterPeersByDiscovery } from "./filterPeers.js";
|
12
9
|
import { StreamManager } from "./stream_manager/index.js";
|
13
10
|
|
14
11
|
/**
|
@@ -23,7 +20,6 @@ export class BaseProtocol implements IBaseProtocolCore {
|
|
23
20
|
protected constructor(
|
24
21
|
public multicodec: string,
|
25
22
|
protected components: Libp2pComponents,
|
26
|
-
private log: Logger,
|
27
23
|
public readonly pubsubTopics: PubsubTopic[]
|
28
24
|
) {
|
29
25
|
this.addLibp2pEventListener = components.events.addEventListener.bind(
|
@@ -42,76 +38,7 @@ export class BaseProtocol implements IBaseProtocolCore {
|
|
42
38
|
);
|
43
39
|
}
|
44
40
|
|
45
|
-
protected async getStream(
|
46
|
-
return this.streamManager.getStream(
|
47
|
-
}
|
48
|
-
|
49
|
-
/**
|
50
|
-
* Returns known peers from the address book (`libp2p.peerStore`) that support
|
51
|
-
* the class protocol. Waku may or may not be currently connected to these
|
52
|
-
* peers.
|
53
|
-
*/
|
54
|
-
public async allPeers(): Promise<Peer[]> {
|
55
|
-
return getPeersForProtocol(this.components.peerStore, [this.multicodec]);
|
56
|
-
}
|
57
|
-
|
58
|
-
public async connectedPeers(): Promise<Peer[]> {
|
59
|
-
const peers = await this.allPeers();
|
60
|
-
return peers.filter((peer) => {
|
61
|
-
const connections = this.components.connectionManager.getConnections(
|
62
|
-
peer.id
|
63
|
-
);
|
64
|
-
return connections.length > 0;
|
65
|
-
});
|
66
|
-
}
|
67
|
-
|
68
|
-
/**
|
69
|
-
* Retrieves a list of connected peers that support the protocol. The list is sorted by latency.
|
70
|
-
*
|
71
|
-
* @param numPeers - The total number of peers to retrieve. If 0, all peers are returned.
|
72
|
-
* @param maxBootstrapPeers - The maximum number of bootstrap peers to retrieve.
|
73
|
-
* @returns A list of peers that support the protocol sorted by latency. By default, returns all peers available, including bootstrap.
|
74
|
-
*/
|
75
|
-
public async getPeers(
|
76
|
-
{
|
77
|
-
numPeers,
|
78
|
-
maxBootstrapPeers
|
79
|
-
}: {
|
80
|
-
numPeers: number;
|
81
|
-
maxBootstrapPeers: number;
|
82
|
-
} = {
|
83
|
-
maxBootstrapPeers: 0,
|
84
|
-
numPeers: 0
|
85
|
-
}
|
86
|
-
): Promise<Peer[]> {
|
87
|
-
// Retrieve all connected peers that support the protocol & shard (if configured)
|
88
|
-
const allAvailableConnectedPeers = await this.connectedPeers();
|
89
|
-
|
90
|
-
// Filter the peers based on discovery & number of peers requested
|
91
|
-
const filteredPeers = filterPeersByDiscovery(
|
92
|
-
allAvailableConnectedPeers,
|
93
|
-
numPeers,
|
94
|
-
maxBootstrapPeers
|
95
|
-
);
|
96
|
-
|
97
|
-
// Sort the peers by latency
|
98
|
-
const sortedFilteredPeers = await sortPeersByLatency(
|
99
|
-
this.components.peerStore,
|
100
|
-
filteredPeers
|
101
|
-
);
|
102
|
-
|
103
|
-
if (sortedFilteredPeers.length === 0) {
|
104
|
-
this.log.warn(
|
105
|
-
"No peers found. Ensure you have a connection to the network."
|
106
|
-
);
|
107
|
-
}
|
108
|
-
|
109
|
-
if (sortedFilteredPeers.length < numPeers) {
|
110
|
-
this.log.warn(
|
111
|
-
`Only ${sortedFilteredPeers.length} peers found. Requested ${numPeers}.`
|
112
|
-
);
|
113
|
-
}
|
114
|
-
|
115
|
-
return sortedFilteredPeers;
|
41
|
+
protected async getStream(peerId: PeerId): Promise<Stream> {
|
42
|
+
return this.streamManager.getStream(peerId);
|
116
43
|
}
|
117
44
|
}
|