@dxos/network-manager 0.8.4-main.f9ba587 → 0.8.4-main.fcfe5033a5

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 (105) hide show
  1. package/dist/lib/browser/{chunk-HQNQOWFA.mjs → chunk-Y2FDDNGM.mjs} +687 -916
  2. package/dist/lib/browser/chunk-Y2FDDNGM.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +342 -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 +78 -49
  7. package/dist/lib/browser/testing/index.mjs.map +3 -3
  8. package/dist/lib/browser/transport/tcp/index.mjs +2 -35
  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 +160 -0
  13. package/dist/lib/browser/transport/tcp/tcp-transport.mjs.map +7 -0
  14. package/dist/lib/node-esm/{chunk-JPPMRZTH.mjs → chunk-OU3FYVBA.mjs} +687 -916
  15. package/dist/lib/node-esm/chunk-OU3FYVBA.mjs.map +7 -0
  16. package/dist/lib/node-esm/index.mjs +342 -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 +78 -49
  20. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  21. package/dist/lib/node-esm/transport/tcp/index.mjs +2 -156
  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 +160 -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/index.d.ts +1 -1
  29. package/dist/types/src/index.d.ts.map +1 -1
  30. package/dist/types/src/network-manager.d.ts +5 -4
  31. package/dist/types/src/network-manager.d.ts.map +1 -1
  32. package/dist/types/src/signal/index.d.ts +2 -2
  33. package/dist/types/src/signal/index.d.ts.map +1 -1
  34. package/dist/types/src/signal/signal-connection.d.ts +3 -2
  35. package/dist/types/src/signal/signal-connection.d.ts.map +1 -1
  36. package/dist/types/src/signal/signal-messenger.d.ts +3 -2
  37. package/dist/types/src/signal/signal-messenger.d.ts.map +1 -1
  38. package/dist/types/src/signal/swarm-messenger.d.ts +8 -8
  39. package/dist/types/src/signal/swarm-messenger.d.ts.map +1 -1
  40. package/dist/types/src/swarm/connection.d.ts +2 -1
  41. package/dist/types/src/swarm/connection.d.ts.map +1 -1
  42. package/dist/types/src/swarm/peer.d.ts +6 -5
  43. package/dist/types/src/swarm/peer.d.ts.map +1 -1
  44. package/dist/types/src/swarm/swarm.d.ts +6 -5
  45. package/dist/types/src/swarm/swarm.d.ts.map +1 -1
  46. package/dist/types/src/testing/test-builder.d.ts +1 -1
  47. package/dist/types/src/testing/test-builder.d.ts.map +1 -1
  48. package/dist/types/src/testing/test-wire-protocol.d.ts +1 -1
  49. package/dist/types/src/testing/test-wire-protocol.d.ts.map +1 -1
  50. package/dist/types/src/tests/basic-test-suite.d.ts.map +1 -1
  51. package/dist/types/src/tests/property-test-suite.d.ts.map +1 -1
  52. package/dist/types/src/topology/index.d.ts +1 -1
  53. package/dist/types/src/topology/index.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/webrtc/rtc-peer-connection.d.ts +2 -2
  57. package/dist/types/src/transport/webrtc/rtc-peer-connection.d.ts.map +1 -1
  58. package/dist/types/src/transport/webrtc/rtc-transport-channel.d.ts +1 -1
  59. package/dist/types/src/transport/webrtc/rtc-transport-channel.d.ts.map +1 -1
  60. package/dist/types/src/transport/webrtc/rtc-transport-factory.d.ts.map +1 -1
  61. package/dist/types/src/transport/webrtc/rtc-transport-proxy.d.ts.map +1 -1
  62. package/dist/types/src/transport/webrtc/rtc-transport-service.d.ts +1 -1
  63. package/dist/types/src/transport/webrtc/rtc-transport-service.d.ts.map +1 -1
  64. package/dist/types/src/wire-protocol.d.ts +5 -5
  65. package/dist/types/src/wire-protocol.d.ts.map +1 -1
  66. package/dist/types/tsconfig.tsbuildinfo +1 -1
  67. package/package.json +37 -33
  68. package/src/connection-log.ts +1 -1
  69. package/src/index.ts +1 -1
  70. package/src/network-manager.ts +20 -16
  71. package/src/signal/ice.test.ts +1 -1
  72. package/src/signal/index.ts +2 -2
  73. package/src/signal/integration.node.test.ts +13 -12
  74. package/src/signal/signal-connection.ts +3 -2
  75. package/src/signal/signal-messenger.ts +3 -2
  76. package/src/signal/swarm-messenger.node.test.ts +26 -25
  77. package/src/signal/swarm-messenger.ts +66 -56
  78. package/src/swarm/connection.test.ts +9 -8
  79. package/src/swarm/connection.ts +16 -14
  80. package/src/swarm/peer.ts +9 -8
  81. package/src/swarm/swarm-mapper.ts +1 -1
  82. package/src/swarm/swarm.test.ts +8 -7
  83. package/src/swarm/swarm.ts +13 -13
  84. package/src/testing/test-builder.ts +15 -7
  85. package/src/testing/test-wire-protocol.ts +2 -2
  86. package/src/tests/basic-test-suite.ts +2 -2
  87. package/src/tests/memory-transport.test.ts +2 -2
  88. package/src/tests/property-test-suite.ts +4 -3
  89. package/src/tests/tcp-transport.node.test.ts +2 -2
  90. package/src/tests/webrtc-transport.test.ts +5 -3
  91. package/src/topology/index.ts +1 -1
  92. package/src/transport/tcp/index.ts +1 -1
  93. package/src/transport/tcp/tcp-transport.ts +1 -1
  94. package/src/transport/webrtc/rtc-connection-factory.ts +1 -1
  95. package/src/transport/webrtc/rtc-peer-connection.ts +4 -4
  96. package/src/transport/webrtc/rtc-transport-channel.test.ts +1 -1
  97. package/src/transport/webrtc/rtc-transport-channel.ts +2 -2
  98. package/src/transport/webrtc/rtc-transport-factory.ts +2 -2
  99. package/src/transport/webrtc/rtc-transport-proxy.test.ts +5 -4
  100. package/src/transport/webrtc/rtc-transport-proxy.ts +6 -4
  101. package/src/transport/webrtc/rtc-transport-service.ts +5 -5
  102. package/src/transport/webrtc/rtc-transport.test.ts +5 -4
  103. package/src/wire-protocol.ts +6 -6
  104. package/dist/lib/browser/chunk-HQNQOWFA.mjs.map +0 -7
  105. package/dist/lib/node-esm/chunk-JPPMRZTH.mjs.map +0 -7
@@ -8,9 +8,10 @@ import {
8
8
  TransportKind,
9
9
  createRtcTransportFactory,
10
10
  createTeleportProtocolFactory
11
- } from "../chunk-JPPMRZTH.mjs";
11
+ } from "../chunk-OU3FYVBA.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";
@@ -21,56 +22,57 @@ import { ComplexMap as ComplexMap2 } from "@dxos/util";
21
22
  import { TcpTransportFactory } from "#tcp-transport";
22
23
 
23
24
  // src/testing/test-wire-protocol.ts
24
- import { asyncTimeout, Event } from "@dxos/async";
25
+ import { Event, asyncTimeout } from "@dxos/async";
25
26
  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
30
  var __dxlog_file = "/__w/dxos/dxos/packages/core/mesh/network-manager/src/testing/test-wire-protocol.ts";
30
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);
31
38
  constructor(_extensionFactory = () => []) {
32
39
  this._extensionFactory = _extensionFactory;
33
- this.connections = new ComplexMap(PublicKey.hash);
34
- this.streamConnections = new ComplexMap(PublicKey.hash);
35
- this.connected = new Event();
36
- this.disconnected = new Event();
37
- this.otherConnections = new ComplexMap(({ remotePeerId, extension }) => remotePeerId.toHex() + extension);
38
- this.factory = createTeleportProtocolFactory(async (teleport) => {
39
- log("create", {
40
- remotePeerId: teleport.remotePeerId
41
- }, {
42
- F: __dxlog_file,
43
- L: 35,
44
- S: this,
45
- C: (f, a) => f(...a)
46
- });
47
- const handleDisconnect = () => {
48
- this.connections.delete(teleport.remotePeerId);
49
- this.disconnected.emit(teleport.remotePeerId);
50
- };
51
- const extension = new TestExtension({
52
- onClose: async () => handleDisconnect(),
53
- onAbort: async () => handleDisconnect()
54
- });
55
- this.connections.set(teleport.remotePeerId, extension);
56
- teleport.addExtension("test", extension);
57
- this.connected.emit(teleport.remotePeerId);
58
- const streamExtension = new TestExtensionWithStreams({
59
- onClose: async () => {
60
- this.streamConnections.delete(teleport.remotePeerId);
61
- }
62
- });
63
- this.streamConnections.set(teleport.remotePeerId, streamExtension);
64
- teleport.addExtension("test-stream", streamExtension);
65
- for (const { name, extension: extension2 } of this._extensionFactory()) {
66
- this.otherConnections.set({
67
- remotePeerId: teleport.remotePeerId,
68
- extension: name
69
- }, extension2);
70
- teleport.addExtension(name, extension2);
40
+ }
41
+ factory = createTeleportProtocolFactory(async (teleport) => {
42
+ log("create", {
43
+ remotePeerId: teleport.remotePeerId
44
+ }, {
45
+ F: __dxlog_file,
46
+ L: 35,
47
+ S: this,
48
+ C: (f, a) => f(...a)
49
+ });
50
+ const handleDisconnect = () => {
51
+ this.connections.delete(teleport.remotePeerId);
52
+ this.disconnected.emit(teleport.remotePeerId);
53
+ };
54
+ const extension = new TestExtension({
55
+ onClose: async () => handleDisconnect(),
56
+ onAbort: async () => handleDisconnect()
57
+ });
58
+ this.connections.set(teleport.remotePeerId, extension);
59
+ teleport.addExtension("test", extension);
60
+ this.connected.emit(teleport.remotePeerId);
61
+ const streamExtension = new TestExtensionWithStreams({
62
+ onClose: async () => {
63
+ this.streamConnections.delete(teleport.remotePeerId);
71
64
  }
72
65
  });
73
- }
66
+ this.streamConnections.set(teleport.remotePeerId, streamExtension);
67
+ teleport.addExtension("test-stream", streamExtension);
68
+ for (const { name, extension: extension2 } of this._extensionFactory()) {
69
+ this.otherConnections.set({
70
+ remotePeerId: teleport.remotePeerId,
71
+ extension: name
72
+ }, extension2);
73
+ teleport.addExtension(name, extension2);
74
+ }
75
+ });
74
76
  async waitForConnection(peerId) {
75
77
  if (this.connections.has(peerId)) {
76
78
  return this.connections.get(peerId);
@@ -119,9 +121,10 @@ var TEST_SIGNAL_HOSTS = [
119
121
  }
120
122
  ];
121
123
  var TestBuilder = class {
124
+ options;
125
+ _signalContext = new MemorySignalManagerContext();
122
126
  constructor(options = {}) {
123
127
  this.options = options;
124
- this._signalContext = new MemorySignalManagerContext();
125
128
  }
126
129
  createSignalManager() {
127
130
  if (this.options.signalHosts) {
@@ -134,11 +137,24 @@ var TestBuilder = class {
134
137
  }
135
138
  };
136
139
  var TestPeer = class {
140
+ testBuilder;
141
+ peerId;
142
+ transport;
143
+ _swarms = new ComplexMap2(PublicKey2.hash);
144
+ /**
145
+ * @internal
146
+ */
147
+ _signalManager;
148
+ /**
149
+ * @internal
150
+ */
151
+ _networkManager;
152
+ _proxy;
153
+ _service;
137
154
  constructor(testBuilder, peerId, transport = testBuilder.options.signalHosts ? TransportKind.WEB_RTC : TransportKind.MEMORY) {
138
155
  this.testBuilder = testBuilder;
139
156
  this.peerId = peerId;
140
157
  this.transport = transport;
141
- this._swarms = new ComplexMap2(PublicKey2.hash);
142
158
  this._signalManager = this.testBuilder.createSignalManager();
143
159
  this._networkManager = this.createNetworkManager(this.transport);
144
160
  this._networkManager.setPeerInfo({
@@ -152,7 +168,7 @@ var TestPeer = class {
152
168
  if (this.testBuilder.options.signalHosts) {
153
169
  log2.info(`using ${transport} transport with signal server.`, void 0, {
154
170
  F: __dxlog_file2,
155
- L: 94,
171
+ L: 102,
156
172
  S: this,
157
173
  C: (f, a) => f(...a)
158
174
  });
@@ -201,14 +217,14 @@ var TestPeer = class {
201
217
  if (transport !== TransportKind.MEMORY && transport !== TransportKind.TCP) {
202
218
  log2.warn(`specified transport ${transport} but no signalling configured, using memory transport instead`, void 0, {
203
219
  F: __dxlog_file2,
204
- L: 140,
220
+ L: 148,
205
221
  S: this,
206
222
  C: (f, a) => f(...a)
207
223
  });
208
224
  }
209
225
  log2.info(`using ${transport} transport without signal server.`, void 0, {
210
226
  F: __dxlog_file2,
211
- L: 142,
227
+ L: 150,
212
228
  S: this,
213
229
  C: (f, a) => f(...a)
214
230
  });
@@ -229,7 +245,10 @@ var TestPeer = class {
229
245
  this._swarms.clear();
230
246
  await this._proxy?.close();
231
247
  await this._service?.close();
232
- await this._networkManager.close();
248
+ await this._networkManager.close(Context.default(void 0, {
249
+ F: __dxlog_file2,
250
+ L: 172
251
+ }));
233
252
  }
234
253
  getSwarm(topic) {
235
254
  const swarm = this._swarms.get(topic);
@@ -251,6 +270,10 @@ var TestPeer = class {
251
270
  }
252
271
  };
253
272
  var TestSwarmConnection = class {
273
+ peer;
274
+ topic;
275
+ extensionFactory;
276
+ protocol;
254
277
  constructor(peer, topic, extensionFactory) {
255
278
  this.peer = peer;
256
279
  this.topic = topic;
@@ -260,7 +283,10 @@ var TestSwarmConnection = class {
260
283
  // TODO(burdon): Need to create new plugin instance per swarm?
261
284
  // If so, then perhaps joinSwarm should return swarm object with access to plugins.
262
285
  async join(topology = new FullyConnectedTopology()) {
263
- await this.peer._networkManager.joinSwarm({
286
+ await this.peer._networkManager.joinSwarm(Context.default(void 0, {
287
+ F: __dxlog_file2,
288
+ L: 221
289
+ }), {
264
290
  topic: this.topic,
265
291
  peerInfo: {
266
292
  peerKey: this.peer.peerId.toHex(),
@@ -272,7 +298,10 @@ var TestSwarmConnection = class {
272
298
  return this;
273
299
  }
274
300
  async leave() {
275
- await this.peer._networkManager.leaveSwarm(this.topic);
301
+ await this.peer._networkManager.leaveSwarm(Context.default(void 0, {
302
+ F: __dxlog_file2,
303
+ L: 232
304
+ }), this.topic);
276
305
  return this;
277
306
  }
278
307
  };
@@ -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 { createLinkedPorts, createProtoRpcPeer, type ProtoRpcPeer } from '@dxos/rpc';\nimport { ComplexMap } from '@dxos/util';\n\nimport { TcpTransportFactory } from '#tcp-transport';\nimport { type TestTeleportExtensionFactory, TestWireProtocol } from './test-wire-protocol';\nimport { SwarmNetworkManager } from '../network-manager';\nimport { FullyConnectedTopology } from '../topology';\nimport { MemoryTransportFactory, type TransportFactory, TransportKind } from '../transport';\nimport { createRtcTransportFactory, RtcTransportProxyFactory, RtcTransportService } from '../transport';\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 { asyncTimeout, Event } from '@dxos/async';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { TestExtension, TestExtensionWithStreams } from '@dxos/teleport';\nimport type { TestStreamStats, TeleportExtension } 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", "asyncTimeout", "Event", "PublicKey", "log", "TestExtension", "TestExtensionWithStreams", "ComplexMap", "TestWireProtocol", "_extensionFactory", "connections", "ComplexMap", "PublicKey", "hash", "streamConnections", "connected", "Event", "disconnected", "otherConnections", "remotePeerId", "extension", "toHex", "factory", "createTeleportProtocolFactory", "teleport", "log", "handleDisconnect", "delete", "emit", "TestExtension", "onClose", "onAbort", "set", "addExtension", "streamExtension", "TestExtensionWithStreams", "name", "waitForConnection", "peerId", "has", "get", "asyncTimeout", "waitFor", "connectedId", "equals", "testConnection", "message", "connection", "test", "openStream", "streamTag", "streamLoadInterval", "streamLoadChunkSize", "Error", "addNewStream", "closeStream", "port", "process", "env", "SIGNAL_PORT", "TEST_SIGNAL_HOSTS", "server", "TestBuilder", "options", "_signalContext", "MemorySignalManagerContext", "createSignalManager", "signalHosts", "WebsocketSignalManager", "MemorySignalManager", "createPeer", "peerId", "PublicKey", "random", "TestPeer", "transport", "testBuilder", "TransportKind", "WEB_RTC", "MEMORY", "_swarms", "ComplexMap", "hash", "_signalManager", "_networkManager", "createNetworkManager", "setPeerInfo", "identityKey", "toHex", "peerKey", "transportFactory", "log", "info", "Error", "TCP", "TcpTransportFactory", "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", "open", "close", "Promise", "all", "Array", "from", "values", "map", "swarm", "leave", "clear", "getSwarm", "topic", "get", "createSwarm", "extensionFactory", "TestSwarmConnection", "set", "goOffline", "setConnectionState", "ConnectionState", "OFFLINE", "goOnline", "ONLINE", "peer", "protocol", "TestWireProtocol", "join", "topology", "FullyConnectedTopology", "joinSwarm", "peerInfo", "protocolProvider", "factory", "leaveSwarm"]
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", "PublicKey", "hash", "streamConnections", "connected", "Event", "disconnected", "otherConnections", "remotePeerId", "extension", "toHex", "_extensionFactory", "factory", "createTeleportProtocolFactory", "teleport", "log", "handleDisconnect", "delete", "emit", "TestExtension", "onClose", "onAbort", "set", "addExtension", "streamExtension", "TestExtensionWithStreams", "name", "waitForConnection", "peerId", "has", "get", "asyncTimeout", "waitFor", "connectedId", "equals", "testConnection", "message", "connection", "test", "openStream", "streamTag", "streamLoadInterval", "streamLoadChunkSize", "Error", "addNewStream", "closeStream", "port", "process", "env", "SIGNAL_PORT", "TEST_SIGNAL_HOSTS", "server", "TestBuilder", "_signalContext", "MemorySignalManagerContext", "options", "createSignalManager", "signalHosts", "WebsocketSignalManager", "MemorySignalManager", "createPeer", "peerId", "PublicKey", "random", "TestPeer", "transport", "_swarms", "ComplexMap", "hash", "_signalManager", "_networkManager", "_proxy", "_service", "testBuilder", "TransportKind", "WEB_RTC", "MEMORY", "createNetworkManager", "setPeerInfo", "identityKey", "toHex", "peerKey", "transportFactory", "log", "info", "Error", "TCP", "TcpTransportFactory", "createRtcTransportFactory", "WEB_RTC_PROXY", "proxyPort", "servicePort", "createLinkedPorts", "createProtoRpcPeer", "requested", "BridgeService", "schema", "getService", "noHandshake", "encodingOptions", "preserveAny", "exposed", "handlers", "RtcTransportService", "RtcTransportProxyFactory", "setBridgeService", "rpc", "warn", "MemoryTransportFactory", "SwarmNetworkManager", "signalManager", "open", "close", "Promise", "all", "Array", "from", "values", "map", "swarm", "leave", "clear", "Context", "default", "getSwarm", "topic", "get", "createSwarm", "extensionFactory", "TestSwarmConnection", "set", "goOffline", "setConnectionState", "ConnectionState", "OFFLINE", "goOnline", "ONLINE", "protocol", "peer", "TestWireProtocol", "join", "topology", "FullyConnectedTopology", "joinSwarm", "peerInfo", "protocolProvider", "factory", "leaveSwarm"]
7
7
  }
@@ -1,159 +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
- var __dxlog_file = "/__w/dxos/dxos/packages/core/mesh/network-manager/src/transport/tcp/tcp-transport.ts";
9
- var TcpTransportFactory = {
10
- createTransport: (options) => new TcpTransport(options)
11
- };
12
- var TcpTransport = class {
13
- constructor(options) {
14
- this.options = options;
15
- this._server = void 0;
16
- this._socket = void 0;
17
- this._connected = false;
18
- this._closed = false;
19
- this.closed = new Event();
20
- this.connected = new Event();
21
- this.errors = new ErrorStream();
22
- }
23
- get isOpen() {
24
- return this._connected && !this._closed;
25
- }
26
- async open() {
27
- log("opening", void 0, {
28
- F: __dxlog_file,
29
- L: 39,
30
- S: this,
31
- C: (f, a) => f(...a)
32
- });
33
- if (this.options.initiator) {
34
- setTimeout(async () => {
35
- const { Server } = await import("node:net");
36
- this._server = new Server((socket) => {
37
- log("new connection", void 0, {
38
- F: __dxlog_file,
39
- L: 47,
40
- S: this,
41
- C: (f, a) => f(...a)
42
- });
43
- if (this._connected) {
44
- socket.destroy();
45
- }
46
- this._handleSocket(socket);
47
- });
48
- this._server.on("listening", () => {
49
- const { port } = this._server.address();
50
- log("listening", {
51
- port
52
- }, {
53
- F: __dxlog_file,
54
- L: 56,
55
- S: this,
56
- C: (f, a) => f(...a)
57
- });
58
- void this.options.sendSignal({
59
- payload: {
60
- port
61
- }
62
- }).catch((err) => {
63
- if (!this._closed) {
64
- this.errors.raise(err);
65
- }
66
- });
67
- });
68
- this._server.on("error", (err) => {
69
- this.errors.raise(err);
70
- });
71
- this._server.listen(0);
72
- });
73
- }
74
- return this;
75
- }
76
- async close() {
77
- log("closing", void 0, {
78
- F: __dxlog_file,
79
- L: 79,
80
- S: this,
81
- C: (f, a) => f(...a)
82
- });
83
- this._socket?.destroy();
84
- this._server?.close();
85
- this._closed = true;
86
- return this;
87
- }
88
- async onSignal({ payload }) {
89
- log("received signal", {
90
- payload
91
- }, {
92
- F: __dxlog_file,
93
- L: 87,
94
- S: this,
95
- C: (f, a) => f(...a)
96
- });
97
- if (this.options.initiator || this._connected) {
98
- return;
99
- }
100
- const socket = new Socket();
101
- this._handleSocket(socket);
102
- socket.connect({
103
- port: payload.port,
104
- host: "localhost"
105
- });
106
- }
107
- async getDetails() {
108
- if (this.options.initiator) {
109
- const { port: port2, address: address2 } = this._server?.address();
110
- return `LISTEN ${address2}:${port2}`;
111
- }
112
- const { port, address } = this._socket?.address();
113
- return `ACCEPT ${address}:${port}`;
114
- }
115
- async getStats() {
116
- return {
117
- bytesSent: 0,
118
- bytesReceived: 0,
119
- packetsSent: 0,
120
- packetsReceived: 0
121
- };
122
- }
123
- _handleSocket(socket) {
124
- log("handling socket", {
125
- remotePort: socket.remotePort,
126
- localPort: socket.localPort
127
- }, {
128
- F: __dxlog_file,
129
- L: 117,
130
- S: this,
131
- C: (f, a) => f(...a)
132
- });
133
- this._socket = socket;
134
- this._socket.on("connect", () => {
135
- log("connected to", {
136
- port: this._socket?.remotePort
137
- }, {
138
- F: __dxlog_file,
139
- L: 121,
140
- S: this,
141
- C: (f, a) => f(...a)
142
- });
143
- this._connected = true;
144
- });
145
- this._socket.on("error", (err) => {
146
- this.errors.raise(err);
147
- });
148
- this._socket.on("close", () => {
149
- this.closed.emit();
150
- });
151
- this.connected.emit();
152
- this.options.stream.pipe(this._socket).pipe(this.options.stream);
153
- }
154
- };
155
- export {
156
- TcpTransport,
157
- TcpTransportFactory
158
- };
3
+ // src/transport/tcp/index.ts
4
+ export * from "#tcp-transport-impl";
159
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, Socket, type Server } 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", "_server", "undefined", "_socket", "_connected", "_closed", "closed", "connected", "errors", "isOpen", "open", "initiator", "setTimeout", "Server", "socket", "destroy", "_handleSocket", "on", "port", "address", "sendSignal", "payload", "catch", "err", "raise", "listen", "close", "onSignal", "connect", "host", "getDetails", "getStats", "bytesSent", "bytesReceived", "packetsSent", "packetsReceived", "remotePort", "localPort", "emit", "stream", "pipe"]
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
  }
@@ -0,0 +1,36 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // src/transport/tcp/tcp-transport.browser.ts
4
+ import { Event } from "@dxos/async";
5
+ import { ErrorStream } from "@dxos/debug";
6
+ var TcpTransportFactory = {
7
+ createTransport: () => new TcpTransport()
8
+ };
9
+ var TcpTransport = class {
10
+ closed = new Event();
11
+ connected = new Event();
12
+ errors = new ErrorStream();
13
+ get isOpen() {
14
+ return true;
15
+ }
16
+ async open() {
17
+ return this;
18
+ }
19
+ async close() {
20
+ return this;
21
+ }
22
+ async onSignal() {
23
+ throw new Error("Method not implemented.");
24
+ }
25
+ async getStats() {
26
+ throw new Error("Method not implemented.");
27
+ }
28
+ async getDetails() {
29
+ throw new Error("Method not implemented.");
30
+ }
31
+ };
32
+ export {
33
+ TcpTransport,
34
+ TcpTransportFactory
35
+ };
36
+ //# sourceMappingURL=tcp-transport.browser.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/transport/tcp/tcp-transport.browser.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2020 DXOS.org\n//\n\nimport { Event } from '@dxos/async';\nimport { ErrorStream } from '@dxos/debug';\n\nimport { type Transport, type TransportFactory, type TransportStats } from '../transport';\n\nexport const TcpTransportFactory: TransportFactory = {\n createTransport: () => new TcpTransport(),\n};\n\n/**\n * NOTE: Browser stub.\n */\nexport class TcpTransport implements Transport {\n public readonly closed = new Event<void>();\n public readonly connected = new Event<void>();\n public readonly errors = new ErrorStream();\n\n get isOpen() {\n return true;\n }\n\n async open(): Promise<this> {\n return this;\n }\n\n async close(): Promise<this> {\n return this;\n }\n\n async onSignal(): Promise<void> {\n throw new Error('Method not implemented.');\n }\n\n async getStats(): Promise<TransportStats> {\n throw new Error('Method not implemented.');\n }\n\n async getDetails(): Promise<string> {\n throw new Error('Method not implemented.');\n }\n}\n"],
5
+ "mappings": ";;;AAIA,SAASA,aAAa;AACtB,SAASC,mBAAmB;AAIrB,IAAMC,sBAAwC;EACnDC,iBAAiB,MAAM,IAAIC,aAAAA;AAC7B;AAKO,IAAMA,eAAN,MAAMA;EACKC,SAAS,IAAIC,MAAAA;EACbC,YAAY,IAAID,MAAAA;EAChBE,SAAS,IAAIC,YAAAA;EAE7B,IAAIC,SAAS;AACX,WAAO;EACT;EAEA,MAAMC,OAAsB;AAC1B,WAAO;EACT;EAEA,MAAMC,QAAuB;AAC3B,WAAO;EACT;EAEA,MAAMC,WAA0B;AAC9B,UAAM,IAAIC,MAAM,yBAAA;EAClB;EAEA,MAAMC,WAAoC;AACxC,UAAM,IAAID,MAAM,yBAAA;EAClB;EAEA,MAAME,aAA8B;AAClC,UAAM,IAAIF,MAAM,yBAAA;EAClB;AACF;",
6
+ "names": ["Event", "ErrorStream", "TcpTransportFactory", "createTransport", "TcpTransport", "closed", "Event", "connected", "errors", "ErrorStream", "isOpen", "open", "close", "onSignal", "Error", "getStats", "getDetails"]
7
+ }