@dxos/network-manager 0.8.4-main.bc674ce → 0.8.4-main.bcb3aa67d6

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 (45) hide show
  1. package/dist/lib/browser/{chunk-AQSYW43M.mjs → chunk-WMCWASCJ.mjs} +76 -81
  2. package/dist/lib/browser/chunk-WMCWASCJ.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +1 -1
  4. package/dist/lib/browser/meta.json +1 -1
  5. package/dist/lib/browser/testing/index.mjs +17 -7
  6. package/dist/lib/browser/testing/index.mjs.map +3 -3
  7. package/dist/lib/node-esm/{chunk-SCX3PZRE.mjs → chunk-AL2EW6AJ.mjs} +76 -81
  8. package/dist/lib/node-esm/chunk-AL2EW6AJ.mjs.map +7 -0
  9. package/dist/lib/node-esm/index.mjs +1 -1
  10. package/dist/lib/node-esm/meta.json +1 -1
  11. package/dist/lib/node-esm/testing/index.mjs +17 -7
  12. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  13. package/dist/types/src/network-manager.d.ts +5 -4
  14. package/dist/types/src/network-manager.d.ts.map +1 -1
  15. package/dist/types/src/signal/signal-connection.d.ts +3 -2
  16. package/dist/types/src/signal/signal-connection.d.ts.map +1 -1
  17. package/dist/types/src/signal/signal-messenger.d.ts +3 -2
  18. package/dist/types/src/signal/signal-messenger.d.ts.map +1 -1
  19. package/dist/types/src/signal/swarm-messenger.d.ts +7 -7
  20. package/dist/types/src/signal/swarm-messenger.d.ts.map +1 -1
  21. package/dist/types/src/swarm/connection.d.ts +2 -1
  22. package/dist/types/src/swarm/connection.d.ts.map +1 -1
  23. package/dist/types/src/swarm/peer.d.ts +4 -3
  24. package/dist/types/src/swarm/peer.d.ts.map +1 -1
  25. package/dist/types/src/swarm/swarm.d.ts +3 -2
  26. package/dist/types/src/swarm/swarm.d.ts.map +1 -1
  27. package/dist/types/src/testing/test-builder.d.ts.map +1 -1
  28. package/dist/types/src/tests/property-test-suite.d.ts.map +1 -1
  29. package/dist/types/tsconfig.tsbuildinfo +1 -1
  30. package/package.json +18 -18
  31. package/src/network-manager.ts +19 -15
  32. package/src/signal/integration.node.test.ts +11 -10
  33. package/src/signal/signal-connection.ts +3 -2
  34. package/src/signal/signal-messenger.ts +3 -2
  35. package/src/signal/swarm-messenger.node.test.ts +25 -24
  36. package/src/signal/swarm-messenger.ts +65 -55
  37. package/src/swarm/connection.test.ts +6 -6
  38. package/src/swarm/connection.ts +5 -5
  39. package/src/swarm/peer.ts +5 -5
  40. package/src/swarm/swarm.test.ts +2 -2
  41. package/src/swarm/swarm.ts +9 -9
  42. package/src/testing/test-builder.ts +4 -3
  43. package/src/tests/property-test-suite.ts +4 -3
  44. package/dist/lib/browser/chunk-AQSYW43M.mjs.map +0 -7
  45. package/dist/lib/node-esm/chunk-SCX3PZRE.mjs.map +0 -7
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxos/network-manager",
3
- "version": "0.8.4-main.bc674ce",
3
+ "version": "0.8.4-main.bcb3aa67d6",
4
4
  "description": "Network Manager",
5
5
  "homepage": "https://dxos.org",
6
6
  "bugs": "https://github.com/dxos/dxos/issues",
@@ -81,26 +81,26 @@
81
81
  ],
82
82
  "dependencies": {
83
83
  "node-datachannel": "^0.30.0",
84
- "@dxos/async": "0.8.4-main.bc674ce",
85
- "@dxos/context": "0.8.4-main.bc674ce",
86
- "@dxos/debug": "0.8.4-main.bc674ce",
87
- "@dxos/codec-protobuf": "0.8.4-main.bc674ce",
88
- "@dxos/invariant": "0.8.4-main.bc674ce",
89
- "@dxos/log": "0.8.4-main.bc674ce",
90
- "@dxos/keys": "0.8.4-main.bc674ce",
91
- "@dxos/messaging": "0.8.4-main.bc674ce",
92
- "@dxos/protocols": "0.8.4-main.bc674ce",
93
- "@dxos/node-std": "0.8.4-main.bc674ce",
94
- "@dxos/rpc": "0.8.4-main.bc674ce",
95
- "@dxos/util": "0.8.4-main.bc674ce",
96
- "@dxos/tracing": "0.8.4-main.bc674ce",
97
- "@dxos/teleport": "0.8.4-main.bc674ce"
84
+ "@dxos/async": "0.8.4-main.bcb3aa67d6",
85
+ "@dxos/codec-protobuf": "0.8.4-main.bcb3aa67d6",
86
+ "@dxos/debug": "0.8.4-main.bcb3aa67d6",
87
+ "@dxos/invariant": "0.8.4-main.bcb3aa67d6",
88
+ "@dxos/context": "0.8.4-main.bcb3aa67d6",
89
+ "@dxos/keys": "0.8.4-main.bcb3aa67d6",
90
+ "@dxos/messaging": "0.8.4-main.bcb3aa67d6",
91
+ "@dxos/log": "0.8.4-main.bcb3aa67d6",
92
+ "@dxos/node-std": "0.8.4-main.bcb3aa67d6",
93
+ "@dxos/rpc": "0.8.4-main.bcb3aa67d6",
94
+ "@dxos/teleport": "0.8.4-main.bcb3aa67d6",
95
+ "@dxos/tracing": "0.8.4-main.bcb3aa67d6",
96
+ "@dxos/util": "0.8.4-main.bcb3aa67d6",
97
+ "@dxos/protocols": "0.8.4-main.bcb3aa67d6"
98
98
  },
99
99
  "devDependencies": {
100
100
  "fetch-mock": "^11.0.0",
101
- "@dxos/edge-client": "0.8.4-main.bc674ce",
102
- "@dxos/keyring": "0.8.4-main.bc674ce",
103
- "@dxos/signal": "0.8.4-main.bc674ce"
101
+ "@dxos/edge-client": "0.8.4-main.bcb3aa67d6",
102
+ "@dxos/keyring": "0.8.4-main.bcb3aa67d6",
103
+ "@dxos/signal": "0.8.4-main.bcb3aa67d6"
104
104
  },
105
105
  "publishConfig": {
106
106
  "access": "public"
@@ -3,6 +3,7 @@
3
3
  //
4
4
 
5
5
  import { Event, synchronized } from '@dxos/async';
6
+ import { Context } from '@dxos/context';
6
7
  import { invariant } from '@dxos/invariant';
7
8
  import { PublicKey } from '@dxos/keys';
8
9
  import { log } from '@dxos/log';
@@ -21,7 +22,7 @@ import { type WireProtocolProvider } from './wire-protocol';
21
22
  * Represents a single connection to a remote peer.
22
23
  */
23
24
  export type SwarmConnection = {
24
- close(): Promise<void>;
25
+ close(ctx: Context): Promise<void>;
25
26
  };
26
27
 
27
28
  // TODO(burdon): Add timeout.
@@ -91,8 +92,8 @@ export class SwarmNetworkManager {
91
92
  this._signalManager.swarmEvent.on((event) => this._swarms.get(event.topic)?.onSwarmEvent(event));
92
93
  this._messenger = new Messenger({ signalManager: this._signalManager });
93
94
  this._signalConnection = {
94
- join: (opts) => this._signalManager.join(opts),
95
- leave: (opts) => this._signalManager.leave(opts),
95
+ join: (ctx, opts) => this._signalManager.join(ctx, opts),
96
+ leave: (ctx, opts) => this._signalManager.leave(ctx, opts),
96
97
  };
97
98
  this._peerInfo = peerInfo;
98
99
 
@@ -136,9 +137,9 @@ export class SwarmNetworkManager {
136
137
  log.trace('dxos.mesh.network-manager.open', trace.end({ id: this._instanceId }));
137
138
  }
138
139
 
139
- async close(): Promise<void> {
140
+ async close(ctx: Context): Promise<void> {
140
141
  for (const topic of this._swarms.keys()) {
141
- await this.leaveSwarm(topic).catch((err) => {
142
+ await this.leaveSwarm(ctx, topic).catch((err) => {
142
143
  log(err);
143
144
  });
144
145
  }
@@ -151,12 +152,15 @@ export class SwarmNetworkManager {
151
152
  * Join the swarm.
152
153
  */
153
154
  @synchronized
154
- async joinSwarm({
155
- topic, //
156
- topology,
157
- protocolProvider: protocol,
158
- label,
159
- }: SwarmOptions): Promise<SwarmConnection> {
155
+ async joinSwarm(
156
+ ctx: Context,
157
+ {
158
+ topic, //
159
+ topology,
160
+ protocolProvider: protocol,
161
+ label,
162
+ }: SwarmOptions,
163
+ ): Promise<SwarmConnection> {
160
164
  invariant(PublicKey.isPublicKey(topic));
161
165
  invariant(topology);
162
166
  invariant(this._peerInfo);
@@ -187,14 +191,14 @@ export class SwarmNetworkManager {
187
191
  // Open before joining.
188
192
  await swarm.open();
189
193
 
190
- this._signalConnection.join({ topic, peer: this._peerInfo }).catch((error) => log.catch(error));
194
+ this._signalConnection.join(ctx, { topic, peer: this._peerInfo }).catch((error) => log.catch(error));
191
195
 
192
196
  this.topicsUpdated.emit();
193
197
  this._connectionLog?.joinedSwarm(swarm);
194
198
  log('joined', { topic: PublicKey.from(topic), count: this._swarms.size });
195
199
 
196
200
  return {
197
- close: () => this.leaveSwarm(topic),
201
+ close: (ctx: Context) => this.leaveSwarm(ctx, topic),
198
202
  };
199
203
  }
200
204
 
@@ -202,7 +206,7 @@ export class SwarmNetworkManager {
202
206
  * Close the connection.
203
207
  */
204
208
  @synchronized
205
- async leaveSwarm(topic: PublicKey): Promise<void> {
209
+ async leaveSwarm(ctx: Context, topic: PublicKey): Promise<void> {
206
210
  if (!this._swarms.has(topic)) {
207
211
  // log.warn('swarm not open', { topic: PublicKey.from(topic).truncate() });
208
212
  return;
@@ -210,7 +214,7 @@ export class SwarmNetworkManager {
210
214
 
211
215
  log('leaving', { topic: PublicKey.from(topic) });
212
216
  const swarm = this._swarms.get(topic)!;
213
- await this._signalConnection.leave({ topic, peer: swarm.ownPeer });
217
+ await this._signalConnection.leave(ctx, { topic, peer: swarm.ownPeer });
214
218
 
215
219
  const map = this._mappers.get(topic)!;
216
220
  map.destroy();
@@ -4,6 +4,7 @@
4
4
 
5
5
  import { afterAll, beforeAll, describe, expect, onTestFinished, test } from 'vitest';
6
6
 
7
+ import { Context } from '@dxos/context';
7
8
  import { PublicKey } from '@dxos/keys';
8
9
  import { Messenger, type PeerInfo, WebsocketSignalManager } from '@dxos/messaging';
9
10
  import { type SignalServerRunner, runTestSignalServer } from '@dxos/signal';
@@ -42,17 +43,17 @@ describe('Signal Integration Test', () => {
42
43
  onTestFinished(() => messenger.close());
43
44
  await messenger.listen({
44
45
  peer,
45
- onMessage: async (message) => await messageRouter.receiveMessage(message),
46
+ onMessage: async (message) => await messageRouter.receiveMessage(Context.default(), message),
46
47
  });
47
48
 
48
49
  const receivedSignals: SignalMessage[] = [];
49
- const signalMock = async (msg: SignalMessage) => {
50
+ const signalMock = async (_ctx: Context, msg: SignalMessage) => {
50
51
  receivedSignals.push(msg);
51
52
  };
52
53
  const messageRouter = new SwarmMessenger({
53
- sendMessage: messenger.sendMessage.bind(messenger),
54
+ sendMessage: (ctx, message) => messenger.sendMessage(ctx, message),
54
55
  onSignal: signalMock,
55
- onOffer: async () => ({ accept: true }),
56
+ onOffer: async (_ctx) => ({ accept: true }),
56
57
  topic,
57
58
  });
58
59
 
@@ -78,14 +79,14 @@ describe('Signal Integration Test', () => {
78
79
  ({ peerAvailable }) => !!peerAvailable && peerNetworking1.peer.peerKey === peerAvailable.peer.peerKey,
79
80
  );
80
81
 
81
- await peerNetworking1.signalManager.join({ topic, peer: peerNetworking1.peer });
82
- await peerNetworking2.signalManager.join({ topic, peer: peerNetworking2.peer });
82
+ await peerNetworking1.signalManager.join(Context.default(), { topic, peer: peerNetworking1.peer });
83
+ await peerNetworking2.signalManager.join(Context.default(), { topic, peer: peerNetworking2.peer });
83
84
 
84
85
  await promise1;
85
86
  await promise2;
86
87
 
87
88
  expect(
88
- await peerNetworking1.messageRouter.offer({
89
+ await peerNetworking1.messageRouter.offer(Context.default(), {
89
90
  topic,
90
91
  author: peerNetworking1.peer,
91
92
  recipient: peerNetworking2.peer,
@@ -97,7 +98,7 @@ describe('Signal Integration Test', () => {
97
98
  ).toEqual(expect.objectContaining({ accept: true }));
98
99
 
99
100
  expect(
100
- await peerNetworking2.messageRouter.offer({
101
+ await peerNetworking2.messageRouter.offer(Context.default(), {
101
102
  topic,
102
103
  author: peerNetworking2.peer,
103
104
  recipient: peerNetworking1.peer,
@@ -119,7 +120,7 @@ describe('Signal Integration Test', () => {
119
120
  signalBatch: undefined,
120
121
  },
121
122
  };
122
- await peerNetworking1.messageRouter.signal(message);
123
+ await peerNetworking1.messageRouter.signal(Context.default(), message);
123
124
 
124
125
  await expect.poll(() => peerNetworking2.receivedSignals[0]).toEqual(expect.objectContaining(message));
125
126
  }
@@ -135,7 +136,7 @@ describe('Signal Integration Test', () => {
135
136
  signalBatch: undefined,
136
137
  },
137
138
  };
138
- await peerNetworking2.messageRouter.signal(message);
139
+ await peerNetworking2.messageRouter.signal(Context.default(), message);
139
140
 
140
141
  await expect.poll(() => peerNetworking1.receivedSignals[0]).toEqual(expect.objectContaining(message));
141
142
  }
@@ -2,6 +2,7 @@
2
2
  // Copyright 2020 DXOS.org
3
3
  //
4
4
 
5
+ import { type Context } from '@dxos/context';
5
6
  import { type PublicKey } from '@dxos/keys';
6
7
  import { type PeerInfo } from '@dxos/messaging';
7
8
 
@@ -12,10 +13,10 @@ export interface SignalConnection {
12
13
  /**
13
14
  * Join topic on signal network, to be discoverable by other peers.
14
15
  */
15
- join(params: { topic: PublicKey; peer: PeerInfo }): Promise<void>;
16
+ join(ctx: Context, params: { topic: PublicKey; peer: PeerInfo }): Promise<void>;
16
17
 
17
18
  /**
18
19
  * Leave topic on signal network, to stop being discoverable by other peers.
19
20
  */
20
- leave(params: { topic: PublicKey; peer: PeerInfo }): Promise<void>;
21
+ leave(ctx: Context, params: { topic: PublicKey; peer: PeerInfo }): Promise<void>;
21
22
  }
@@ -2,6 +2,7 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
+ import { Context } from '@dxos/context';
5
6
  import { type PublicKey } from '@dxos/keys';
6
7
  import { type PeerInfo } from '@dxos/messaging';
7
8
  import { type Answer, type Offer, type Signal, type SignalBatch } from '@dxos/protocols/proto/dxos/mesh/swarm';
@@ -29,10 +30,10 @@ export interface SignalMessenger {
29
30
  /**
30
31
  * Offer/answer RPC.
31
32
  */
32
- offer(msg: OfferMessage): Promise<Answer>;
33
+ offer(ctx: Context, msg: OfferMessage): Promise<Answer>;
33
34
 
34
35
  /**
35
36
  * Reliably send a signal to a peer.
36
37
  */
37
- signal(msg: SignalMessage): Promise<void>;
38
+ signal(ctx: Context, msg: SignalMessage): Promise<void>;
38
39
  }
@@ -5,6 +5,7 @@
5
5
  import { afterAll, beforeAll, beforeEach, describe, expect, onTestFinished, test } from 'vitest';
6
6
 
7
7
  import { type Awaited } from '@dxos/async';
8
+ import { Context } from '@dxos/context';
8
9
  import { PublicKey } from '@dxos/keys';
9
10
  import { Messenger, WebsocketSignalManager } from '@dxos/messaging';
10
11
  import { type Answer } from '@dxos/protocols/proto/dxos/mesh/swarm';
@@ -37,8 +38,8 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
37
38
  topic,
38
39
  }: {
39
40
  signalApiUrl: string;
40
- onSignal?: (msg: SignalMessage) => Promise<void>;
41
- onOffer?: (msg: OfferMessage) => Promise<Answer>;
41
+ onSignal?: (ctx: Context, msg: SignalMessage) => Promise<void>;
42
+ onOffer?: (ctx: Context, msg: OfferMessage) => Promise<Answer>;
42
43
  topic: PublicKey;
43
44
  }) => {
44
45
  const peer = { peerKey: PublicKey.random().toHex() };
@@ -52,12 +53,12 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
52
53
  await messenger.listen({
53
54
  peer,
54
55
  payloadType: 'dxos.mesh.swarm.SwarmMessage',
55
- onMessage: async (message) => await router.receiveMessage(message),
56
+ onMessage: async (message) => await router.receiveMessage(Context.default(), message),
56
57
  });
57
58
 
58
59
  const router: SwarmMessenger = new SwarmMessenger({
59
60
  // todo(mykola): added catch to avoid not finished request.
60
- sendMessage: async (message) => await messenger.sendMessage(message),
61
+ sendMessage: async (ctx, message) => await messenger.sendMessage(ctx, message),
61
62
  onSignal,
62
63
  onOffer,
63
64
  topic,
@@ -72,7 +73,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
72
73
 
73
74
  test('signaling between 2 clients', async () => {
74
75
  const received: SignalMessage[] = [];
75
- const signalMock1 = async (msg: SignalMessage) => {
76
+ const signalMock1 = async (_ctx: Context, msg: SignalMessage) => {
76
77
  received.push(msg);
77
78
  };
78
79
  const { signalManager: signalManager1, peer: peer1 } = await createSignalClientAndMessageRouter({
@@ -89,8 +90,8 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
89
90
  topic,
90
91
  });
91
92
 
92
- await signalManager1.join({ topic, peer: peer1 });
93
- await signalManager2.join({ topic, peer: peer2 });
93
+ await signalManager1.join(Context.default(), { topic, peer: peer1 });
94
+ await signalManager2.join(Context.default(), { topic, peer: peer2 });
94
95
 
95
96
  const msg: SignalMessage = {
96
97
  author: peer2,
@@ -102,7 +103,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
102
103
  signalBatch: undefined,
103
104
  },
104
105
  };
105
- await router2.signal(msg);
106
+ await router2.signal(Context.default(), msg);
106
107
 
107
108
  await expect.poll(() => received[0]).toEqual(expect.objectContaining(msg));
108
109
  });
@@ -125,9 +126,9 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
125
126
  topic,
126
127
  });
127
128
 
128
- await signalManager1.join({ topic, peer: peer1 });
129
- await signalManager2.join({ topic, peer: peer2 });
130
- const answer = await router1.offer({
129
+ await signalManager1.join(Context.default(), { topic, peer: peer1 });
130
+ await signalManager2.join(Context.default(), { topic, peer: peer2 });
131
+ const answer = await router1.offer(Context.default(), {
131
132
  author: peer1,
132
133
  recipient: peer2,
133
134
  sessionId: PublicKey.random(),
@@ -139,7 +140,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
139
140
 
140
141
  test('signaling between 3 clients', async () => {
141
142
  const received1: SignalMessage[] = [];
142
- const signalMock1 = async (msg: SignalMessage) => {
143
+ const signalMock1 = async (_ctx: Context, msg: SignalMessage) => {
143
144
  received1.push(msg);
144
145
  };
145
146
  const {
@@ -153,7 +154,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
153
154
  topic,
154
155
  });
155
156
  const received2: SignalMessage[] = [];
156
- const signalMock2 = async (msg: SignalMessage) => {
157
+ const signalMock2 = async (_ctx: Context, msg: SignalMessage) => {
157
158
  received2.push(msg);
158
159
  };
159
160
  const {
@@ -167,7 +168,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
167
168
  topic,
168
169
  });
169
170
  const received3: SignalMessage[] = [];
170
- const signalMock3 = async (msg: SignalMessage) => {
171
+ const signalMock3 = async (_ctx: Context, msg: SignalMessage) => {
171
172
  received3.push(msg);
172
173
  };
173
174
  const {
@@ -181,9 +182,9 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
181
182
  topic,
182
183
  });
183
184
 
184
- await signalManager1.join({ topic, peer: peer1 });
185
- await signalManager2.join({ topic, peer: peer2 });
186
- await signalManager3.join({ topic, peer: peer3 });
185
+ await signalManager1.join(Context.default(), { topic, peer: peer1 });
186
+ await signalManager2.join(Context.default(), { topic, peer: peer2 });
187
+ await signalManager3.join(Context.default(), { topic, peer: peer3 });
187
188
 
188
189
  // sending signal from peer1 to peer3.
189
190
  const msg1to3: SignalMessage = {
@@ -193,7 +194,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
193
194
  topic,
194
195
  data: { signal: { payload: { msg: '1to3' } }, signalBatch: undefined },
195
196
  };
196
- await router1.signal(msg1to3);
197
+ await router1.signal(Context.default(), msg1to3);
197
198
  await expect.poll(() => received3[0]).toEqual(expect.objectContaining(msg1to3));
198
199
 
199
200
  // sending signal from peer2 to peer3.
@@ -204,7 +205,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
204
205
  topic,
205
206
  data: { signal: { payload: { msg: '2to3' } }, signalBatch: undefined },
206
207
  };
207
- await router2.signal(msg2to3);
208
+ await router2.signal(Context.default(), msg2to3);
208
209
  await expect.poll(() => received3[1]).toEqual(expect.objectContaining(msg2to3));
209
210
 
210
211
  // sending signal from peer3 to peer1.
@@ -215,7 +216,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
215
216
  topic,
216
217
  data: { signal: { payload: { msg: '3to1' } }, signalBatch: undefined },
217
218
  };
218
- await router3.signal(msg3to1);
219
+ await router3.signal(Context.default(), msg3to1);
219
220
  await expect.poll(() => received1[0]).toEqual(expect.objectContaining(msg3to1));
220
221
  });
221
222
 
@@ -241,11 +242,11 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
241
242
  topic,
242
243
  });
243
244
 
244
- await signalManager1.join({ topic, peer: peer1 });
245
- await signalManager2.join({ topic, peer: peer2 });
245
+ await signalManager1.join(Context.default(), { topic, peer: peer1 });
246
+ await signalManager2.join(Context.default(), { topic, peer: peer2 });
246
247
 
247
248
  // sending offer from peer1 to peer2.
248
- const answer1 = await router1.offer({
249
+ const answer1 = await router1.offer(Context.default(), {
249
250
  author: peer1,
250
251
  recipient: peer2,
251
252
  sessionId: PublicKey.random(),
@@ -255,7 +256,7 @@ describe('SwarmMessenger', { timeout: 7000 }, () => {
255
256
  expect(answer1.accept).toEqual(true);
256
257
 
257
258
  // sending offer from peer2 to peer1.
258
- const answer2 = await router2.offer({
259
+ const answer2 = await router2.offer(Context.default(), {
259
260
  author: peer2,
260
261
  recipient: peer1,
261
262
  sessionId: PublicKey.random(),
@@ -20,9 +20,9 @@ interface OfferRecord {
20
20
  }
21
21
 
22
22
  export type SwarmMessengerOptions = {
23
- sendMessage: (params: Message) => Promise<void>;
24
- onOffer: (message: OfferMessage) => Promise<Answer>;
25
- onSignal: (message: SignalMessage) => Promise<void>;
23
+ sendMessage: (ctx: Context, params: Message) => Promise<void>;
24
+ onOffer: (ctx: Context, message: OfferMessage) => Promise<Answer>;
25
+ onSignal: (ctx: Context, message: SignalMessage) => Promise<void>;
26
26
  topic: PublicKey;
27
27
  };
28
28
 
@@ -32,11 +32,9 @@ const SwarmMessage = schema.getCodecForType('dxos.mesh.swarm.SwarmMessage');
32
32
  * Adds offer/answer and signal interfaces.
33
33
  */
34
34
  export class SwarmMessenger implements SignalMessenger {
35
- private readonly _ctx = new Context();
36
-
37
- private readonly _sendMessage: (msg: Message) => Promise<void>;
38
- private readonly _onSignal: (message: SignalMessage) => Promise<void>;
39
- private readonly _onOffer: (message: OfferMessage) => Promise<Answer>;
35
+ private readonly _sendMessage: SwarmMessengerOptions['sendMessage'];
36
+ private readonly _onSignal: SwarmMessengerOptions['onSignal'];
37
+ private readonly _onOffer: SwarmMessengerOptions['onOffer'];
40
38
  private readonly _topic: PublicKey;
41
39
 
42
40
  private readonly _offerRecords: ComplexMap<PublicKey, OfferRecord> = new ComplexMap((key) => key.toHex());
@@ -48,15 +46,18 @@ export class SwarmMessenger implements SignalMessenger {
48
46
  this._topic = topic;
49
47
  }
50
48
 
51
- async receiveMessage({
52
- author,
53
- recipient,
54
- payload,
55
- }: {
56
- author: PeerInfo;
57
- recipient: PeerInfo;
58
- payload: Any;
59
- }): Promise<void> {
49
+ async receiveMessage(
50
+ ctx: Context,
51
+ {
52
+ author,
53
+ recipient,
54
+ payload,
55
+ }: {
56
+ author: PeerInfo;
57
+ recipient: PeerInfo;
58
+ payload: Any;
59
+ },
60
+ ): Promise<void> {
60
61
  if (payload.type_url !== 'dxos.mesh.swarm.SwarmMessage') {
61
62
  // Ignore not swarm messages.
62
63
  return;
@@ -71,35 +72,35 @@ export class SwarmMessenger implements SignalMessenger {
71
72
  log('received', { from: author, to: recipient, msg: message });
72
73
 
73
74
  if (message.data?.offer) {
74
- await this._handleOffer({ author, recipient, message });
75
+ await this._handleOffer(ctx, { author, recipient, message });
75
76
  } else if (message.data?.answer) {
76
77
  await this._resolveAnswers(message);
77
78
  } else if (message.data?.signal) {
78
- await this._handleSignal({ author, recipient, message });
79
+ await this._handleSignal(ctx, { author, recipient, message });
79
80
  } else if (message.data?.signalBatch) {
80
- await this._handleSignal({ author, recipient, message });
81
+ await this._handleSignal(ctx, { author, recipient, message });
81
82
  } else {
82
83
  log.warn('unknown message', { message });
83
84
  }
84
85
  }
85
86
 
86
- async signal(message: SignalMessage): Promise<void> {
87
+ async signal(ctx: Context, message: SignalMessage): Promise<void> {
87
88
  invariant(message.data?.signal || message.data?.signalBatch, 'Invalid message');
88
- await this._sendReliableMessage({
89
+ await this._sendReliableMessage(ctx, {
89
90
  author: message.author,
90
91
  recipient: message.recipient,
91
92
  message,
92
93
  });
93
94
  }
94
95
 
95
- async offer(message: OfferMessage): Promise<Answer> {
96
+ async offer(ctx: Context, message: OfferMessage): Promise<Answer> {
96
97
  const networkMessage: SwarmMessage = {
97
98
  ...message,
98
99
  messageId: PublicKey.random(),
99
100
  };
100
101
  return new Promise<Answer>((resolve, reject) => {
101
102
  this._offerRecords.set(networkMessage.messageId!, { resolve });
102
- this._sendReliableMessage({
103
+ this._sendReliableMessage(ctx, {
103
104
  author: message.author,
104
105
  recipient: message.recipient,
105
106
  message: networkMessage,
@@ -107,15 +108,18 @@ export class SwarmMessenger implements SignalMessenger {
107
108
  });
108
109
  }
109
110
 
110
- private async _sendReliableMessage({
111
- author,
112
- recipient,
113
- message,
114
- }: {
115
- author: PeerInfo;
116
- recipient: PeerInfo;
117
- message: MakeOptional<SwarmMessage, 'messageId'>;
118
- }): Promise<void> {
111
+ private async _sendReliableMessage(
112
+ ctx: Context,
113
+ {
114
+ author,
115
+ recipient,
116
+ message,
117
+ }: {
118
+ author: PeerInfo;
119
+ recipient: PeerInfo;
120
+ message: MakeOptional<SwarmMessage, 'messageId'>;
121
+ },
122
+ ): Promise<void> {
119
123
  const networkMessage: SwarmMessage = {
120
124
  ...message,
121
125
  // Setting unique message_id if it not specified yet.
@@ -123,7 +127,7 @@ export class SwarmMessenger implements SignalMessenger {
123
127
  };
124
128
 
125
129
  log('sending', { from: author, to: recipient, msg: networkMessage });
126
- await this._sendMessage({
130
+ await this._sendMessage(ctx, {
127
131
  author,
128
132
  recipient,
129
133
  payload: {
@@ -144,15 +148,18 @@ export class SwarmMessenger implements SignalMessenger {
144
148
  }
145
149
  }
146
150
 
147
- private async _handleOffer({
148
- author,
149
- recipient,
150
- message,
151
- }: {
152
- author: PeerInfo;
153
- recipient: PeerInfo;
154
- message: SwarmMessage;
155
- }): Promise<void> {
151
+ private async _handleOffer(
152
+ ctx: Context,
153
+ {
154
+ author,
155
+ recipient,
156
+ message,
157
+ }: {
158
+ author: PeerInfo;
159
+ recipient: PeerInfo;
160
+ message: SwarmMessage;
161
+ },
162
+ ): Promise<void> {
156
163
  invariant(message.data.offer, 'No offer');
157
164
  const offerMessage: OfferMessage = {
158
165
  author,
@@ -160,10 +167,10 @@ export class SwarmMessenger implements SignalMessenger {
160
167
  ...message,
161
168
  data: { offer: message.data.offer },
162
169
  };
163
- const answer = await this._onOffer(offerMessage);
170
+ const answer = await this._onOffer(ctx, offerMessage);
164
171
  answer.offerMessageId = message.messageId;
165
172
  try {
166
- await this._sendReliableMessage({
173
+ await this._sendReliableMessage(ctx, {
167
174
  author: recipient,
168
175
  recipient: author,
169
176
  message: {
@@ -181,15 +188,18 @@ export class SwarmMessenger implements SignalMessenger {
181
188
  }
182
189
  }
183
190
 
184
- private async _handleSignal({
185
- author,
186
- recipient,
187
- message,
188
- }: {
189
- author: PeerInfo;
190
- recipient: PeerInfo;
191
- message: SwarmMessage;
192
- }): Promise<void> {
191
+ private async _handleSignal(
192
+ ctx: Context,
193
+ {
194
+ author,
195
+ recipient,
196
+ message,
197
+ }: {
198
+ author: PeerInfo;
199
+ recipient: PeerInfo;
200
+ message: SwarmMessage;
201
+ },
202
+ ): Promise<void> {
193
203
  invariant(message.messageId);
194
204
  invariant(message.data.signal || message.data.signalBatch, 'Invalid message');
195
205
  const signalMessage: SignalMessage = {
@@ -202,6 +212,6 @@ export class SwarmMessenger implements SignalMessenger {
202
212
  },
203
213
  };
204
214
 
205
- await this._onSignal(signalMessage);
215
+ await this._onSignal(ctx, signalMessage);
206
216
  }
207
217
  }
@@ -44,9 +44,9 @@ describe.skip('Connection', () => {
44
44
  sessionId,
45
45
  true,
46
46
  {
47
- offer: async (msg) => ({ accept: true }),
48
- signal: async (msg) => {
49
- await fastConnection.signal(msg);
47
+ offer: async (_ctx, _msg) => ({ accept: true }),
48
+ signal: async (ctx, msg) => {
49
+ await fastConnection.signal(ctx, msg);
50
50
  },
51
51
  },
52
52
  slowPeerProtocol.factory({
@@ -66,9 +66,9 @@ describe.skip('Connection', () => {
66
66
  sessionId,
67
67
  false,
68
68
  {
69
- offer: async (msg) => ({ accept: true }),
70
- signal: async (msg) => {
71
- await slowConnection.signal(msg);
69
+ offer: async (_ctx, _msg) => ({ accept: true }),
70
+ signal: async (ctx, msg) => {
71
+ await slowConnection.signal(ctx, msg);
72
72
  },
73
73
  },
74
74
  fastPeerProtocol.factory({