@dxos/network-manager 0.8.4-main.84f28bd → 0.8.4-main.8baae0fced
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +102 -5
- package/README.md +1 -1
- package/dist/lib/browser/{chunk-HQNQOWFA.mjs → chunk-UFYPMUBI.mjs} +599 -1973
- package/dist/lib/browser/chunk-UFYPMUBI.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +198 -4
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +65 -70
- package/dist/lib/browser/testing/index.mjs.map +3 -3
- package/dist/lib/browser/transport/tcp/index.mjs +2 -35
- package/dist/lib/browser/transport/tcp/index.mjs.map +4 -4
- package/dist/lib/browser/transport/tcp/tcp-transport.browser.mjs +36 -0
- package/dist/lib/browser/transport/tcp/tcp-transport.browser.mjs.map +7 -0
- package/dist/lib/browser/transport/tcp/tcp-transport.mjs +125 -0
- package/dist/lib/browser/transport/tcp/tcp-transport.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-JPPMRZTH.mjs → chunk-3KIKKHMP.mjs} +599 -1973
- package/dist/lib/node-esm/chunk-3KIKKHMP.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +198 -4
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/testing/index.mjs +65 -70
- package/dist/lib/node-esm/testing/index.mjs.map +3 -3
- package/dist/lib/node-esm/transport/tcp/index.mjs +2 -156
- package/dist/lib/node-esm/transport/tcp/index.mjs.map +4 -4
- package/dist/lib/node-esm/transport/tcp/tcp-transport.browser.mjs +36 -0
- package/dist/lib/node-esm/transport/tcp/tcp-transport.browser.mjs.map +7 -0
- package/dist/lib/node-esm/transport/tcp/tcp-transport.mjs +125 -0
- package/dist/lib/node-esm/transport/tcp/tcp-transport.mjs.map +7 -0
- package/dist/types/src/connection-log.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +1 -1
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/network-manager.d.ts +6 -6
- package/dist/types/src/network-manager.d.ts.map +1 -1
- package/dist/types/src/signal/ice.d.ts.map +1 -1
- package/dist/types/src/signal/index.d.ts +2 -2
- package/dist/types/src/signal/index.d.ts.map +1 -1
- package/dist/types/src/signal/signal-connection.d.ts +3 -2
- package/dist/types/src/signal/signal-connection.d.ts.map +1 -1
- package/dist/types/src/signal/signal-messenger.d.ts +3 -2
- package/dist/types/src/signal/signal-messenger.d.ts.map +1 -1
- package/dist/types/src/signal/swarm-messenger.d.ts +8 -8
- package/dist/types/src/signal/swarm-messenger.d.ts.map +1 -1
- package/dist/types/src/swarm/connection-limiter.d.ts.map +1 -1
- package/dist/types/src/swarm/connection.d.ts +2 -2
- package/dist/types/src/swarm/connection.d.ts.map +1 -1
- package/dist/types/src/swarm/peer.d.ts +6 -5
- package/dist/types/src/swarm/peer.d.ts.map +1 -1
- package/dist/types/src/swarm/swarm-mapper.d.ts.map +1 -1
- package/dist/types/src/swarm/swarm.d.ts +6 -8
- package/dist/types/src/swarm/swarm.d.ts.map +1 -1
- package/dist/types/src/testing/test-builder.d.ts +1 -1
- package/dist/types/src/testing/test-builder.d.ts.map +1 -1
- package/dist/types/src/testing/test-wire-protocol.d.ts +1 -1
- package/dist/types/src/testing/test-wire-protocol.d.ts.map +1 -1
- package/dist/types/src/tests/basic-test-suite.d.ts.map +1 -1
- package/dist/types/src/tests/property-test-suite.d.ts.map +1 -1
- package/dist/types/src/tests/utils.d.ts.map +1 -1
- package/dist/types/src/topology/fully-connected-topology.d.ts.map +1 -1
- package/dist/types/src/topology/index.d.ts +1 -1
- package/dist/types/src/topology/index.d.ts.map +1 -1
- package/dist/types/src/topology/mmst-topology.d.ts.map +1 -1
- package/dist/types/src/topology/star-topology.d.ts.map +1 -1
- package/dist/types/src/transport/memory-transport.d.ts.map +1 -1
- package/dist/types/src/transport/tcp/index.d.ts +1 -1
- package/dist/types/src/transport/tcp/index.d.ts.map +1 -1
- package/dist/types/src/transport/tcp/tcp-transport.browser.d.ts.map +1 -1
- package/dist/types/src/transport/tcp/tcp-transport.d.ts.map +1 -1
- package/dist/types/src/transport/webrtc/rtc-peer-connection.d.ts +6 -6
- package/dist/types/src/transport/webrtc/rtc-peer-connection.d.ts.map +1 -1
- package/dist/types/src/transport/webrtc/rtc-transport-channel.d.ts +1 -1
- package/dist/types/src/transport/webrtc/rtc-transport-channel.d.ts.map +1 -1
- package/dist/types/src/transport/webrtc/rtc-transport-factory.d.ts.map +1 -1
- package/dist/types/src/transport/webrtc/rtc-transport-proxy.d.ts.map +1 -1
- package/dist/types/src/transport/webrtc/rtc-transport-service.d.ts +1 -1
- package/dist/types/src/transport/webrtc/rtc-transport-service.d.ts.map +1 -1
- package/dist/types/src/transport/webrtc/rtc-transport-stats.d.ts.map +1 -1
- package/dist/types/src/transport/webrtc/test-utils.d.ts.map +1 -1
- package/dist/types/src/transport/webrtc/utils.d.ts.map +1 -1
- package/dist/types/src/wire-protocol.d.ts +5 -5
- package/dist/types/src/wire-protocol.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +38 -44
- package/src/connection-log.ts +1 -1
- package/src/index.ts +1 -1
- package/src/network-manager.ts +22 -20
- package/src/signal/ice.test.ts +1 -1
- package/src/signal/index.ts +2 -2
- package/src/signal/integration.node.test.ts +13 -12
- package/src/signal/signal-connection.ts +3 -2
- package/src/signal/signal-messenger.ts +3 -2
- package/src/signal/swarm-messenger.node.test.ts +26 -25
- package/src/signal/swarm-messenger.ts +66 -56
- package/src/swarm/connection.test.ts +9 -8
- package/src/swarm/connection.ts +18 -25
- package/src/swarm/peer.ts +9 -8
- package/src/swarm/swarm-mapper.ts +1 -1
- package/src/swarm/swarm.test.ts +8 -7
- package/src/swarm/swarm.ts +14 -20
- package/src/testing/test-builder.ts +15 -7
- package/src/testing/test-wire-protocol.ts +2 -2
- package/src/tests/basic-test-suite.ts +2 -2
- package/src/tests/memory-transport.test.ts +2 -2
- package/src/tests/property-test-suite.ts +4 -3
- package/src/tests/tcp-transport.node.test.ts +2 -2
- package/src/tests/webrtc-transport.test.ts +5 -3
- package/src/topology/index.ts +1 -1
- package/src/transport/tcp/index.ts +1 -1
- package/src/transport/tcp/tcp-transport.ts +1 -1
- package/src/transport/webrtc/rtc-connection-factory.ts +1 -1
- package/src/transport/webrtc/rtc-peer-connection.ts +4 -4
- package/src/transport/webrtc/rtc-transport-channel.test.ts +1 -1
- package/src/transport/webrtc/rtc-transport-channel.ts +2 -2
- package/src/transport/webrtc/rtc-transport-factory.ts +2 -2
- package/src/transport/webrtc/rtc-transport-proxy.test.ts +5 -4
- package/src/transport/webrtc/rtc-transport-proxy.ts +6 -4
- package/src/transport/webrtc/rtc-transport-service.ts +5 -5
- package/src/transport/webrtc/rtc-transport.test.ts +5 -4
- package/src/wire-protocol.ts +6 -6
- package/dist/lib/browser/chunk-HQNQOWFA.mjs.map +0 -7
- 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-
|
|
11
|
+
} from "../chunk-3KIKKHMP.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,68 +22,59 @@ 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 {
|
|
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
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
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
|
+
}, { "~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);
|
|
71
59
|
}
|
|
72
60
|
});
|
|
73
|
-
|
|
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
|
+
});
|
|
74
71
|
async waitForConnection(peerId) {
|
|
75
72
|
if (this.connections.has(peerId)) {
|
|
76
73
|
return this.connections.get(peerId);
|
|
77
74
|
}
|
|
78
75
|
log("waitForConnection", {
|
|
79
76
|
peerId
|
|
80
|
-
}, {
|
|
81
|
-
F: __dxlog_file,
|
|
82
|
-
L: 66,
|
|
83
|
-
S: this,
|
|
84
|
-
C: (f, a) => f(...a)
|
|
85
|
-
});
|
|
77
|
+
}, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 54, S: this });
|
|
86
78
|
await asyncTimeout(
|
|
87
79
|
this.connected.waitFor((connectedId) => connectedId.equals(peerId)),
|
|
88
80
|
// TODO(nf): Make this configurable.
|
|
@@ -119,9 +111,10 @@ var TEST_SIGNAL_HOSTS = [
|
|
|
119
111
|
}
|
|
120
112
|
];
|
|
121
113
|
var TestBuilder = class {
|
|
114
|
+
options;
|
|
115
|
+
_signalContext = new MemorySignalManagerContext();
|
|
122
116
|
constructor(options = {}) {
|
|
123
117
|
this.options = options;
|
|
124
|
-
this._signalContext = new MemorySignalManagerContext();
|
|
125
118
|
}
|
|
126
119
|
createSignalManager() {
|
|
127
120
|
if (this.options.signalHosts) {
|
|
@@ -134,11 +127,24 @@ var TestBuilder = class {
|
|
|
134
127
|
}
|
|
135
128
|
};
|
|
136
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;
|
|
137
144
|
constructor(testBuilder, peerId, transport = testBuilder.options.signalHosts ? TransportKind.WEB_RTC : TransportKind.MEMORY) {
|
|
138
145
|
this.testBuilder = testBuilder;
|
|
139
146
|
this.peerId = peerId;
|
|
140
147
|
this.transport = transport;
|
|
141
|
-
this._swarms = new ComplexMap2(PublicKey2.hash);
|
|
142
148
|
this._signalManager = this.testBuilder.createSignalManager();
|
|
143
149
|
this._networkManager = this.createNetworkManager(this.transport);
|
|
144
150
|
this._networkManager.setPeerInfo({
|
|
@@ -150,12 +156,7 @@ var TestPeer = class {
|
|
|
150
156
|
createNetworkManager(transport) {
|
|
151
157
|
let transportFactory;
|
|
152
158
|
if (this.testBuilder.options.signalHosts) {
|
|
153
|
-
log2.info(`using ${transport} transport with signal server.`, void 0, {
|
|
154
|
-
F: __dxlog_file2,
|
|
155
|
-
L: 94,
|
|
156
|
-
S: this,
|
|
157
|
-
C: (f, a) => f(...a)
|
|
158
|
-
});
|
|
159
|
+
log2.info(`using ${transport} transport with signal server.`, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 72, S: this });
|
|
159
160
|
switch (transport) {
|
|
160
161
|
case TransportKind.MEMORY:
|
|
161
162
|
throw new Error("Memory transport not supported with signal server.");
|
|
@@ -199,19 +200,9 @@ var TestPeer = class {
|
|
|
199
200
|
}
|
|
200
201
|
} else {
|
|
201
202
|
if (transport !== TransportKind.MEMORY && transport !== TransportKind.TCP) {
|
|
202
|
-
log2.warn(`specified transport ${transport} but no signalling configured, using memory transport instead`, void 0, {
|
|
203
|
-
F: __dxlog_file2,
|
|
204
|
-
L: 140,
|
|
205
|
-
S: this,
|
|
206
|
-
C: (f, a) => f(...a)
|
|
207
|
-
});
|
|
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 });
|
|
208
204
|
}
|
|
209
|
-
log2.info(`using ${transport} transport without signal server.`, void 0, {
|
|
210
|
-
F: __dxlog_file2,
|
|
211
|
-
L: 142,
|
|
212
|
-
S: this,
|
|
213
|
-
C: (f, a) => f(...a)
|
|
214
|
-
});
|
|
205
|
+
log2.info(`using ${transport} transport without signal server.`, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 119, S: this });
|
|
215
206
|
transportFactory = MemoryTransportFactory;
|
|
216
207
|
}
|
|
217
208
|
return new SwarmNetworkManager({
|
|
@@ -229,7 +220,7 @@ var TestPeer = class {
|
|
|
229
220
|
this._swarms.clear();
|
|
230
221
|
await this._proxy?.close();
|
|
231
222
|
await this._service?.close();
|
|
232
|
-
await this._networkManager.close();
|
|
223
|
+
await this._networkManager.close(Context.default(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 137 }));
|
|
233
224
|
}
|
|
234
225
|
getSwarm(topic) {
|
|
235
226
|
const swarm = this._swarms.get(topic);
|
|
@@ -251,6 +242,10 @@ var TestPeer = class {
|
|
|
251
242
|
}
|
|
252
243
|
};
|
|
253
244
|
var TestSwarmConnection = class {
|
|
245
|
+
peer;
|
|
246
|
+
topic;
|
|
247
|
+
extensionFactory;
|
|
248
|
+
protocol;
|
|
254
249
|
constructor(peer, topic, extensionFactory) {
|
|
255
250
|
this.peer = peer;
|
|
256
251
|
this.topic = topic;
|
|
@@ -260,7 +255,7 @@ var TestSwarmConnection = class {
|
|
|
260
255
|
// TODO(burdon): Need to create new plugin instance per swarm?
|
|
261
256
|
// If so, then perhaps joinSwarm should return swarm object with access to plugins.
|
|
262
257
|
async join(topology = new FullyConnectedTopology()) {
|
|
263
|
-
await this.peer._networkManager.joinSwarm({
|
|
258
|
+
await this.peer._networkManager.joinSwarm(Context.default(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 179 }), {
|
|
264
259
|
topic: this.topic,
|
|
265
260
|
peerInfo: {
|
|
266
261
|
peerKey: this.peer.peerId.toHex(),
|
|
@@ -272,7 +267,7 @@ var TestSwarmConnection = class {
|
|
|
272
267
|
return this;
|
|
273
268
|
}
|
|
274
269
|
async leave() {
|
|
275
|
-
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);
|
|
276
271
|
return this;
|
|
277
272
|
}
|
|
278
273
|
};
|
|
@@ -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": ";;;;;;;;;;;;;AAIA,SAASA,aAAAA,kBAAiB;AAC1B,SAASC,OAAAA,YAAW;AACpB,SACEC,qBACAC,4BAEAC,8BACK;AACP,SAASC,cAAc;AACvB,SAASC,uBAAuB;AAEhC,
|
|
6
|
-
"names": ["PublicKey", "log", "MemorySignalManager", "MemorySignalManagerContext", "WebsocketSignalManager", "schema", "ConnectionState", "createLinkedPorts", "createProtoRpcPeer", "ComplexMap", "TcpTransportFactory", "
|
|
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,159 +1,5 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
|
|
3
|
-
// src/transport/tcp/
|
|
4
|
-
|
|
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/
|
|
4
|
-
"sourcesContent": ["//\n// Copyright
|
|
5
|
-
"mappings": ";;;AAIA,
|
|
6
|
-
"names": [
|
|
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,IAAIL,MAAAA;EACbM,YAAY,IAAIN,MAAAA;EAChBO,SAAS,IAAIN,YAAAA;EAE7B,IAAIO,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", "connected", "errors", "isOpen", "open", "close", "onSignal", "Error", "getStats", "getDetails"]
|
|
7
|
+
}
|