@dxos/messaging 0.8.4-main.b97322e → 0.8.4-main.bc2380dfbc
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/LICENSE +102 -5
- package/dist/lib/neutral/chunk-EC4H56J5.mjs +497 -0
- package/dist/lib/neutral/chunk-EC4H56J5.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +1249 -0
- package/dist/lib/neutral/index.mjs.map +7 -0
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/lib/{browser → neutral}/testing/index.mjs +13 -12
- package/dist/lib/neutral/testing/index.mjs.map +7 -0
- package/dist/types/src/messenger-monitor.d.ts.map +1 -1
- package/dist/types/src/messenger.blueprint-test.d.ts +1 -1
- package/dist/types/src/messenger.blueprint-test.d.ts.map +1 -1
- package/dist/types/src/messenger.d.ts +4 -3
- package/dist/types/src/messenger.d.ts.map +1 -1
- package/dist/types/src/signal-client/signal-client-monitor.d.ts.map +1 -1
- package/dist/types/src/signal-client/signal-client.d.ts +7 -8
- package/dist/types/src/signal-client/signal-client.d.ts.map +1 -1
- package/dist/types/src/signal-client/signal-local-state.d.ts +1 -1
- package/dist/types/src/signal-client/signal-local-state.d.ts.map +1 -1
- package/dist/types/src/signal-client/signal-rpc-client-monitor.d.ts.map +1 -1
- package/dist/types/src/signal-client/signal-rpc-client.d.ts +3 -3
- package/dist/types/src/signal-client/signal-rpc-client.d.ts.map +1 -1
- package/dist/types/src/signal-manager/edge-signal-manager.d.ts +6 -6
- package/dist/types/src/signal-manager/edge-signal-manager.d.ts.map +1 -1
- package/dist/types/src/signal-manager/memory-signal-manager.d.ts +6 -5
- package/dist/types/src/signal-manager/memory-signal-manager.d.ts.map +1 -1
- package/dist/types/src/signal-manager/signal-manager.d.ts +1 -1
- package/dist/types/src/signal-manager/signal-manager.d.ts.map +1 -1
- package/dist/types/src/signal-manager/utils.d.ts.map +1 -1
- package/dist/types/src/signal-manager/websocket-signal-manager-monitor.d.ts.map +1 -1
- package/dist/types/src/signal-manager/websocket-signal-manager.d.ts +6 -7
- package/dist/types/src/signal-manager/websocket-signal-manager.d.ts.map +1 -1
- package/dist/types/src/signal-methods.d.ts +7 -7
- package/dist/types/src/signal-methods.d.ts.map +1 -1
- package/dist/types/src/testing/test-builder.d.ts +1 -1
- package/dist/types/src/testing/test-builder.d.ts.map +1 -1
- package/dist/types/src/testing/test-peer.d.ts +1 -1
- package/dist/types/src/testing/test-peer.d.ts.map +1 -1
- package/dist/types/src/testing/utils.d.ts +1 -1
- package/dist/types/src/testing/utils.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +27 -30
- package/src/messenger.blueprint-test.ts +15 -14
- package/src/messenger.node.test.ts +7 -38
- package/src/messenger.ts +38 -33
- package/src/signal-client/signal-client.node.test.ts +12 -11
- package/src/signal-client/signal-client.ts +12 -15
- package/src/signal-client/signal-local-state.ts +3 -3
- package/src/signal-client/signal-rpc-client.node.test.ts +1 -1
- package/src/signal-client/signal-rpc-client.ts +7 -9
- package/src/signal-manager/edge-signal-manager.ts +31 -18
- package/src/signal-manager/memory-signal-manager.ts +18 -15
- package/src/signal-manager/signal-manager.ts +1 -1
- package/src/signal-manager/websocket-signal-manager.node.test.ts +15 -14
- package/src/signal-manager/websocket-signal-manager.ts +12 -18
- package/src/signal-methods.ts +8 -8
- package/src/testing/test-builder.ts +6 -4
- package/src/testing/test-peer.ts +2 -2
- package/src/testing/utils.ts +2 -2
- package/dist/lib/browser/chunk-QLQS7TUS.mjs +0 -2309
- package/dist/lib/browser/chunk-QLQS7TUS.mjs.map +0 -7
- package/dist/lib/browser/index.mjs +0 -22
- package/dist/lib/browser/index.mjs.map +0 -7
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/browser/testing/index.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GIM3VIFP.mjs +0 -2309
- package/dist/lib/node-esm/chunk-GIM3VIFP.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -22
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/testing/index.mjs +0 -143
- package/dist/lib/node-esm/testing/index.mjs.map +0 -7
package/package.json
CHANGED
|
@@ -1,33 +1,30 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dxos/messaging",
|
|
3
|
-
"version": "0.8.4-main.
|
|
3
|
+
"version": "0.8.4-main.bc2380dfbc",
|
|
4
4
|
"description": "Messaging",
|
|
5
5
|
"homepage": "https://dxos.org",
|
|
6
6
|
"bugs": "https://github.com/dxos/dxos/issues",
|
|
7
|
-
"
|
|
7
|
+
"repository": {
|
|
8
|
+
"type": "git",
|
|
9
|
+
"url": "https://github.com/dxos/dxos"
|
|
10
|
+
},
|
|
11
|
+
"license": "FSL-1.1-Apache-2.0",
|
|
8
12
|
"author": "DXOS.org",
|
|
9
|
-
"sideEffects":
|
|
13
|
+
"sideEffects": false,
|
|
10
14
|
"type": "module",
|
|
11
15
|
"exports": {
|
|
12
16
|
".": {
|
|
17
|
+
"source": "./src/index.ts",
|
|
13
18
|
"types": "./dist/types/src/index.d.ts",
|
|
14
|
-
"
|
|
15
|
-
"node": "./dist/lib/node-esm/index.mjs"
|
|
19
|
+
"default": "./dist/lib/neutral/index.mjs"
|
|
16
20
|
},
|
|
17
21
|
"./testing": {
|
|
22
|
+
"source": "./src/testing/index.ts",
|
|
18
23
|
"types": "./dist/types/src/testing/index.d.ts",
|
|
19
|
-
"
|
|
20
|
-
"node": "./dist/lib/node-esm/testing/index.mjs"
|
|
24
|
+
"default": "./dist/lib/neutral/testing/index.mjs"
|
|
21
25
|
}
|
|
22
26
|
},
|
|
23
27
|
"types": "dist/types/src/index.d.ts",
|
|
24
|
-
"typesVersions": {
|
|
25
|
-
"*": {
|
|
26
|
-
"testing": [
|
|
27
|
-
"dist/types/src/testing/index.d.ts"
|
|
28
|
-
]
|
|
29
|
-
}
|
|
30
|
-
},
|
|
31
28
|
"files": [
|
|
32
29
|
"dist",
|
|
33
30
|
"src",
|
|
@@ -35,24 +32,24 @@
|
|
|
35
32
|
],
|
|
36
33
|
"dependencies": {
|
|
37
34
|
"isomorphic-ws": "^5.0.0",
|
|
38
|
-
"ws": "^8.
|
|
39
|
-
"@dxos/async": "0.8.4-main.
|
|
40
|
-
"@dxos/
|
|
41
|
-
"@dxos/context": "0.8.4-main.
|
|
42
|
-
"@dxos/
|
|
43
|
-
"@dxos/
|
|
44
|
-
"@dxos/
|
|
45
|
-
"@dxos/
|
|
46
|
-
"@dxos/
|
|
47
|
-
"@dxos/
|
|
48
|
-
"@dxos/
|
|
49
|
-
"@dxos/
|
|
50
|
-
"@dxos/
|
|
35
|
+
"ws": "^8.17.1",
|
|
36
|
+
"@dxos/async": "0.8.4-main.bc2380dfbc",
|
|
37
|
+
"@dxos/invariant": "0.8.4-main.bc2380dfbc",
|
|
38
|
+
"@dxos/context": "0.8.4-main.bc2380dfbc",
|
|
39
|
+
"@dxos/codec-protobuf": "0.8.4-main.bc2380dfbc",
|
|
40
|
+
"@dxos/log": "0.8.4-main.bc2380dfbc",
|
|
41
|
+
"@dxos/edge-client": "0.8.4-main.bc2380dfbc",
|
|
42
|
+
"@dxos/keys": "0.8.4-main.bc2380dfbc",
|
|
43
|
+
"@dxos/node-std": "0.8.4-main.bc2380dfbc",
|
|
44
|
+
"@dxos/rpc": "0.8.4-main.bc2380dfbc",
|
|
45
|
+
"@dxos/util": "0.8.4-main.bc2380dfbc",
|
|
46
|
+
"@dxos/tracing": "0.8.4-main.bc2380dfbc",
|
|
47
|
+
"@dxos/protocols": "0.8.4-main.bc2380dfbc"
|
|
51
48
|
},
|
|
52
49
|
"devDependencies": {
|
|
53
|
-
"@dxos/keyring": "0.8.4-main.
|
|
54
|
-
"@dxos/
|
|
55
|
-
"@dxos/
|
|
50
|
+
"@dxos/keyring": "0.8.4-main.bc2380dfbc",
|
|
51
|
+
"@dxos/test-utils": "0.8.4-main.bc2380dfbc",
|
|
52
|
+
"@dxos/signal": "0.8.4-main.bc2380dfbc"
|
|
56
53
|
},
|
|
57
54
|
"publishConfig": {
|
|
58
55
|
"access": "public"
|
|
@@ -2,14 +2,15 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { describe, expect,
|
|
5
|
+
import { describe, expect, onTestFinished, test } from 'vitest';
|
|
6
6
|
|
|
7
7
|
import { asyncTimeout, latch, sleep } from '@dxos/async';
|
|
8
|
+
import { Context } from '@dxos/context';
|
|
8
9
|
import { range } from '@dxos/util';
|
|
9
10
|
|
|
10
11
|
import { WebsocketSignalManager } from './signal-manager';
|
|
11
12
|
import { type Message } from './signal-methods';
|
|
12
|
-
import {
|
|
13
|
+
import { PAYLOAD_1, PAYLOAD_2, PAYLOAD_3, TestBuilder, messageEqual } from './testing';
|
|
13
14
|
|
|
14
15
|
export const messengerTests = (signalManagerFactory: TestBuilder['createSignalManager']) => {
|
|
15
16
|
test('Message between peers', async () => {
|
|
@@ -30,7 +31,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
30
31
|
|
|
31
32
|
const promise = peer2.waitTillReceive(message);
|
|
32
33
|
|
|
33
|
-
await peer1.messenger.sendMessage(message);
|
|
34
|
+
await peer1.messenger.sendMessage(Context.default(), message);
|
|
34
35
|
|
|
35
36
|
await promise;
|
|
36
37
|
});
|
|
@@ -52,7 +53,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
52
53
|
};
|
|
53
54
|
|
|
54
55
|
const promise = peer2.waitTillReceive(message);
|
|
55
|
-
await peer1.messenger.sendMessage(message);
|
|
56
|
+
await peer1.messenger.sendMessage(Context.default(), message);
|
|
56
57
|
await asyncTimeout(promise, 1_000);
|
|
57
58
|
}
|
|
58
59
|
|
|
@@ -64,7 +65,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
64
65
|
};
|
|
65
66
|
|
|
66
67
|
const promise = peer3.waitTillReceive(message);
|
|
67
|
-
await peer1.messenger.sendMessage(message);
|
|
68
|
+
await peer1.messenger.sendMessage(Context.default(), message);
|
|
68
69
|
await asyncTimeout(promise, 1_000);
|
|
69
70
|
}
|
|
70
71
|
|
|
@@ -76,7 +77,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
76
77
|
};
|
|
77
78
|
|
|
78
79
|
const promise = peer1.waitTillReceive(message);
|
|
79
|
-
await peer2.messenger.sendMessage(message);
|
|
80
|
+
await peer2.messenger.sendMessage(Context.default(), message);
|
|
80
81
|
await asyncTimeout(promise, 1_000);
|
|
81
82
|
}
|
|
82
83
|
});
|
|
@@ -128,7 +129,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
128
129
|
};
|
|
129
130
|
const promise = peer2.waitTillReceive(message);
|
|
130
131
|
|
|
131
|
-
await peer1.messenger.sendMessage(message);
|
|
132
|
+
await peer1.messenger.sendMessage(Context.default(), message);
|
|
132
133
|
|
|
133
134
|
// 3 listeners (default one that was returned by setupPeer() and 2 that listen for type "1") should receive message.
|
|
134
135
|
await asyncTimeout(promise, 1_000);
|
|
@@ -175,7 +176,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
175
176
|
};
|
|
176
177
|
|
|
177
178
|
const receivePromise = peer2.waitTillReceive(message);
|
|
178
|
-
await peer1.messenger.sendMessage(message);
|
|
179
|
+
await peer1.messenger.sendMessage(Context.default(), message);
|
|
179
180
|
|
|
180
181
|
// 2 subscribed listeners should receive message.
|
|
181
182
|
await asyncTimeout(receivePromise, 1_000);
|
|
@@ -195,7 +196,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
195
196
|
};
|
|
196
197
|
|
|
197
198
|
const receivePromise = peer2.waitTillReceive(message);
|
|
198
|
-
await peer1.messenger.sendMessage(message);
|
|
199
|
+
await peer1.messenger.sendMessage(Context.default(), message);
|
|
199
200
|
|
|
200
201
|
// 1 listener that was not unsubscribed should receive message.
|
|
201
202
|
await asyncTimeout(receivePromise, 1_000);
|
|
@@ -221,7 +222,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
221
222
|
|
|
222
223
|
{
|
|
223
224
|
const receivePromise = peer2.waitTillReceive(message);
|
|
224
|
-
await peer1.messenger.sendMessage(message);
|
|
225
|
+
await peer1.messenger.sendMessage(Context.default(), message);
|
|
225
226
|
await asyncTimeout(receivePromise, 1_000);
|
|
226
227
|
}
|
|
227
228
|
|
|
@@ -236,7 +237,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
236
237
|
|
|
237
238
|
{
|
|
238
239
|
const receivePromise = peer2.waitTillReceive(message);
|
|
239
|
-
await peer1.messenger.sendMessage(message);
|
|
240
|
+
await peer1.messenger.sendMessage(Context.default(), message);
|
|
240
241
|
await asyncTimeout(receivePromise, 1_000);
|
|
241
242
|
}
|
|
242
243
|
});
|
|
@@ -275,7 +276,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
275
276
|
Array(3)
|
|
276
277
|
.fill(0)
|
|
277
278
|
.forEach(async () => {
|
|
278
|
-
await peer2.messenger.sendMessage(message);
|
|
279
|
+
await peer2.messenger.sendMessage(Context.default(), message);
|
|
279
280
|
});
|
|
280
281
|
|
|
281
282
|
// expect to receive 3 messages.
|
|
@@ -302,7 +303,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
302
303
|
count = inc();
|
|
303
304
|
});
|
|
304
305
|
// sending message.
|
|
305
|
-
await peer2.messenger.sendMessage({
|
|
306
|
+
await peer2.messenger.sendMessage(Context.default(), {
|
|
306
307
|
author: peer2.peerInfo,
|
|
307
308
|
recipient: peer1.peerInfo,
|
|
308
309
|
payload: PAYLOAD_1,
|
|
@@ -322,7 +323,7 @@ export const messengerTests = (signalManagerFactory: TestBuilder['createSignalMa
|
|
|
322
323
|
void range(100).map(async () => {
|
|
323
324
|
const peer = await builder.createPeer();
|
|
324
325
|
|
|
325
|
-
void peer.messenger.sendMessage({
|
|
326
|
+
void peer.messenger.sendMessage(Context.default(), {
|
|
326
327
|
author: peer.peerInfo,
|
|
327
328
|
recipient: peer.peerInfo,
|
|
328
329
|
payload: {
|
|
@@ -2,48 +2,17 @@
|
|
|
2
2
|
// Copyright 2022 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
import { asyncTimeout } from '@dxos/async';
|
|
8
|
-
import { runTestSignalServer, type SignalServerRunner } from '@dxos/signal';
|
|
5
|
+
import { beforeEach, describe } from 'vitest';
|
|
9
6
|
|
|
10
7
|
import { messengerTests } from './messenger.blueprint-test';
|
|
11
|
-
import {
|
|
12
|
-
import { type Message } from './signal-methods';
|
|
13
|
-
import { PAYLOAD_1, TestBuilder } from './testing';
|
|
8
|
+
import { MemorySignalManager, MemorySignalManagerContext } from './signal-manager';
|
|
14
9
|
|
|
10
|
+
// TODO(mykola): Use EDGE signal server.
|
|
15
11
|
describe('Messenger with WebsocketSignalManager', () => {
|
|
16
|
-
let
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
broker = await runTestSignalServer();
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
afterAll(() => {
|
|
23
|
-
void broker.stop();
|
|
12
|
+
let context: MemorySignalManagerContext;
|
|
13
|
+
beforeEach(async () => {
|
|
14
|
+
context = new MemorySignalManagerContext();
|
|
24
15
|
});
|
|
25
16
|
|
|
26
|
-
messengerTests(async () => new
|
|
27
|
-
|
|
28
|
-
test('Message with broken signal server', { timeout: 1000 }, async () => {
|
|
29
|
-
const builder = new TestBuilder({
|
|
30
|
-
signalManagerFactory: async () =>
|
|
31
|
-
new WebsocketSignalManager([{ server: 'ws://broken.kube.' }, { server: broker.url() }]),
|
|
32
|
-
});
|
|
33
|
-
onTestFinished(() => builder.close());
|
|
34
|
-
const peer1 = await builder.createPeer();
|
|
35
|
-
const peer2 = await builder.createPeer();
|
|
36
|
-
|
|
37
|
-
const message: Message = {
|
|
38
|
-
author: peer1.peerInfo,
|
|
39
|
-
recipient: peer2.peerInfo,
|
|
40
|
-
payload: PAYLOAD_1,
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
{
|
|
44
|
-
const receivePromise = peer2.waitTillReceive(message);
|
|
45
|
-
await peer1.messenger.sendMessage(message);
|
|
46
|
-
await asyncTimeout(receivePromise, 1_000);
|
|
47
|
-
}
|
|
48
|
-
});
|
|
17
|
+
messengerTests(async () => new MemorySignalManager(context));
|
|
49
18
|
});
|
package/src/messenger.ts
CHANGED
|
@@ -8,14 +8,14 @@ import { Context } from '@dxos/context';
|
|
|
8
8
|
import { invariant } from '@dxos/invariant';
|
|
9
9
|
import { PublicKey } from '@dxos/keys';
|
|
10
10
|
import { log } from '@dxos/log';
|
|
11
|
-
import { TimeoutError as ProtocolTimeoutError
|
|
11
|
+
import { TimeoutError as ProtocolTimeoutError } from '@dxos/protocols';
|
|
12
12
|
import { schema } from '@dxos/protocols/proto';
|
|
13
13
|
import { type ReliablePayload } from '@dxos/protocols/proto/dxos/mesh/messaging';
|
|
14
14
|
import { ComplexMap, ComplexSet } from '@dxos/util';
|
|
15
15
|
|
|
16
16
|
import { MessengerMonitor } from './messenger-monitor';
|
|
17
17
|
import { type SignalManager } from './signal-manager';
|
|
18
|
-
import { type
|
|
18
|
+
import { type Message, type PeerInfo } from './signal-methods';
|
|
19
19
|
import { MESSAGE_TIMEOUT } from './timeouts';
|
|
20
20
|
|
|
21
21
|
export type OnMessage = (params: Message) => Promise<void>;
|
|
@@ -68,8 +68,7 @@ export class Messenger {
|
|
|
68
68
|
if (!this._closed) {
|
|
69
69
|
return;
|
|
70
70
|
}
|
|
71
|
-
|
|
72
|
-
log.trace('dxos.mesh.messenger.open', trace.begin({ id: traceId }));
|
|
71
|
+
log('opening messenger');
|
|
73
72
|
this._ctx = new Context({
|
|
74
73
|
onError: (err) => log.catch(err),
|
|
75
74
|
});
|
|
@@ -90,7 +89,7 @@ export class Messenger {
|
|
|
90
89
|
);
|
|
91
90
|
|
|
92
91
|
this._closed = false;
|
|
93
|
-
log
|
|
92
|
+
log('opened messenger');
|
|
94
93
|
}
|
|
95
94
|
|
|
96
95
|
async close(): Promise<void> {
|
|
@@ -101,7 +100,7 @@ export class Messenger {
|
|
|
101
100
|
await this._ctx.dispose();
|
|
102
101
|
}
|
|
103
102
|
|
|
104
|
-
async sendMessage({ author, recipient, payload }: Message): Promise<void> {
|
|
103
|
+
async sendMessage(ctx: Context, { author, recipient, payload }: Message): Promise<void> {
|
|
105
104
|
invariant(!this._closed, 'Closed');
|
|
106
105
|
const messageContext = this._ctx.derive();
|
|
107
106
|
|
|
@@ -127,7 +126,7 @@ export class Messenger {
|
|
|
127
126
|
async () => {
|
|
128
127
|
log('retrying message', { messageId: reliablePayload.messageId });
|
|
129
128
|
sendAttempts++;
|
|
130
|
-
await this._encodeAndSend({ author, recipient, reliablePayload }).catch((err) =>
|
|
129
|
+
await this._encodeAndSend(ctx, { author, recipient, reliablePayload }).catch((err) =>
|
|
131
130
|
log('failed to send message', { err }),
|
|
132
131
|
);
|
|
133
132
|
},
|
|
@@ -140,10 +139,10 @@ export class Messenger {
|
|
|
140
139
|
log('message not delivered', { messageId: reliablePayload.messageId });
|
|
141
140
|
this._onAckCallbacks.delete(reliablePayload.messageId!);
|
|
142
141
|
timeoutHit(
|
|
143
|
-
new ProtocolTimeoutError(
|
|
144
|
-
'signaling message not delivered',
|
|
145
|
-
new TimeoutError(MESSAGE_TIMEOUT, 'Message not delivered'),
|
|
146
|
-
),
|
|
142
|
+
new ProtocolTimeoutError({
|
|
143
|
+
message: 'signaling message not delivered',
|
|
144
|
+
cause: new TimeoutError(MESSAGE_TIMEOUT, 'Message not delivered'),
|
|
145
|
+
}),
|
|
147
146
|
);
|
|
148
147
|
void messageContext.dispose();
|
|
149
148
|
this._monitor.recordReliableMessage({ sendAttempts, sent: false });
|
|
@@ -158,7 +157,7 @@ export class Messenger {
|
|
|
158
157
|
this._monitor.recordReliableMessage({ sendAttempts, sent: true });
|
|
159
158
|
});
|
|
160
159
|
|
|
161
|
-
await this._encodeAndSend({ author, recipient, reliablePayload });
|
|
160
|
+
await this._encodeAndSend(ctx, { author, recipient, reliablePayload });
|
|
162
161
|
return promise;
|
|
163
162
|
}
|
|
164
163
|
|
|
@@ -204,16 +203,19 @@ export class Messenger {
|
|
|
204
203
|
};
|
|
205
204
|
}
|
|
206
205
|
|
|
207
|
-
private async _encodeAndSend(
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
206
|
+
private async _encodeAndSend(
|
|
207
|
+
ctx: Context,
|
|
208
|
+
{
|
|
209
|
+
author,
|
|
210
|
+
recipient,
|
|
211
|
+
reliablePayload,
|
|
212
|
+
}: {
|
|
213
|
+
author: PeerInfo;
|
|
214
|
+
recipient: PeerInfo;
|
|
215
|
+
reliablePayload: ReliablePayload;
|
|
216
|
+
},
|
|
217
|
+
): Promise<void> {
|
|
218
|
+
await this._signalManager.sendMessage(ctx, {
|
|
217
219
|
author,
|
|
218
220
|
recipient,
|
|
219
221
|
payload: {
|
|
@@ -243,7 +245,7 @@ export class Messenger {
|
|
|
243
245
|
log('handling message', { messageId: reliablePayload.messageId });
|
|
244
246
|
|
|
245
247
|
try {
|
|
246
|
-
await this._sendAcknowledgement({
|
|
248
|
+
await this._sendAcknowledgement(this._ctx, {
|
|
247
249
|
author,
|
|
248
250
|
recipient,
|
|
249
251
|
messageId: reliablePayload.messageId,
|
|
@@ -272,18 +274,21 @@ export class Messenger {
|
|
|
272
274
|
this._onAckCallbacks.get(Acknowledgement.decode(payload.value).messageId)?.();
|
|
273
275
|
}
|
|
274
276
|
|
|
275
|
-
private async _sendAcknowledgement(
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
277
|
+
private async _sendAcknowledgement(
|
|
278
|
+
ctx: Context,
|
|
279
|
+
{
|
|
280
|
+
author,
|
|
281
|
+
recipient,
|
|
282
|
+
messageId,
|
|
283
|
+
}: {
|
|
284
|
+
author: PeerInfo;
|
|
285
|
+
recipient: PeerInfo;
|
|
286
|
+
messageId: PublicKey;
|
|
287
|
+
},
|
|
288
|
+
): Promise<void> {
|
|
284
289
|
log('sending ACK', { messageId, from: recipient, to: author });
|
|
285
290
|
|
|
286
|
-
await this._signalManager.sendMessage({
|
|
291
|
+
await this._signalManager.sendMessage(ctx, {
|
|
287
292
|
author: recipient,
|
|
288
293
|
recipient: author,
|
|
289
294
|
payload: {
|
|
@@ -2,18 +2,19 @@
|
|
|
2
2
|
// Copyright 2020 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { afterAll, beforeAll, describe, expect,
|
|
5
|
+
import { afterAll, beforeAll, describe, expect, onTestFinished, test } from 'vitest';
|
|
6
6
|
|
|
7
7
|
import { asyncTimeout, waitForCondition } from '@dxos/async';
|
|
8
8
|
import { type Any, type TaggedType } from '@dxos/codec-protobuf';
|
|
9
|
+
import { Context } from '@dxos/context';
|
|
9
10
|
import { PublicKey } from '@dxos/keys';
|
|
10
11
|
import { log } from '@dxos/log';
|
|
11
12
|
import { type TYPES } from '@dxos/protocols/proto';
|
|
12
|
-
import {
|
|
13
|
+
import { type SignalServerRunner, runTestSignalServer } from '@dxos/signal';
|
|
13
14
|
import { ComplexSet, range } from '@dxos/util';
|
|
14
15
|
|
|
15
|
-
import { SignalClient } from './signal-client';
|
|
16
16
|
import { type Message, type PeerInfo } from '../signal-methods';
|
|
17
|
+
import { SignalClient } from './signal-client';
|
|
17
18
|
|
|
18
19
|
const PAYLOAD: TaggedType<TYPES, 'google.protobuf.Any'> = {
|
|
19
20
|
'@type': 'google.protobuf.Any',
|
|
@@ -42,7 +43,7 @@ describe('SignalClient', () => {
|
|
|
42
43
|
|
|
43
44
|
const message = createMessage(peer2, peer1);
|
|
44
45
|
const receivedMessage = peer1.waitForNextMessage();
|
|
45
|
-
await peer2.client.sendMessage(message);
|
|
46
|
+
await peer2.client.sendMessage(Context.default(), message);
|
|
46
47
|
expect(await receivedMessage).toEqual(message);
|
|
47
48
|
});
|
|
48
49
|
|
|
@@ -50,8 +51,8 @@ describe('SignalClient', () => {
|
|
|
50
51
|
const topic = PublicKey.random();
|
|
51
52
|
const [peer1, peer2] = setupPeers({ peerCount: 2 });
|
|
52
53
|
|
|
53
|
-
await peer1.client.join({ topic, peer: peer1.peerInfo });
|
|
54
|
-
await peer2.client.join({ topic, peer: peer2.peerInfo });
|
|
54
|
+
await peer1.client.join(Context.default(), { topic, peer: peer1.peerInfo });
|
|
55
|
+
await peer2.client.join(Context.default(), { topic, peer: peer2.peerInfo });
|
|
55
56
|
|
|
56
57
|
await peer1.waitForPeer(peer2.peerKey);
|
|
57
58
|
await peer2.waitForPeer(peer1.peerKey);
|
|
@@ -66,7 +67,7 @@ describe('SignalClient', () => {
|
|
|
66
67
|
const message = createMessage(peer2, peer1);
|
|
67
68
|
const receivedMessage = peer1.waitForNextMessage();
|
|
68
69
|
|
|
69
|
-
await peer1.client.sendMessage(message);
|
|
70
|
+
await peer1.client.sendMessage(Context.default(), message);
|
|
70
71
|
expect(await receivedMessage).toEqual(message);
|
|
71
72
|
});
|
|
72
73
|
|
|
@@ -81,7 +82,7 @@ describe('SignalClient', () => {
|
|
|
81
82
|
|
|
82
83
|
{
|
|
83
84
|
const receivedMessage = peer1.waitForNextMessage({ timeout: 1_000 });
|
|
84
|
-
await peer2.client.sendMessage(message);
|
|
85
|
+
await peer2.client.sendMessage(Context.default(), message);
|
|
85
86
|
expect(await receivedMessage).toEqual(message);
|
|
86
87
|
}
|
|
87
88
|
|
|
@@ -90,7 +91,7 @@ describe('SignalClient', () => {
|
|
|
90
91
|
|
|
91
92
|
{
|
|
92
93
|
const receivedMessage = peer1.waitForNextMessage({ timeout: 200 });
|
|
93
|
-
await peer2.client.sendMessage(message);
|
|
94
|
+
await peer2.client.sendMessage(Context.default(), message);
|
|
94
95
|
await expect(receivedMessage).rejects.toBeDefined();
|
|
95
96
|
}
|
|
96
97
|
});
|
|
@@ -105,7 +106,7 @@ describe('SignalClient', () => {
|
|
|
105
106
|
|
|
106
107
|
{
|
|
107
108
|
const waitMessage = peer1.waitForNextMessage();
|
|
108
|
-
await peer2.client.sendMessage(message);
|
|
109
|
+
await peer2.client.sendMessage(Context.default(), message);
|
|
109
110
|
expect(await waitMessage).toEqual(message);
|
|
110
111
|
}
|
|
111
112
|
|
|
@@ -119,7 +120,7 @@ describe('SignalClient', () => {
|
|
|
119
120
|
|
|
120
121
|
{
|
|
121
122
|
const waitMessage = peer1.waitForNextMessage();
|
|
122
|
-
await peer2.client.sendMessage(message);
|
|
123
|
+
await peer2.client.sendMessage(Context.default(), message);
|
|
123
124
|
expect(await waitMessage).toEqual(message);
|
|
124
125
|
}
|
|
125
126
|
});
|
|
@@ -3,25 +3,24 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { DeferredTask, Event, Trigger, scheduleTask, scheduleTaskInterval, sleep } from '@dxos/async';
|
|
6
|
-
import { type Context,
|
|
6
|
+
import { type Context, Resource, cancelWithContext } from '@dxos/context';
|
|
7
7
|
import { invariant } from '@dxos/invariant';
|
|
8
8
|
import { PublicKey } from '@dxos/keys';
|
|
9
9
|
import { log } from '@dxos/log';
|
|
10
|
-
import { trace } from '@dxos/protocols';
|
|
11
10
|
import { type SwarmResponse } from '@dxos/protocols/proto/dxos/edge/messenger';
|
|
12
|
-
import { type
|
|
11
|
+
import { type JoinRequest, type LeaveRequest, type QueryRequest } from '@dxos/protocols/proto/dxos/edge/signal';
|
|
13
12
|
import { SignalState } from '@dxos/protocols/proto/dxos/mesh/signal';
|
|
14
13
|
|
|
15
|
-
import { SignalClientMonitor } from './signal-client-monitor';
|
|
16
|
-
import { SignalLocalState } from './signal-local-state';
|
|
17
|
-
import { SignalRPCClient } from './signal-rpc-client';
|
|
18
14
|
import {
|
|
19
|
-
type PeerInfo,
|
|
20
15
|
type Message,
|
|
16
|
+
type PeerInfo,
|
|
21
17
|
type SignalClientMethods,
|
|
22
18
|
type SignalStatus,
|
|
23
19
|
type SwarmEvent,
|
|
24
20
|
} from '../signal-methods';
|
|
21
|
+
import { SignalClientMonitor } from './signal-client-monitor';
|
|
22
|
+
import { SignalLocalState } from './signal-local-state';
|
|
23
|
+
import { SignalRPCClient } from './signal-rpc-client';
|
|
25
24
|
|
|
26
25
|
const DEFAULT_RECONNECT_TIMEOUT = 100;
|
|
27
26
|
const MAX_RECONNECT_TIMEOUT = 5_000;
|
|
@@ -56,8 +55,6 @@ export class SignalClient extends Resource implements SignalClientMethods {
|
|
|
56
55
|
*/
|
|
57
56
|
private _reconnectAfter = DEFAULT_RECONNECT_TIMEOUT;
|
|
58
57
|
|
|
59
|
-
private readonly _instanceId = PublicKey.random().toHex();
|
|
60
|
-
|
|
61
58
|
/**
|
|
62
59
|
* @internal
|
|
63
60
|
*/
|
|
@@ -93,7 +90,7 @@ export class SignalClient extends Resource implements SignalClientMethods {
|
|
|
93
90
|
}
|
|
94
91
|
|
|
95
92
|
protected override async _open(): Promise<void> {
|
|
96
|
-
log
|
|
93
|
+
log('opening signal client');
|
|
97
94
|
|
|
98
95
|
if ([SignalState.CONNECTED, SignalState.CONNECTING].includes(this._state)) {
|
|
99
96
|
return;
|
|
@@ -136,7 +133,7 @@ export class SignalClient extends Resource implements SignalClientMethods {
|
|
|
136
133
|
});
|
|
137
134
|
|
|
138
135
|
this._createClient();
|
|
139
|
-
log
|
|
136
|
+
log('opened signal client');
|
|
140
137
|
}
|
|
141
138
|
|
|
142
139
|
protected override async _catch(err: Error): Promise<void> {
|
|
@@ -172,24 +169,24 @@ export class SignalClient extends Resource implements SignalClientMethods {
|
|
|
172
169
|
};
|
|
173
170
|
}
|
|
174
171
|
|
|
175
|
-
async join(args: JoinRequest): Promise<void> {
|
|
172
|
+
async join(_ctx: Context, args: JoinRequest): Promise<void> {
|
|
176
173
|
log('joining', { topic: args.topic, peerId: args.peer.peerKey });
|
|
177
174
|
this._monitor.recordJoin();
|
|
178
175
|
this.localState.join({ topic: args.topic, peerId: PublicKey.from(args.peer.peerKey) });
|
|
179
176
|
this._reconcileTask?.schedule();
|
|
180
177
|
}
|
|
181
178
|
|
|
182
|
-
async leave(args: LeaveRequest): Promise<void> {
|
|
179
|
+
async leave(_ctx: Context, args: LeaveRequest): Promise<void> {
|
|
183
180
|
log('leaving', { topic: args.topic, peerId: args.peer.peerKey });
|
|
184
181
|
this._monitor.recordLeave();
|
|
185
182
|
this.localState.leave({ topic: args.topic, peerId: PublicKey.from(args.peer.peerKey) });
|
|
186
183
|
}
|
|
187
184
|
|
|
188
|
-
async query(params: QueryRequest): Promise<SwarmResponse> {
|
|
185
|
+
async query(_ctx: Context, params: QueryRequest): Promise<SwarmResponse> {
|
|
189
186
|
throw new Error('Not implemented');
|
|
190
187
|
}
|
|
191
188
|
|
|
192
|
-
async sendMessage(msg: Message): Promise<void> {
|
|
189
|
+
async sendMessage(_ctx: Context, msg: Message): Promise<void> {
|
|
193
190
|
return this._monitor.recordMessageSending(msg, async () => {
|
|
194
191
|
await this._clientReady.wait();
|
|
195
192
|
invariant(this._state === SignalState.CONNECTED, 'Not connected to Signal Server');
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
5
|
+
import { Event, asyncTimeout } from '@dxos/async';
|
|
6
6
|
import type { Stream } from '@dxos/codec-protobuf/stream';
|
|
7
|
-
import {
|
|
7
|
+
import { type Context, cancelWithContext } from '@dxos/context';
|
|
8
8
|
import { PublicKey } from '@dxos/keys';
|
|
9
9
|
import { log } from '@dxos/log';
|
|
10
10
|
import {
|
|
@@ -13,8 +13,8 @@ import {
|
|
|
13
13
|
} from '@dxos/protocols/proto/dxos/mesh/signal';
|
|
14
14
|
import { ComplexMap, ComplexSet, safeAwaitAll } from '@dxos/util';
|
|
15
15
|
|
|
16
|
-
import { type SignalRPCClient } from './signal-rpc-client';
|
|
17
16
|
import type { Message, SwarmEvent } from '../signal-methods';
|
|
17
|
+
import { type SignalRPCClient } from './signal-rpc-client';
|
|
18
18
|
|
|
19
19
|
export class SignalLocalState {
|
|
20
20
|
/**
|
|
@@ -9,7 +9,7 @@ import { PublicKey } from '@dxos/keys';
|
|
|
9
9
|
import { log } from '@dxos/log';
|
|
10
10
|
import { schema } from '@dxos/protocols/proto';
|
|
11
11
|
import { type Message as SignalMessage, type SwarmEvent } from '@dxos/protocols/proto/dxos/mesh/signal';
|
|
12
|
-
import {
|
|
12
|
+
import { type SignalServerRunner, runTestSignalServer } from '@dxos/signal';
|
|
13
13
|
|
|
14
14
|
import { SignalRPCClient } from './signal-rpc-client';
|
|
15
15
|
|
|
@@ -4,16 +4,15 @@
|
|
|
4
4
|
|
|
5
5
|
import WebSocket from 'isomorphic-ws';
|
|
6
6
|
|
|
7
|
-
import {
|
|
7
|
+
import { TimeoutError, Trigger, scheduleTaskInterval } from '@dxos/async';
|
|
8
8
|
import { type Any, type Stream } from '@dxos/codec-protobuf';
|
|
9
9
|
import { Context } from '@dxos/context';
|
|
10
10
|
import { invariant } from '@dxos/invariant';
|
|
11
11
|
import { PublicKey } from '@dxos/keys';
|
|
12
12
|
import { log } from '@dxos/log';
|
|
13
|
-
import { trace } from '@dxos/protocols';
|
|
14
13
|
import { schema } from '@dxos/protocols/proto';
|
|
15
|
-
import { type Message as SignalMessage
|
|
16
|
-
import {
|
|
14
|
+
import { type Signal, type Message as SignalMessage } from '@dxos/protocols/proto/dxos/mesh/signal';
|
|
15
|
+
import { type ProtoRpcPeer, createProtoRpcPeer } from '@dxos/rpc';
|
|
17
16
|
|
|
18
17
|
import { SignalRpcClientMonitor } from './signal-rpc-client-monitor';
|
|
19
18
|
|
|
@@ -36,7 +35,7 @@ export type SignalCallbacks = {
|
|
|
36
35
|
getMetadata?: () => any;
|
|
37
36
|
};
|
|
38
37
|
|
|
39
|
-
export type
|
|
38
|
+
export type SignalRPCClientProps = {
|
|
40
39
|
url: string;
|
|
41
40
|
callbacks?: SignalCallbacks;
|
|
42
41
|
};
|
|
@@ -61,9 +60,8 @@ export class SignalRPCClient {
|
|
|
61
60
|
|
|
62
61
|
private readonly _monitor = new SignalRpcClientMonitor();
|
|
63
62
|
|
|
64
|
-
constructor({ url, callbacks = {} }:
|
|
65
|
-
|
|
66
|
-
log.trace('dxos.mesh.signal-rpc-client.constructor', trace.begin({ id: traceId }));
|
|
63
|
+
constructor({ url, callbacks = {} }: SignalRPCClientProps) {
|
|
64
|
+
log('creating signal rpc client', { url });
|
|
67
65
|
this._url = url;
|
|
68
66
|
this._callbacks = callbacks;
|
|
69
67
|
this._socket = new WebSocket(this._url);
|
|
@@ -149,7 +147,7 @@ export class SignalRPCClient {
|
|
|
149
147
|
log.warn(`Socket ${event.type ?? 'unknown'} error`, { message: event.message, url: this._url });
|
|
150
148
|
};
|
|
151
149
|
|
|
152
|
-
log
|
|
150
|
+
log('created signal rpc client', { url });
|
|
153
151
|
}
|
|
154
152
|
|
|
155
153
|
async close(): Promise<void> {
|