@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.
Files changed (71) hide show
  1. package/LICENSE +102 -5
  2. package/dist/lib/neutral/chunk-EC4H56J5.mjs +497 -0
  3. package/dist/lib/neutral/chunk-EC4H56J5.mjs.map +7 -0
  4. package/dist/lib/neutral/index.mjs +1249 -0
  5. package/dist/lib/neutral/index.mjs.map +7 -0
  6. package/dist/lib/neutral/meta.json +1 -0
  7. package/dist/lib/{browser → neutral}/testing/index.mjs +13 -12
  8. package/dist/lib/neutral/testing/index.mjs.map +7 -0
  9. package/dist/types/src/messenger-monitor.d.ts.map +1 -1
  10. package/dist/types/src/messenger.blueprint-test.d.ts +1 -1
  11. package/dist/types/src/messenger.blueprint-test.d.ts.map +1 -1
  12. package/dist/types/src/messenger.d.ts +4 -3
  13. package/dist/types/src/messenger.d.ts.map +1 -1
  14. package/dist/types/src/signal-client/signal-client-monitor.d.ts.map +1 -1
  15. package/dist/types/src/signal-client/signal-client.d.ts +7 -8
  16. package/dist/types/src/signal-client/signal-client.d.ts.map +1 -1
  17. package/dist/types/src/signal-client/signal-local-state.d.ts +1 -1
  18. package/dist/types/src/signal-client/signal-local-state.d.ts.map +1 -1
  19. package/dist/types/src/signal-client/signal-rpc-client-monitor.d.ts.map +1 -1
  20. package/dist/types/src/signal-client/signal-rpc-client.d.ts +3 -3
  21. package/dist/types/src/signal-client/signal-rpc-client.d.ts.map +1 -1
  22. package/dist/types/src/signal-manager/edge-signal-manager.d.ts +6 -6
  23. package/dist/types/src/signal-manager/edge-signal-manager.d.ts.map +1 -1
  24. package/dist/types/src/signal-manager/memory-signal-manager.d.ts +6 -5
  25. package/dist/types/src/signal-manager/memory-signal-manager.d.ts.map +1 -1
  26. package/dist/types/src/signal-manager/signal-manager.d.ts +1 -1
  27. package/dist/types/src/signal-manager/signal-manager.d.ts.map +1 -1
  28. package/dist/types/src/signal-manager/utils.d.ts.map +1 -1
  29. package/dist/types/src/signal-manager/websocket-signal-manager-monitor.d.ts.map +1 -1
  30. package/dist/types/src/signal-manager/websocket-signal-manager.d.ts +6 -7
  31. package/dist/types/src/signal-manager/websocket-signal-manager.d.ts.map +1 -1
  32. package/dist/types/src/signal-methods.d.ts +7 -7
  33. package/dist/types/src/signal-methods.d.ts.map +1 -1
  34. package/dist/types/src/testing/test-builder.d.ts +1 -1
  35. package/dist/types/src/testing/test-builder.d.ts.map +1 -1
  36. package/dist/types/src/testing/test-peer.d.ts +1 -1
  37. package/dist/types/src/testing/test-peer.d.ts.map +1 -1
  38. package/dist/types/src/testing/utils.d.ts +1 -1
  39. package/dist/types/src/testing/utils.d.ts.map +1 -1
  40. package/dist/types/tsconfig.tsbuildinfo +1 -1
  41. package/package.json +27 -30
  42. package/src/messenger.blueprint-test.ts +15 -14
  43. package/src/messenger.node.test.ts +7 -38
  44. package/src/messenger.ts +38 -33
  45. package/src/signal-client/signal-client.node.test.ts +12 -11
  46. package/src/signal-client/signal-client.ts +12 -15
  47. package/src/signal-client/signal-local-state.ts +3 -3
  48. package/src/signal-client/signal-rpc-client.node.test.ts +1 -1
  49. package/src/signal-client/signal-rpc-client.ts +7 -9
  50. package/src/signal-manager/edge-signal-manager.ts +31 -18
  51. package/src/signal-manager/memory-signal-manager.ts +18 -15
  52. package/src/signal-manager/signal-manager.ts +1 -1
  53. package/src/signal-manager/websocket-signal-manager.node.test.ts +15 -14
  54. package/src/signal-manager/websocket-signal-manager.ts +12 -18
  55. package/src/signal-methods.ts +8 -8
  56. package/src/testing/test-builder.ts +6 -4
  57. package/src/testing/test-peer.ts +2 -2
  58. package/src/testing/utils.ts +2 -2
  59. package/dist/lib/browser/chunk-QLQS7TUS.mjs +0 -2309
  60. package/dist/lib/browser/chunk-QLQS7TUS.mjs.map +0 -7
  61. package/dist/lib/browser/index.mjs +0 -22
  62. package/dist/lib/browser/index.mjs.map +0 -7
  63. package/dist/lib/browser/meta.json +0 -1
  64. package/dist/lib/browser/testing/index.mjs.map +0 -7
  65. package/dist/lib/node-esm/chunk-GIM3VIFP.mjs +0 -2309
  66. package/dist/lib/node-esm/chunk-GIM3VIFP.mjs.map +0 -7
  67. package/dist/lib/node-esm/index.mjs +0 -22
  68. package/dist/lib/node-esm/index.mjs.map +0 -7
  69. package/dist/lib/node-esm/meta.json +0 -1
  70. package/dist/lib/node-esm/testing/index.mjs +0 -143
  71. 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.b97322e",
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
- "license": "MIT",
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": true,
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
- "browser": "./dist/lib/browser/index.mjs",
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
- "browser": "./dist/lib/browser/testing/index.mjs",
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.14.2",
39
- "@dxos/async": "0.8.4-main.b97322e",
40
- "@dxos/codec-protobuf": "0.8.4-main.b97322e",
41
- "@dxos/context": "0.8.4-main.b97322e",
42
- "@dxos/edge-client": "0.8.4-main.b97322e",
43
- "@dxos/invariant": "0.8.4-main.b97322e",
44
- "@dxos/log": "0.8.4-main.b97322e",
45
- "@dxos/node-std": "0.8.4-main.b97322e",
46
- "@dxos/keys": "0.8.4-main.b97322e",
47
- "@dxos/protocols": "0.8.4-main.b97322e",
48
- "@dxos/tracing": "0.8.4-main.b97322e",
49
- "@dxos/util": "0.8.4-main.b97322e",
50
- "@dxos/rpc": "0.8.4-main.b97322e"
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.b97322e",
54
- "@dxos/signal": "0.8.4-main.b97322e",
55
- "@dxos/test-utils": "0.8.4-main.b97322e"
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, test, onTestFinished } from 'vitest';
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 { messageEqual, PAYLOAD_1, PAYLOAD_2, PAYLOAD_3, TestBuilder } from './testing';
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 { afterAll, onTestFinished, beforeAll, test, describe } from 'vitest';
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 { WebsocketSignalManager } from './signal-manager';
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 broker: SignalServerRunner;
17
-
18
- beforeAll(async () => {
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 WebsocketSignalManager([{ server: broker.url() }]));
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, trace } from '@dxos/protocols';
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 PeerInfo, type Message } from './signal-methods';
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
- const traceId = PublicKey.random().toHex();
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.trace('dxos.mesh.messenger.open', trace.end({ id: traceId }));
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
- author,
209
- recipient,
210
- reliablePayload,
211
- }: {
212
- author: PeerInfo;
213
- recipient: PeerInfo;
214
- reliablePayload: ReliablePayload;
215
- }): Promise<void> {
216
- await this._signalManager.sendMessage({
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
- author,
277
- recipient,
278
- messageId,
279
- }: {
280
- author: PeerInfo;
281
- recipient: PeerInfo;
282
- messageId: PublicKey;
283
- }): Promise<void> {
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, test, onTestFinished } from 'vitest';
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 { runTestSignalServer, type SignalServerRunner } from '@dxos/signal';
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, cancelWithContext, Resource } from '@dxos/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 QueryRequest, type JoinRequest, type LeaveRequest } from '@dxos/protocols/proto/dxos/edge/signal';
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.trace('dxos.mesh.signal-client.open', trace.begin({ id: this._instanceId }));
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.trace('dxos.mesh.signal-client.open', trace.end({ id: this._instanceId }));
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 { asyncTimeout, Event } from '@dxos/async';
5
+ import { Event, asyncTimeout } from '@dxos/async';
6
6
  import type { Stream } from '@dxos/codec-protobuf/stream';
7
- import { cancelWithContext, type Context } from '@dxos/context';
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 { runTestSignalServer, type SignalServerRunner } from '@dxos/signal';
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 { scheduleTaskInterval, TimeoutError, Trigger } from '@dxos/async';
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, type Signal } from '@dxos/protocols/proto/dxos/mesh/signal';
16
- import { createProtoRpcPeer, type ProtoRpcPeer } from '@dxos/rpc';
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 SignalRPCClientParams = {
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 = {} }: SignalRPCClientParams) {
65
- const traceId = PublicKey.random().toHex();
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.trace('dxos.mesh.signal-rpc-client.constructor', trace.end({ id: traceId }));
150
+ log('created signal rpc client', { url });
153
151
  }
154
152
 
155
153
  async close(): Promise<void> {