@dxos/network-manager 2.33.9-dev.bba8fc00 → 2.33.9-dev.ceab0857
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/dist/src/network-manager.blueprint-test.d.ts +3 -1
- package/dist/src/network-manager.blueprint-test.d.ts.map +1 -1
- package/dist/src/network-manager.blueprint-test.js +46 -17
- package/dist/src/network-manager.blueprint-test.js.map +1 -1
- package/dist/src/network-manager.browser-test.js +1 -1
- package/dist/src/network-manager.browser-test.js.map +1 -1
- package/dist/src/network-manager.d.ts.map +1 -1
- package/dist/src/network-manager.js +6 -6
- package/dist/src/network-manager.js.map +1 -1
- package/dist/src/network-manager.test.js +5 -4
- package/dist/src/network-manager.test.js.map +1 -1
- package/dist/src/proto/gen/dxos/credentials.d.ts.map +1 -1
- package/dist/src/proto/gen/dxos/halo/keys.d.ts.map +1 -1
- package/dist/src/proto/gen/dxos/halo/keys.js.map +1 -1
- package/dist/src/proto/gen/dxos/mesh/signal.d.ts +52 -45
- package/dist/src/proto/gen/dxos/mesh/signal.d.ts.map +1 -1
- package/dist/src/proto/gen/dxos/mesh/signalMessage.d.ts +79 -0
- package/dist/src/proto/gen/dxos/mesh/signalMessage.d.ts.map +1 -0
- package/dist/src/proto/gen/dxos/mesh/signalMessage.js +3 -0
- package/dist/src/proto/gen/dxos/mesh/signalMessage.js.map +1 -0
- package/dist/src/proto/gen/google/protobuf.d.ts +6 -0
- package/dist/src/proto/gen/google/protobuf.d.ts.map +1 -1
- package/dist/src/proto/gen/index.d.ts +17 -5
- package/dist/src/proto/gen/index.d.ts.map +1 -1
- package/dist/src/proto/gen/index.js +1 -1
- package/dist/src/proto/gen/index.js.map +1 -1
- package/dist/src/proto/substitutions.d.ts +4 -0
- package/dist/src/proto/substitutions.d.ts.map +1 -1
- package/dist/src/proto/substitutions.js +3 -1
- package/dist/src/proto/substitutions.js.map +1 -1
- package/dist/src/signal/in-memory-signal-manager.d.ts +7 -7
- package/dist/src/signal/in-memory-signal-manager.d.ts.map +1 -1
- package/dist/src/signal/in-memory-signal-manager.js +29 -8
- package/dist/src/signal/in-memory-signal-manager.js.map +1 -1
- package/dist/src/signal/index.d.ts +1 -2
- package/dist/src/signal/index.d.ts.map +1 -1
- package/dist/src/signal/index.js +1 -2
- package/dist/src/signal/index.js.map +1 -1
- package/dist/src/signal/integration.test.d.ts +2 -0
- package/dist/src/signal/integration.test.d.ts.map +1 -0
- package/dist/src/signal/integration.test.js +102 -0
- package/dist/src/signal/integration.test.js.map +1 -0
- package/dist/src/signal/message-router.d.ts +7 -7
- package/dist/src/signal/message-router.d.ts.map +1 -1
- package/dist/src/signal/message-router.js +6 -1
- package/dist/src/signal/message-router.js.map +1 -1
- package/dist/src/signal/message-router.test.js +15 -19
- package/dist/src/signal/message-router.test.js.map +1 -1
- package/dist/src/signal/signal-client.d.ts +33 -18
- package/dist/src/signal/signal-client.d.ts.map +1 -1
- package/dist/src/signal/signal-client.js +102 -92
- package/dist/src/signal/signal-client.js.map +1 -1
- package/dist/src/signal/signal-client.test.js +60 -77
- package/dist/src/signal/signal-client.test.js.map +1 -1
- package/dist/src/signal/{websocket-signal-manager.d.ts → signal-manager-impl.d.ts} +13 -11
- package/dist/src/signal/signal-manager-impl.d.ts.map +1 -0
- package/dist/src/signal/signal-manager-impl.js +151 -0
- package/dist/src/signal/signal-manager-impl.js.map +1 -0
- package/dist/src/signal/signal-manager.d.ts +12 -11
- package/dist/src/signal/signal-manager.d.ts.map +1 -1
- package/dist/src/signal/signal-rpc-client.d.ts +19 -0
- package/dist/src/signal/signal-rpc-client.d.ts.map +1 -0
- package/dist/src/signal/signal-rpc-client.js +108 -0
- package/dist/src/signal/signal-rpc-client.js.map +1 -0
- package/dist/src/signal/signal-rpc-client.test.d.ts +2 -0
- package/dist/src/signal/signal-rpc-client.test.d.ts.map +1 -0
- package/dist/src/signal/signal-rpc-client.test.js +74 -0
- package/dist/src/signal/signal-rpc-client.test.js.map +1 -0
- package/dist/src/swarm/connection.d.ts +3 -3
- package/dist/src/swarm/connection.d.ts.map +1 -1
- package/dist/src/swarm/connection.js +1 -4
- package/dist/src/swarm/connection.js.map +1 -1
- package/dist/src/swarm/swarm.d.ts +6 -7
- package/dist/src/swarm/swarm.d.ts.map +1 -1
- package/dist/src/swarm/swarm.js +21 -17
- package/dist/src/swarm/swarm.js.map +1 -1
- package/dist/src/swarm/swarm.test.js +156 -117
- package/dist/src/swarm/swarm.test.js.map +1 -1
- package/dist/src/topology/fully-connected-topology.d.ts +0 -1
- package/dist/src/topology/fully-connected-topology.d.ts.map +1 -1
- package/dist/src/topology/fully-connected-topology.js +1 -6
- package/dist/src/topology/fully-connected-topology.js.map +1 -1
- package/dist/src/topology/mmst-topology.d.ts +0 -1
- package/dist/src/topology/mmst-topology.d.ts.map +1 -1
- package/dist/src/topology/mmst-topology.js +1 -6
- package/dist/src/topology/mmst-topology.js.map +1 -1
- package/dist/src/topology/star-topology.d.ts +0 -1
- package/dist/src/topology/star-topology.d.ts.map +1 -1
- package/dist/src/topology/star-topology.js +1 -6
- package/dist/src/topology/star-topology.js.map +1 -1
- package/dist/src/topology/topology.d.ts +0 -6
- package/dist/src/topology/topology.d.ts.map +1 -1
- package/dist/src/transport/in-memory-transport.d.ts +2 -2
- package/dist/src/transport/in-memory-transport.d.ts.map +1 -1
- package/dist/src/transport/in-memory-transport.js.map +1 -1
- package/dist/src/transport/transport.d.ts +3 -3
- package/dist/src/transport/transport.d.ts.map +1 -1
- package/dist/src/transport/webrtc-transport.d.ts +3 -3
- package/dist/src/transport/webrtc-transport.d.ts.map +1 -1
- package/dist/src/transport/webrtc-transport.js.map +1 -1
- package/dist/tests-setup.js +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +14 -12
- package/src/network-manager.blueprint-test.ts +57 -22
- package/src/network-manager.browser-test.ts +1 -1
- package/src/network-manager.test.ts +8 -7
- package/src/network-manager.ts +8 -9
- package/src/proto/defs/dxos/mesh/signal.proto +53 -35
- package/src/proto/defs/dxos/mesh/signalMessage.proto +51 -0
- package/src/proto/gen/dxos/credentials.ts +1 -0
- package/src/proto/gen/dxos/halo/keys.ts +1 -0
- package/src/proto/gen/dxos/mesh/signal.ts +51 -45
- package/src/proto/gen/dxos/mesh/signalMessage.ts +83 -0
- package/src/proto/gen/google/protobuf.ts +7 -0
- package/src/proto/gen/index.ts +18 -6
- package/src/proto/substitutions.ts +3 -1
- package/src/signal/in-memory-signal-manager.ts +37 -12
- package/src/signal/index.ts +1 -2
- package/src/signal/integration.test.ts +117 -0
- package/src/signal/message-router.test.ts +36 -41
- package/src/signal/message-router.ts +22 -18
- package/src/signal/signal-client.test.ts +70 -92
- package/src/signal/signal-client.ts +119 -113
- package/src/signal/signal-manager-impl.ts +166 -0
- package/src/signal/signal-manager.ts +12 -12
- package/src/signal/signal-rpc-client.test.ts +86 -0
- package/src/signal/signal-rpc-client.ts +121 -0
- package/src/swarm/connection.ts +5 -8
- package/src/swarm/swarm.test.ts +208 -169
- package/src/swarm/swarm.ts +24 -20
- package/src/topology/fully-connected-topology.ts +1 -9
- package/src/topology/mmst-topology.ts +1 -9
- package/src/topology/star-topology.ts +1 -7
- package/src/topology/topology.ts +0 -7
- package/src/transport/in-memory-transport.ts +2 -2
- package/src/transport/transport.ts +3 -3
- package/src/transport/webrtc-transport.ts +3 -3
- package/dist/browser-mocha/bundle.js +0 -119286
- package/dist/browser-mocha/main.js +0 -27
- package/dist/src/signal/websocket-rpc.d.ts +0 -30
- package/dist/src/signal/websocket-rpc.d.ts.map +0 -1
- package/dist/src/signal/websocket-rpc.js +0 -203
- package/dist/src/signal/websocket-rpc.js.map +0 -1
- package/dist/src/signal/websocket-signal-manager.d.ts.map +0 -1
- package/dist/src/signal/websocket-signal-manager.js +0 -134
- package/dist/src/signal/websocket-signal-manager.js.map +0 -1
- package/src/signal/websocket-rpc.ts +0 -208
- package/src/signal/websocket-signal-manager.ts +0 -158
|
@@ -19,124 +19,163 @@ const topology_1 = require("../topology");
|
|
|
19
19
|
const transport_1 = require("../transport");
|
|
20
20
|
const swarm_1 = require("./swarm");
|
|
21
21
|
const log = (0, debug_1.default)('dxos:network-manager:swarm:test');
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
22
|
+
describe('Swarm', () => {
|
|
23
|
+
class MockSignalConnection {
|
|
24
|
+
constructor(_swarm, _delay = 10) {
|
|
25
|
+
this._swarm = _swarm;
|
|
26
|
+
this._delay = _delay;
|
|
27
|
+
}
|
|
28
|
+
async offer(msg) {
|
|
29
|
+
await (0, async_1.sleep)(this._delay);
|
|
30
|
+
return this._swarm().onOffer(msg);
|
|
31
|
+
}
|
|
32
|
+
async signal(msg) {
|
|
33
|
+
await (0, async_1.sleep)(this._delay);
|
|
34
|
+
await this._swarm().onSignal(msg);
|
|
35
|
+
}
|
|
26
36
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
37
|
+
const setup = ({ router = false } = {}) => {
|
|
38
|
+
const topic = protocols_1.PublicKey.random();
|
|
39
|
+
const peerId1 = protocols_1.PublicKey.random();
|
|
40
|
+
const peerId2 = protocols_1.PublicKey.random();
|
|
41
|
+
// eslint-disable-next-line prefer-const
|
|
42
|
+
let swarm1;
|
|
43
|
+
// eslint-disable-next-line prefer-const
|
|
44
|
+
let swarm2;
|
|
45
|
+
const mr1 = new message_router_1.MessageRouter({
|
|
46
|
+
sendMessage: msg => mr2.receiveMessage(msg),
|
|
47
|
+
onSignal: msg => swarm1.onSignal(msg),
|
|
48
|
+
onOffer: msg => swarm1.onOffer(msg)
|
|
49
|
+
});
|
|
50
|
+
(0, testutils_1.afterTest)(() => mr1.destroy());
|
|
51
|
+
const mr2 = new message_router_1.MessageRouter({
|
|
52
|
+
sendMessage: msg => mr1.receiveMessage(msg),
|
|
53
|
+
onSignal: msg => swarm2.onSignal(msg),
|
|
54
|
+
onOffer: msg => swarm2.onOffer(msg)
|
|
55
|
+
});
|
|
56
|
+
(0, testutils_1.afterTest)(() => mr2.destroy());
|
|
57
|
+
const sm1 = router ? mr1 : new MockSignalConnection(() => swarm2);
|
|
58
|
+
const sm2 = router ? mr2 : new MockSignalConnection(() => swarm1);
|
|
59
|
+
swarm1 = new swarm_1.Swarm(topic, peerId1, new topology_1.FullyConnectedTopology(), () => new mesh_protocol_1.Protocol(), sm1, (0, transport_1.createWebRTCTransportFactory)(), undefined);
|
|
60
|
+
swarm2 = new swarm_1.Swarm(topic, peerId2, new topology_1.FullyConnectedTopology(), () => new mesh_protocol_1.Protocol(), sm2, (0, transport_1.createWebRTCTransportFactory)(), undefined);
|
|
61
|
+
(0, testutils_1.afterTest)(async () => {
|
|
62
|
+
await swarm1.destroy();
|
|
63
|
+
await swarm2.destroy();
|
|
64
|
+
});
|
|
65
|
+
return { swarm1, swarm2, peerId1, peerId2 };
|
|
66
|
+
};
|
|
67
|
+
(0, mocha_1.it)('connects two peers in a swarm', async () => {
|
|
68
|
+
const { swarm1, swarm2, peerId1, peerId2 } = setup();
|
|
69
|
+
(0, earljs_1.expect)(swarm1.connections.length).toEqual(0);
|
|
70
|
+
(0, earljs_1.expect)(swarm2.connections.length).toEqual(0);
|
|
71
|
+
const promise = Promise.all([
|
|
72
|
+
(0, async_1.promiseTimeout)(swarm1.connected.waitForCount(1), 3000, new Error('Swarm1 connect timeout.')),
|
|
73
|
+
(0, async_1.promiseTimeout)(swarm2.connected.waitForCount(1), 3000, new Error('Swarm2 connect timeout.'))
|
|
74
|
+
]);
|
|
75
|
+
// Behavior of the Signal Server.
|
|
76
|
+
swarm1.onSwarmEvent({
|
|
77
|
+
peerAvailable: {
|
|
78
|
+
peer: peerId1.asUint8Array(),
|
|
79
|
+
since: new Date()
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
swarm1.onSwarmEvent({
|
|
83
|
+
peerAvailable: {
|
|
84
|
+
peer: peerId2.asUint8Array(),
|
|
85
|
+
since: new Date()
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
log('Candidates changed');
|
|
89
|
+
await promise;
|
|
90
|
+
log('Swarms connected');
|
|
91
|
+
const swarm1Connection = swarm1.connections[0];
|
|
92
|
+
const swarm2Connection = swarm2.connections[0];
|
|
93
|
+
const onData = (0, earljs_1.mockFn)().returns(undefined);
|
|
94
|
+
swarm2Connection.transport.peer.on('data', onData);
|
|
95
|
+
const data = Buffer.from('1234');
|
|
96
|
+
swarm1Connection.transport.peer.send(data);
|
|
97
|
+
await (0, wait_for_expect_1.default)(() => {
|
|
98
|
+
(0, earljs_1.expect)(onData).toHaveBeenCalledWith([data]);
|
|
99
|
+
});
|
|
100
|
+
}).timeout(5000);
|
|
101
|
+
(0, mocha_1.it)('two peers try to originate connections to each other simultaneously', async () => {
|
|
102
|
+
const { swarm1, swarm2, peerId1, peerId2 } = setup();
|
|
103
|
+
(0, earljs_1.expect)(swarm1.connections.length).toEqual(0);
|
|
104
|
+
(0, earljs_1.expect)(swarm2.connections.length).toEqual(0);
|
|
105
|
+
swarm1.onSwarmEvent({
|
|
106
|
+
peerAvailable: {
|
|
107
|
+
peer: peerId2.asUint8Array(),
|
|
108
|
+
since: new Date()
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
swarm2.onSwarmEvent({
|
|
112
|
+
peerAvailable: {
|
|
113
|
+
peer: peerId1.asUint8Array(),
|
|
114
|
+
since: new Date()
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
await Promise.all([
|
|
118
|
+
swarm1.connected.waitForCount(1),
|
|
119
|
+
swarm2.connected.waitForCount(1)
|
|
120
|
+
]);
|
|
121
|
+
}).timeout(5000);
|
|
122
|
+
(0, mocha_1.it)('second peer discovered after delay', async () => {
|
|
123
|
+
const { swarm1, swarm2, peerId1, peerId2 } = setup();
|
|
124
|
+
(0, earljs_1.expect)(swarm1.connections.length).toEqual(0);
|
|
125
|
+
(0, earljs_1.expect)(swarm2.connections.length).toEqual(0);
|
|
126
|
+
swarm1.onSwarmEvent({
|
|
127
|
+
peerAvailable: {
|
|
128
|
+
peer: peerId2.asUint8Array(),
|
|
129
|
+
since: new Date()
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
await (0, async_1.sleep)(15);
|
|
133
|
+
swarm2.onSwarmEvent({
|
|
134
|
+
peerAvailable: {
|
|
135
|
+
peer: peerId1.asUint8Array(),
|
|
136
|
+
since: new Date()
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
await Promise.all([
|
|
140
|
+
swarm1.connected.waitForCount(1),
|
|
141
|
+
swarm1.connected.waitForCount(1)
|
|
142
|
+
]);
|
|
143
|
+
const swarm1Connection = swarm1.connections[0];
|
|
144
|
+
const swarm2Connection = swarm2.connections[0];
|
|
145
|
+
const onData = (0, earljs_1.mockFn)().returns(undefined);
|
|
146
|
+
swarm2Connection.transport.peer.on('data', onData);
|
|
147
|
+
const data = Buffer.from('1234');
|
|
148
|
+
swarm1Connection.transport.peer.send(data);
|
|
149
|
+
await (0, wait_for_expect_1.default)(() => {
|
|
150
|
+
(0, earljs_1.expect)(onData).toHaveBeenCalledWith([data]);
|
|
151
|
+
});
|
|
152
|
+
}).timeout(5000);
|
|
153
|
+
(0, mocha_1.it)('swarming with message router', async () => {
|
|
154
|
+
const { swarm1, swarm2, peerId2 } = setup({ router: true });
|
|
155
|
+
const promise = Promise.all([
|
|
156
|
+
(0, async_1.promiseTimeout)(swarm1.connected.waitForCount(1), 3000, new Error('Swarm1 connect timeout.')),
|
|
157
|
+
(0, async_1.promiseTimeout)(swarm2.connected.waitForCount(1), 3000, new Error('Swarm2 connect timeout.'))
|
|
158
|
+
]);
|
|
159
|
+
swarm1.onSwarmEvent({
|
|
160
|
+
peerAvailable: {
|
|
161
|
+
peer: peerId2.asUint8Array(),
|
|
162
|
+
since: new Date()
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
log('Candidates changed');
|
|
166
|
+
await promise;
|
|
167
|
+
log('Swarms connected');
|
|
168
|
+
const swarm1Connection = swarm1.connections[0];
|
|
169
|
+
const swarm2Connection = swarm2.connections[0];
|
|
170
|
+
const onData = (0, earljs_1.mockFn)().returns(undefined);
|
|
171
|
+
swarm2Connection.transport.peer.on('data', onData);
|
|
172
|
+
const data = Buffer.from('1234');
|
|
173
|
+
swarm1Connection.transport.peer.send(data);
|
|
174
|
+
await (0, wait_for_expect_1.default)(() => {
|
|
175
|
+
(0, earljs_1.expect)(onData).toHaveBeenCalledWith([data]);
|
|
176
|
+
});
|
|
61
177
|
await swarm1.destroy();
|
|
62
178
|
await swarm2.destroy();
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
};
|
|
66
|
-
(0, mocha_1.it)('connects two peers in a swarm', async () => {
|
|
67
|
-
const { swarm1, swarm2, peerId2 } = setup();
|
|
68
|
-
(0, earljs_1.expect)(swarm1.connections.length).toEqual(0);
|
|
69
|
-
(0, earljs_1.expect)(swarm2.connections.length).toEqual(0);
|
|
70
|
-
const promise = Promise.all([
|
|
71
|
-
(0, async_1.promiseTimeout)(swarm1.connected.waitForCount(1), 3000, new Error('Swarm1 connect timeout.')),
|
|
72
|
-
(0, async_1.promiseTimeout)(swarm2.connected.waitForCount(1), 3000, new Error('Swarm2 connect timeout.'))
|
|
73
|
-
]);
|
|
74
|
-
swarm1.onPeerCandidatesChanged([peerId2]);
|
|
75
|
-
log('Candidates changed');
|
|
76
|
-
await promise;
|
|
77
|
-
log('Swarms connected');
|
|
78
|
-
const swarm1Connection = swarm1.connections[0];
|
|
79
|
-
const swarm2Connection = swarm2.connections[0];
|
|
80
|
-
const onData = (0, earljs_1.mockFn)().returns(undefined);
|
|
81
|
-
swarm2Connection.transport.peer.on('data', onData);
|
|
82
|
-
const data = Buffer.from('1234');
|
|
83
|
-
swarm1Connection.transport.peer.send(data);
|
|
84
|
-
await (0, wait_for_expect_1.default)(() => {
|
|
85
|
-
(0, earljs_1.expect)(onData).toHaveBeenCalledWith([data]);
|
|
86
|
-
});
|
|
87
|
-
}).timeout(5000);
|
|
88
|
-
(0, mocha_1.it)('two peers try to originate connections to each other simultaneously', async () => {
|
|
89
|
-
const { swarm1, swarm2, peerId1, peerId2 } = setup();
|
|
90
|
-
(0, earljs_1.expect)(swarm1.connections.length).toEqual(0);
|
|
91
|
-
(0, earljs_1.expect)(swarm2.connections.length).toEqual(0);
|
|
92
|
-
swarm1.onPeerCandidatesChanged([peerId2]);
|
|
93
|
-
swarm2.onPeerCandidatesChanged([peerId1]);
|
|
94
|
-
await Promise.all([
|
|
95
|
-
swarm1.connected.waitForCount(1),
|
|
96
|
-
swarm2.connected.waitForCount(1)
|
|
97
|
-
]);
|
|
98
|
-
}).timeout(5000);
|
|
99
|
-
(0, mocha_1.it)('second peer discovered after delay', async () => {
|
|
100
|
-
const { swarm1, swarm2, peerId1, peerId2 } = setup();
|
|
101
|
-
(0, earljs_1.expect)(swarm1.connections.length).toEqual(0);
|
|
102
|
-
(0, earljs_1.expect)(swarm2.connections.length).toEqual(0);
|
|
103
|
-
swarm1.onPeerCandidatesChanged([peerId2]);
|
|
104
|
-
await (0, async_1.sleep)(15);
|
|
105
|
-
swarm2.onPeerCandidatesChanged([peerId1]);
|
|
106
|
-
await Promise.all([
|
|
107
|
-
swarm1.connected.waitForCount(1),
|
|
108
|
-
swarm1.connected.waitForCount(1)
|
|
109
|
-
]);
|
|
110
|
-
const swarm1Connection = swarm1.connections[0];
|
|
111
|
-
const swarm2Connection = swarm2.connections[0];
|
|
112
|
-
const onData = (0, earljs_1.mockFn)().returns(undefined);
|
|
113
|
-
swarm2Connection.transport.peer.on('data', onData);
|
|
114
|
-
const data = Buffer.from('1234');
|
|
115
|
-
swarm1Connection.transport.peer.send(data);
|
|
116
|
-
await (0, wait_for_expect_1.default)(() => {
|
|
117
|
-
(0, earljs_1.expect)(onData).toHaveBeenCalledWith([data]);
|
|
118
|
-
});
|
|
119
|
-
}).timeout(5000);
|
|
120
|
-
(0, mocha_1.it)('swarming with message router', async () => {
|
|
121
|
-
const { swarm1, swarm2, peerId2 } = setup({ router: true });
|
|
122
|
-
const promise = Promise.all([
|
|
123
|
-
(0, async_1.promiseTimeout)(swarm1.connected.waitForCount(1), 3000, new Error('Swarm1 connect timeout.')),
|
|
124
|
-
(0, async_1.promiseTimeout)(swarm2.connected.waitForCount(1), 3000, new Error('Swarm2 connect timeout.'))
|
|
125
|
-
]);
|
|
126
|
-
swarm1.onPeerCandidatesChanged([peerId2]);
|
|
127
|
-
log('Candidates changed');
|
|
128
|
-
await promise;
|
|
129
|
-
log('Swarms connected');
|
|
130
|
-
const swarm1Connection = swarm1.connections[0];
|
|
131
|
-
const swarm2Connection = swarm2.connections[0];
|
|
132
|
-
const onData = (0, earljs_1.mockFn)().returns(undefined);
|
|
133
|
-
swarm2Connection.transport.peer.on('data', onData);
|
|
134
|
-
const data = Buffer.from('1234');
|
|
135
|
-
swarm1Connection.transport.peer.send(data);
|
|
136
|
-
await (0, wait_for_expect_1.default)(() => {
|
|
137
|
-
(0, earljs_1.expect)(onData).toHaveBeenCalledWith([data]);
|
|
138
|
-
});
|
|
139
|
-
await swarm1.destroy();
|
|
140
|
-
await swarm2.destroy();
|
|
141
|
-
}).timeout(5000);
|
|
179
|
+
}).timeout(5000);
|
|
180
|
+
});
|
|
142
181
|
//# sourceMappingURL=swarm.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"swarm.test.js","sourceRoot":"","sources":["../../../src/swarm/swarm.test.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;AAEF,kDAA0B;AAC1B,mCAAwC;AACxC,iCAAmC;AACnC,sEAA4C;AAE5C,uCAAoD;AACpD,uDAA+C;AAC/C,+CAA4C;AAC5C,+CAA4C;AAI5C,6DAAyD;AACzD,0CAAqD;AACrD,4CAA6E;AAC7E,mCAAgC;AAEhC,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,iCAAiC,CAAC,CAAC;AAErD,MAAM,oBAAoB;
|
|
1
|
+
{"version":3,"file":"swarm.test.js","sourceRoot":"","sources":["../../../src/swarm/swarm.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,6 @@ import { PublicKey } from '@dxos/protocols';
|
|
|
2
2
|
import { SwarmController, Topology } from './topology';
|
|
3
3
|
export declare class FullyConnectedTopology implements Topology {
|
|
4
4
|
private _controller?;
|
|
5
|
-
private _intervalId?;
|
|
6
5
|
init(controller: SwarmController): void;
|
|
7
6
|
update(): void;
|
|
8
7
|
onOffer(peer: PublicKey): Promise<boolean>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fully-connected-topology.d.ts","sourceRoot":"","sources":["../../../src/topology/fully-connected-topology.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEvD,qBAAa,sBAAuB,YAAW,QAAQ;IACrD,OAAO,CAAC,WAAW,CAAC,CAAkB;IAEtC,
|
|
1
|
+
{"version":3,"file":"fully-connected-topology.d.ts","sourceRoot":"","sources":["../../../src/topology/fully-connected-topology.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEvD,qBAAa,sBAAuB,YAAW,QAAQ;IACrD,OAAO,CAAC,WAAW,CAAC,CAAkB;IAEtC,IAAI,CAAE,UAAU,EAAE,eAAe,GAAG,IAAI;IAKxC,MAAM,IAAK,IAAI;IAQT,OAAO,CAAE,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC;IAI3C,OAAO,IAAK,OAAO,CAAC,IAAI,CAAC;IAI/B,QAAQ;CAGT"}
|
|
@@ -12,9 +12,6 @@ class FullyConnectedTopology {
|
|
|
12
12
|
init(controller) {
|
|
13
13
|
(0, node_assert_1.default)(!this._controller, 'Already initialized');
|
|
14
14
|
this._controller = controller;
|
|
15
|
-
this._intervalId = setInterval(() => {
|
|
16
|
-
controller.lookup();
|
|
17
|
-
}, 10000);
|
|
18
15
|
}
|
|
19
16
|
update() {
|
|
20
17
|
(0, node_assert_1.default)(this._controller, 'Not initialized');
|
|
@@ -27,9 +24,7 @@ class FullyConnectedTopology {
|
|
|
27
24
|
return true;
|
|
28
25
|
}
|
|
29
26
|
async destroy() {
|
|
30
|
-
|
|
31
|
-
clearInterval(this._intervalId);
|
|
32
|
-
}
|
|
27
|
+
// Nothing to do.
|
|
33
28
|
}
|
|
34
29
|
toString() {
|
|
35
30
|
return 'FullyConnectedTopology';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fully-connected-topology.js","sourceRoot":"","sources":["../../../src/topology/fully-connected-topology.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,8DAAiC;AAMjC,MAAa,sBAAsB;
|
|
1
|
+
{"version":3,"file":"fully-connected-topology.js","sourceRoot":"","sources":["../../../src/topology/fully-connected-topology.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,8DAAiC;AAMjC,MAAa,sBAAsB;IAGjC,IAAI,CAAE,UAA2B;QAC/B,IAAA,qBAAM,EAAC,CAAC,IAAI,CAAC,WAAW,EAAE,qBAAqB,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;IAChC,CAAC;IAED,MAAM;QACJ,IAAA,qBAAM,EAAC,IAAI,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAC;QAC5C,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC/D,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE;YAC7B,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SAChC;IACH,CAAC;IAED,KAAK,CAAC,OAAO,CAAE,IAAe;QAC5B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,OAAO;QACX,iBAAiB;IACnB,CAAC;IAED,QAAQ;QACN,OAAO,wBAAwB,CAAC;IAClC,CAAC;CACF;AA3BD,wDA2BC"}
|
|
@@ -19,7 +19,6 @@ export declare class MMSTTopology implements Topology {
|
|
|
19
19
|
private readonly _maxPeers;
|
|
20
20
|
private readonly _sampleSize;
|
|
21
21
|
private _controller?;
|
|
22
|
-
private _lookupIntervalId?;
|
|
23
22
|
private _sampleCollected;
|
|
24
23
|
constructor({ originateConnections, maxPeers, sampleSize }?: MMSTTopologyOptions);
|
|
25
24
|
init(controller: SwarmController): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mmst-topology.d.ts","sourceRoot":"","sources":["../../../src/topology/mmst-topology.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAIvD,MAAM,WAAW,mBAAmB;IAClC;;OAEG;IACH,oBAAoB,CAAC,EAAE,MAAM,CAAA;IAE7B;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAA;IAEjB;;OAEG;IACH,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB;AAED,qBAAa,YAAa,YAAW,QAAQ;IAC3C,OAAO,CAAC,QAAQ,CAAC,qBAAqB,CAAS;IAC/C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IAErC,OAAO,CAAC,WAAW,CAAC,CAAkB;IAEtC,OAAO,CAAC,
|
|
1
|
+
{"version":3,"file":"mmst-topology.d.ts","sourceRoot":"","sources":["../../../src/topology/mmst-topology.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAIvD,MAAM,WAAW,mBAAmB;IAClC;;OAEG;IACH,oBAAoB,CAAC,EAAE,MAAM,CAAA;IAE7B;;OAEG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAA;IAEjB;;OAEG;IACH,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB;AAED,qBAAa,YAAa,YAAW,QAAQ;IAC3C,OAAO,CAAC,QAAQ,CAAC,qBAAqB,CAAS;IAC/C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IAErC,OAAO,CAAC,WAAW,CAAC,CAAkB;IAEtC,OAAO,CAAC,gBAAgB,CAAS;gBAEpB,EACX,oBAAwB,EACxB,QAAY,EACZ,UAAe,EAChB,GAAE,mBAAwB;IAM3B,IAAI,CAAE,UAAU,EAAE,eAAe,GAAG,IAAI;IAKxC,MAAM,IAAK,IAAI;IAWT,OAAO,CAAE,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC;IAQ3C,OAAO,IAAK,OAAO,CAAC,IAAI,CAAC;IAI/B,OAAO,CAAC,aAAa;IAsBrB,QAAQ;CAGT"}
|
|
@@ -21,9 +21,6 @@ class MMSTTopology {
|
|
|
21
21
|
init(controller) {
|
|
22
22
|
(0, node_assert_1.default)(!this._controller, 'Already initialized');
|
|
23
23
|
this._controller = controller;
|
|
24
|
-
this._lookupIntervalId = setInterval(() => {
|
|
25
|
-
controller.lookup();
|
|
26
|
-
}, 10000);
|
|
27
24
|
}
|
|
28
25
|
update() {
|
|
29
26
|
(0, node_assert_1.default)(this._controller, 'Not initialized');
|
|
@@ -43,9 +40,7 @@ class MMSTTopology {
|
|
|
43
40
|
return accept;
|
|
44
41
|
}
|
|
45
42
|
async destroy() {
|
|
46
|
-
|
|
47
|
-
clearInterval(this._lookupIntervalId);
|
|
48
|
-
}
|
|
43
|
+
// Nothing to do.
|
|
49
44
|
}
|
|
50
45
|
_runAlgorithm() {
|
|
51
46
|
(0, node_assert_1.default)(this._controller, 'Not initialized');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mmst-topology.js","sourceRoot":"","sources":["../../../src/topology/mmst-topology.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,kDAA0B;AAC1B,8DAAiC;AACjC,gEAAoC;AAMpC,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,6CAA6C,CAAC,CAAC;AAmBjE,MAAa,YAAY;
|
|
1
|
+
{"version":3,"file":"mmst-topology.js","sourceRoot":"","sources":["../../../src/topology/mmst-topology.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,6 @@ import { SwarmController, Topology } from './topology';
|
|
|
3
3
|
export declare class StarTopology implements Topology {
|
|
4
4
|
private readonly _centralPeer;
|
|
5
5
|
private _controller?;
|
|
6
|
-
private _intervalId?;
|
|
7
6
|
constructor(_centralPeer: PublicKey);
|
|
8
7
|
toString(): string;
|
|
9
8
|
init(controller: SwarmController): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"star-topology.d.ts","sourceRoot":"","sources":["../../../src/topology/star-topology.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAIvD,qBAAa,YAAa,YAAW,QAAQ;
|
|
1
|
+
{"version":3,"file":"star-topology.d.ts","sourceRoot":"","sources":["../../../src/topology/star-topology.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAIvD,qBAAa,YAAa,YAAW,QAAQ;IAIzC,OAAO,CAAC,QAAQ,CAAC,YAAY;IAH/B,OAAO,CAAC,WAAW,CAAC,CAAkB;gBAGnB,YAAY,EAAE,SAAS;IAG1C,QAAQ;IAIR,IAAI,CAAE,UAAU,EAAE,eAAe,GAAG,IAAI;IAKxC,MAAM,IAAK,IAAI;IAuBT,OAAO,CAAE,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC;IAO3C,OAAO,IAAK,OAAO,CAAC,IAAI,CAAC;CAGhC"}
|
|
@@ -20,9 +20,6 @@ class StarTopology {
|
|
|
20
20
|
init(controller) {
|
|
21
21
|
(0, node_assert_1.default)(!this._controller, 'Already initialized.');
|
|
22
22
|
this._controller = controller;
|
|
23
|
-
this._intervalId = setInterval(() => {
|
|
24
|
-
controller.lookup();
|
|
25
|
-
}, 10000);
|
|
26
23
|
}
|
|
27
24
|
update() {
|
|
28
25
|
(0, node_assert_1.default)(this._controller, 'Not initialized.');
|
|
@@ -52,9 +49,7 @@ class StarTopology {
|
|
|
52
49
|
return ownPeerId.equals(this._centralPeer) || peer.equals(this._centralPeer);
|
|
53
50
|
}
|
|
54
51
|
async destroy() {
|
|
55
|
-
|
|
56
|
-
clearInterval(this._intervalId);
|
|
57
|
-
}
|
|
52
|
+
// Nothing to do.
|
|
58
53
|
}
|
|
59
54
|
}
|
|
60
55
|
exports.StarTopology = StarTopology;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"star-topology.js","sourceRoot":"","sources":["../../../src/topology/star-topology.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,kDAA0B;AAC1B,8DAAiC;AAMjC,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,oCAAoC,CAAC,CAAC;AAExD,MAAa,YAAY;
|
|
1
|
+
{"version":3,"file":"star-topology.js","sourceRoot":"","sources":["../../../src/topology/star-topology.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,kDAA0B;AAC1B,8DAAiC;AAMjC,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,oCAAoC,CAAC,CAAC;AAExD,MAAa,YAAY;IAGvB,YACmB,YAAuB;QAAvB,iBAAY,GAAZ,YAAY,CAAW;IACvC,CAAC;IAEJ,QAAQ;QACN,OAAO,gBAAgB,IAAI,CAAC,YAAY,GAAG,CAAC;IAC9C,CAAC;IAED,IAAI,CAAE,UAA2B;QAC/B,IAAA,qBAAM,EAAC,CAAC,IAAI,CAAC,WAAW,EAAE,sBAAsB,CAAC,CAAC;QAClD,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;IAChC,CAAC;IAED,MAAM;QACJ,IAAA,qBAAM,EAAC,IAAI,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;QAC7C,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QACzE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;YACxC,GAAG,CAAC,gEAAgE,CAAC,CAAC;YACtE,gDAAgD;YAChD,KAAK,MAAM,IAAI,IAAI,SAAS,EAAE;gBAC5B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;oBACnC,GAAG,CAAC,6BAA6B,IAAI,EAAE,CAAC,CAAC;oBACzC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;iBACnC;aACF;SACF;QAED,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE;YAC7B,2BAA2B;YAC3B,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;gBACzE,GAAG,CAAC,sBAAsB,IAAI,EAAE,CAAC,CAAC;gBAClC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;aAChC;SACF;IACH,CAAC;IAED,KAAK,CAAC,OAAO,CAAE,IAAe;QAC5B,IAAA,qBAAM,EAAC,IAAI,CAAC,WAAW,EAAE,kBAAkB,CAAC,CAAC;QAC7C,MAAM,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAClD,GAAG,CAAC,cAAc,IAAI,cAAc,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,kBAAkB,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;QAC3H,OAAO,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC/E,CAAC;IAED,KAAK,CAAC,OAAO;QACX,iBAAiB;IACnB,CAAC;CACF;AAjDD,oCAiDC"}
|
|
@@ -12,12 +12,6 @@ export interface SwarmController {
|
|
|
12
12
|
* Disconnect from a peer.
|
|
13
13
|
*/
|
|
14
14
|
disconnect(peer: PublicKey): void;
|
|
15
|
-
/**
|
|
16
|
-
* Trigger a lookup of any other peers swarming on this topic.
|
|
17
|
-
*
|
|
18
|
-
* Updates will be propagated through `update` method.
|
|
19
|
-
*/
|
|
20
|
-
lookup(): void;
|
|
21
15
|
}
|
|
22
16
|
export interface SwarmState {
|
|
23
17
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"topology.d.ts","sourceRoot":"","sources":["../../../src/topology/topology.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,MAAM,WAAW,eAAe;IAC9B;;OAEG;IACH,QAAQ,IAAI,UAAU,CAAC;IAEvB;;OAEG;IACH,OAAO,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,CAAC;IAE/B;;OAEG;IACH,UAAU,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"topology.d.ts","sourceRoot":"","sources":["../../../src/topology/topology.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,MAAM,WAAW,eAAe;IAC9B;;OAEG;IACH,QAAQ,IAAI,UAAU,CAAC;IAEvB;;OAEG;IACH,OAAO,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,CAAC;IAE/B;;OAEG;IACH,UAAU,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,CAAC;CACnC;AAED,MAAM,WAAW,UAAU;IACzB;;OAEG;IACH,SAAS,EAAE,SAAS,CAAA;IAEpB;;OAEG;IACH,SAAS,EAAE,SAAS,EAAE,CAAA;IAEtB;;OAEG;IACH,UAAU,EAAE,SAAS,EAAE,CAAA;CACxB;AAED,MAAM,WAAW,QAAQ;IACvB;;;;;;OAMG;IACH,IAAI,CAAC,UAAU,EAAE,eAAe,GAAG,IAAI,CAAC;IAExC;;OAEG;IACH,MAAM,IAAI,IAAI,CAAC;IAEf;;;;OAIG;IACH,OAAO,CAAC,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAE3C;;;;OAIG;IACH,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC1B"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { Event } from '@dxos/async';
|
|
3
3
|
import { ErrorStream } from '@dxos/debug';
|
|
4
4
|
import { PublicKey } from '@dxos/protocols';
|
|
5
|
-
import {
|
|
5
|
+
import { SignalMessage } from '../proto/gen/dxos/mesh/signalMessage';
|
|
6
6
|
import { Transport, TransportFactory } from './transport';
|
|
7
7
|
export declare class InMemoryTransport implements Transport {
|
|
8
8
|
private readonly _ownId;
|
|
@@ -22,7 +22,7 @@ export declare class InMemoryTransport implements Transport {
|
|
|
22
22
|
constructor(_ownId: PublicKey, _remoteId: PublicKey, _sessionId: PublicKey, _topic: PublicKey, _stream: NodeJS.ReadWriteStream);
|
|
23
23
|
get remoteId(): PublicKey;
|
|
24
24
|
get sessionId(): PublicKey;
|
|
25
|
-
signal(msg:
|
|
25
|
+
signal(msg: SignalMessage): Promise<void>;
|
|
26
26
|
close(): Promise<void>;
|
|
27
27
|
}
|
|
28
28
|
export declare const inMemoryTransportFactory: TransportFactory;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"in-memory-transport.d.ts","sourceRoot":"","sources":["../../../src/transport/in-memory-transport.ts"],"names":[],"mappings":";AAQA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAG5C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"in-memory-transport.d.ts","sourceRoot":"","sources":["../../../src/transport/in-memory-transport.ts"],"names":[],"mappings":";AAQA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAG5C,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AACrE,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAU1D,qBAAa,iBAAkB,YAAW,SAAS;IAmB/C,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO;IApB1B,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,YAAY,CACgD;IAEpF,SAAgB,MAAM,cAAqB;IAC3C,SAAgB,SAAS,cAAqB;IAC9C,SAAgB,MAAM,cAAqB;IAE3C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAgB;IACxC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAgB;IAE3C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAgD;IAC/E,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAgD;IAE/E,OAAO,CAAC,iBAAiB,CAAC,CAAoB;gBAG3B,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,SAAS,EACrB,MAAM,EAAE,SAAS,EACjB,OAAO,EAAE,MAAM,CAAC,eAAe;IA0BlD,IAAI,QAAQ,IAAK,SAAS,CAEzB;IAED,IAAI,SAAS,IAAK,SAAS,CAE1B;IAEK,MAAM,CAAE,GAAG,EAAE,aAAa;IAI1B,KAAK,IAAK,OAAO,CAAC,IAAI,CAAC;CA0B9B;AAGD,eAAO,MAAM,wBAAwB,EAAE,gBAMtC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"in-memory-transport.js","sourceRoot":"","sources":["../../../src/transport/in-memory-transport.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,kDAA0B;AAC1B,8DAAiC;AACjC,mCAAmC;AAEnC,uCAAoC;AACpC,uCAA0C;AAE1C,qCAAwC;AAKxC,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,0DAA0D,CAAC,CAAC;AAI9E,yGAAyG;AACzG,MAAM,yBAAyB,GAAG,CAAC,CAAC;AAEpC,wBAAwB;AACxB,MAAa,iBAAiB;IAkB5B,YACmB,MAAiB,EACjB,SAAoB,EACpB,UAAqB,EACrB,MAAiB,EACjB,OAA+B;QAJ/B,WAAM,GAAN,MAAM,CAAW;QACjB,cAAS,GAAT,SAAS,CAAW;QACpB,eAAU,GAAV,UAAU,CAAW;QACrB,WAAM,GAAN,MAAM,CAAW;QACjB,YAAO,GAAP,OAAO,CAAwB;QAjBlC,WAAM,GAAG,IAAI,aAAK,EAAQ,CAAC;QAC3B,cAAS,GAAG,IAAI,aAAK,EAAQ,CAAC;QAC9B,WAAM,GAAG,IAAI,mBAAW,EAAE,CAAC;QAK1B,mBAAc,GAAG,iBAAiB,CAAC,yBAAyB,CAAC,CAAC;QAC9D,mBAAc,GAAG,iBAAiB,CAAC,yBAAyB,CAAC,CAAC;QAW7E,GAAG,CAAC,gCAAgC,IAAI,CAAC,MAAM,WAAW,IAAI,CAAC,MAAM,aAAa,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAEpG,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1D,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;QAE7D,IAAA,qBAAM,EAAC,CAAC,iBAAiB,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,gCAAgC,CAAC,CAAC;QAC5F,iBAAiB,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QAEvD,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC7E,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAEhD,GAAG,CAAC,2CAA2C,IAAI,CAAC,MAAM,WAAW,IAAI,CAAC,MAAM,aAAa,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;YAC/G,IAAI,CAAC,OAAO;iBACT,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;iBACzB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC;iBACpC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;iBACzB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAEtB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;SACzC;IACH,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,MAAM,CAAE,
|
|
1
|
+
{"version":3,"file":"in-memory-transport.js","sourceRoot":"","sources":["../../../src/transport/in-memory-transport.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { Event } from '@dxos/async';
|
|
3
3
|
import { ErrorStream } from '@dxos/debug';
|
|
4
4
|
import { PublicKey } from '@dxos/protocols';
|
|
5
|
-
import {
|
|
5
|
+
import { SignalMessage } from '../proto/gen/dxos/mesh/signalMessage';
|
|
6
6
|
/**
|
|
7
7
|
* Abstraction over a P2P connection transport. Currently either WebRTC or in-memory.
|
|
8
8
|
*/
|
|
@@ -10,7 +10,7 @@ export interface Transport {
|
|
|
10
10
|
closed: Event;
|
|
11
11
|
connected: Event;
|
|
12
12
|
errors: ErrorStream;
|
|
13
|
-
signal(msg:
|
|
13
|
+
signal(msg: SignalMessage): Promise<void>;
|
|
14
14
|
close(): Promise<void>;
|
|
15
15
|
}
|
|
16
16
|
export interface TransportOptions {
|
|
@@ -29,7 +29,7 @@ export interface TransportOptions {
|
|
|
29
29
|
/**
|
|
30
30
|
* Send a signal message to remote peer.
|
|
31
31
|
*/
|
|
32
|
-
sendSignal: (msg:
|
|
32
|
+
sendSignal: (msg: SignalMessage) => Promise<void>;
|
|
33
33
|
}
|
|
34
34
|
export declare type TransportFactory = (options: TransportOptions) => Transport;
|
|
35
35
|
//# sourceMappingURL=transport.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transport.d.ts","sourceRoot":"","sources":["../../../src/transport/transport.ts"],"names":[],"mappings":";AAIA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"transport.d.ts","sourceRoot":"","sources":["../../../src/transport/transport.ts"],"names":[],"mappings":";AAIA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAErE;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,MAAM,EAAE,KAAK,CAAA;IACb,SAAS,EAAE,KAAK,CAAA;IAChB,MAAM,EAAE,WAAW,CAAA;IACnB,MAAM,CAAE,GAAG,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAC1C,KAAK,IAAK,OAAO,CAAC,IAAI,CAAC,CAAA;CACxB;AAED,MAAM,WAAW,gBAAgB;IAC/B;;OAEG;IACH,SAAS,EAAE,OAAO,CAAA;IAElB,KAAK,EAAE,SAAS,CAAA;IAChB,QAAQ,EAAE,SAAS,CAAA;IACnB,SAAS,EAAE,SAAS,CAAA;IACpB,KAAK,EAAE,SAAS,CAAA;IAEhB;;OAEG;IACH,MAAM,EAAE,MAAM,CAAC,eAAe,CAAA;IAE9B;;OAEG;IACH,UAAU,EAAE,CAAC,GAAG,EAAE,aAAa,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;CAClD;AAED,oBAAY,gBAAgB,GAAG,CAAC,OAAO,EAAE,gBAAgB,KAAK,SAAS,CAAA"}
|
|
@@ -3,7 +3,7 @@ import SimplePeerConstructor from 'simple-peer';
|
|
|
3
3
|
import { Event } from '@dxos/async';
|
|
4
4
|
import { ErrorStream } from '@dxos/debug';
|
|
5
5
|
import { PublicKey } from '@dxos/protocols';
|
|
6
|
-
import {
|
|
6
|
+
import { SignalMessage } from '../proto/gen/dxos/mesh/signalMessage';
|
|
7
7
|
import { Transport, TransportFactory } from './transport';
|
|
8
8
|
/**
|
|
9
9
|
* Implements Transport for WebRTC. Uses simple-peer under the hood.
|
|
@@ -21,11 +21,11 @@ export declare class WebRTCTransport implements Transport {
|
|
|
21
21
|
readonly closed: Event<void>;
|
|
22
22
|
readonly connected: Event<void>;
|
|
23
23
|
readonly errors: ErrorStream;
|
|
24
|
-
constructor(_initiator: boolean, _stream: NodeJS.ReadWriteStream, _ownId: PublicKey, _remoteId: PublicKey, _sessionId: PublicKey, _topic: PublicKey, _sendSignal: (msg:
|
|
24
|
+
constructor(_initiator: boolean, _stream: NodeJS.ReadWriteStream, _ownId: PublicKey, _remoteId: PublicKey, _sessionId: PublicKey, _topic: PublicKey, _sendSignal: (msg: SignalMessage) => void, _webrtcConfig?: any);
|
|
25
25
|
get remoteId(): PublicKey;
|
|
26
26
|
get sessionId(): PublicKey;
|
|
27
27
|
get peer(): SimplePeerConstructor.Instance;
|
|
28
|
-
signal(msg:
|
|
28
|
+
signal(msg: SignalMessage): Promise<void>;
|
|
29
29
|
close(): Promise<void>;
|
|
30
30
|
private _disconnectStreams;
|
|
31
31
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"webrtc-transport.d.ts","sourceRoot":"","sources":["../../../src/transport/webrtc-transport.ts"],"names":[],"mappings":";AAOA,OAAO,qBAAiD,MAAM,aAAa,CAAC;AAE5E,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"webrtc-transport.d.ts","sourceRoot":"","sources":["../../../src/transport/webrtc-transport.ts"],"names":[],"mappings":";AAOA,OAAO,qBAAiD,MAAM,aAAa,CAAC;AAE5E,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AACrE,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAI1D;;GAEG;AACH,qBAAa,eAAgB,YAAW,SAAS;IAU7C,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAC;IAhBjC,OAAO,CAAC,KAAK,CAAa;IAE1B,QAAQ,CAAC,MAAM,cAAe;IAE9B,QAAQ,CAAC,SAAS,cAAe;IAEjC,QAAQ,CAAC,MAAM,cAAqB;gBAGjB,UAAU,EAAE,OAAO,EACnB,OAAO,EAAE,MAAM,CAAC,eAAe,EAC/B,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,SAAS,EACpB,UAAU,EAAE,SAAS,EACrB,MAAM,EAAE,SAAS,EACjB,WAAW,EAAE,CAAC,GAAG,EAAE,aAAa,KAAK,IAAI,EACzC,aAAa,CAAC,KAAK;IAyCtC,IAAI,QAAQ,cAEX;IAED,IAAI,SAAS,cAEZ;IAED,IAAI,IAAI,mCAEP;IAEK,MAAM,CAAE,GAAG,EAAE,aAAa;IAM1B,KAAK;YAMG,kBAAkB;CAIjC;AAED,eAAO,MAAM,4BAA4B,kBAAmB,GAAG,KAAG,gBASjE,CAAC"}
|