@dxos/network-manager 0.8.4-main.dedc0f3 → 0.8.4-main.e00bdcdb52

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 (99) hide show
  1. package/dist/lib/browser/{chunk-VAQETEB2.mjs → chunk-LRGOUKHO.mjs} +697 -2383
  2. package/dist/lib/browser/chunk-LRGOUKHO.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +198 -4
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +88 -140
  7. package/dist/lib/browser/testing/index.mjs.map +3 -3
  8. package/dist/lib/browser/transport/tcp/index.mjs +2 -48
  9. package/dist/lib/browser/transport/tcp/index.mjs.map +4 -4
  10. package/dist/lib/browser/transport/tcp/tcp-transport.browser.mjs +36 -0
  11. package/dist/lib/browser/transport/tcp/tcp-transport.browser.mjs.map +7 -0
  12. package/dist/lib/browser/transport/tcp/tcp-transport.mjs +125 -0
  13. package/dist/lib/browser/transport/tcp/tcp-transport.mjs.map +7 -0
  14. package/dist/lib/node-esm/{chunk-RAHYLU4N.mjs → chunk-E6G6B72R.mjs} +697 -2383
  15. package/dist/lib/node-esm/chunk-E6G6B72R.mjs.map +7 -0
  16. package/dist/lib/node-esm/index.mjs +198 -4
  17. package/dist/lib/node-esm/index.mjs.map +4 -4
  18. package/dist/lib/node-esm/meta.json +1 -1
  19. package/dist/lib/node-esm/testing/index.mjs +88 -140
  20. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  21. package/dist/lib/node-esm/transport/tcp/index.mjs +2 -177
  22. package/dist/lib/node-esm/transport/tcp/index.mjs.map +4 -4
  23. package/dist/lib/node-esm/transport/tcp/tcp-transport.browser.mjs +36 -0
  24. package/dist/lib/node-esm/transport/tcp/tcp-transport.browser.mjs.map +7 -0
  25. package/dist/lib/node-esm/transport/tcp/tcp-transport.mjs +125 -0
  26. package/dist/lib/node-esm/transport/tcp/tcp-transport.mjs.map +7 -0
  27. package/dist/types/src/connection-log.d.ts.map +1 -1
  28. package/dist/types/src/network-manager.d.ts +6 -6
  29. package/dist/types/src/network-manager.d.ts.map +1 -1
  30. package/dist/types/src/signal/ice.d.ts.map +1 -1
  31. package/dist/types/src/signal/signal-connection.d.ts +3 -2
  32. package/dist/types/src/signal/signal-connection.d.ts.map +1 -1
  33. package/dist/types/src/signal/signal-messenger.d.ts +3 -2
  34. package/dist/types/src/signal/signal-messenger.d.ts.map +1 -1
  35. package/dist/types/src/signal/swarm-messenger.d.ts +7 -7
  36. package/dist/types/src/signal/swarm-messenger.d.ts.map +1 -1
  37. package/dist/types/src/swarm/connection-limiter.d.ts.map +1 -1
  38. package/dist/types/src/swarm/connection.d.ts +2 -2
  39. package/dist/types/src/swarm/connection.d.ts.map +1 -1
  40. package/dist/types/src/swarm/peer.d.ts +4 -3
  41. package/dist/types/src/swarm/peer.d.ts.map +1 -1
  42. package/dist/types/src/swarm/swarm-mapper.d.ts.map +1 -1
  43. package/dist/types/src/swarm/swarm.d.ts +3 -5
  44. package/dist/types/src/swarm/swarm.d.ts.map +1 -1
  45. package/dist/types/src/testing/test-builder.d.ts.map +1 -1
  46. package/dist/types/src/testing/test-wire-protocol.d.ts.map +1 -1
  47. package/dist/types/src/tests/basic-test-suite.d.ts.map +1 -1
  48. package/dist/types/src/tests/property-test-suite.d.ts.map +1 -1
  49. package/dist/types/src/tests/utils.d.ts.map +1 -1
  50. package/dist/types/src/topology/fully-connected-topology.d.ts.map +1 -1
  51. package/dist/types/src/topology/mmst-topology.d.ts.map +1 -1
  52. package/dist/types/src/topology/star-topology.d.ts.map +1 -1
  53. package/dist/types/src/transport/memory-transport.d.ts.map +1 -1
  54. package/dist/types/src/transport/tcp/index.d.ts +1 -1
  55. package/dist/types/src/transport/tcp/index.d.ts.map +1 -1
  56. package/dist/types/src/transport/tcp/tcp-transport.browser.d.ts.map +1 -1
  57. package/dist/types/src/transport/tcp/tcp-transport.d.ts.map +1 -1
  58. package/dist/types/src/transport/webrtc/rtc-peer-connection.d.ts +4 -4
  59. package/dist/types/src/transport/webrtc/rtc-peer-connection.d.ts.map +1 -1
  60. package/dist/types/src/transport/webrtc/rtc-transport-channel.d.ts.map +1 -1
  61. package/dist/types/src/transport/webrtc/rtc-transport-factory.d.ts.map +1 -1
  62. package/dist/types/src/transport/webrtc/rtc-transport-proxy.d.ts.map +1 -1
  63. package/dist/types/src/transport/webrtc/rtc-transport-service.d.ts.map +1 -1
  64. package/dist/types/src/transport/webrtc/rtc-transport-stats.d.ts.map +1 -1
  65. package/dist/types/src/transport/webrtc/test-utils.d.ts.map +1 -1
  66. package/dist/types/src/transport/webrtc/utils.d.ts.map +1 -1
  67. package/dist/types/src/wire-protocol.d.ts +5 -5
  68. package/dist/types/src/wire-protocol.d.ts.map +1 -1
  69. package/dist/types/tsconfig.tsbuildinfo +1 -1
  70. package/package.json +33 -43
  71. package/src/network-manager.ts +21 -19
  72. package/src/signal/integration.node.test.ts +11 -10
  73. package/src/signal/signal-connection.ts +3 -2
  74. package/src/signal/signal-messenger.ts +3 -2
  75. package/src/signal/swarm-messenger.node.test.ts +25 -24
  76. package/src/signal/swarm-messenger.ts +65 -55
  77. package/src/swarm/connection.test.ts +8 -8
  78. package/src/swarm/connection.ts +15 -22
  79. package/src/swarm/peer.ts +7 -7
  80. package/src/swarm/swarm.test.ts +4 -4
  81. package/src/swarm/swarm.ts +10 -17
  82. package/src/testing/test-builder.ts +4 -4
  83. package/src/tests/basic-test-suite.ts +0 -1
  84. package/src/tests/memory-transport.test.ts +0 -2
  85. package/src/tests/property-test-suite.ts +4 -3
  86. package/src/tests/tcp-transport.node.test.ts +0 -2
  87. package/src/tests/webrtc-transport.test.ts +4 -3
  88. package/src/transport/tcp/index.ts +1 -1
  89. package/src/transport/webrtc/rtc-peer-connection.ts +1 -2
  90. package/src/transport/webrtc/rtc-transport-channel.test.ts +0 -2
  91. package/src/transport/webrtc/rtc-transport-channel.ts +1 -2
  92. package/src/transport/webrtc/rtc-transport-factory.ts +0 -1
  93. package/src/transport/webrtc/rtc-transport-proxy.test.ts +2 -3
  94. package/src/transport/webrtc/rtc-transport-proxy.ts +6 -4
  95. package/src/transport/webrtc/rtc-transport-service.ts +0 -1
  96. package/src/transport/webrtc/rtc-transport.test.ts +2 -2
  97. package/src/wire-protocol.ts +6 -6
  98. package/dist/lib/browser/chunk-VAQETEB2.mjs.map +0 -7
  99. package/dist/lib/node-esm/chunk-RAHYLU4N.mjs.map +0 -7
@@ -8,9 +8,10 @@ import {
8
8
  TransportKind,
9
9
  createRtcTransportFactory,
10
10
  createTeleportProtocolFactory
11
- } from "../chunk-RAHYLU4N.mjs";
11
+ } from "../chunk-E6G6B72R.mjs";
12
12
 
13
13
  // src/testing/test-builder.ts
14
+ import { Context } from "@dxos/context";
14
15
  import { PublicKey as PublicKey2 } from "@dxos/keys";
15
16
  import { log as log2 } from "@dxos/log";
16
17
  import { MemorySignalManager, MemorySignalManagerContext, WebsocketSignalManager } from "@dxos/messaging";
@@ -26,33 +27,54 @@ import { PublicKey } from "@dxos/keys";
26
27
  import { log } from "@dxos/log";
27
28
  import { TestExtension, TestExtensionWithStreams } from "@dxos/teleport";
28
29
  import { ComplexMap } from "@dxos/util";
29
- function _define_property(obj, key, value) {
30
- if (key in obj) {
31
- Object.defineProperty(obj, key, {
32
- value,
33
- enumerable: true,
34
- configurable: true,
35
- writable: true
36
- });
37
- } else {
38
- obj[key] = value;
39
- }
40
- return obj;
41
- }
42
30
  var __dxlog_file = "/__w/dxos/dxos/packages/core/mesh/network-manager/src/testing/test-wire-protocol.ts";
43
31
  var TestWireProtocol = class {
32
+ _extensionFactory;
33
+ connections = new ComplexMap(PublicKey.hash);
34
+ streamConnections = new ComplexMap(PublicKey.hash);
35
+ connected = new Event();
36
+ disconnected = new Event();
37
+ otherConnections = new ComplexMap(({ remotePeerId, extension }) => remotePeerId.toHex() + extension);
38
+ constructor(_extensionFactory = () => []) {
39
+ this._extensionFactory = _extensionFactory;
40
+ }
41
+ factory = createTeleportProtocolFactory(async (teleport) => {
42
+ log("create", {
43
+ remotePeerId: teleport.remotePeerId
44
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 21, S: this });
45
+ const handleDisconnect = () => {
46
+ this.connections.delete(teleport.remotePeerId);
47
+ this.disconnected.emit(teleport.remotePeerId);
48
+ };
49
+ const extension = new TestExtension({
50
+ onClose: async () => handleDisconnect(),
51
+ onAbort: async () => handleDisconnect()
52
+ });
53
+ this.connections.set(teleport.remotePeerId, extension);
54
+ teleport.addExtension("test", extension);
55
+ this.connected.emit(teleport.remotePeerId);
56
+ const streamExtension = new TestExtensionWithStreams({
57
+ onClose: async () => {
58
+ this.streamConnections.delete(teleport.remotePeerId);
59
+ }
60
+ });
61
+ this.streamConnections.set(teleport.remotePeerId, streamExtension);
62
+ teleport.addExtension("test-stream", streamExtension);
63
+ for (const { name, extension: extension2 } of this._extensionFactory()) {
64
+ this.otherConnections.set({
65
+ remotePeerId: teleport.remotePeerId,
66
+ extension: name
67
+ }, extension2);
68
+ teleport.addExtension(name, extension2);
69
+ }
70
+ });
44
71
  async waitForConnection(peerId) {
45
72
  if (this.connections.has(peerId)) {
46
73
  return this.connections.get(peerId);
47
74
  }
48
75
  log("waitForConnection", {
49
76
  peerId
50
- }, {
51
- F: __dxlog_file,
52
- L: 66,
53
- S: this,
54
- C: (f, a) => f(...a)
55
- });
77
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 54, S: this });
56
78
  await asyncTimeout(
57
79
  this.connected.waitFor((connectedId) => connectedId.equals(peerId)),
58
80
  // TODO(nf): Make this configurable.
@@ -78,72 +100,9 @@ var TestWireProtocol = class {
78
100
  const connection = this.streamConnections.get(peerId);
79
101
  return connection.closeStream(streamTag);
80
102
  }
81
- constructor(_extensionFactory = () => []) {
82
- _define_property(this, "_extensionFactory", void 0);
83
- _define_property(this, "connections", void 0);
84
- _define_property(this, "streamConnections", void 0);
85
- _define_property(this, "connected", void 0);
86
- _define_property(this, "disconnected", void 0);
87
- _define_property(this, "otherConnections", void 0);
88
- _define_property(this, "factory", void 0);
89
- this._extensionFactory = _extensionFactory;
90
- this.connections = new ComplexMap(PublicKey.hash);
91
- this.streamConnections = new ComplexMap(PublicKey.hash);
92
- this.connected = new Event();
93
- this.disconnected = new Event();
94
- this.otherConnections = new ComplexMap(({ remotePeerId, extension }) => remotePeerId.toHex() + extension);
95
- this.factory = createTeleportProtocolFactory(async (teleport) => {
96
- log("create", {
97
- remotePeerId: teleport.remotePeerId
98
- }, {
99
- F: __dxlog_file,
100
- L: 35,
101
- S: this,
102
- C: (f, a) => f(...a)
103
- });
104
- const handleDisconnect = () => {
105
- this.connections.delete(teleport.remotePeerId);
106
- this.disconnected.emit(teleport.remotePeerId);
107
- };
108
- const extension = new TestExtension({
109
- onClose: async () => handleDisconnect(),
110
- onAbort: async () => handleDisconnect()
111
- });
112
- this.connections.set(teleport.remotePeerId, extension);
113
- teleport.addExtension("test", extension);
114
- this.connected.emit(teleport.remotePeerId);
115
- const streamExtension = new TestExtensionWithStreams({
116
- onClose: async () => {
117
- this.streamConnections.delete(teleport.remotePeerId);
118
- }
119
- });
120
- this.streamConnections.set(teleport.remotePeerId, streamExtension);
121
- teleport.addExtension("test-stream", streamExtension);
122
- for (const { name, extension: extension2 } of this._extensionFactory()) {
123
- this.otherConnections.set({
124
- remotePeerId: teleport.remotePeerId,
125
- extension: name
126
- }, extension2);
127
- teleport.addExtension(name, extension2);
128
- }
129
- });
130
- }
131
103
  };
132
104
 
133
105
  // src/testing/test-builder.ts
134
- function _define_property2(obj, key, value) {
135
- if (key in obj) {
136
- Object.defineProperty(obj, key, {
137
- value,
138
- enumerable: true,
139
- configurable: true,
140
- writable: true
141
- });
142
- } else {
143
- obj[key] = value;
144
- }
145
- return obj;
146
- }
147
106
  var __dxlog_file2 = "/__w/dxos/dxos/packages/core/mesh/network-manager/src/testing/test-builder.ts";
148
107
  var port = process.env.SIGNAL_PORT ?? 4e3;
149
108
  var TEST_SIGNAL_HOSTS = [
@@ -152,6 +111,11 @@ var TEST_SIGNAL_HOSTS = [
152
111
  }
153
112
  ];
154
113
  var TestBuilder = class {
114
+ options;
115
+ _signalContext = new MemorySignalManagerContext();
116
+ constructor(options = {}) {
117
+ this.options = options;
118
+ }
155
119
  createSignalManager() {
156
120
  if (this.options.signalHosts) {
157
121
  return new WebsocketSignalManager(this.options.signalHosts);
@@ -161,24 +125,38 @@ var TestBuilder = class {
161
125
  createPeer(peerId = PublicKey2.random()) {
162
126
  return new TestPeer(this, peerId, this.options.transport);
163
127
  }
164
- constructor(options = {}) {
165
- _define_property2(this, "options", void 0);
166
- _define_property2(this, "_signalContext", void 0);
167
- this.options = options;
168
- this._signalContext = new MemorySignalManagerContext();
169
- }
170
128
  };
171
129
  var TestPeer = class {
130
+ testBuilder;
131
+ peerId;
132
+ transport;
133
+ _swarms = new ComplexMap2(PublicKey2.hash);
134
+ /**
135
+ * @internal
136
+ */
137
+ _signalManager;
138
+ /**
139
+ * @internal
140
+ */
141
+ _networkManager;
142
+ _proxy;
143
+ _service;
144
+ constructor(testBuilder, peerId, transport = testBuilder.options.signalHosts ? TransportKind.WEB_RTC : TransportKind.MEMORY) {
145
+ this.testBuilder = testBuilder;
146
+ this.peerId = peerId;
147
+ this.transport = transport;
148
+ this._signalManager = this.testBuilder.createSignalManager();
149
+ this._networkManager = this.createNetworkManager(this.transport);
150
+ this._networkManager.setPeerInfo({
151
+ identityKey: peerId.toHex(),
152
+ peerKey: peerId.toHex()
153
+ });
154
+ }
172
155
  // TODO(burdon): Move to TestBuilder.
173
156
  createNetworkManager(transport) {
174
157
  let transportFactory;
175
158
  if (this.testBuilder.options.signalHosts) {
176
- log2.info(`using ${transport} transport with signal server.`, void 0, {
177
- F: __dxlog_file2,
178
- L: 102,
179
- S: this,
180
- C: (f, a) => f(...a)
181
- });
159
+ log2.info(`using ${transport} transport with signal server.`, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 72, S: this });
182
160
  switch (transport) {
183
161
  case TransportKind.MEMORY:
184
162
  throw new Error("Memory transport not supported with signal server.");
@@ -222,19 +200,9 @@ var TestPeer = class {
222
200
  }
223
201
  } else {
224
202
  if (transport !== TransportKind.MEMORY && transport !== TransportKind.TCP) {
225
- log2.warn(`specified transport ${transport} but no signalling configured, using memory transport instead`, void 0, {
226
- F: __dxlog_file2,
227
- L: 148,
228
- S: this,
229
- C: (f, a) => f(...a)
230
- });
203
+ log2.warn(`specified transport ${transport} but no signalling configured, using memory transport instead`, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 117, S: this });
231
204
  }
232
- log2.info(`using ${transport} transport without signal server.`, void 0, {
233
- F: __dxlog_file2,
234
- L: 150,
235
- S: this,
236
- C: (f, a) => f(...a)
237
- });
205
+ log2.info(`using ${transport} transport without signal server.`, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 119, S: this });
238
206
  transportFactory = MemoryTransportFactory;
239
207
  }
240
208
  return new SwarmNetworkManager({
@@ -252,7 +220,7 @@ var TestPeer = class {
252
220
  this._swarms.clear();
253
221
  await this._proxy?.close();
254
222
  await this._service?.close();
255
- await this._networkManager.close();
223
+ await this._networkManager.close(Context.default(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 137 }));
256
224
  }
257
225
  getSwarm(topic) {
258
226
  const swarm = this._swarms.get(topic);
@@ -272,32 +240,22 @@ var TestPeer = class {
272
240
  async goOnline() {
273
241
  await this._networkManager.setConnectionState(ConnectionState.ONLINE);
274
242
  }
275
- constructor(testBuilder, peerId, transport = testBuilder.options.signalHosts ? TransportKind.WEB_RTC : TransportKind.MEMORY) {
276
- _define_property2(this, "testBuilder", void 0);
277
- _define_property2(this, "peerId", void 0);
278
- _define_property2(this, "transport", void 0);
279
- _define_property2(this, "_swarms", void 0);
280
- _define_property2(this, "_signalManager", void 0);
281
- _define_property2(this, "_networkManager", void 0);
282
- _define_property2(this, "_proxy", void 0);
283
- _define_property2(this, "_service", void 0);
284
- this.testBuilder = testBuilder;
285
- this.peerId = peerId;
286
- this.transport = transport;
287
- this._swarms = new ComplexMap2(PublicKey2.hash);
288
- this._signalManager = this.testBuilder.createSignalManager();
289
- this._networkManager = this.createNetworkManager(this.transport);
290
- this._networkManager.setPeerInfo({
291
- identityKey: peerId.toHex(),
292
- peerKey: peerId.toHex()
293
- });
294
- }
295
243
  };
296
244
  var TestSwarmConnection = class {
245
+ peer;
246
+ topic;
247
+ extensionFactory;
248
+ protocol;
249
+ constructor(peer, topic, extensionFactory) {
250
+ this.peer = peer;
251
+ this.topic = topic;
252
+ this.extensionFactory = extensionFactory;
253
+ this.protocol = new TestWireProtocol(this.extensionFactory);
254
+ }
297
255
  // TODO(burdon): Need to create new plugin instance per swarm?
298
256
  // If so, then perhaps joinSwarm should return swarm object with access to plugins.
299
257
  async join(topology = new FullyConnectedTopology()) {
300
- await this.peer._networkManager.joinSwarm({
258
+ await this.peer._networkManager.joinSwarm(Context.default(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 179 }), {
301
259
  topic: this.topic,
302
260
  peerInfo: {
303
261
  peerKey: this.peer.peerId.toHex(),
@@ -309,19 +267,9 @@ var TestSwarmConnection = class {
309
267
  return this;
310
268
  }
311
269
  async leave() {
312
- await this.peer._networkManager.leaveSwarm(this.topic);
270
+ await this.peer._networkManager.leaveSwarm(Context.default(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 191 }), this.topic);
313
271
  return this;
314
272
  }
315
- constructor(peer, topic, extensionFactory) {
316
- _define_property2(this, "peer", void 0);
317
- _define_property2(this, "topic", void 0);
318
- _define_property2(this, "extensionFactory", void 0);
319
- _define_property2(this, "protocol", void 0);
320
- this.peer = peer;
321
- this.topic = topic;
322
- this.extensionFactory = extensionFactory;
323
- this.protocol = new TestWireProtocol(this.extensionFactory);
324
- }
325
273
  };
326
274
  export {
327
275
  TEST_SIGNAL_HOSTS,
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../src/testing/test-builder.ts", "../../../../src/testing/test-wire-protocol.ts"],
4
- "sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport {\n MemorySignalManager,\n MemorySignalManagerContext,\n type SignalManager,\n WebsocketSignalManager,\n} from '@dxos/messaging';\nimport { schema } from '@dxos/protocols/proto';\nimport { ConnectionState } from '@dxos/protocols/proto/dxos/client/services';\nimport { type Runtime } from '@dxos/protocols/proto/dxos/config';\nimport { type ProtoRpcPeer, createLinkedPorts, createProtoRpcPeer } from '@dxos/rpc';\nimport { ComplexMap } from '@dxos/util';\n\nimport { TcpTransportFactory } from '#tcp-transport';\n\nimport { SwarmNetworkManager } from '../network-manager';\nimport { FullyConnectedTopology } from '../topology';\nimport {\n MemoryTransportFactory,\n RtcTransportProxyFactory,\n RtcTransportService,\n type TransportFactory,\n TransportKind,\n createRtcTransportFactory,\n} from '../transport';\n\nimport { type TestTeleportExtensionFactory, TestWireProtocol } from './test-wire-protocol';\n\n// Signal server will be started by the setup script.\nconst port = process.env.SIGNAL_PORT ?? 4000;\nexport const TEST_SIGNAL_HOSTS: Runtime.Services.Signal[] = [\n { server: `ws://localhost:${port}/.well-known/dx/signal` },\n];\n\nexport type TestBuilderOptions = {\n signalHosts?: Runtime.Services.Signal[];\n bridge?: boolean;\n transport?: TransportKind;\n};\n\n/**\n * Builder used to construct networks and peers.\n */\nexport class TestBuilder {\n private _signalContext = new MemorySignalManagerContext();\n\n constructor(public readonly options: TestBuilderOptions = {}) {}\n\n createSignalManager(): WebsocketSignalManager | MemorySignalManager {\n if (this.options.signalHosts) {\n return new WebsocketSignalManager(this.options.signalHosts);\n }\n\n return new MemorySignalManager(this._signalContext);\n }\n\n createPeer(peerId: PublicKey = PublicKey.random()): TestPeer {\n return new TestPeer(this, peerId, this.options.transport);\n }\n}\n\n/**\n * Testing network peer.\n */\nexport class TestPeer {\n private readonly _swarms = new ComplexMap<PublicKey, TestSwarmConnection>(PublicKey.hash);\n\n /**\n * @internal\n */\n readonly _signalManager: SignalManager;\n\n /**\n * @internal\n */\n readonly _networkManager: SwarmNetworkManager;\n\n private _proxy?: ProtoRpcPeer<any>;\n private _service?: ProtoRpcPeer<any>;\n\n constructor(\n private readonly testBuilder: TestBuilder,\n public readonly peerId: PublicKey,\n public readonly transport: TransportKind = testBuilder.options.signalHosts\n ? TransportKind.WEB_RTC\n : TransportKind.MEMORY,\n ) {\n this._signalManager = this.testBuilder.createSignalManager();\n this._networkManager = this.createNetworkManager(this.transport);\n this._networkManager.setPeerInfo({ identityKey: peerId.toHex(), peerKey: peerId.toHex() });\n }\n\n // TODO(burdon): Move to TestBuilder.\n createNetworkManager(transport: TransportKind): SwarmNetworkManager {\n let transportFactory: TransportFactory;\n if (this.testBuilder.options.signalHosts) {\n log.info(`using ${transport} transport with signal server.`);\n switch (transport) {\n case TransportKind.MEMORY:\n throw new Error('Memory transport not supported with signal server.');\n case TransportKind.TCP:\n transportFactory = TcpTransportFactory;\n break;\n case TransportKind.WEB_RTC:\n transportFactory = createRtcTransportFactory();\n break;\n case TransportKind.WEB_RTC_PROXY:\n {\n // Simulates bridge to shared worker.\n const [proxyPort, servicePort] = createLinkedPorts();\n\n this._proxy = createProtoRpcPeer({\n port: proxyPort,\n requested: {\n BridgeService: schema.getService('dxos.mesh.bridge.BridgeService'),\n },\n noHandshake: true,\n encodingOptions: {\n preserveAny: true,\n },\n });\n\n this._service = createProtoRpcPeer({\n port: servicePort,\n exposed: {\n BridgeService: schema.getService('dxos.mesh.bridge.BridgeService'),\n },\n handlers: { BridgeService: new RtcTransportService() },\n noHandshake: true,\n encodingOptions: {\n preserveAny: true,\n },\n });\n\n transportFactory = new RtcTransportProxyFactory().setBridgeService(this._proxy.rpc.BridgeService);\n }\n break;\n default:\n throw new Error(`Unsupported transport: ${transport}`);\n }\n } else {\n if (transport !== TransportKind.MEMORY && transport !== TransportKind.TCP) {\n log.warn(`specified transport ${transport} but no signalling configured, using memory transport instead`);\n }\n log.info(`using ${transport} transport without signal server.`);\n transportFactory = MemoryTransportFactory;\n }\n\n return new SwarmNetworkManager({\n signalManager: this._signalManager,\n transportFactory,\n });\n }\n\n async open(): Promise<void> {\n await this._networkManager.open();\n await this._proxy?.open();\n await this._service?.open();\n }\n\n async close(): Promise<void> {\n await Promise.all(Array.from(this._swarms.values()).map((swarm) => swarm.leave()));\n this._swarms.clear();\n\n await this._proxy?.close();\n await this._service?.close();\n await this._networkManager.close();\n }\n\n getSwarm(topic: PublicKey): TestSwarmConnection {\n const swarm = this._swarms.get(topic);\n if (!swarm) {\n throw new Error(`Swarm not found for topic: ${topic}`);\n }\n\n return swarm;\n }\n\n createSwarm(topic: PublicKey, extensionFactory: TestTeleportExtensionFactory = () => []): TestSwarmConnection {\n // TODO(burdon): Multiple.\n // if (this._swarms.get(topic)) {\n // throw new Error(`Swarm already exists for topic: ${topic.truncate()}`);\n // }\n\n const swarm = new TestSwarmConnection(this, topic, extensionFactory);\n this._swarms.set(topic, swarm);\n return swarm;\n }\n\n async goOffline(): Promise<void> {\n await this._networkManager.setConnectionState(ConnectionState.OFFLINE);\n }\n\n async goOnline(): Promise<void> {\n await this._networkManager.setConnectionState(ConnectionState.ONLINE);\n }\n}\n\n// TODO(burdon): Reconcile with new Swarm concept.\nexport class TestSwarmConnection {\n protocol: TestWireProtocol;\n\n constructor(\n readonly peer: TestPeer,\n readonly topic: PublicKey,\n readonly extensionFactory: TestTeleportExtensionFactory,\n ) {\n // TODO(burdon): Configure plugins.\n // TODO(burdon): Prevent reuse?\n this.protocol = new TestWireProtocol(this.extensionFactory);\n }\n\n // TODO(burdon): Need to create new plugin instance per swarm?\n // If so, then perhaps joinSwarm should return swarm object with access to plugins.\n async join(topology = new FullyConnectedTopology()): Promise<this> {\n await this.peer._networkManager.joinSwarm({\n topic: this.topic,\n peerInfo: { peerKey: this.peer.peerId.toHex(), identityKey: this.peer.peerId.toHex() },\n protocolProvider: this.protocol.factory,\n topology,\n });\n\n return this;\n }\n\n async leave(): Promise<this> {\n await this.peer._networkManager.leaveSwarm(this.topic);\n return this;\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Event, asyncTimeout } from '@dxos/async';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { TestExtension, TestExtensionWithStreams } from '@dxos/teleport';\nimport type { TeleportExtension, TestStreamStats } from '@dxos/teleport';\nimport { ComplexMap } from '@dxos/util';\n\nimport { createTeleportProtocolFactory } from '../wire-protocol';\n\nexport type TestTeleportExtension = {\n name: string;\n extension: TeleportExtension;\n};\n\nexport type TestTeleportExtensionFactory = () => TestTeleportExtension[];\n\nexport class TestWireProtocol {\n public readonly connections = new ComplexMap<PublicKey, TestExtension>(PublicKey.hash);\n public readonly streamConnections = new ComplexMap<PublicKey, TestExtensionWithStreams>(PublicKey.hash);\n\n public readonly connected = new Event<PublicKey>();\n public readonly disconnected = new Event<PublicKey>();\n\n public readonly otherConnections = new ComplexMap<{ remotePeerId: PublicKey; extension: string }, TeleportExtension>(\n ({ remotePeerId, extension }) => remotePeerId.toHex() + extension,\n );\n\n constructor(private readonly _extensionFactory: TestTeleportExtensionFactory = () => []) {}\n\n readonly factory = createTeleportProtocolFactory(async (teleport) => {\n log('create', { remotePeerId: teleport.remotePeerId });\n const handleDisconnect = () => {\n this.connections.delete(teleport.remotePeerId);\n this.disconnected.emit(teleport.remotePeerId);\n };\n const extension = new TestExtension({\n onClose: async () => handleDisconnect(),\n onAbort: async () => handleDisconnect(),\n });\n this.connections.set(teleport.remotePeerId, extension);\n teleport.addExtension('test', extension);\n this.connected.emit(teleport.remotePeerId);\n\n const streamExtension = new TestExtensionWithStreams({\n onClose: async () => {\n this.streamConnections.delete(teleport.remotePeerId);\n },\n });\n this.streamConnections.set(teleport.remotePeerId, streamExtension);\n teleport.addExtension('test-stream', streamExtension);\n\n for (const { name, extension } of this._extensionFactory()) {\n this.otherConnections.set({ remotePeerId: teleport.remotePeerId, extension: name }, extension);\n teleport.addExtension(name, extension);\n }\n });\n\n async waitForConnection(peerId: PublicKey): Promise<TestExtension> {\n if (this.connections.has(peerId)) {\n return this.connections.get(peerId)!;\n }\n log('waitForConnection', { peerId });\n await asyncTimeout(\n this.connected.waitFor((connectedId) => connectedId.equals(peerId)),\n // TODO(nf): Make this configurable.\n 10_000,\n );\n return this.connections.get(peerId)!;\n }\n\n async testConnection(peerId: PublicKey, message?: string): Promise<void> {\n const connection = await this.waitForConnection(peerId);\n await connection.test(message);\n }\n\n async openStream(\n peerId: PublicKey,\n streamTag: string,\n streamLoadInterval: number,\n streamLoadChunkSize: number,\n ): Promise<string> {\n if (!this.streamConnections.has(peerId)) {\n throw new Error('Connection does not exist.');\n }\n const connection = this.streamConnections.get(peerId)!;\n return connection.addNewStream(streamLoadInterval, streamLoadChunkSize, streamTag);\n }\n\n async closeStream(peerId: PublicKey, streamTag: string): Promise<TestStreamStats> {\n if (!this.streamConnections.has(peerId)) {\n throw new Error('Connection does not exist.');\n }\n const connection = this.streamConnections.get(peerId)!;\n return connection.closeStream(streamTag);\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["PublicKey", "log", "MemorySignalManager", "MemorySignalManagerContext", "WebsocketSignalManager", "schema", "ConnectionState", "createLinkedPorts", "createProtoRpcPeer", "ComplexMap", "TcpTransportFactory", "Event", "asyncTimeout", "PublicKey", "log", "TestExtension", "TestExtensionWithStreams", "ComplexMap", "TestWireProtocol", "waitForConnection", "peerId", "connections", "has", "get", "log", "asyncTimeout", "connected", "waitFor", "connectedId", "equals", "testConnection", "message", "connection", "test", "openStream", "streamTag", "streamLoadInterval", "streamLoadChunkSize", "streamConnections", "Error", "addNewStream", "closeStream", "_extensionFactory", "disconnected", "otherConnections", "factory", "ComplexMap", "PublicKey", "hash", "Event", "remotePeerId", "extension", "toHex", "createTeleportProtocolFactory", "teleport", "handleDisconnect", "delete", "emit", "TestExtension", "onClose", "onAbort", "set", "addExtension", "streamExtension", "TestExtensionWithStreams", "name", "port", "process", "env", "SIGNAL_PORT", "TEST_SIGNAL_HOSTS", "server", "TestBuilder", "createSignalManager", "options", "signalHosts", "WebsocketSignalManager", "MemorySignalManager", "_signalContext", "createPeer", "peerId", "PublicKey", "random", "TestPeer", "transport", "_define_property", "MemorySignalManagerContext", "createNetworkManager", "transportFactory", "testBuilder", "log", "info", "TransportKind", "MEMORY", "Error", "TCP", "TcpTransportFactory", "WEB_RTC", "createRtcTransportFactory", "WEB_RTC_PROXY", "proxyPort", "servicePort", "createLinkedPorts", "_proxy", "createProtoRpcPeer", "requested", "BridgeService", "schema", "getService", "noHandshake", "encodingOptions", "preserveAny", "_service", "exposed", "handlers", "RtcTransportService", "RtcTransportProxyFactory", "setBridgeService", "rpc", "warn", "MemoryTransportFactory", "SwarmNetworkManager", "signalManager", "_signalManager", "open", "_networkManager", "close", "Promise", "all", "Array", "from", "_swarms", "values", "map", "swarm", "leave", "clear", "getSwarm", "topic", "get", "createSwarm", "extensionFactory", "TestSwarmConnection", "set", "goOffline", "setConnectionState", "ConnectionState", "OFFLINE", "goOnline", "ONLINE", "ComplexMap", "hash", "setPeerInfo", "identityKey", "toHex", "peerKey", "join", "topology", "FullyConnectedTopology", "peer", "joinSwarm", "peerInfo", "protocolProvider", "protocol", "factory", "leaveSwarm", "TestWireProtocol"]
4
+ "sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport { Context } from '@dxos/context';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport {\n MemorySignalManager,\n MemorySignalManagerContext,\n type SignalManager,\n WebsocketSignalManager,\n} from '@dxos/messaging';\nimport { schema } from '@dxos/protocols/proto';\nimport { ConnectionState } from '@dxos/protocols/proto/dxos/client/services';\nimport { type Runtime } from '@dxos/protocols/proto/dxos/config';\nimport { type ProtoRpcPeer, createLinkedPorts, createProtoRpcPeer } from '@dxos/rpc';\nimport { ComplexMap } from '@dxos/util';\n\nimport { TcpTransportFactory } from '#tcp-transport';\n\nimport { SwarmNetworkManager } from '../network-manager';\nimport { FullyConnectedTopology } from '../topology';\nimport {\n MemoryTransportFactory,\n RtcTransportProxyFactory,\n RtcTransportService,\n type TransportFactory,\n TransportKind,\n createRtcTransportFactory,\n} from '../transport';\nimport { type TestTeleportExtensionFactory, TestWireProtocol } from './test-wire-protocol';\n\n// Signal server will be started by the setup script.\nconst port = process.env.SIGNAL_PORT ?? 4000;\nexport const TEST_SIGNAL_HOSTS: Runtime.Services.Signal[] = [\n { server: `ws://localhost:${port}/.well-known/dx/signal` },\n];\n\nexport type TestBuilderOptions = {\n signalHosts?: Runtime.Services.Signal[];\n bridge?: boolean;\n transport?: TransportKind;\n};\n\n/**\n * Builder used to construct networks and peers.\n */\nexport class TestBuilder {\n private _signalContext = new MemorySignalManagerContext();\n\n constructor(public readonly options: TestBuilderOptions = {}) {}\n\n createSignalManager(): WebsocketSignalManager | MemorySignalManager {\n if (this.options.signalHosts) {\n return new WebsocketSignalManager(this.options.signalHosts);\n }\n\n return new MemorySignalManager(this._signalContext);\n }\n\n createPeer(peerId: PublicKey = PublicKey.random()): TestPeer {\n return new TestPeer(this, peerId, this.options.transport);\n }\n}\n\n/**\n * Testing network peer.\n */\nexport class TestPeer {\n private readonly _swarms = new ComplexMap<PublicKey, TestSwarmConnection>(PublicKey.hash);\n\n /**\n * @internal\n */\n readonly _signalManager: SignalManager;\n\n /**\n * @internal\n */\n readonly _networkManager: SwarmNetworkManager;\n\n private _proxy?: ProtoRpcPeer<any>;\n private _service?: ProtoRpcPeer<any>;\n\n constructor(\n private readonly testBuilder: TestBuilder,\n public readonly peerId: PublicKey,\n public readonly transport: TransportKind = testBuilder.options.signalHosts\n ? TransportKind.WEB_RTC\n : TransportKind.MEMORY,\n ) {\n this._signalManager = this.testBuilder.createSignalManager();\n this._networkManager = this.createNetworkManager(this.transport);\n this._networkManager.setPeerInfo({ identityKey: peerId.toHex(), peerKey: peerId.toHex() });\n }\n\n // TODO(burdon): Move to TestBuilder.\n createNetworkManager(transport: TransportKind): SwarmNetworkManager {\n let transportFactory: TransportFactory;\n if (this.testBuilder.options.signalHosts) {\n log.info(`using ${transport} transport with signal server.`);\n switch (transport) {\n case TransportKind.MEMORY:\n throw new Error('Memory transport not supported with signal server.');\n case TransportKind.TCP:\n transportFactory = TcpTransportFactory;\n break;\n case TransportKind.WEB_RTC:\n transportFactory = createRtcTransportFactory();\n break;\n case TransportKind.WEB_RTC_PROXY:\n {\n // Simulates bridge to shared worker.\n const [proxyPort, servicePort] = createLinkedPorts();\n\n this._proxy = createProtoRpcPeer({\n port: proxyPort,\n requested: {\n BridgeService: schema.getService('dxos.mesh.bridge.BridgeService'),\n },\n noHandshake: true,\n encodingOptions: {\n preserveAny: true,\n },\n });\n\n this._service = createProtoRpcPeer({\n port: servicePort,\n exposed: {\n BridgeService: schema.getService('dxos.mesh.bridge.BridgeService'),\n },\n handlers: { BridgeService: new RtcTransportService() },\n noHandshake: true,\n encodingOptions: {\n preserveAny: true,\n },\n });\n\n transportFactory = new RtcTransportProxyFactory().setBridgeService(this._proxy.rpc.BridgeService);\n }\n break;\n default:\n throw new Error(`Unsupported transport: ${transport}`);\n }\n } else {\n if (transport !== TransportKind.MEMORY && transport !== TransportKind.TCP) {\n log.warn(`specified transport ${transport} but no signalling configured, using memory transport instead`);\n }\n log.info(`using ${transport} transport without signal server.`);\n transportFactory = MemoryTransportFactory;\n }\n\n return new SwarmNetworkManager({\n signalManager: this._signalManager,\n transportFactory,\n });\n }\n\n async open(): Promise<void> {\n await this._networkManager.open();\n await this._proxy?.open();\n await this._service?.open();\n }\n\n async close(): Promise<void> {\n await Promise.all(Array.from(this._swarms.values()).map((swarm) => swarm.leave()));\n this._swarms.clear();\n\n await this._proxy?.close();\n await this._service?.close();\n await this._networkManager.close(Context.default());\n }\n\n getSwarm(topic: PublicKey): TestSwarmConnection {\n const swarm = this._swarms.get(topic);\n if (!swarm) {\n throw new Error(`Swarm not found for topic: ${topic}`);\n }\n\n return swarm;\n }\n\n createSwarm(topic: PublicKey, extensionFactory: TestTeleportExtensionFactory = () => []): TestSwarmConnection {\n // TODO(burdon): Multiple.\n // if (this._swarms.get(topic)) {\n // throw new Error(`Swarm already exists for topic: ${topic.truncate()}`);\n // }\n\n const swarm = new TestSwarmConnection(this, topic, extensionFactory);\n this._swarms.set(topic, swarm);\n return swarm;\n }\n\n async goOffline(): Promise<void> {\n await this._networkManager.setConnectionState(ConnectionState.OFFLINE);\n }\n\n async goOnline(): Promise<void> {\n await this._networkManager.setConnectionState(ConnectionState.ONLINE);\n }\n}\n\n// TODO(burdon): Reconcile with new Swarm concept.\nexport class TestSwarmConnection {\n protocol: TestWireProtocol;\n\n constructor(\n readonly peer: TestPeer,\n readonly topic: PublicKey,\n readonly extensionFactory: TestTeleportExtensionFactory,\n ) {\n // TODO(burdon): Configure plugins.\n // TODO(burdon): Prevent reuse?\n this.protocol = new TestWireProtocol(this.extensionFactory);\n }\n\n // TODO(burdon): Need to create new plugin instance per swarm?\n // If so, then perhaps joinSwarm should return swarm object with access to plugins.\n async join(topology = new FullyConnectedTopology()): Promise<this> {\n await this.peer._networkManager.joinSwarm(Context.default(), {\n topic: this.topic,\n peerInfo: { peerKey: this.peer.peerId.toHex(), identityKey: this.peer.peerId.toHex() },\n protocolProvider: this.protocol.factory,\n topology,\n });\n\n return this;\n }\n\n async leave(): Promise<this> {\n await this.peer._networkManager.leaveSwarm(Context.default(), this.topic);\n return this;\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { Event, asyncTimeout } from '@dxos/async';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { TestExtension, TestExtensionWithStreams } from '@dxos/teleport';\nimport type { TeleportExtension, TestStreamStats } from '@dxos/teleport';\nimport { ComplexMap } from '@dxos/util';\n\nimport { createTeleportProtocolFactory } from '../wire-protocol';\n\nexport type TestTeleportExtension = {\n name: string;\n extension: TeleportExtension;\n};\n\nexport type TestTeleportExtensionFactory = () => TestTeleportExtension[];\n\nexport class TestWireProtocol {\n public readonly connections = new ComplexMap<PublicKey, TestExtension>(PublicKey.hash);\n public readonly streamConnections = new ComplexMap<PublicKey, TestExtensionWithStreams>(PublicKey.hash);\n\n public readonly connected = new Event<PublicKey>();\n public readonly disconnected = new Event<PublicKey>();\n\n public readonly otherConnections = new ComplexMap<{ remotePeerId: PublicKey; extension: string }, TeleportExtension>(\n ({ remotePeerId, extension }) => remotePeerId.toHex() + extension,\n );\n\n constructor(private readonly _extensionFactory: TestTeleportExtensionFactory = () => []) {}\n\n readonly factory = createTeleportProtocolFactory(async (teleport) => {\n log('create', { remotePeerId: teleport.remotePeerId });\n const handleDisconnect = () => {\n this.connections.delete(teleport.remotePeerId);\n this.disconnected.emit(teleport.remotePeerId);\n };\n const extension = new TestExtension({\n onClose: async () => handleDisconnect(),\n onAbort: async () => handleDisconnect(),\n });\n this.connections.set(teleport.remotePeerId, extension);\n teleport.addExtension('test', extension);\n this.connected.emit(teleport.remotePeerId);\n\n const streamExtension = new TestExtensionWithStreams({\n onClose: async () => {\n this.streamConnections.delete(teleport.remotePeerId);\n },\n });\n this.streamConnections.set(teleport.remotePeerId, streamExtension);\n teleport.addExtension('test-stream', streamExtension);\n\n for (const { name, extension } of this._extensionFactory()) {\n this.otherConnections.set({ remotePeerId: teleport.remotePeerId, extension: name }, extension);\n teleport.addExtension(name, extension);\n }\n });\n\n async waitForConnection(peerId: PublicKey): Promise<TestExtension> {\n if (this.connections.has(peerId)) {\n return this.connections.get(peerId)!;\n }\n log('waitForConnection', { peerId });\n await asyncTimeout(\n this.connected.waitFor((connectedId) => connectedId.equals(peerId)),\n // TODO(nf): Make this configurable.\n 10_000,\n );\n return this.connections.get(peerId)!;\n }\n\n async testConnection(peerId: PublicKey, message?: string): Promise<void> {\n const connection = await this.waitForConnection(peerId);\n await connection.test(message);\n }\n\n async openStream(\n peerId: PublicKey,\n streamTag: string,\n streamLoadInterval: number,\n streamLoadChunkSize: number,\n ): Promise<string> {\n if (!this.streamConnections.has(peerId)) {\n throw new Error('Connection does not exist.');\n }\n const connection = this.streamConnections.get(peerId)!;\n return connection.addNewStream(streamLoadInterval, streamLoadChunkSize, streamTag);\n }\n\n async closeStream(peerId: PublicKey, streamTag: string): Promise<TestStreamStats> {\n if (!this.streamConnections.has(peerId)) {\n throw new Error('Connection does not exist.');\n }\n const connection = this.streamConnections.get(peerId)!;\n return connection.closeStream(streamTag);\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["Context", "PublicKey", "log", "MemorySignalManager", "MemorySignalManagerContext", "WebsocketSignalManager", "schema", "ConnectionState", "createLinkedPorts", "createProtoRpcPeer", "ComplexMap", "TcpTransportFactory", "Event", "asyncTimeout", "PublicKey", "log", "TestExtension", "TestExtensionWithStreams", "ComplexMap", "TestWireProtocol", "connections", "ComplexMap", "streamConnections", "connected", "Event", "disconnected", "otherConnections", "_extensionFactory", "factory", "createTeleportProtocolFactory", "remotePeerId", "handleDisconnect", "delete", "emit", "teleport", "extension", "TestExtension", "onAbort", "streamExtension", "TestExtensionWithStreams", "onClose", "name", "addExtension", "get", "peerId", "testConnection", "message", "test", "openStream", "streamTag", "connection", "closeStream", "Error", "__dxlog_file", "server", "_signalContext", "MemorySignalManagerContext", "options", "createSignalManager", "WebsocketSignalManager", "MemorySignalManager", "createPeer", "peerId", "random", "PublicKey", "_swarms", "_service", "transport", "_signalManager", "_networkManager", "setPeerInfo", "identityKey", "toHex", "peerKey", "createNetworkManager", "testBuilder", "log", "TransportKind", "MEMORY", "TCP", "transportFactory", "TcpTransportFactory", "WEB_RTC", "WEB_RTC_PROXY", "port", "proxyPort", "requested", "BridgeService", "noHandshake", "encodingOptions", "preserveAny", "exposed", "handlers", "info", "SwarmNetworkManager", "open", "close", "_proxy", "getSwarm", "topic", "swarm", "Error", "createSwarm", "goOffline", "goOnline", "protocol", "extensionFactory", "peerInfo", "protocolProvider", "factory", "topology", "leave"]
7
7
  }
@@ -1,180 +1,5 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
 
3
- // src/transport/tcp/tcp-transport.ts
4
- import { Socket } from "node:net";
5
- import { Event } from "@dxos/async";
6
- import { ErrorStream } from "@dxos/debug";
7
- import { log } from "@dxos/log";
8
- function _define_property(obj, key, value) {
9
- if (key in obj) {
10
- Object.defineProperty(obj, key, {
11
- value,
12
- enumerable: true,
13
- configurable: true,
14
- writable: true
15
- });
16
- } else {
17
- obj[key] = value;
18
- }
19
- return obj;
20
- }
21
- var __dxlog_file = "/__w/dxos/dxos/packages/core/mesh/network-manager/src/transport/tcp/tcp-transport.ts";
22
- var TcpTransportFactory = {
23
- createTransport: (options) => new TcpTransport(options)
24
- };
25
- var TcpTransport = class {
26
- get isOpen() {
27
- return this._connected && !this._closed;
28
- }
29
- async open() {
30
- log("opening", void 0, {
31
- F: __dxlog_file,
32
- L: 39,
33
- S: this,
34
- C: (f, a) => f(...a)
35
- });
36
- if (this.options.initiator) {
37
- setTimeout(async () => {
38
- const { Server } = await import("node:net");
39
- this._server = new Server((socket) => {
40
- log("new connection", void 0, {
41
- F: __dxlog_file,
42
- L: 47,
43
- S: this,
44
- C: (f, a) => f(...a)
45
- });
46
- if (this._connected) {
47
- socket.destroy();
48
- }
49
- this._handleSocket(socket);
50
- });
51
- this._server.on("listening", () => {
52
- const { port } = this._server.address();
53
- log("listening", {
54
- port
55
- }, {
56
- F: __dxlog_file,
57
- L: 56,
58
- S: this,
59
- C: (f, a) => f(...a)
60
- });
61
- void this.options.sendSignal({
62
- payload: {
63
- port
64
- }
65
- }).catch((err) => {
66
- if (!this._closed) {
67
- this.errors.raise(err);
68
- }
69
- });
70
- });
71
- this._server.on("error", (err) => {
72
- this.errors.raise(err);
73
- });
74
- this._server.listen(0);
75
- });
76
- }
77
- return this;
78
- }
79
- async close() {
80
- log("closing", void 0, {
81
- F: __dxlog_file,
82
- L: 79,
83
- S: this,
84
- C: (f, a) => f(...a)
85
- });
86
- this._socket?.destroy();
87
- this._server?.close();
88
- this._closed = true;
89
- return this;
90
- }
91
- async onSignal({ payload }) {
92
- log("received signal", {
93
- payload
94
- }, {
95
- F: __dxlog_file,
96
- L: 87,
97
- S: this,
98
- C: (f, a) => f(...a)
99
- });
100
- if (this.options.initiator || this._connected) {
101
- return;
102
- }
103
- const socket = new Socket();
104
- this._handleSocket(socket);
105
- socket.connect({
106
- port: payload.port,
107
- host: "localhost"
108
- });
109
- }
110
- async getDetails() {
111
- if (this.options.initiator) {
112
- const { port: port2, address: address2 } = this._server?.address();
113
- return `LISTEN ${address2}:${port2}`;
114
- }
115
- const { port, address } = this._socket?.address();
116
- return `ACCEPT ${address}:${port}`;
117
- }
118
- async getStats() {
119
- return {
120
- bytesSent: 0,
121
- bytesReceived: 0,
122
- packetsSent: 0,
123
- packetsReceived: 0
124
- };
125
- }
126
- _handleSocket(socket) {
127
- log("handling socket", {
128
- remotePort: socket.remotePort,
129
- localPort: socket.localPort
130
- }, {
131
- F: __dxlog_file,
132
- L: 117,
133
- S: this,
134
- C: (f, a) => f(...a)
135
- });
136
- this._socket = socket;
137
- this._socket.on("connect", () => {
138
- log("connected to", {
139
- port: this._socket?.remotePort
140
- }, {
141
- F: __dxlog_file,
142
- L: 121,
143
- S: this,
144
- C: (f, a) => f(...a)
145
- });
146
- this._connected = true;
147
- });
148
- this._socket.on("error", (err) => {
149
- this.errors.raise(err);
150
- });
151
- this._socket.on("close", () => {
152
- this.closed.emit();
153
- });
154
- this.connected.emit();
155
- this.options.stream.pipe(this._socket).pipe(this.options.stream);
156
- }
157
- constructor(options) {
158
- _define_property(this, "options", void 0);
159
- _define_property(this, "_server", void 0);
160
- _define_property(this, "_socket", void 0);
161
- _define_property(this, "_connected", void 0);
162
- _define_property(this, "_closed", void 0);
163
- _define_property(this, "closed", void 0);
164
- _define_property(this, "connected", void 0);
165
- _define_property(this, "errors", void 0);
166
- this.options = options;
167
- this._server = void 0;
168
- this._socket = void 0;
169
- this._connected = false;
170
- this._closed = false;
171
- this.closed = new Event();
172
- this.connected = new Event();
173
- this.errors = new ErrorStream();
174
- }
175
- };
176
- export {
177
- TcpTransport,
178
- TcpTransportFactory
179
- };
3
+ // src/transport/tcp/index.ts
4
+ export * from "#tcp-transport-impl";
180
5
  //# sourceMappingURL=index.mjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../../../src/transport/tcp/tcp-transport.ts"],
4
- "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\nimport { type AddressInfo, type Server, Socket } from 'node:net';\n\nimport { Event } from '@dxos/async';\nimport { ErrorStream } from '@dxos/debug';\nimport { log } from '@dxos/log';\nimport { type Signal } from '@dxos/protocols/proto/dxos/mesh/swarm';\n\nimport { type Transport, type TransportFactory, type TransportOptions, type TransportStats } from '../transport';\n\nexport const TcpTransportFactory: TransportFactory = {\n createTransport: (options) => new TcpTransport(options),\n};\n\n/**\n * Fake transport.\n */\nexport class TcpTransport implements Transport {\n private _server?: Server = undefined;\n private _socket?: Socket = undefined;\n\n private _connected = false;\n private _closed = false;\n\n public readonly closed = new Event<void>();\n public readonly connected = new Event<void>();\n public readonly errors = new ErrorStream();\n\n constructor(private readonly options: TransportOptions) {}\n\n get isOpen() {\n return this._connected && !this._closed;\n }\n\n async open(): Promise<this> {\n log('opening');\n\n // Initiator will send a signal, the receiver will receive the unique ID and connect the streams.\n if (this.options.initiator) {\n // TODO(burdon): Why timeout?\n setTimeout(async () => {\n const { Server } = await import('node:net');\n this._server = new Server((socket) => {\n log('new connection');\n if (this._connected) {\n socket.destroy();\n }\n this._handleSocket(socket);\n });\n\n this._server.on('listening', () => {\n const { port } = this._server!.address() as AddressInfo;\n log('listening', { port });\n void this.options\n .sendSignal({\n payload: { port },\n })\n .catch((err) => {\n if (!this._closed) {\n this.errors.raise(err);\n }\n });\n });\n\n this._server.on('error', (err) => {\n this.errors.raise(err);\n });\n\n this._server.listen(0);\n });\n }\n return this;\n }\n\n async close(): Promise<this> {\n log('closing');\n this._socket?.destroy();\n this._server?.close();\n this._closed = true;\n return this;\n }\n\n async onSignal({ payload }: Signal): Promise<void> {\n log('received signal', { payload });\n if (this.options.initiator || this._connected) {\n return;\n }\n\n const socket = new Socket();\n this._handleSocket(socket);\n socket.connect({ port: payload.port, host: 'localhost' });\n }\n\n async getDetails(): Promise<string> {\n if (this.options.initiator) {\n const { port, address } = this._server?.address() as AddressInfo;\n return `LISTEN ${address}:${port}`;\n }\n\n const { port, address } = this._socket?.address() as AddressInfo;\n return `ACCEPT ${address}:${port}`;\n }\n\n async getStats(): Promise<TransportStats> {\n return {\n bytesSent: 0,\n bytesReceived: 0,\n packetsSent: 0,\n packetsReceived: 0,\n };\n }\n\n private _handleSocket(socket: Socket): void {\n log('handling socket', { remotePort: socket.remotePort, localPort: socket.localPort });\n this._socket = socket;\n\n this._socket.on('connect', () => {\n log('connected to', { port: this._socket?.remotePort });\n this._connected = true;\n });\n\n this._socket.on('error', (err) => {\n this.errors.raise(err);\n });\n\n this._socket.on('close', () => {\n this.closed.emit();\n });\n\n this.connected.emit();\n this.options.stream.pipe(this._socket!).pipe(this.options.stream);\n }\n}\n"],
5
- "mappings": "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",
6
- "names": ["Socket", "Event", "ErrorStream", "log", "TcpTransportFactory", "createTransport", "options", "TcpTransport", "isOpen", "_connected", "_closed", "open", "initiator", "setTimeout", "Server", "_server", "socket", "destroy", "_handleSocket", "on", "port", "address", "sendSignal", "payload", "catch", "err", "errors", "raise", "listen", "close", "_socket", "onSignal", "connect", "host", "getDetails", "getStats", "bytesSent", "bytesReceived", "packetsSent", "packetsReceived", "remotePort", "localPort", "closed", "emit", "connected", "stream", "pipe", "undefined"]
3
+ "sources": ["../../../../../src/transport/tcp/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nexport * from '#tcp-transport-impl';\n"],
5
+ "mappings": ";;;AAIA,cAAc;",
6
+ "names": []
7
7
  }