@waku/core 0.0.36 → 0.0.37-2ed5ddc.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/index.js +4628 -873
- package/bundle/lib/message/version_0.js +1 -1
- package/bundle/{version_0-9DPFjcJG.js → version_0-Bc0h7ah2.js} +312 -33
- package/dist/.tsbuildinfo +1 -1
- package/dist/lib/connection_manager/connection_limiter.d.ts +35 -0
- package/dist/lib/connection_manager/connection_limiter.js +103 -0
- package/dist/lib/connection_manager/connection_limiter.js.map +1 -0
- package/dist/lib/connection_manager/connection_manager.d.ts +19 -105
- package/dist/lib/connection_manager/connection_manager.js +64 -507
- package/dist/lib/connection_manager/connection_manager.js.map +1 -1
- package/dist/lib/connection_manager/discovery_dialer.d.ts +32 -0
- package/dist/lib/connection_manager/discovery_dialer.js +131 -0
- package/dist/lib/connection_manager/discovery_dialer.js.map +1 -0
- package/dist/lib/connection_manager/keep_alive_manager.d.ts +17 -7
- package/dist/lib/connection_manager/keep_alive_manager.js +110 -74
- package/dist/lib/connection_manager/keep_alive_manager.js.map +1 -1
- package/dist/lib/connection_manager/network_monitor.d.ts +22 -0
- package/dist/lib/connection_manager/network_monitor.js +63 -0
- package/dist/lib/connection_manager/network_monitor.js.map +1 -0
- package/dist/lib/connection_manager/shard_reader.d.ts +28 -0
- package/dist/lib/connection_manager/shard_reader.js +70 -0
- package/dist/lib/connection_manager/shard_reader.js.map +1 -0
- package/dist/lib/connection_manager/utils.d.ts +16 -1
- package/dist/lib/connection_manager/utils.js +23 -0
- package/dist/lib/connection_manager/utils.js.map +1 -1
- package/dist/lib/filter/filter.d.ts +2 -3
- package/dist/lib/filter/filter.js +8 -25
- package/dist/lib/filter/filter.js.map +1 -1
- package/dist/lib/light_push/light_push.d.ts +2 -3
- package/dist/lib/light_push/light_push.js +1 -3
- package/dist/lib/light_push/light_push.js.map +1 -1
- package/dist/lib/store/store.d.ts +2 -3
- package/dist/lib/store/store.js +1 -3
- package/dist/lib/store/store.js.map +1 -1
- package/package.json +1 -125
- package/src/lib/connection_manager/connection_limiter.ts +161 -0
- package/src/lib/connection_manager/connection_manager.ts +85 -674
- package/src/lib/connection_manager/discovery_dialer.ts +195 -0
- package/src/lib/connection_manager/keep_alive_manager.ts +154 -87
- package/src/lib/connection_manager/network_monitor.ts +88 -0
- package/src/lib/connection_manager/shard_reader.ts +134 -0
- package/src/lib/connection_manager/utils.ts +27 -1
- package/src/lib/filter/filter.ts +7 -28
- package/src/lib/light_push/light_push.ts +1 -5
- package/src/lib/store/store.ts +1 -5
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"shard_reader.js","sourceRoot":"","sources":["../../../src/lib/connection_manager/shard_reader.ts"],"names":[],"mappings":"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"}
|
@@ -1,7 +1,22 @@
|
|
1
|
-
import type
|
1
|
+
import { type Peer, type PeerId } from "@libp2p/interface";
|
2
|
+
import { Multiaddr, MultiaddrInput } from "@multiformats/multiaddr";
|
2
3
|
/**
|
3
4
|
* Reads peer's metadata and retrieves ping value.
|
4
5
|
* @param peer Peer or null
|
5
6
|
* @returns -1 if no ping attached, otherwise returns ping value
|
6
7
|
*/
|
7
8
|
export declare const getPeerPing: (peer: Peer | null) => number;
|
9
|
+
/**
|
10
|
+
* Maps a PeerId or MultiaddrInput to a PeerId or Multiaddr.
|
11
|
+
* @param input - The PeerId or MultiaddrInput to map.
|
12
|
+
* @returns The PeerId or Multiaddr.
|
13
|
+
* @throws {Error} If the input is not a valid PeerId or MultiaddrInput.
|
14
|
+
*/
|
15
|
+
export declare const mapToPeerIdOrMultiaddr: (input: PeerId | MultiaddrInput) => PeerId | Multiaddr;
|
16
|
+
/**
|
17
|
+
* Maps a PeerId or MultiaddrInput to a PeerId.
|
18
|
+
* @param input - The PeerId or MultiaddrInput to map.
|
19
|
+
* @returns The PeerId.
|
20
|
+
* @throws {Error} If the input is not a valid PeerId or MultiaddrInput.
|
21
|
+
*/
|
22
|
+
export declare const mapToPeerId: (input: PeerId | MultiaddrInput) => PeerId;
|
@@ -1,3 +1,6 @@
|
|
1
|
+
import { isPeerId } from "@libp2p/interface";
|
2
|
+
import { peerIdFromString } from "@libp2p/peer-id";
|
3
|
+
import { multiaddr } from "@multiformats/multiaddr";
|
1
4
|
import { bytesToUtf8 } from "@waku/utils/bytes";
|
2
5
|
/**
|
3
6
|
* Reads peer's metadata and retrieves ping value.
|
@@ -19,4 +22,24 @@ export const getPeerPing = (peer) => {
|
|
19
22
|
return -1;
|
20
23
|
}
|
21
24
|
};
|
25
|
+
/**
|
26
|
+
* Maps a PeerId or MultiaddrInput to a PeerId or Multiaddr.
|
27
|
+
* @param input - The PeerId or MultiaddrInput to map.
|
28
|
+
* @returns The PeerId or Multiaddr.
|
29
|
+
* @throws {Error} If the input is not a valid PeerId or MultiaddrInput.
|
30
|
+
*/
|
31
|
+
export const mapToPeerIdOrMultiaddr = (input) => {
|
32
|
+
return isPeerId(input) ? input : multiaddr(input);
|
33
|
+
};
|
34
|
+
/**
|
35
|
+
* Maps a PeerId or MultiaddrInput to a PeerId.
|
36
|
+
* @param input - The PeerId or MultiaddrInput to map.
|
37
|
+
* @returns The PeerId.
|
38
|
+
* @throws {Error} If the input is not a valid PeerId or MultiaddrInput.
|
39
|
+
*/
|
40
|
+
export const mapToPeerId = (input) => {
|
41
|
+
return isPeerId(input)
|
42
|
+
? input
|
43
|
+
: peerIdFromString(multiaddr(input).getPeerId());
|
44
|
+
};
|
22
45
|
//# sourceMappingURL=utils.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/connection_manager/utils.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/lib/connection_manager/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAA0B,MAAM,mBAAmB,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAa,SAAS,EAAkB,MAAM,yBAAyB,CAAC;AAC/E,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,IAAiB,EAAU,EAAE;IACvD,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,CAAC,CAAC,CAAC;IACZ,CAAC;IAED,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QAExC,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO,CAAC,CAAC,CAAC;QACZ,CAAC;QAED,OAAO,MAAM,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;IACpC,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,CAAC,CAAC,CAAC;IACZ,CAAC;AACH,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CACpC,KAA8B,EACV,EAAE;IACtB,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;AACpD,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,KAA8B,EAAU,EAAE;IACpE,OAAO,QAAQ,CAAC,KAAK,CAAC;QACpB,CAAC,CAAC,KAAK;QACP,CAAC,CAAC,gBAAgB,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,SAAS,EAAG,CAAC,CAAC;AACtD,CAAC,CAAC"}
|
@@ -7,11 +7,10 @@ export declare const FilterCodecs: {
|
|
7
7
|
};
|
8
8
|
type IncomingMessageHandler = (pubsubTopic: PubsubTopic, wakuMessage: WakuMessage, peerIdStr: string) => Promise<void>;
|
9
9
|
export declare class FilterCore {
|
10
|
-
|
10
|
+
private handleIncomingMessage;
|
11
11
|
private streamManager;
|
12
|
-
private static handleIncomingMessage?;
|
13
12
|
readonly multicodec: string;
|
14
|
-
constructor(handleIncomingMessage: IncomingMessageHandler,
|
13
|
+
constructor(handleIncomingMessage: IncomingMessageHandler, libp2p: Libp2p);
|
15
14
|
subscribe(pubsubTopic: PubsubTopic, peerId: PeerId, contentTopics: ContentTopic[]): Promise<CoreProtocolResult>;
|
16
15
|
unsubscribe(pubsubTopic: PubsubTopic, peerId: PeerId, contentTopics: ContentTopic[]): Promise<CoreProtocolResult>;
|
17
16
|
unsubscribeAll(pubsubTopic: PubsubTopic, peerId: PeerId): Promise<CoreProtocolResult>;
|
@@ -5,38 +5,18 @@ import * as lp from "it-length-prefixed";
|
|
5
5
|
import { pipe } from "it-pipe";
|
6
6
|
import { StreamManager } from "../stream_manager/index.js";
|
7
7
|
import { FilterPushRpc, FilterSubscribeResponse, FilterSubscribeRpc } from "./filter_rpc.js";
|
8
|
-
const log = new Logger("filter
|
8
|
+
const log = new Logger("filter-core");
|
9
9
|
export const FilterCodecs = {
|
10
10
|
SUBSCRIBE: "/vac/waku/filter-subscribe/2.0.0-beta1",
|
11
11
|
PUSH: "/vac/waku/filter-push/2.0.0-beta1"
|
12
12
|
};
|
13
13
|
export class FilterCore {
|
14
|
-
|
14
|
+
handleIncomingMessage;
|
15
15
|
streamManager;
|
16
|
-
static handleIncomingMessage;
|
17
16
|
multicodec = FilterCodecs.SUBSCRIBE;
|
18
|
-
constructor(handleIncomingMessage,
|
19
|
-
this.
|
17
|
+
constructor(handleIncomingMessage, libp2p) {
|
18
|
+
this.handleIncomingMessage = handleIncomingMessage;
|
20
19
|
this.streamManager = new StreamManager(FilterCodecs.SUBSCRIBE, libp2p.components);
|
21
|
-
// TODO(weboko): remove when @waku/sdk 0.0.33 is released
|
22
|
-
const prevHandler = FilterCore.handleIncomingMessage;
|
23
|
-
FilterCore.handleIncomingMessage = !prevHandler
|
24
|
-
? handleIncomingMessage
|
25
|
-
: async (pubsubTopic, message, peerIdStr) => {
|
26
|
-
try {
|
27
|
-
await prevHandler(pubsubTopic, message, peerIdStr);
|
28
|
-
}
|
29
|
-
catch (e) {
|
30
|
-
log.error("Previous FilterCore incoming message handler failed ", e);
|
31
|
-
}
|
32
|
-
try {
|
33
|
-
await handleIncomingMessage(pubsubTopic, message, peerIdStr);
|
34
|
-
}
|
35
|
-
catch (e) {
|
36
|
-
log.error("Present FilterCore incoming message handler failed ", e);
|
37
|
-
}
|
38
|
-
return;
|
39
|
-
};
|
40
20
|
libp2p
|
41
21
|
.handle(FilterCodecs.PUSH, this.onRequest.bind(this), {
|
42
22
|
maxInboundStreams: 100
|
@@ -51,6 +31,9 @@ export class FilterCore {
|
|
51
31
|
let res;
|
52
32
|
try {
|
53
33
|
res = await pipe([request.encode()], lp.encode, stream, lp.decode, async (source) => await all(source));
|
34
|
+
if (!res?.length) {
|
35
|
+
throw Error("Received no response from subscription request.");
|
36
|
+
}
|
54
37
|
}
|
55
38
|
catch (error) {
|
56
39
|
log.error("Failed to send subscribe request", error);
|
@@ -213,7 +196,7 @@ export class FilterCore {
|
|
213
196
|
log.error("Pubsub topic missing from push message");
|
214
197
|
return;
|
215
198
|
}
|
216
|
-
await
|
199
|
+
await this.handleIncomingMessage(pubsubTopic, wakuMessage, connection.remotePeer.toString());
|
217
200
|
}
|
218
201
|
}).then(() => {
|
219
202
|
log.info("Receiving pipe closed.");
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../src/lib/filter/filter.ts"],"names":[],"mappings":"AAEA,OAAO,EAIL,aAAa,EAEd,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,GAAG,MAAM,QAAQ,CAAC;AACzB,OAAO,KAAK,EAAE,MAAM,oBAAoB,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAG/B,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAE3D,OAAO,EACL,aAAa,EACb,uBAAuB,EACvB,kBAAkB,EACnB,MAAM,iBAAiB,CAAC;AAEzB,MAAM,GAAG,GAAG,IAAI,MAAM,CAAC,
|
1
|
+
{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../src/lib/filter/filter.ts"],"names":[],"mappings":"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"}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import type { PeerId } from "@libp2p/interface";
|
2
|
-
import { type CoreProtocolResult, type IEncoder, type IMessage, type Libp2p
|
2
|
+
import { type CoreProtocolResult, type IEncoder, type IMessage, type Libp2p } from "@waku/interfaces";
|
3
3
|
import { PushResponse } from "@waku/proto";
|
4
4
|
export declare const LightPushCodec = "/vac/waku/lightpush/2.0.0-beta1";
|
5
5
|
export { PushResponse };
|
@@ -7,10 +7,9 @@ export { PushResponse };
|
|
7
7
|
* Implements the [Waku v2 Light Push protocol](https://rfc.vac.dev/spec/19/).
|
8
8
|
*/
|
9
9
|
export declare class LightPushCore {
|
10
|
-
readonly pubsubTopics: PubsubTopic[];
|
11
10
|
private readonly streamManager;
|
12
11
|
readonly multicodec = "/vac/waku/lightpush/2.0.0-beta1";
|
13
|
-
constructor(
|
12
|
+
constructor(libp2p: Libp2p);
|
14
13
|
private preparePushMessage;
|
15
14
|
send(encoder: IEncoder, message: IMessage, peerId: PeerId): Promise<CoreProtocolResult>;
|
16
15
|
}
|
@@ -16,11 +16,9 @@ export { PushResponse };
|
|
16
16
|
* Implements the [Waku v2 Light Push protocol](https://rfc.vac.dev/spec/19/).
|
17
17
|
*/
|
18
18
|
export class LightPushCore {
|
19
|
-
pubsubTopics;
|
20
19
|
streamManager;
|
21
20
|
multicodec = LightPushCodec;
|
22
|
-
constructor(
|
23
|
-
this.pubsubTopics = pubsubTopics;
|
21
|
+
constructor(libp2p) {
|
24
22
|
this.streamManager = new StreamManager(LightPushCodec, libp2p.components);
|
25
23
|
}
|
26
24
|
async preparePushMessage(encoder, message) {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"light_push.js","sourceRoot":"","sources":["../../../src/lib/light_push/light_push.ts"],"names":[],"mappings":"AACA,OAAO,EAKL,aAAa,
|
1
|
+
{"version":3,"file":"light_push.js","sourceRoot":"","sources":["../../../src/lib/light_push/light_push.ts"],"names":[],"mappings":"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"}
|
@@ -1,10 +1,9 @@
|
|
1
1
|
import type { PeerId } from "@libp2p/interface";
|
2
|
-
import { IDecodedMessage, IDecoder, Libp2p,
|
2
|
+
import { IDecodedMessage, IDecoder, Libp2p, QueryRequestParams } from "@waku/interfaces";
|
3
3
|
export declare const StoreCodec = "/vac/waku/store-query/3.0.0";
|
4
4
|
export declare class StoreCore {
|
5
|
-
readonly pubsubTopics: PubsubTopic[];
|
6
5
|
private readonly streamManager;
|
7
6
|
readonly multicodec = "/vac/waku/store-query/3.0.0";
|
8
|
-
constructor(
|
7
|
+
constructor(libp2p: Libp2p);
|
9
8
|
queryPerPage<T extends IDecodedMessage>(queryOpts: QueryRequestParams, decoders: Map<string, IDecoder<T>>, peerId: PeerId): AsyncGenerator<Promise<T | undefined>[]>;
|
10
9
|
}
|
package/dist/lib/store/store.js
CHANGED
@@ -9,11 +9,9 @@ import { DEFAULT_PAGE_SIZE, MAX_PAGE_SIZE, StoreQueryRequest, StoreQueryResponse
|
|
9
9
|
const log = new Logger("store");
|
10
10
|
export const StoreCodec = "/vac/waku/store-query/3.0.0";
|
11
11
|
export class StoreCore {
|
12
|
-
pubsubTopics;
|
13
12
|
streamManager;
|
14
13
|
multicodec = StoreCodec;
|
15
|
-
constructor(
|
16
|
-
this.pubsubTopics = pubsubTopics;
|
14
|
+
constructor(libp2p) {
|
17
15
|
this.streamManager = new StreamManager(StoreCodec, libp2p.components);
|
18
16
|
}
|
19
17
|
async *queryPerPage(queryOpts, decoders, peerId) {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/lib/store/store.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/lib/store/store.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
@@ -1,125 +1 @@
|
|
1
|
-
{
|
2
|
-
"name": "@waku/core",
|
3
|
-
"version": "0.0.36",
|
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
|
-
},
|
17
|
-
"typesVersions": {
|
18
|
-
"*": {
|
19
|
-
"lib/*": [
|
20
|
-
"dist/lib/*"
|
21
|
-
],
|
22
|
-
"constants/*": [
|
23
|
-
"dist/constants/*"
|
24
|
-
]
|
25
|
-
}
|
26
|
-
},
|
27
|
-
"type": "module",
|
28
|
-
"homepage": "https://github.com/waku-org/js-waku/tree/master/packages/core#readme",
|
29
|
-
"repository": {
|
30
|
-
"type": "git",
|
31
|
-
"url": "https://github.com/waku-org/js-waku.git"
|
32
|
-
},
|
33
|
-
"bugs": {
|
34
|
-
"url": "https://github.com/waku-org/js-waku/issues"
|
35
|
-
},
|
36
|
-
"license": "MIT OR Apache-2.0",
|
37
|
-
"keywords": [
|
38
|
-
"waku",
|
39
|
-
"decentralised",
|
40
|
-
"communication",
|
41
|
-
"web3",
|
42
|
-
"ethereum",
|
43
|
-
"dapps"
|
44
|
-
],
|
45
|
-
"scripts": {
|
46
|
-
"build": "run-s build:**",
|
47
|
-
"build:esm": "tsc",
|
48
|
-
"build:bundle": "rollup --config rollup.config.js",
|
49
|
-
"fix": "run-s fix:*",
|
50
|
-
"fix:lint": "eslint src *.js --fix",
|
51
|
-
"check": "run-s check:*",
|
52
|
-
"check:tsc": "tsc -p tsconfig.dev.json",
|
53
|
-
"check:lint": "eslint src *.js",
|
54
|
-
"check:spelling": "cspell \"{README.md,src/**/*.ts}\"",
|
55
|
-
"test": "NODE_ENV=test run-s test:*",
|
56
|
-
"test:node": "NODE_ENV=test TS_NODE_PROJECT=./tsconfig.dev.json mocha",
|
57
|
-
"test:browser": "NODE_ENV=test karma start karma.conf.cjs",
|
58
|
-
"watch:build": "tsc -p tsconfig.json -w",
|
59
|
-
"watch:test": "mocha --watch",
|
60
|
-
"prepublish": "npm run build",
|
61
|
-
"reset-hard": "git clean -dfx -e .idea && git reset --hard && npm i && npm run build"
|
62
|
-
},
|
63
|
-
"engines": {
|
64
|
-
"node": ">=22"
|
65
|
-
},
|
66
|
-
"dependencies": {
|
67
|
-
"@waku/enr": "^0.0.30",
|
68
|
-
"@waku/interfaces": "0.0.31",
|
69
|
-
"@libp2p/ping": "2.0.35",
|
70
|
-
"@waku/proto": "0.0.11",
|
71
|
-
"@waku/utils": "0.0.24",
|
72
|
-
"debug": "^4.3.4",
|
73
|
-
"@noble/hashes": "^1.3.2",
|
74
|
-
"it-all": "^3.0.4",
|
75
|
-
"it-length-prefixed": "^9.0.4",
|
76
|
-
"it-pipe": "^3.0.1",
|
77
|
-
"uint8arraylist": "^2.4.3",
|
78
|
-
"uuid": "^9.0.0"
|
79
|
-
},
|
80
|
-
"devDependencies": {
|
81
|
-
"@libp2p/peer-id": "5.1.7",
|
82
|
-
"@libp2p/interface": "2.10.4",
|
83
|
-
"@multiformats/multiaddr": "^12.0.0",
|
84
|
-
"@rollup/plugin-commonjs": "^25.0.7",
|
85
|
-
"@rollup/plugin-json": "^6.0.0",
|
86
|
-
"@rollup/plugin-node-resolve": "^15.2.3",
|
87
|
-
"@types/chai": "^4.3.11",
|
88
|
-
"@types/debug": "^4.1.12",
|
89
|
-
"@types/mocha": "^10.0.6",
|
90
|
-
"@types/uuid": "^9.0.8",
|
91
|
-
"@waku/build-utils": "*",
|
92
|
-
"chai": "^4.3.10",
|
93
|
-
"sinon": "^18.0.0",
|
94
|
-
"cspell": "^8.6.1",
|
95
|
-
"fast-check": "^3.19.0",
|
96
|
-
"ignore-loader": "^0.1.2",
|
97
|
-
"isomorphic-fetch": "^3.0.0",
|
98
|
-
"mocha": "^10.3.0",
|
99
|
-
"npm-run-all": "^4.1.5",
|
100
|
-
"process": "^0.11.10",
|
101
|
-
"rollup": "^4.12.0"
|
102
|
-
},
|
103
|
-
"peerDependencies": {
|
104
|
-
"@multiformats/multiaddr": "^12.0.0",
|
105
|
-
"libp2p": "2.8.11"
|
106
|
-
},
|
107
|
-
"peerDependenciesMeta": {
|
108
|
-
"@multiformats/multiaddr": {
|
109
|
-
"optional": true
|
110
|
-
},
|
111
|
-
"libp2p": {
|
112
|
-
"optional": true
|
113
|
-
}
|
114
|
-
},
|
115
|
-
"files": [
|
116
|
-
"dist",
|
117
|
-
"bundle",
|
118
|
-
"src/**/*.ts",
|
119
|
-
"!**/*.spec.*",
|
120
|
-
"!**/*.json",
|
121
|
-
"CHANGELOG.md",
|
122
|
-
"LICENSE",
|
123
|
-
"README.md"
|
124
|
-
]
|
125
|
-
}
|
1
|
+
{"name":"@waku/core","version":"0.0.37-2ed5ddc.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"}},"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":">=22"},"dependencies":{"@waku/enr":"0.0.31-2ed5ddc.0","@waku/interfaces":"0.0.32-2ed5ddc.0","@libp2p/ping":"2.0.35","@waku/proto":"0.0.12-2ed5ddc.0","@waku/utils":"0.0.25-2ed5ddc.0","debug":"^4.3.4","@noble/hashes":"^1.3.2","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.1.7","@libp2p/interface":"2.10.4","@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.8.11"},"peerDependenciesMeta":{"@multiformats/multiaddr":{"optional":true},"libp2p":{"optional":true}},"files":["dist","bundle","src/**/*.ts","!**/*.spec.*","!**/*.json","CHANGELOG.md","LICENSE","README.md"]}
|
@@ -0,0 +1,161 @@
|
|
1
|
+
import { Peer, PeerId } from "@libp2p/interface";
|
2
|
+
import { ConnectionManagerOptions, Libp2p, Tags } from "@waku/interfaces";
|
3
|
+
import { Logger } from "@waku/utils";
|
4
|
+
|
5
|
+
const log = new Logger("connection-limiter");
|
6
|
+
|
7
|
+
type Libp2pEventHandler<T> = (e: CustomEvent<T>) => void;
|
8
|
+
|
9
|
+
type ConnectionLimiterConstructorOptions = {
|
10
|
+
libp2p: Libp2p;
|
11
|
+
options: ConnectionManagerOptions;
|
12
|
+
};
|
13
|
+
|
14
|
+
interface IConnectionLimiter {
|
15
|
+
/**
|
16
|
+
* Dial all known peers because libp2p might have emitted `peer:discovery` before initialization
|
17
|
+
* and listen to `peer:connect` and `peer:disconnect` events to manage connections.
|
18
|
+
*/
|
19
|
+
start(): void;
|
20
|
+
|
21
|
+
/**
|
22
|
+
* Stop listening to `peer:connect` and `peer:disconnect` events.
|
23
|
+
*/
|
24
|
+
stop(): void;
|
25
|
+
}
|
26
|
+
|
27
|
+
/**
|
28
|
+
* This class is responsible for limiting the number of connections to peers.
|
29
|
+
* It also dials all known peers because libp2p might have emitted `peer:discovery` before initialization
|
30
|
+
* and listen to `peer:connect` and `peer:disconnect` events to manage connections.
|
31
|
+
*/
|
32
|
+
export class ConnectionLimiter implements IConnectionLimiter {
|
33
|
+
private readonly libp2p: Libp2p;
|
34
|
+
private readonly options: ConnectionManagerOptions;
|
35
|
+
|
36
|
+
public constructor(options: ConnectionLimiterConstructorOptions) {
|
37
|
+
this.libp2p = options.libp2p;
|
38
|
+
this.options = options.options;
|
39
|
+
|
40
|
+
this.onConnectedEvent = this.onConnectedEvent.bind(this);
|
41
|
+
this.onDisconnectedEvent = this.onDisconnectedEvent.bind(this);
|
42
|
+
}
|
43
|
+
|
44
|
+
public start(): void {
|
45
|
+
// dial all known peers because libp2p might have emitted `peer:discovery` before initialization
|
46
|
+
void this.dialPeersFromStore();
|
47
|
+
|
48
|
+
this.libp2p.addEventListener(
|
49
|
+
"peer:connect",
|
50
|
+
this.onConnectedEvent as Libp2pEventHandler<PeerId>
|
51
|
+
);
|
52
|
+
|
53
|
+
/**
|
54
|
+
* NOTE: Event is not being emitted on closing nor losing a connection.
|
55
|
+
* @see https://github.com/libp2p/js-libp2p/issues/939
|
56
|
+
* @see https://github.com/status-im/js-waku/issues/252
|
57
|
+
*
|
58
|
+
* >This event will be triggered anytime we are disconnected from another peer,
|
59
|
+
* >regardless of the circumstances of that disconnection.
|
60
|
+
* >If we happen to have multiple connections to a peer,
|
61
|
+
* >this event will **only** be triggered when the last connection is closed.
|
62
|
+
* @see https://github.com/libp2p/js-libp2p/blob/bad9e8c0ff58d60a78314077720c82ae331cc55b/doc/API.md?plain=1#L2100
|
63
|
+
*/
|
64
|
+
this.libp2p.addEventListener(
|
65
|
+
"peer:disconnect",
|
66
|
+
this.onDisconnectedEvent as Libp2pEventHandler<PeerId>
|
67
|
+
);
|
68
|
+
}
|
69
|
+
|
70
|
+
public stop(): void {
|
71
|
+
this.libp2p.removeEventListener(
|
72
|
+
"peer:connect",
|
73
|
+
this.onConnectedEvent as Libp2pEventHandler<PeerId>
|
74
|
+
);
|
75
|
+
|
76
|
+
this.libp2p.removeEventListener(
|
77
|
+
"peer:disconnect",
|
78
|
+
this.onDisconnectedEvent as Libp2pEventHandler<PeerId>
|
79
|
+
);
|
80
|
+
}
|
81
|
+
|
82
|
+
private async onConnectedEvent(evt: CustomEvent<PeerId>): Promise<void> {
|
83
|
+
log.info(`Connected to peer ${evt.detail.toString()}`);
|
84
|
+
|
85
|
+
const peerId = evt.detail;
|
86
|
+
|
87
|
+
const tags = await this.getTagsForPeer(peerId);
|
88
|
+
const isBootstrap = tags.includes(Tags.BOOTSTRAP);
|
89
|
+
|
90
|
+
if (!isBootstrap) {
|
91
|
+
return;
|
92
|
+
}
|
93
|
+
|
94
|
+
if (await this.hasMoreThanMaxBootstrapConnections()) {
|
95
|
+
await this.libp2p.hangUp(peerId);
|
96
|
+
}
|
97
|
+
}
|
98
|
+
|
99
|
+
private async onDisconnectedEvent(): Promise<void> {
|
100
|
+
if (this.libp2p.getConnections().length === 0) {
|
101
|
+
await this.dialPeersFromStore();
|
102
|
+
}
|
103
|
+
}
|
104
|
+
|
105
|
+
private async dialPeersFromStore(): Promise<void> {
|
106
|
+
const allPeers = await this.libp2p.peerStore.all();
|
107
|
+
const allConnections = this.libp2p.getConnections();
|
108
|
+
|
109
|
+
const promises = allPeers
|
110
|
+
.filter((p) => !allConnections.some((c) => c.remotePeer.equals(p.id)))
|
111
|
+
.map((p) => this.libp2p.dial(p.id));
|
112
|
+
|
113
|
+
try {
|
114
|
+
await Promise.all(promises);
|
115
|
+
} catch (error) {
|
116
|
+
log.error(`Unexpected error while dialing peer store peers`, error);
|
117
|
+
}
|
118
|
+
}
|
119
|
+
|
120
|
+
private async hasMoreThanMaxBootstrapConnections(): Promise<boolean> {
|
121
|
+
try {
|
122
|
+
const peers = await Promise.all(
|
123
|
+
this.libp2p
|
124
|
+
.getConnections()
|
125
|
+
.map((conn) => conn.remotePeer)
|
126
|
+
.map((id) => this.getPeer(id))
|
127
|
+
);
|
128
|
+
|
129
|
+
const bootstrapPeers = peers.filter(
|
130
|
+
(peer) => peer && peer.tags.has(Tags.BOOTSTRAP)
|
131
|
+
);
|
132
|
+
|
133
|
+
return bootstrapPeers.length > this.options.maxBootstrapPeers;
|
134
|
+
} catch (error) {
|
135
|
+
log.error(
|
136
|
+
`Unexpected error while checking for bootstrap connections`,
|
137
|
+
error
|
138
|
+
);
|
139
|
+
return false;
|
140
|
+
}
|
141
|
+
}
|
142
|
+
|
143
|
+
private async getPeer(peerId: PeerId): Promise<Peer | null> {
|
144
|
+
try {
|
145
|
+
return await this.libp2p.peerStore.get(peerId);
|
146
|
+
} catch (error) {
|
147
|
+
log.error(`Failed to get peer ${peerId}, error: ${error}`);
|
148
|
+
return null;
|
149
|
+
}
|
150
|
+
}
|
151
|
+
|
152
|
+
private async getTagsForPeer(peerId: PeerId): Promise<string[]> {
|
153
|
+
try {
|
154
|
+
const peer = await this.libp2p.peerStore.get(peerId);
|
155
|
+
return Array.from(peer.tags.keys());
|
156
|
+
} catch (error) {
|
157
|
+
log.error(`Failed to get peer ${peerId}, error: ${error}`);
|
158
|
+
return [];
|
159
|
+
}
|
160
|
+
}
|
161
|
+
}
|