@dxos/network-manager 2.16.17 → 2.17.3
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/browser-mocha/bundle.js +3110 -3092
- package/dist/src/connection-log.d.ts +1 -1
- package/dist/src/connection-log.d.ts.map +1 -1
- package/dist/src/connection-log.js +3 -3
- package/dist/src/connection-log.js.map +1 -1
- package/dist/src/network-manager.blueprint-test.js +31 -31
- package/dist/src/network-manager.blueprint-test.js.map +1 -1
- package/dist/src/network-manager.browser-test.js +2 -2
- package/dist/src/network-manager.browser-test.js.map +1 -1
- package/dist/src/network-manager.js +7 -7
- package/dist/src/network-manager.js.map +1 -1
- package/dist/src/network-manager.test.js +3 -3
- package/dist/src/network-manager.test.js.map +1 -1
- package/dist/src/presence.test.js +10 -10
- package/dist/src/presence.test.js.map +1 -1
- package/dist/src/protocol-factory.js +9 -9
- package/dist/src/protocol-factory.js.map +1 -1
- package/dist/src/signal/in-memory-signal-manager.js +2 -2
- package/dist/src/signal/in-memory-signal-manager.js.map +1 -1
- package/dist/src/signal/signal-api.js +1 -1
- package/dist/src/signal/signal-api.js.map +1 -1
- package/dist/src/signal/signal-api.test.js +25 -25
- package/dist/src/signal/signal-api.test.js.map +1 -1
- package/dist/src/signal/websocket-rpc.js +6 -6
- package/dist/src/signal/websocket-rpc.js.map +1 -1
- package/dist/src/signal/websocket-signal-manager.js +2 -2
- package/dist/src/signal/websocket-signal-manager.js.map +1 -1
- package/dist/src/swarm/connection.js +6 -6
- package/dist/src/swarm/connection.js.map +1 -1
- package/dist/src/swarm/swarm-mapper.js +1 -1
- package/dist/src/swarm/swarm-mapper.js.map +1 -1
- package/dist/src/swarm/swarm.d.ts +1 -1
- package/dist/src/swarm/swarm.d.ts.map +1 -1
- package/dist/src/swarm/swarm.js +7 -7
- package/dist/src/swarm/swarm.js.map +1 -1
- package/dist/src/swarm/swarm.test.js +26 -26
- package/dist/src/swarm/swarm.test.js.map +1 -1
- package/dist/src/testing/test-protocol.js +12 -12
- package/dist/src/testing/test-protocol.js.map +1 -1
- package/dist/src/topology/fully-connected-topology.js +2 -2
- package/dist/src/topology/fully-connected-topology.js.map +1 -1
- package/dist/src/topology/mmst-topology.js +6 -6
- package/dist/src/topology/mmst-topology.js.map +1 -1
- package/dist/src/topology/star-topology.js +4 -4
- package/dist/src/topology/star-topology.js.map +1 -1
- package/dist/src/transport/in-memory-transport.js +2 -2
- package/dist/src/transport/in-memory-transport.js.map +1 -1
- package/dist/src/transport/in-memory-transport.test.js +17 -17
- package/dist/src/transport/in-memory-transport.test.js.map +1 -1
- package/dist/src/transport/webrtc-transport.js +2 -2
- package/dist/src/transport/webrtc-transport.js.map +1 -1
- package/dist/src/transport/webrtc-transport.test.js +19 -19
- package/dist/src/transport/webrtc-transport.test.js.map +1 -1
- package/dist/src/transport/wrtc-simple-peer.test.js +1 -1
- package/dist/src/transport/wrtc-simple-peer.test.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +9 -9
- package/src/connection-log.ts +2 -2
- package/src/signal/signal-api.ts +1 -1
- package/src/signal/websocket-rpc.ts +5 -5
- package/src/swarm/swarm.ts +3 -3
- package/src/transport/webrtc-transport.ts +1 -1
|
@@ -14,13 +14,13 @@ const events_1 = require("events");
|
|
|
14
14
|
const crypto_1 = require("@dxos/crypto");
|
|
15
15
|
const protocol_1 = require("@dxos/protocol");
|
|
16
16
|
const protocol_factory_1 = require("../protocol-factory");
|
|
17
|
-
const log = debug_1.default('dxos:network-manager:test');
|
|
17
|
+
const log = (0, debug_1.default)('dxos:network-manager:test');
|
|
18
18
|
const EXTENSION_NAME = 'test';
|
|
19
19
|
// TODO(dboreham): This method should be added to Protocol (and one for "my ID"?).
|
|
20
20
|
const getPeerId = (protocol) => {
|
|
21
21
|
var _a;
|
|
22
22
|
const { peerId } = (_a = protocol.getSession()) !== null && _a !== void 0 ? _a : {};
|
|
23
|
-
return crypto_1.keyToBuffer(peerId);
|
|
23
|
+
return (0, crypto_1.keyToBuffer)(peerId);
|
|
24
24
|
};
|
|
25
25
|
exports.getPeerId = getPeerId;
|
|
26
26
|
/**
|
|
@@ -39,7 +39,7 @@ class TestProtocolPlugin extends events_1.EventEmitter {
|
|
|
39
39
|
constructor(peerId, uppercase = false) {
|
|
40
40
|
super();
|
|
41
41
|
this.initCalled = false;
|
|
42
|
-
assert_1.default(Buffer.isBuffer(peerId));
|
|
42
|
+
(0, assert_1.default)(Buffer.isBuffer(peerId));
|
|
43
43
|
// TODO(dboreham): Mis-named because this is OUR node ID, not the id of any peer.
|
|
44
44
|
this._peerId = peerId;
|
|
45
45
|
this._uppercase = uppercase;
|
|
@@ -80,8 +80,8 @@ class TestProtocolPlugin extends events_1.EventEmitter {
|
|
|
80
80
|
* @return Message received from peer in response to our request.
|
|
81
81
|
*/
|
|
82
82
|
async send(peerId, payload) {
|
|
83
|
-
assert_1.default(Buffer.isBuffer(peerId));
|
|
84
|
-
const peerIdStr = crypto_1.keyToString(peerId);
|
|
83
|
+
(0, assert_1.default)(Buffer.isBuffer(peerId));
|
|
84
|
+
const peerIdStr = (0, crypto_1.keyToString)(peerId);
|
|
85
85
|
const peer = this._peers.get(peerIdStr);
|
|
86
86
|
// TODO(dboreham): Throw fatal error if peer not found.
|
|
87
87
|
const extension = peer.getExtension(EXTENSION_NAME);
|
|
@@ -93,7 +93,7 @@ class TestProtocolPlugin extends events_1.EventEmitter {
|
|
|
93
93
|
this.initCalled = true;
|
|
94
94
|
}
|
|
95
95
|
async _receive(protocol, data) {
|
|
96
|
-
const peerIdStr = crypto_1.keyToString(exports.getPeerId(protocol));
|
|
96
|
+
const peerIdStr = (0, crypto_1.keyToString)((0, exports.getPeerId)(protocol));
|
|
97
97
|
let payload = data.data.toString();
|
|
98
98
|
if (this._uppercase) {
|
|
99
99
|
payload = payload.toUpperCase();
|
|
@@ -102,11 +102,11 @@ class TestProtocolPlugin extends events_1.EventEmitter {
|
|
|
102
102
|
this.emit('receive', protocol, payload);
|
|
103
103
|
}
|
|
104
104
|
async _onPeerConnect(protocol) {
|
|
105
|
-
const peerId = exports.getPeerId(protocol);
|
|
105
|
+
const peerId = (0, exports.getPeerId)(protocol);
|
|
106
106
|
if (peerId === undefined) {
|
|
107
107
|
return;
|
|
108
108
|
}
|
|
109
|
-
const peerIdStr = crypto_1.keyToString(peerId);
|
|
109
|
+
const peerIdStr = (0, crypto_1.keyToString)(peerId);
|
|
110
110
|
if (this._peers.has(peerIdStr)) {
|
|
111
111
|
return;
|
|
112
112
|
}
|
|
@@ -114,11 +114,11 @@ class TestProtocolPlugin extends events_1.EventEmitter {
|
|
|
114
114
|
this.emit('connect', protocol);
|
|
115
115
|
}
|
|
116
116
|
async _onPeerDisconnect(protocol) {
|
|
117
|
-
const peerId = exports.getPeerId(protocol);
|
|
117
|
+
const peerId = (0, exports.getPeerId)(protocol);
|
|
118
118
|
if (peerId === undefined) {
|
|
119
119
|
return;
|
|
120
120
|
}
|
|
121
|
-
this._peers.delete(crypto_1.keyToString(peerId));
|
|
121
|
+
this._peers.delete((0, crypto_1.keyToString)(peerId));
|
|
122
122
|
this.emit('disconnect', peerId);
|
|
123
123
|
}
|
|
124
124
|
}
|
|
@@ -128,11 +128,11 @@ exports.TestProtocolPlugin = TestProtocolPlugin;
|
|
|
128
128
|
*/
|
|
129
129
|
// TODO(dboreham): Try to encapsulate swarmKey, nodeId.
|
|
130
130
|
const testProtocolProvider = (swarmKey, nodeId, protocolPlugin) => {
|
|
131
|
-
return protocol_factory_1.protocolFactory({
|
|
131
|
+
return (0, protocol_factory_1.protocolFactory)({
|
|
132
132
|
getTopics: () => {
|
|
133
133
|
return [swarmKey];
|
|
134
134
|
},
|
|
135
|
-
session: { peerId: crypto_1.keyToString(nodeId) },
|
|
135
|
+
session: { peerId: (0, crypto_1.keyToString)(nodeId) },
|
|
136
136
|
plugins: [protocolPlugin]
|
|
137
137
|
});
|
|
138
138
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"test-protocol.js","sourceRoot":"","sources":["../../../src/testing/test-protocol.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,mEAAmE;AAEnE,oDAA4B;AAC5B,kDAA0B;AAC1B,mCAAsC;AAEtC,yCAAwD;AACxD,6CAAqD;AAErD,0DAAsD;AAEtD,MAAM,GAAG,GAAG,eAAK,
|
|
1
|
+
{"version":3,"file":"test-protocol.js","sourceRoot":"","sources":["../../../src/testing/test-protocol.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,14 +10,14 @@ exports.FullyConnectedTopology = void 0;
|
|
|
10
10
|
const assert_1 = __importDefault(require("assert"));
|
|
11
11
|
class FullyConnectedTopology {
|
|
12
12
|
init(controller) {
|
|
13
|
-
assert_1.default(!this._controller, 'Already initialized');
|
|
13
|
+
(0, assert_1.default)(!this._controller, 'Already initialized');
|
|
14
14
|
this._controller = controller;
|
|
15
15
|
this._intervalId = setInterval(() => {
|
|
16
16
|
controller.lookup();
|
|
17
17
|
}, 10000);
|
|
18
18
|
}
|
|
19
19
|
update() {
|
|
20
|
-
assert_1.default(this._controller, 'Not initialized');
|
|
20
|
+
(0, assert_1.default)(this._controller, 'Not initialized');
|
|
21
21
|
const { candidates: discovered } = this._controller.getState();
|
|
22
22
|
for (const peer of discovered) {
|
|
23
23
|
this._controller.connect(peer);
|
|
@@ -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,oDAA4B;AAM5B,MAAa,sBAAsB;IAKjC,IAAI,CAAE,UAA2B;QAC/B,gBAAM,
|
|
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,oDAA4B;AAM5B,MAAa,sBAAsB;IAKjC,IAAI,CAAE,UAA2B;QAC/B,IAAA,gBAAM,EAAC,CAAC,IAAI,CAAC,WAAW,EAAE,qBAAqB,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAE9B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC,GAAG,EAAE;YAClC,UAAU,CAAC,MAAM,EAAE,CAAC;QACtB,CAAC,EAAE,KAAM,CAAC,CAAC;IACb,CAAC;IAED,MAAM;QACJ,IAAA,gBAAM,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,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE;YAClC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACjC;IACH,CAAC;IAED,QAAQ;QACN,OAAO,wBAAwB,CAAC;IAClC,CAAC;CACF;AAnCD,wDAmCC"}
|
|
@@ -10,7 +10,7 @@ exports.MMSTTopology = void 0;
|
|
|
10
10
|
const assert_1 = __importDefault(require("assert"));
|
|
11
11
|
const debug_1 = __importDefault(require("debug"));
|
|
12
12
|
const xor_distance_1 = __importDefault(require("xor-distance"));
|
|
13
|
-
const log = debug_1.default('dxos:network-manager:topology:mmst-topology');
|
|
13
|
+
const log = (0, debug_1.default)('dxos:network-manager:topology:mmst-topology');
|
|
14
14
|
class MMSTTopology {
|
|
15
15
|
constructor({ originateConnections = 2, maxPeers = 4, sampleSize = 10 } = {}) {
|
|
16
16
|
this._sampleCollected = false;
|
|
@@ -19,14 +19,14 @@ class MMSTTopology {
|
|
|
19
19
|
this._sampleSize = sampleSize;
|
|
20
20
|
}
|
|
21
21
|
init(controller) {
|
|
22
|
-
assert_1.default(!this._controller, 'Already initialized');
|
|
22
|
+
(0, assert_1.default)(!this._controller, 'Already initialized');
|
|
23
23
|
this._controller = controller;
|
|
24
24
|
this._lookupIntervalId = setInterval(() => {
|
|
25
25
|
controller.lookup();
|
|
26
26
|
}, 10000);
|
|
27
27
|
}
|
|
28
28
|
update() {
|
|
29
|
-
assert_1.default(this._controller, 'Not initialized');
|
|
29
|
+
(0, assert_1.default)(this._controller, 'Not initialized');
|
|
30
30
|
const { connected, candidates } = this._controller.getState();
|
|
31
31
|
// Run the algorithms if we have first candidates, ran it before, or have more connections than needed.
|
|
32
32
|
if (this._sampleCollected || connected.length > this._maxPeers || candidates.length > 0) {
|
|
@@ -36,7 +36,7 @@ class MMSTTopology {
|
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
38
|
async onOffer(peer) {
|
|
39
|
-
assert_1.default(this._controller, 'Not initialized');
|
|
39
|
+
(0, assert_1.default)(this._controller, 'Not initialized');
|
|
40
40
|
const { connected } = this._controller.getState();
|
|
41
41
|
const accept = connected.length < this._maxPeers;
|
|
42
42
|
log(`Offer ${peer} accept=${accept}`);
|
|
@@ -48,7 +48,7 @@ class MMSTTopology {
|
|
|
48
48
|
}
|
|
49
49
|
}
|
|
50
50
|
_runAlgorithm() {
|
|
51
|
-
assert_1.default(this._controller, 'Not initialized');
|
|
51
|
+
(0, assert_1.default)(this._controller, 'Not initialized');
|
|
52
52
|
const { connected, candidates, ownPeerId } = this._controller.getState();
|
|
53
53
|
if (connected.length > this._maxPeers) {
|
|
54
54
|
// Disconnect extra peers.
|
|
@@ -74,6 +74,6 @@ class MMSTTopology {
|
|
|
74
74
|
}
|
|
75
75
|
exports.MMSTTopology = MMSTTopology;
|
|
76
76
|
function sortByXorDistance(keys, reference) {
|
|
77
|
-
return keys.sort((a, b) => xor_distance_1.default.gt(xor_distance_1.default(a.asBuffer(), reference.asBuffer()), xor_distance_1.default(b.asBuffer(), reference.asBuffer())));
|
|
77
|
+
return keys.sort((a, b) => xor_distance_1.default.gt((0, xor_distance_1.default)(a.asBuffer(), reference.asBuffer()), (0, xor_distance_1.default)(b.asBuffer(), reference.asBuffer())));
|
|
78
78
|
}
|
|
79
79
|
//# sourceMappingURL=mmst-topology.js.map
|
|
@@ -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,oDAA4B;AAC5B,kDAA0B;AAC1B,gEAAoC;AAMpC,MAAM,GAAG,GAAG,eAAK,
|
|
1
|
+
{"version":3,"file":"mmst-topology.js","sourceRoot":"","sources":["../../../src/topology/mmst-topology.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,20 +9,20 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
9
9
|
exports.StarTopology = void 0;
|
|
10
10
|
const assert_1 = __importDefault(require("assert"));
|
|
11
11
|
const debug_1 = __importDefault(require("debug"));
|
|
12
|
-
const log = debug_1.default('dxos:network-manager:topology:star');
|
|
12
|
+
const log = (0, debug_1.default)('dxos:network-manager:topology:star');
|
|
13
13
|
class StarTopology {
|
|
14
14
|
constructor(_centralPeer) {
|
|
15
15
|
this._centralPeer = _centralPeer;
|
|
16
16
|
}
|
|
17
17
|
init(controller) {
|
|
18
|
-
assert_1.default(!this._controller, 'Already initialized');
|
|
18
|
+
(0, assert_1.default)(!this._controller, 'Already initialized');
|
|
19
19
|
this._controller = controller;
|
|
20
20
|
this._intervalId = setInterval(() => {
|
|
21
21
|
controller.lookup();
|
|
22
22
|
}, 10000);
|
|
23
23
|
}
|
|
24
24
|
update() {
|
|
25
|
-
assert_1.default(this._controller, 'Not initialized');
|
|
25
|
+
(0, assert_1.default)(this._controller, 'Not initialized');
|
|
26
26
|
const { candidates, connected, ownPeerId } = this._controller.getState();
|
|
27
27
|
if (!ownPeerId.equals(this._centralPeer)) {
|
|
28
28
|
log('As leaf peer dropping all connections apart from central peer.');
|
|
@@ -43,7 +43,7 @@ class StarTopology {
|
|
|
43
43
|
}
|
|
44
44
|
}
|
|
45
45
|
async onOffer(peer) {
|
|
46
|
-
assert_1.default(this._controller, 'Not initialized');
|
|
46
|
+
(0, assert_1.default)(this._controller, 'Not initialized');
|
|
47
47
|
const { ownPeerId } = this._controller.getState();
|
|
48
48
|
log(`Offer from ${peer} isCentral=${peer.equals(this._centralPeer)} isSelfCentral=${ownPeerId.equals(this._centralPeer)}`);
|
|
49
49
|
return ownPeerId.equals(this._centralPeer) || peer.equals(this._centralPeer);
|
|
@@ -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,oDAA4B;AAC5B,kDAA0B;AAM1B,MAAM,GAAG,GAAG,eAAK,
|
|
1
|
+
{"version":3,"file":"star-topology.js","sourceRoot":"","sources":["../../../src/topology/star-topology.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,oDAA4B;AAC5B,kDAA0B;AAM1B,MAAM,GAAG,GAAG,IAAA,eAAK,EAAC,oCAAoC,CAAC,CAAC;AAExD,MAAa,YAAY;IAKvB,YACmB,YAAuB;QAAvB,iBAAY,GAAZ,YAAY,CAAW;IACvC,CAAC;IAEJ,IAAI,CAAE,UAA2B;QAC/B,IAAA,gBAAM,EAAC,CAAC,IAAI,CAAC,WAAW,EAAE,qBAAqB,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAE9B,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC,GAAG,EAAE;YAClC,UAAU,CAAC,MAAM,EAAE,CAAC;QACtB,CAAC,EAAE,KAAM,CAAC,CAAC;IACb,CAAC;IAED,MAAM;QACJ,IAAA,gBAAM,EAAC,IAAI,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAC;QAC5C,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,GAAG,CAAC,6BAA6B,IAAI,EAAE,CAAC,CAAC;gBACzC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE;oBACnC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;iBACnC;aACF;SACF;QACD,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,8BAA8B,IAAI,EAAE,CAAC,CAAC;gBAC1C,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;aAChC;SACF;IACH,CAAC;IAED,KAAK,CAAC,OAAO,CAAE,IAAe;QAC5B,IAAA,gBAAM,EAAC,IAAI,CAAC,WAAW,EAAE,iBAAiB,CAAC,CAAC;QAC5C,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,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE;YAClC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACjC;IACH,CAAC;IAED,QAAQ;QACN,OAAO,gBAAgB,IAAI,CAAC,YAAY,GAAG,CAAC;IAC9C,CAAC;CACF;AAxDD,oCAwDC"}
|
|
@@ -13,7 +13,7 @@ const stream_1 = require("stream");
|
|
|
13
13
|
const async_1 = require("@dxos/async");
|
|
14
14
|
const debug_2 = require("@dxos/debug");
|
|
15
15
|
const util_1 = require("@dxos/util");
|
|
16
|
-
const log = debug_1.default('dxos:network-manager:swarm:transport:in-memory-transport');
|
|
16
|
+
const log = (0, debug_1.default)('dxos:network-manager:swarm:transport:in-memory-transport');
|
|
17
17
|
// Delay (in milliseconds) for data being sent through in-memory connections to simulate network latency.
|
|
18
18
|
const IN_MEMORY_TRANSPORT_DELAY = 1;
|
|
19
19
|
class InMemoryTransport {
|
|
@@ -31,7 +31,7 @@ class InMemoryTransport {
|
|
|
31
31
|
log(`Registering connection topic=${this._topic} peerId=${this._ownId} remoteId=${this._remoteId}`);
|
|
32
32
|
this._ownKey = [this._topic, this._ownId, this._remoteId];
|
|
33
33
|
this._remoteKey = [this._topic, this._remoteId, this._ownId];
|
|
34
|
-
assert_1.default(!InMemoryTransport._connections.has(this._ownKey), 'Duplicate in-memory connection');
|
|
34
|
+
(0, assert_1.default)(!InMemoryTransport._connections.has(this._ownKey), 'Duplicate in-memory connection');
|
|
35
35
|
InMemoryTransport._connections.set(this._ownKey, this);
|
|
36
36
|
this._remoteConnection = InMemoryTransport._connections.get(this._remoteKey);
|
|
37
37
|
if (this._remoteConnection) {
|
|
@@ -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,oDAA4B;AAC5B,kDAA0B;AAC1B,mCAAmC;AAEnC,uCAAoC;AAEpC,uCAA0C;AAC1C,qCAAwC;AAKxC,MAAM,GAAG,GAAG,eAAK,
|
|
1
|
+
{"version":3,"file":"in-memory-transport.js","sourceRoot":"","sources":["../../../src/transport/in-memory-transport.ts"],"names":[],"mappings":"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"}
|
|
@@ -23,15 +23,15 @@ function createPair() {
|
|
|
23
23
|
const peer2Id = crypto_1.PublicKey.random();
|
|
24
24
|
const sessionId = crypto_1.PublicKey.random();
|
|
25
25
|
const plugin1 = new test_protocol_1.TestProtocolPlugin(peer1Id.asBuffer());
|
|
26
|
-
const protocolProvider1 = test_protocol_1.testProtocolProvider(topic.asBuffer(), peer1Id.asBuffer(), plugin1);
|
|
27
|
-
const connection1 = new in_memory_transport_1.InMemoryTransport(peer1Id, peer2Id, sessionId, topic, protocolProvider1({ channel: crypto_1.discoveryKey(topic), initiator: true }).stream);
|
|
28
|
-
testutils_1.afterTest(() => connection1.close());
|
|
29
|
-
testutils_1.afterTest(() => connection1.errors.assertNoUnhandledErrors());
|
|
26
|
+
const protocolProvider1 = (0, test_protocol_1.testProtocolProvider)(topic.asBuffer(), peer1Id.asBuffer(), plugin1);
|
|
27
|
+
const connection1 = new in_memory_transport_1.InMemoryTransport(peer1Id, peer2Id, sessionId, topic, protocolProvider1({ channel: (0, crypto_1.discoveryKey)(topic), initiator: true }).stream);
|
|
28
|
+
(0, testutils_1.afterTest)(() => connection1.close());
|
|
29
|
+
(0, testutils_1.afterTest)(() => connection1.errors.assertNoUnhandledErrors());
|
|
30
30
|
const plugin2 = new test_protocol_1.TestProtocolPlugin(peer2Id.asBuffer());
|
|
31
|
-
const protocolProvider2 = test_protocol_1.testProtocolProvider(topic.asBuffer(), peer2Id.asBuffer(), plugin2);
|
|
32
|
-
const connection2 = new in_memory_transport_1.InMemoryTransport(peer2Id, peer1Id, sessionId, topic, protocolProvider2({ channel: crypto_1.discoveryKey(topic), initiator: false }).stream);
|
|
33
|
-
testutils_1.afterTest(() => connection2.close());
|
|
34
|
-
testutils_1.afterTest(() => connection2.errors.assertNoUnhandledErrors());
|
|
31
|
+
const protocolProvider2 = (0, test_protocol_1.testProtocolProvider)(topic.asBuffer(), peer2Id.asBuffer(), plugin2);
|
|
32
|
+
const connection2 = new in_memory_transport_1.InMemoryTransport(peer2Id, peer1Id, sessionId, topic, protocolProvider2({ channel: (0, crypto_1.discoveryKey)(topic), initiator: false }).stream);
|
|
33
|
+
(0, testutils_1.afterTest)(() => connection2.close());
|
|
34
|
+
(0, testutils_1.afterTest)(() => connection2.errors.assertNoUnhandledErrors());
|
|
35
35
|
return { connection1, connection2, plugin1, plugin2, peer1Id, peer2Id, topic };
|
|
36
36
|
}
|
|
37
37
|
describe('InMemoryTransport', () => {
|
|
@@ -46,14 +46,14 @@ describe('InMemoryTransport', () => {
|
|
|
46
46
|
plugin2.on('connect', async (protocol) => {
|
|
47
47
|
await plugin2.send(peer1Id.asBuffer(), 'Foo');
|
|
48
48
|
});
|
|
49
|
-
await wait_for_expect_1.default(() => {
|
|
50
|
-
expect_1.default(received.length).toBe(2);
|
|
51
|
-
expect_1.default(received[0]).toBeInstanceOf(protocol_1.Protocol);
|
|
52
|
-
expect_1.default(received[1]).toBe('Foo');
|
|
49
|
+
await (0, wait_for_expect_1.default)(() => {
|
|
50
|
+
(0, expect_1.default)(received.length).toBe(2);
|
|
51
|
+
(0, expect_1.default)(received[0]).toBeInstanceOf(protocol_1.Protocol);
|
|
52
|
+
(0, expect_1.default)(received[1]).toBe('Foo');
|
|
53
53
|
});
|
|
54
54
|
});
|
|
55
55
|
it('10 pairs of peers connecting at the same time', async () => {
|
|
56
|
-
await Promise.all(util_1.range(10).map(async () => {
|
|
56
|
+
await Promise.all((0, util_1.range)(10).map(async () => {
|
|
57
57
|
const { plugin1, plugin2, peer1Id } = createPair();
|
|
58
58
|
const received = [];
|
|
59
59
|
const mockReceive = (p, s) => {
|
|
@@ -64,10 +64,10 @@ describe('InMemoryTransport', () => {
|
|
|
64
64
|
plugin2.on('connect', async (protocol) => {
|
|
65
65
|
await plugin2.send(peer1Id.asBuffer(), 'Foo');
|
|
66
66
|
});
|
|
67
|
-
await wait_for_expect_1.default(() => {
|
|
68
|
-
expect_1.default(received.length).toBe(2);
|
|
69
|
-
expect_1.default(received[0]).toBeInstanceOf(protocol_1.Protocol);
|
|
70
|
-
expect_1.default(received[1]).toBe('Foo');
|
|
67
|
+
await (0, wait_for_expect_1.default)(() => {
|
|
68
|
+
(0, expect_1.default)(received.length).toBe(2);
|
|
69
|
+
(0, expect_1.default)(received[0]).toBeInstanceOf(protocol_1.Protocol);
|
|
70
|
+
(0, expect_1.default)(received[1]).toBe('Foo');
|
|
71
71
|
});
|
|
72
72
|
}));
|
|
73
73
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"in-memory-transport.test.js","sourceRoot":"","sources":["../../../src/transport/in-memory-transport.test.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;AAEF,oDAA4B;AAC5B,sEAA4C;AAE5C,yCAAuD;AACvD,6CAA0C;AAC1C,+CAA4C;AAC5C,qCAAmC;AAEnC,4DAAoF;AACpF,+DAA0D;AAE1D,4BAA4B;AAC5B,gGAAgG;AAChG,8DAA8D;AAE9D,SAAS,UAAU;IACjB,MAAM,KAAK,GAAG,kBAAS,CAAC,MAAM,EAAE,CAAC;IACjC,MAAM,OAAO,GAAG,kBAAS,CAAC,MAAM,EAAE,CAAC;IACnC,MAAM,OAAO,GAAG,kBAAS,CAAC,MAAM,EAAE,CAAC;IACnC,MAAM,SAAS,GAAG,kBAAS,CAAC,MAAM,EAAE,CAAC;IAErC,MAAM,OAAO,GAAG,IAAI,kCAAkB,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC3D,MAAM,iBAAiB,GAAG,oCAAoB,
|
|
1
|
+
{"version":3,"file":"in-memory-transport.test.js","sourceRoot":"","sources":["../../../src/transport/in-memory-transport.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -13,7 +13,7 @@ const simple_peer_1 = __importDefault(require("simple-peer"));
|
|
|
13
13
|
const wrtc_1 = __importDefault(require("wrtc"));
|
|
14
14
|
const async_1 = require("@dxos/async");
|
|
15
15
|
const debug_2 = require("@dxos/debug");
|
|
16
|
-
const log = debug_1.default('dxos:network-manager:swarm:transport:webrtc');
|
|
16
|
+
const log = (0, debug_1.default)('dxos:network-manager:swarm:transport:webrtc');
|
|
17
17
|
/**
|
|
18
18
|
* Implements Transport for WebRTC. Uses simple-peer under the hood.
|
|
19
19
|
*/
|
|
@@ -76,7 +76,7 @@ class WebrtcTransport {
|
|
|
76
76
|
return this._peer;
|
|
77
77
|
}
|
|
78
78
|
signal(msg) {
|
|
79
|
-
assert_1.default(this._peer, 'Connection not ready to accept signals.');
|
|
79
|
+
(0, assert_1.default)(this._peer, 'Connection not ready to accept signals.');
|
|
80
80
|
this._peer.signal(msg.data);
|
|
81
81
|
}
|
|
82
82
|
async close() {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"webrtc-transport.js","sourceRoot":"","sources":["../../../src/transport/webrtc-transport.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;;AAEF,oDAA4B;AAC5B,kDAA0B;AAC1B,8DAA4E;AAC5E,gDAAwB;AAExB,uCAAoC;AAEpC,uCAA0C;AAK1C,MAAM,GAAG,GAAG,eAAK,
|
|
1
|
+
{"version":3,"file":"webrtc-transport.js","sourceRoot":"","sources":["../../../src/transport/webrtc-transport.ts"],"names":[],"mappings":"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"}
|
|
@@ -18,39 +18,39 @@ const test_protocol_1 = require("../testing/test-protocol");
|
|
|
18
18
|
const webrtc_transport_1 = require("./webrtc-transport");
|
|
19
19
|
describe('WebrtcTransport', () => {
|
|
20
20
|
// This doesn't clean up correctly and crashes with SIGSEGV / SIGABRT at the end. Probably an issue with wrtc package.
|
|
21
|
-
mocha_1.it('open and close', async () => {
|
|
21
|
+
(0, mocha_1.it)('open and close', async () => {
|
|
22
22
|
const connection = new webrtc_transport_1.WebrtcTransport(true, new stream_1.Duplex(), crypto_1.PublicKey.random(), crypto_1.PublicKey.random(), crypto_1.PublicKey.random(), crypto_1.PublicKey.random(), async (msg) => { });
|
|
23
23
|
let callsCounter = 0;
|
|
24
24
|
const closedCb = () => {
|
|
25
25
|
callsCounter++;
|
|
26
26
|
};
|
|
27
27
|
connection.closed.once(closedCb);
|
|
28
|
-
await async_1.sleep(10); // Let simple-peer process events.
|
|
28
|
+
await (0, async_1.sleep)(10); // Let simple-peer process events.
|
|
29
29
|
await connection.close();
|
|
30
|
-
await async_1.sleep(1); // Process events.
|
|
31
|
-
expect_1.default(callsCounter).toEqual(1);
|
|
30
|
+
await (0, async_1.sleep)(1); // Process events.
|
|
31
|
+
(0, expect_1.default)(callsCounter).toEqual(1);
|
|
32
32
|
}).timeout(1000);
|
|
33
|
-
mocha_1.it('establish connection and send data through with protocol', async () => {
|
|
33
|
+
(0, mocha_1.it)('establish connection and send data through with protocol', async () => {
|
|
34
34
|
const topic = crypto_1.PublicKey.random();
|
|
35
35
|
const peer1Id = crypto_1.PublicKey.random();
|
|
36
36
|
const peer2Id = crypto_1.PublicKey.random();
|
|
37
37
|
const sessionId = crypto_1.PublicKey.random();
|
|
38
38
|
const plugin1 = new test_protocol_1.TestProtocolPlugin(peer1Id.asBuffer());
|
|
39
|
-
const protocolProvider1 = test_protocol_1.testProtocolProvider(topic.asBuffer(), peer1Id.asBuffer(), plugin1);
|
|
40
|
-
const connection1 = new webrtc_transport_1.WebrtcTransport(true, protocolProvider1({ channel: crypto_1.discoveryKey(topic), initiator: true }).stream, peer1Id, peer2Id, sessionId, topic, async (msg) => {
|
|
41
|
-
await async_1.sleep(10);
|
|
39
|
+
const protocolProvider1 = (0, test_protocol_1.testProtocolProvider)(topic.asBuffer(), peer1Id.asBuffer(), plugin1);
|
|
40
|
+
const connection1 = new webrtc_transport_1.WebrtcTransport(true, protocolProvider1({ channel: (0, crypto_1.discoveryKey)(topic), initiator: true }).stream, peer1Id, peer2Id, sessionId, topic, async (msg) => {
|
|
41
|
+
await (0, async_1.sleep)(10);
|
|
42
42
|
await connection2.signal(msg);
|
|
43
43
|
});
|
|
44
|
-
testutils_1.afterTest(() => connection1.close());
|
|
45
|
-
testutils_1.afterTest(() => connection1.errors.assertNoUnhandledErrors());
|
|
44
|
+
(0, testutils_1.afterTest)(() => connection1.close());
|
|
45
|
+
(0, testutils_1.afterTest)(() => connection1.errors.assertNoUnhandledErrors());
|
|
46
46
|
const plugin2 = new test_protocol_1.TestProtocolPlugin(peer2Id.asBuffer());
|
|
47
|
-
const protocolProvider2 = test_protocol_1.testProtocolProvider(topic.asBuffer(), peer2Id.asBuffer(), plugin2);
|
|
48
|
-
const connection2 = new webrtc_transport_1.WebrtcTransport(false, protocolProvider2({ channel: crypto_1.discoveryKey(topic), initiator: false }).stream, peer2Id, peer1Id, sessionId, topic, async (msg) => {
|
|
49
|
-
await async_1.sleep(10);
|
|
47
|
+
const protocolProvider2 = (0, test_protocol_1.testProtocolProvider)(topic.asBuffer(), peer2Id.asBuffer(), plugin2);
|
|
48
|
+
const connection2 = new webrtc_transport_1.WebrtcTransport(false, protocolProvider2({ channel: (0, crypto_1.discoveryKey)(topic), initiator: false }).stream, peer2Id, peer1Id, sessionId, topic, async (msg) => {
|
|
49
|
+
await (0, async_1.sleep)(10);
|
|
50
50
|
await connection1.signal(msg);
|
|
51
51
|
});
|
|
52
|
-
testutils_1.afterTest(() => connection2.close());
|
|
53
|
-
testutils_1.afterTest(() => connection2.errors.assertNoUnhandledErrors());
|
|
52
|
+
(0, testutils_1.afterTest)(() => connection2.close());
|
|
53
|
+
(0, testutils_1.afterTest)(() => connection2.errors.assertNoUnhandledErrors());
|
|
54
54
|
const received = [];
|
|
55
55
|
const mockReceive = (p, s) => {
|
|
56
56
|
received.push(p, s);
|
|
@@ -60,10 +60,10 @@ describe('WebrtcTransport', () => {
|
|
|
60
60
|
plugin2.on('connect', async (protocol) => {
|
|
61
61
|
await plugin2.send(peer1Id.asBuffer(), 'Foo');
|
|
62
62
|
});
|
|
63
|
-
await wait_for_expect_1.default(() => {
|
|
64
|
-
expect_1.default(received.length).toBe(2);
|
|
65
|
-
expect_1.default(received[0]).toBeInstanceOf(protocol_1.Protocol);
|
|
66
|
-
expect_1.default(received[1]).toBe('Foo');
|
|
63
|
+
await (0, wait_for_expect_1.default)(() => {
|
|
64
|
+
(0, expect_1.default)(received.length).toBe(2);
|
|
65
|
+
(0, expect_1.default)(received[0]).toBeInstanceOf(protocol_1.Protocol);
|
|
66
|
+
(0, expect_1.default)(received[1]).toBe('Foo');
|
|
67
67
|
});
|
|
68
68
|
}).timeout(2000);
|
|
69
69
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"webrtc-transport.test.js","sourceRoot":"","sources":["../../../src/transport/webrtc-transport.test.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;AAEF,oDAA4B;AAC5B,iCAAmC;AACnC,mCAAgC;AAChC,sEAA4C;AAE5C,uCAAoC;AACpC,yCAAuD;AACvD,6CAA0C;AAC1C,+CAA4C;AAE5C,4DAAoF;AACpF,yDAAqD;AAErD,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,sHAAsH;IACtH,UAAI,
|
|
1
|
+
{"version":3,"file":"webrtc-transport.test.js","sourceRoot":"","sources":["../../../src/transport/webrtc-transport.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"wrtc-simple-peer.test.js","sourceRoot":"","sources":["../../../src/transport/wrtc-simple-peer.test.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;AAEF,iCAAmC;AACnC,8DAAgD;AAChD,gDAAwB;AAExB,uCAAoC;AAEpC,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,2EAA2E;IAC3E,UAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,IAAI,EAAE;QACrC,MAAM,IAAI,GAAG,IAAI,qBAAqB,CAAC;YACrC,SAAS,EAAE,IAAI;YACf,IAAI,EAAJ,cAAI;SACL,CAAC,CAAC;QAEH,MAAM,aAAK,
|
|
1
|
+
{"version":3,"file":"wrtc-simple-peer.test.js","sourceRoot":"","sources":["../../../src/transport/wrtc-simple-peer.test.ts"],"names":[],"mappings":";AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;;;;;AAEF,iCAAmC;AACnC,8DAAgD;AAChD,gDAAwB;AAExB,uCAAoC;AAEpC,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,2EAA2E;IAC3E,UAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,KAAK,IAAI,EAAE;QACrC,MAAM,IAAI,GAAG,IAAI,qBAAqB,CAAC;YACrC,SAAS,EAAE,IAAI;YACf,IAAI,EAAJ,cAAI;SACL,CAAC,CAAC;QAEH,MAAM,IAAA,aAAK,EAAC,CAAC,CAAC,CAAC;QAEf,MAAM,IAAI,CAAC,OAAO,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC,OAAO,CAAC,IAAK,CAAC,CAAC;AACpB,CAAC,CAAC,CAAC"}
|