@waku/core 0.0.34-c41b319.0 → 0.0.34-c43cec2.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-CCK9RCtH.js → base_protocol-DxFKDXX2.js} +20 -19
- package/bundle/{index-Db7LxDrL.js → index-yLOEQnIE.js} +39 -75
- package/bundle/index.js +133 -1815
- package/bundle/lib/base_protocol.js +2 -2
- package/bundle/lib/message/version_0.js +2 -2
- package/bundle/{version_0-ANFNAdFD.js → version_0-Che4t3mN.js} +42 -163
- package/dist/.tsbuildinfo +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/lib/base_protocol.d.ts +2 -2
- package/dist/lib/base_protocol.js +2 -2
- package/dist/lib/base_protocol.js.map +1 -1
- package/dist/lib/connection_manager/connection_manager.d.ts +3 -56
- package/dist/lib/connection_manager/connection_manager.js +13 -96
- package/dist/lib/connection_manager/connection_manager.js.map +1 -1
- package/dist/lib/filter/index.d.ts +18 -1
- package/dist/lib/filter/index.js +208 -1
- package/dist/lib/filter/index.js.map +1 -1
- package/dist/lib/health_manager.d.ts +14 -0
- package/dist/lib/health_manager.js +70 -0
- package/dist/lib/health_manager.js.map +1 -0
- package/dist/lib/light_push/index.d.ts +15 -1
- package/dist/lib/light_push/index.js +144 -1
- package/dist/lib/light_push/index.js.map +1 -1
- package/dist/lib/metadata/index.d.ts +3 -1
- package/dist/lib/metadata/index.js +118 -1
- package/dist/lib/metadata/index.js.map +1 -1
- package/dist/lib/store/index.d.ts +9 -1
- package/dist/lib/store/index.js +82 -1
- package/dist/lib/store/index.js.map +1 -1
- package/dist/lib/stream_manager/stream_manager.d.ts +2 -2
- package/dist/lib/stream_manager/stream_manager.js +17 -16
- package/dist/lib/stream_manager/stream_manager.js.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +2 -0
- package/src/lib/base_protocol.ts +3 -3
- package/src/lib/connection_manager/connection_manager.ts +20 -114
- package/src/lib/filter/index.ts +315 -1
- package/src/lib/health_manager.ts +90 -0
- package/src/lib/light_push/index.ts +189 -1
- package/src/lib/metadata/index.ts +182 -1
- package/src/lib/store/index.ts +136 -1
- package/src/lib/stream_manager/stream_manager.ts +18 -16
- package/dist/lib/filter/filter.d.ts +0 -18
- package/dist/lib/filter/filter.js +0 -209
- package/dist/lib/filter/filter.js.map +0 -1
- package/dist/lib/light_push/light_push.d.ts +0 -15
- package/dist/lib/light_push/light_push.js +0 -144
- package/dist/lib/light_push/light_push.js.map +0 -1
- package/dist/lib/metadata/metadata.d.ts +0 -3
- package/dist/lib/metadata/metadata.js +0 -119
- package/dist/lib/metadata/metadata.js.map +0 -1
- package/dist/lib/store/store.d.ts +0 -9
- package/dist/lib/store/store.js +0 -83
- package/dist/lib/store/store.js.map +0 -1
- package/src/lib/filter/filter.ts +0 -315
- package/src/lib/light_push/light_push.ts +0 -188
- package/src/lib/metadata/metadata.ts +0 -182
- package/src/lib/store/store.ts +0 -136
@@ -1,209 +0,0 @@
|
|
1
|
-
import { ProtocolError } from "@waku/interfaces";
|
2
|
-
import { Logger } from "@waku/utils";
|
3
|
-
import all from "it-all";
|
4
|
-
import * as lp from "it-length-prefixed";
|
5
|
-
import { pipe } from "it-pipe";
|
6
|
-
import { BaseProtocol } from "../base_protocol.js";
|
7
|
-
import { FilterPushRpc, FilterSubscribeResponse, FilterSubscribeRpc } from "./filter_rpc.js";
|
8
|
-
const log = new Logger("filter:v2");
|
9
|
-
export const FilterCodecs = {
|
10
|
-
SUBSCRIBE: "/vac/waku/filter-subscribe/2.0.0-beta1",
|
11
|
-
PUSH: "/vac/waku/filter-push/2.0.0-beta1"
|
12
|
-
};
|
13
|
-
export class FilterCore extends BaseProtocol {
|
14
|
-
handleIncomingMessage;
|
15
|
-
pubsubTopics;
|
16
|
-
constructor(handleIncomingMessage, pubsubTopics, libp2p) {
|
17
|
-
super(FilterCodecs.SUBSCRIBE, libp2p.components, pubsubTopics);
|
18
|
-
this.handleIncomingMessage = handleIncomingMessage;
|
19
|
-
this.pubsubTopics = pubsubTopics;
|
20
|
-
libp2p
|
21
|
-
.handle(FilterCodecs.PUSH, this.onRequest.bind(this), {
|
22
|
-
maxInboundStreams: 100
|
23
|
-
})
|
24
|
-
.catch((e) => {
|
25
|
-
log.error("Failed to register ", FilterCodecs.PUSH, e);
|
26
|
-
});
|
27
|
-
}
|
28
|
-
async subscribe(pubsubTopic, peerId, contentTopics) {
|
29
|
-
const stream = await this.getStream(peerId);
|
30
|
-
const request = FilterSubscribeRpc.createSubscribeRequest(pubsubTopic, contentTopics);
|
31
|
-
let res;
|
32
|
-
try {
|
33
|
-
res = await pipe([request.encode()], lp.encode, stream, lp.decode, async (source) => await all(source));
|
34
|
-
}
|
35
|
-
catch (error) {
|
36
|
-
log.error("Failed to send subscribe request", error);
|
37
|
-
return {
|
38
|
-
success: null,
|
39
|
-
failure: {
|
40
|
-
error: ProtocolError.GENERIC_FAIL,
|
41
|
-
peerId: peerId
|
42
|
-
}
|
43
|
-
};
|
44
|
-
}
|
45
|
-
const { statusCode, requestId, statusDesc } = FilterSubscribeResponse.decode(res[0].slice());
|
46
|
-
if (statusCode < 200 || statusCode >= 300) {
|
47
|
-
log.error(`Filter subscribe request ${requestId} failed with status code ${statusCode}: ${statusDesc}`);
|
48
|
-
return {
|
49
|
-
failure: {
|
50
|
-
error: ProtocolError.REMOTE_PEER_REJECTED,
|
51
|
-
peerId: peerId
|
52
|
-
},
|
53
|
-
success: null
|
54
|
-
};
|
55
|
-
}
|
56
|
-
return {
|
57
|
-
failure: null,
|
58
|
-
success: peerId
|
59
|
-
};
|
60
|
-
}
|
61
|
-
async unsubscribe(pubsubTopic, peerId, contentTopics) {
|
62
|
-
let stream;
|
63
|
-
try {
|
64
|
-
stream = await this.getStream(peerId);
|
65
|
-
}
|
66
|
-
catch (error) {
|
67
|
-
log.error(`Failed to get a stream for remote peer${peerId.toString()}`, error);
|
68
|
-
return {
|
69
|
-
success: null,
|
70
|
-
failure: {
|
71
|
-
error: ProtocolError.NO_STREAM_AVAILABLE,
|
72
|
-
peerId: peerId
|
73
|
-
}
|
74
|
-
};
|
75
|
-
}
|
76
|
-
const unsubscribeRequest = FilterSubscribeRpc.createUnsubscribeRequest(pubsubTopic, contentTopics);
|
77
|
-
try {
|
78
|
-
await pipe([unsubscribeRequest.encode()], lp.encode, stream.sink);
|
79
|
-
}
|
80
|
-
catch (error) {
|
81
|
-
log.error("Failed to send unsubscribe request", error);
|
82
|
-
return {
|
83
|
-
success: null,
|
84
|
-
failure: {
|
85
|
-
error: ProtocolError.GENERIC_FAIL,
|
86
|
-
peerId: peerId
|
87
|
-
}
|
88
|
-
};
|
89
|
-
}
|
90
|
-
return {
|
91
|
-
success: peerId,
|
92
|
-
failure: null
|
93
|
-
};
|
94
|
-
}
|
95
|
-
async unsubscribeAll(pubsubTopic, peerId) {
|
96
|
-
const stream = await this.getStream(peerId);
|
97
|
-
const request = FilterSubscribeRpc.createUnsubscribeAllRequest(pubsubTopic);
|
98
|
-
const res = await pipe([request.encode()], lp.encode, stream, lp.decode, async (source) => await all(source));
|
99
|
-
if (!res || !res.length) {
|
100
|
-
return {
|
101
|
-
failure: {
|
102
|
-
error: ProtocolError.NO_RESPONSE,
|
103
|
-
peerId: peerId
|
104
|
-
},
|
105
|
-
success: null
|
106
|
-
};
|
107
|
-
}
|
108
|
-
const { statusCode, requestId, statusDesc } = FilterSubscribeResponse.decode(res[0].slice());
|
109
|
-
if (statusCode < 200 || statusCode >= 300) {
|
110
|
-
log.error(`Filter unsubscribe all request ${requestId} failed with status code ${statusCode}: ${statusDesc}`);
|
111
|
-
return {
|
112
|
-
failure: {
|
113
|
-
error: ProtocolError.REMOTE_PEER_REJECTED,
|
114
|
-
peerId: peerId
|
115
|
-
},
|
116
|
-
success: null
|
117
|
-
};
|
118
|
-
}
|
119
|
-
return {
|
120
|
-
failure: null,
|
121
|
-
success: peerId
|
122
|
-
};
|
123
|
-
}
|
124
|
-
async ping(peerId) {
|
125
|
-
let stream;
|
126
|
-
try {
|
127
|
-
stream = await this.getStream(peerId);
|
128
|
-
}
|
129
|
-
catch (error) {
|
130
|
-
log.error(`Failed to get a stream for remote peer${peerId.toString()}`, error);
|
131
|
-
return {
|
132
|
-
success: null,
|
133
|
-
failure: {
|
134
|
-
error: ProtocolError.NO_STREAM_AVAILABLE,
|
135
|
-
peerId: peerId
|
136
|
-
}
|
137
|
-
};
|
138
|
-
}
|
139
|
-
const request = FilterSubscribeRpc.createSubscriberPingRequest();
|
140
|
-
let res;
|
141
|
-
try {
|
142
|
-
res = await pipe([request.encode()], lp.encode, stream, lp.decode, async (source) => await all(source));
|
143
|
-
}
|
144
|
-
catch (error) {
|
145
|
-
log.error("Failed to send ping request", error);
|
146
|
-
return {
|
147
|
-
success: null,
|
148
|
-
failure: {
|
149
|
-
error: ProtocolError.GENERIC_FAIL,
|
150
|
-
peerId: peerId
|
151
|
-
}
|
152
|
-
};
|
153
|
-
}
|
154
|
-
if (!res || !res.length) {
|
155
|
-
return {
|
156
|
-
success: null,
|
157
|
-
failure: {
|
158
|
-
error: ProtocolError.NO_RESPONSE,
|
159
|
-
peerId: peerId
|
160
|
-
}
|
161
|
-
};
|
162
|
-
}
|
163
|
-
const { statusCode, requestId, statusDesc } = FilterSubscribeResponse.decode(res[0].slice());
|
164
|
-
if (statusCode < 200 || statusCode >= 300) {
|
165
|
-
log.error(`Filter ping request ${requestId} failed with status code ${statusCode}: ${statusDesc}`);
|
166
|
-
return {
|
167
|
-
success: null,
|
168
|
-
failure: {
|
169
|
-
error: ProtocolError.REMOTE_PEER_REJECTED,
|
170
|
-
peerId: peerId
|
171
|
-
}
|
172
|
-
};
|
173
|
-
}
|
174
|
-
return {
|
175
|
-
success: peerId,
|
176
|
-
failure: null
|
177
|
-
};
|
178
|
-
}
|
179
|
-
onRequest(streamData) {
|
180
|
-
const { connection, stream } = streamData;
|
181
|
-
const { remotePeer } = connection;
|
182
|
-
log.info(`Received message from ${remotePeer.toString()}`);
|
183
|
-
try {
|
184
|
-
pipe(stream, lp.decode, async (source) => {
|
185
|
-
for await (const bytes of source) {
|
186
|
-
const response = FilterPushRpc.decode(bytes.slice());
|
187
|
-
const { pubsubTopic, wakuMessage } = response;
|
188
|
-
if (!wakuMessage) {
|
189
|
-
log.error("Received empty message");
|
190
|
-
return;
|
191
|
-
}
|
192
|
-
if (!pubsubTopic) {
|
193
|
-
log.error("Pubsub topic missing from push message");
|
194
|
-
return;
|
195
|
-
}
|
196
|
-
await this.handleIncomingMessage(pubsubTopic, wakuMessage, connection.remotePeer.toString());
|
197
|
-
}
|
198
|
-
}).then(() => {
|
199
|
-
log.info("Receiving pipe closed.");
|
200
|
-
}, async (e) => {
|
201
|
-
log.error(`Error with receiving pipe on peer:${connection.remotePeer.toString()} -- stream:${stream.id} -- protocol:${stream.protocol}: `, e);
|
202
|
-
});
|
203
|
-
}
|
204
|
-
catch (e) {
|
205
|
-
log.error("Error decoding message", e);
|
206
|
-
}
|
207
|
-
}
|
208
|
-
}
|
209
|
-
//# sourceMappingURL=filter.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"filter.js","sourceRoot":"","sources":["../../../src/lib/filter/filter.ts"],"names":[],"mappings":"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"}
|
@@ -1,15 +0,0 @@
|
|
1
|
-
import type { PeerId } from "@libp2p/interface";
|
2
|
-
import { type CoreProtocolResult, type IBaseProtocolCore, type IEncoder, type IMessage, type Libp2p, PubsubTopic } from "@waku/interfaces";
|
3
|
-
import { PushResponse } from "@waku/proto";
|
4
|
-
import { BaseProtocol } from "../base_protocol.js";
|
5
|
-
export declare const LightPushCodec = "/vac/waku/lightpush/2.0.0-beta1";
|
6
|
-
export { PushResponse };
|
7
|
-
/**
|
8
|
-
* Implements the [Waku v2 Light Push protocol](https://rfc.vac.dev/spec/19/).
|
9
|
-
*/
|
10
|
-
export declare class LightPushCore extends BaseProtocol implements IBaseProtocolCore {
|
11
|
-
readonly pubsubTopics: PubsubTopic[];
|
12
|
-
constructor(pubsubTopics: PubsubTopic[], libp2p: Libp2p);
|
13
|
-
private preparePushMessage;
|
14
|
-
send(encoder: IEncoder, message: IMessage, peerId: PeerId): Promise<CoreProtocolResult>;
|
15
|
-
}
|
@@ -1,144 +0,0 @@
|
|
1
|
-
import { ProtocolError } from "@waku/interfaces";
|
2
|
-
import { PushResponse } from "@waku/proto";
|
3
|
-
import { isMessageSizeUnderCap } from "@waku/utils";
|
4
|
-
import { Logger } from "@waku/utils";
|
5
|
-
import all from "it-all";
|
6
|
-
import * as lp from "it-length-prefixed";
|
7
|
-
import { pipe } from "it-pipe";
|
8
|
-
import { Uint8ArrayList } from "uint8arraylist";
|
9
|
-
import { BaseProtocol } from "../base_protocol.js";
|
10
|
-
import { PushRpc } from "./push_rpc.js";
|
11
|
-
import { isRLNResponseError, matchRLNErrorMessage } from "./utils.js";
|
12
|
-
const log = new Logger("light-push");
|
13
|
-
export const LightPushCodec = "/vac/waku/lightpush/2.0.0-beta1";
|
14
|
-
export { PushResponse };
|
15
|
-
/**
|
16
|
-
* Implements the [Waku v2 Light Push protocol](https://rfc.vac.dev/spec/19/).
|
17
|
-
*/
|
18
|
-
export class LightPushCore extends BaseProtocol {
|
19
|
-
pubsubTopics;
|
20
|
-
constructor(pubsubTopics, libp2p) {
|
21
|
-
super(LightPushCodec, libp2p.components, pubsubTopics);
|
22
|
-
this.pubsubTopics = pubsubTopics;
|
23
|
-
}
|
24
|
-
async preparePushMessage(encoder, message) {
|
25
|
-
try {
|
26
|
-
if (!message.payload || message.payload.length === 0) {
|
27
|
-
log.error("Failed to send waku light push: payload is empty");
|
28
|
-
return { query: null, error: ProtocolError.EMPTY_PAYLOAD };
|
29
|
-
}
|
30
|
-
if (!(await isMessageSizeUnderCap(encoder, message))) {
|
31
|
-
log.error("Failed to send waku light push: message is bigger than 1MB");
|
32
|
-
return { query: null, error: ProtocolError.SIZE_TOO_BIG };
|
33
|
-
}
|
34
|
-
const protoMessage = await encoder.toProtoObj(message);
|
35
|
-
if (!protoMessage) {
|
36
|
-
log.error("Failed to encode to protoMessage, aborting push");
|
37
|
-
return {
|
38
|
-
query: null,
|
39
|
-
error: ProtocolError.ENCODE_FAILED
|
40
|
-
};
|
41
|
-
}
|
42
|
-
const query = PushRpc.createRequest(protoMessage, encoder.pubsubTopic);
|
43
|
-
return { query, error: null };
|
44
|
-
}
|
45
|
-
catch (error) {
|
46
|
-
log.error("Failed to prepare push message", error);
|
47
|
-
return {
|
48
|
-
query: null,
|
49
|
-
error: ProtocolError.GENERIC_FAIL
|
50
|
-
};
|
51
|
-
}
|
52
|
-
}
|
53
|
-
async send(encoder, message, peerId) {
|
54
|
-
const { query, error: preparationError } = await this.preparePushMessage(encoder, message);
|
55
|
-
if (preparationError || !query) {
|
56
|
-
return {
|
57
|
-
success: null,
|
58
|
-
failure: {
|
59
|
-
error: preparationError,
|
60
|
-
peerId
|
61
|
-
}
|
62
|
-
};
|
63
|
-
}
|
64
|
-
let stream;
|
65
|
-
try {
|
66
|
-
stream = await this.getStream(peerId);
|
67
|
-
}
|
68
|
-
catch (error) {
|
69
|
-
log.error("Failed to get stream", error);
|
70
|
-
return {
|
71
|
-
success: null,
|
72
|
-
failure: {
|
73
|
-
error: ProtocolError.NO_STREAM_AVAILABLE,
|
74
|
-
peerId: peerId
|
75
|
-
}
|
76
|
-
};
|
77
|
-
}
|
78
|
-
let res;
|
79
|
-
try {
|
80
|
-
res = await pipe([query.encode()], lp.encode, stream, lp.decode, async (source) => await all(source));
|
81
|
-
}
|
82
|
-
catch (err) {
|
83
|
-
log.error("Failed to send waku light push request", err);
|
84
|
-
return {
|
85
|
-
success: null,
|
86
|
-
failure: {
|
87
|
-
error: ProtocolError.GENERIC_FAIL,
|
88
|
-
peerId: peerId
|
89
|
-
}
|
90
|
-
};
|
91
|
-
}
|
92
|
-
const bytes = new Uint8ArrayList();
|
93
|
-
res.forEach((chunk) => {
|
94
|
-
bytes.append(chunk);
|
95
|
-
});
|
96
|
-
let response;
|
97
|
-
try {
|
98
|
-
response = PushRpc.decode(bytes).response;
|
99
|
-
}
|
100
|
-
catch (err) {
|
101
|
-
log.error("Failed to decode push reply", err);
|
102
|
-
return {
|
103
|
-
success: null,
|
104
|
-
failure: {
|
105
|
-
error: ProtocolError.DECODE_FAILED,
|
106
|
-
peerId: peerId
|
107
|
-
}
|
108
|
-
};
|
109
|
-
}
|
110
|
-
if (!response) {
|
111
|
-
log.error("Remote peer fault: No response in PushRPC");
|
112
|
-
return {
|
113
|
-
success: null,
|
114
|
-
failure: {
|
115
|
-
error: ProtocolError.NO_RESPONSE,
|
116
|
-
peerId: peerId
|
117
|
-
}
|
118
|
-
};
|
119
|
-
}
|
120
|
-
if (isRLNResponseError(response.info)) {
|
121
|
-
const rlnErrorCase = matchRLNErrorMessage(response.info);
|
122
|
-
log.error("Remote peer rejected the message: ", rlnErrorCase);
|
123
|
-
return {
|
124
|
-
success: null,
|
125
|
-
failure: {
|
126
|
-
error: rlnErrorCase,
|
127
|
-
peerId: peerId
|
128
|
-
}
|
129
|
-
};
|
130
|
-
}
|
131
|
-
if (!response.isSuccess) {
|
132
|
-
log.error("Remote peer rejected the message: ", response.info);
|
133
|
-
return {
|
134
|
-
success: null,
|
135
|
-
failure: {
|
136
|
-
error: ProtocolError.REMOTE_PEER_REJECTED,
|
137
|
-
peerId: peerId
|
138
|
-
}
|
139
|
-
};
|
140
|
-
}
|
141
|
-
return { success: peerId, failure: null };
|
142
|
-
}
|
143
|
-
}
|
144
|
-
//# sourceMappingURL=light_push.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"light_push.js","sourceRoot":"","sources":["../../../src/lib/light_push/light_push.ts"],"names":[],"mappings":"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"}
|
@@ -1,119 +0,0 @@
|
|
1
|
-
import { ProtocolError } from "@waku/interfaces";
|
2
|
-
import { proto_metadata } from "@waku/proto";
|
3
|
-
import { encodeRelayShard, Logger, pubsubTopicsToShardInfo } from "@waku/utils";
|
4
|
-
import all from "it-all";
|
5
|
-
import * as lp from "it-length-prefixed";
|
6
|
-
import { pipe } from "it-pipe";
|
7
|
-
import { Uint8ArrayList } from "uint8arraylist";
|
8
|
-
import { BaseProtocol } from "../base_protocol.js";
|
9
|
-
const log = new Logger("metadata");
|
10
|
-
export const MetadataCodec = "/vac/waku/metadata/1.0.0";
|
11
|
-
class Metadata extends BaseProtocol {
|
12
|
-
pubsubTopics;
|
13
|
-
libp2pComponents;
|
14
|
-
handshakesConfirmed = new Map();
|
15
|
-
constructor(pubsubTopics, libp2p) {
|
16
|
-
super(MetadataCodec, libp2p.components, pubsubTopics);
|
17
|
-
this.pubsubTopics = pubsubTopics;
|
18
|
-
this.libp2pComponents = libp2p;
|
19
|
-
void libp2p.registrar.handle(MetadataCodec, (streamData) => {
|
20
|
-
void this.onRequest(streamData);
|
21
|
-
});
|
22
|
-
}
|
23
|
-
/**
|
24
|
-
* Make a metadata query to a peer
|
25
|
-
*/
|
26
|
-
async query(peerId) {
|
27
|
-
const request = proto_metadata.WakuMetadataRequest.encode(pubsubTopicsToShardInfo(this.pubsubTopics));
|
28
|
-
const peer = await this.libp2pComponents.peerStore.get(peerId);
|
29
|
-
if (!peer) {
|
30
|
-
return {
|
31
|
-
shardInfo: null,
|
32
|
-
error: ProtocolError.NO_PEER_AVAILABLE
|
33
|
-
};
|
34
|
-
}
|
35
|
-
let stream;
|
36
|
-
try {
|
37
|
-
stream = await this.getStream(peerId);
|
38
|
-
}
|
39
|
-
catch (error) {
|
40
|
-
log.error("Failed to get stream", error);
|
41
|
-
return {
|
42
|
-
shardInfo: null,
|
43
|
-
error: ProtocolError.NO_STREAM_AVAILABLE
|
44
|
-
};
|
45
|
-
}
|
46
|
-
const encodedResponse = await pipe([request], lp.encode, stream, lp.decode, async (source) => await all(source));
|
47
|
-
const { error, shardInfo } = this.decodeMetadataResponse(encodedResponse);
|
48
|
-
if (error) {
|
49
|
-
return {
|
50
|
-
shardInfo: null,
|
51
|
-
error
|
52
|
-
};
|
53
|
-
}
|
54
|
-
await this.savePeerShardInfo(peerId, shardInfo);
|
55
|
-
return {
|
56
|
-
shardInfo,
|
57
|
-
error: null
|
58
|
-
};
|
59
|
-
}
|
60
|
-
async confirmOrAttemptHandshake(peerId) {
|
61
|
-
const shardInfo = this.handshakesConfirmed.get(peerId.toString());
|
62
|
-
if (shardInfo) {
|
63
|
-
return {
|
64
|
-
shardInfo,
|
65
|
-
error: null
|
66
|
-
};
|
67
|
-
}
|
68
|
-
return await this.query(peerId);
|
69
|
-
}
|
70
|
-
/**
|
71
|
-
* Handle an incoming metadata request
|
72
|
-
*/
|
73
|
-
async onRequest(streamData) {
|
74
|
-
try {
|
75
|
-
const { stream, connection } = streamData;
|
76
|
-
const encodedShardInfo = proto_metadata.WakuMetadataResponse.encode(pubsubTopicsToShardInfo(this.pubsubTopics));
|
77
|
-
const encodedResponse = await pipe([encodedShardInfo], lp.encode, stream, lp.decode, async (source) => await all(source));
|
78
|
-
const { error, shardInfo } = this.decodeMetadataResponse(encodedResponse);
|
79
|
-
if (error) {
|
80
|
-
return;
|
81
|
-
}
|
82
|
-
await this.savePeerShardInfo(connection.remotePeer, shardInfo);
|
83
|
-
}
|
84
|
-
catch (error) {
|
85
|
-
log.error("Error handling metadata request", error);
|
86
|
-
}
|
87
|
-
}
|
88
|
-
decodeMetadataResponse(encodedResponse) {
|
89
|
-
const bytes = new Uint8ArrayList();
|
90
|
-
encodedResponse.forEach((chunk) => {
|
91
|
-
bytes.append(chunk);
|
92
|
-
});
|
93
|
-
const response = proto_metadata.WakuMetadataResponse.decode(bytes);
|
94
|
-
if (!response) {
|
95
|
-
log.error("Error decoding metadata response");
|
96
|
-
return {
|
97
|
-
shardInfo: null,
|
98
|
-
error: ProtocolError.DECODE_FAILED
|
99
|
-
};
|
100
|
-
}
|
101
|
-
return {
|
102
|
-
shardInfo: response,
|
103
|
-
error: null
|
104
|
-
};
|
105
|
-
}
|
106
|
-
async savePeerShardInfo(peerId, shardInfo) {
|
107
|
-
// add or update the shardInfo to peer store
|
108
|
-
await this.libp2pComponents.peerStore.merge(peerId, {
|
109
|
-
metadata: {
|
110
|
-
shardInfo: encodeRelayShard(shardInfo)
|
111
|
-
}
|
112
|
-
});
|
113
|
-
this.handshakesConfirmed.set(peerId.toString(), shardInfo);
|
114
|
-
}
|
115
|
-
}
|
116
|
-
export function wakuMetadata(pubsubTopics) {
|
117
|
-
return (components) => new Metadata(pubsubTopics, components);
|
118
|
-
}
|
119
|
-
//# sourceMappingURL=metadata.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../../src/lib/metadata/metadata.ts"],"names":[],"mappings":"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"}
|
@@ -1,9 +0,0 @@
|
|
1
|
-
import type { PeerId } from "@libp2p/interface";
|
2
|
-
import { IDecodedMessage, IDecoder, IStoreCore, Libp2p, PubsubTopic, QueryRequestParams } from "@waku/interfaces";
|
3
|
-
import { BaseProtocol } from "../base_protocol.js";
|
4
|
-
export declare const StoreCodec = "/vac/waku/store-query/3.0.0";
|
5
|
-
export declare class StoreCore extends BaseProtocol implements IStoreCore {
|
6
|
-
readonly pubsubTopics: PubsubTopic[];
|
7
|
-
constructor(pubsubTopics: PubsubTopic[], libp2p: Libp2p);
|
8
|
-
queryPerPage<T extends IDecodedMessage>(queryOpts: QueryRequestParams, decoders: Map<string, IDecoder<T>>, peerId: PeerId): AsyncGenerator<Promise<T | undefined>[]>;
|
9
|
-
}
|
package/dist/lib/store/store.js
DELETED
@@ -1,83 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/lib/store/store.ts"],"names":[],"mappings":"AASA,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;AAC/B,OAAO,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAEhD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAExD,OAAO,EACL,iBAAiB,EACjB,aAAa,EACb,iBAAiB,EACjB,kBAAkB,EACnB,MAAM,UAAU,CAAC;AAElB,MAAM,GAAG,GAAG,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC;AAEhC,MAAM,CAAC,MAAM,UAAU,GAAG,6BAA6B,CAAC;AAExD,MAAM,OAAO,SAAU,SAAQ,YAAY;IAEvB;IADlB,YACkB,YAA2B,EAC3C,MAAc;QAEd,KAAK,CAAC,UAAU,EAAE,MAAM,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QAHnC,iBAAY,GAAZ,YAAY,CAAe;IAI7C,CAAC;IAEM,KAAK,CAAC,CAAC,YAAY,CACxB,SAA6B,EAC7B,QAAkC,EAClC,MAAc;QAEd,IACE,SAAS,CAAC,aAAa,CAAC,QAAQ,EAAE;YAClC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC,QAAQ,EAAE,EACtC,CAAC;YACD,MAAM,IAAI,KAAK,CACb,sEAAsE,CACvE,CAAC;QACJ,CAAC;QAED,IAAI,aAAa,GAAG,SAAS,CAAC,gBAAgB,CAAC;QAC/C,OAAO,IAAI,EAAE,CAAC;YACZ,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC;gBACjD,GAAG,SAAS;gBACZ,gBAAgB,EAAE,aAAa;aAChC,CAAC,CAAC;YAEH,IAAI,MAAM,CAAC;YACX,IAAI,CAAC;gBACH,MAAM,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;YACxC,CAAC;YAAC,OAAO,CAAC,EAAE,CAAC;gBACX,GAAG,CAAC,KAAK,CAAC,sBAAsB,EAAE,CAAC,CAAC,CAAC;gBACrC,MAAM;YACR,CAAC;YAED,MAAM,GAAG,GAAG,MAAM,IAAI,CACpB,CAAC,iBAAiB,CAAC,MAAM,EAAE,CAAC,EAC5B,EAAE,CAAC,MAAM,EACT,MAAM,EACN,EAAE,CAAC,MAAM,EACT,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,MAAM,GAAG,CAAC,MAAM,CAAC,CACpC,CAAC;YAEF,MAAM,KAAK,GAAG,IAAI,cAAc,EAAE,CAAC;YACnC,GAAG,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBACpB,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACtB,CAAC,CAAC,CAAC;YAEH,MAAM,kBAAkB,GAAG,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAE5D,IACE,CAAC,kBAAkB,CAAC,UAAU;gBAC9B,kBAAkB,CAAC,UAAU,IAAI,GAAG,EACpC,CAAC;gBACD,MAAM,YAAY,GAAG,wCAAwC,kBAAkB,CAAC,UAAU,kBAAkB,kBAAkB,CAAC,UAAU,EAAE,CAAC;gBAC5I,GAAG,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;gBACxB,MAAM,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC;YAChC,CAAC;YAED,IAAI,CAAC,kBAAkB,CAAC,QAAQ,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gBACxE,GAAG,CAAC,IAAI,CAAC,uDAAuD,CAAC,CAAC;gBAClE,MAAM;YACR,CAAC;YAED,GAAG,CAAC,IAAI,CACN,GAAG,kBAAkB,CAAC,QAAQ,CAAC,MAAM,gCAAgC,CACtE,CAAC;YAEF,MAAM,eAAe,GAAG,kBAAkB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;gBACnE,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;oBACtB,OAAO,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;gBACpC,CAAC;gBACD,MAAM,YAAY,GAAG,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC;gBACnD,IAAI,YAAY,EAAE,CAAC;oBACjB,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;oBAC3C,IAAI,OAAO,EAAE,CAAC;wBACZ,OAAO,OAAO,CAAC,YAAY,CACzB,QAAQ,CAAC,WAAW,IAAI,EAAE,EAC1B,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,CACjC,CAAC;oBACJ,CAAC;gBACH,CAAC;gBACD,OAAO,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACpC,CAAC,CAAC,CAAC;YAEH,MAAM,eAAe,CAAC;YAEtB,IAAI,SAAS,CAAC,iBAAiB,EAAE,CAAC;gBAChC,aAAa;oBACX,kBAAkB,CAAC,QAAQ,CAAC,kBAAkB,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;yBAChE,WAAW,CAAC;YACnB,CAAC;iBAAM,CAAC;gBACN,aAAa,GAAG,kBAAkB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;YAC7D,CAAC;YAED,IACE,kBAAkB,CAAC,QAAQ,CAAC,MAAM,GAAG,aAAa;gBAClD,kBAAkB,CAAC,QAAQ,CAAC,MAAM;oBAChC,CAAC,SAAS,CAAC,eAAe,IAAI,iBAAiB,CAAC,EAClD,CAAC;gBACD,MAAM;YACR,CAAC;QACH,CAAC;IACH,CAAC;CACF"}
|