@dxos/network-manager 0.8.4-main.fffef41 → 0.8.4-staging.60fe92afc8
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-E3P563GT.mjs → chunk-ERB3AQAF.mjs} +424 -1897
- package/dist/lib/browser/chunk-ERB3AQAF.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 +10 -34
- package/dist/lib/browser/testing/index.mjs.map +3 -3
- package/dist/lib/browser/transport/tcp/index.mjs +2 -33
- 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-PKBROUZV.mjs → chunk-KYLPLEZQ.mjs} +424 -1897
- package/dist/lib/node-esm/chunk-KYLPLEZQ.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 +10 -34
- package/dist/lib/node-esm/testing/index.mjs.map +3 -3
- package/dist/lib/node-esm/transport/tcp/index.mjs +2 -157
- 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/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/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 +7 -7
- 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 +4 -3
- 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 +3 -5
- package/dist/types/src/swarm/swarm.d.ts.map +1 -1
- package/dist/types/src/testing/test-builder.d.ts.map +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/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 +4 -4
- 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.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.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 +33 -33
- package/src/network-manager.ts +24 -22
- package/src/signal/integration.node.test.ts +11 -10
- package/src/signal/signal-connection.ts +3 -2
- package/src/signal/signal-messenger.ts +3 -2
- package/src/signal/swarm-messenger.node.test.ts +25 -24
- package/src/signal/swarm-messenger.ts +65 -55
- package/src/swarm/connection.test.ts +6 -7
- package/src/swarm/connection.ts +15 -22
- package/src/swarm/peer.ts +7 -7
- package/src/swarm/swarm.test.ts +2 -3
- package/src/swarm/swarm.ts +10 -17
- package/src/testing/test-builder.ts +4 -4
- package/src/tests/basic-test-suite.ts +0 -1
- package/src/tests/memory-transport.test.ts +0 -2
- package/src/tests/property-test-suite.ts +4 -3
- package/src/tests/tcp-transport.node.test.ts +0 -2
- package/src/tests/webrtc-transport.test.ts +0 -1
- package/src/transport/tcp/index.ts +1 -1
- package/src/transport/webrtc/rtc-peer-connection.ts +1 -2
- package/src/transport/webrtc/rtc-transport-channel.test.ts +0 -2
- package/src/transport/webrtc/rtc-transport-channel.ts +1 -2
- package/src/transport/webrtc/rtc-transport-factory.ts +0 -1
- package/src/transport/webrtc/rtc-transport-proxy.test.ts +0 -2
- package/src/transport/webrtc/rtc-transport-proxy.ts +6 -4
- package/src/transport/webrtc/rtc-transport-service.ts +0 -1
- package/src/transport/webrtc/rtc-transport.test.ts +0 -1
- package/src/wire-protocol.ts +6 -6
- package/dist/lib/browser/chunk-E3P563GT.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-PKBROUZV.mjs.map +0 -7
|
@@ -11,7 +11,6 @@ import { trace } from '@dxos/tracing';
|
|
|
11
11
|
|
|
12
12
|
import type { IceProvider } from '../../signal';
|
|
13
13
|
import { type TransportOptions } from '../transport';
|
|
14
|
-
|
|
15
14
|
import { type RtcConnectionFactory } from './rtc-connection-factory';
|
|
16
15
|
import { RtcTransportChannel } from './rtc-transport-channel';
|
|
17
16
|
import { areSdpEqual, chooseInitiatorPeer } from './utils';
|
|
@@ -469,7 +468,7 @@ type IceCandidateErrorDetails = { url: string; errorCode: number; errorText: str
|
|
|
469
468
|
|
|
470
469
|
const createIceFailureError = (details: IceCandidateErrorDetails[]) => {
|
|
471
470
|
const candidateErrors = details.map(({ url, errorCode, errorText }) => `${errorCode} ${url}: ${errorText}`);
|
|
472
|
-
return new ConnectivityError(`ICE failed:\n${candidateErrors.join('\n')}`);
|
|
471
|
+
return new ConnectivityError({ message: `ICE failed:\n${candidateErrors.join('\n')}` });
|
|
473
472
|
};
|
|
474
473
|
|
|
475
474
|
type ChannelCreatedCallback = {
|
|
@@ -3,13 +3,11 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { Duplex } from 'node:stream';
|
|
6
|
-
|
|
7
6
|
import { describe, expect, test } from 'vitest';
|
|
8
7
|
|
|
9
8
|
import { sleep } from '@dxos/async';
|
|
10
9
|
|
|
11
10
|
import { type TransportOptions } from '../transport';
|
|
12
|
-
|
|
13
11
|
import { type RtcPeerConnection } from './rtc-peer-connection';
|
|
14
12
|
import { RtcTransportChannel } from './rtc-transport-channel';
|
|
15
13
|
import { handleChannelErrors } from './test-utils';
|
|
@@ -13,7 +13,6 @@ import { ConnectivityError } from '@dxos/protocols';
|
|
|
13
13
|
import { type Signal } from '@dxos/protocols/proto/dxos/mesh/swarm';
|
|
14
14
|
|
|
15
15
|
import { type Transport, type TransportOptions, type TransportStats } from '../transport';
|
|
16
|
-
|
|
17
16
|
import { type RtcPeerConnection } from './rtc-peer-connection';
|
|
18
17
|
import { createRtcTransportStats, describeSelectedRemoteCandidate } from './rtc-transport-stats';
|
|
19
18
|
|
|
@@ -71,7 +70,7 @@ export class RtcTransportChannel extends Resource implements Transport {
|
|
|
71
70
|
const error =
|
|
72
71
|
err instanceof Error
|
|
73
72
|
? err
|
|
74
|
-
: new ConnectivityError(`Failed to create a channel: ${JSON.stringify(err?.message)}`);
|
|
73
|
+
: new ConnectivityError({ message: `Failed to create a channel: ${JSON.stringify(err?.message)}` });
|
|
75
74
|
this.errors.raise(error);
|
|
76
75
|
} else {
|
|
77
76
|
log.verbose('connection establishment failed after transport was closed', { err });
|
|
@@ -3,7 +3,6 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { Duplex } from 'stream';
|
|
6
|
-
|
|
7
6
|
import { describe, expect, onTestFinished, test } from 'vitest';
|
|
8
7
|
|
|
9
8
|
import { Event as AsyncEvent, TestStream, Trigger, sleep } from '@dxos/async';
|
|
@@ -14,7 +13,6 @@ import { type BridgeService } from '@dxos/protocols/proto/dxos/mesh/bridge';
|
|
|
14
13
|
import { type RpcPort, createLinkedPorts, createProtoRpcPeer } from '@dxos/rpc';
|
|
15
14
|
|
|
16
15
|
import { type Transport, type TransportFactory, type TransportOptions, type TransportStats } from '../transport';
|
|
17
|
-
|
|
18
16
|
import { RtcTransportProxy } from './rtc-transport-proxy';
|
|
19
17
|
import { RtcTransportService } from './rtc-transport-service';
|
|
20
18
|
import { handleChannelErrors } from './test-utils';
|
|
@@ -176,7 +176,9 @@ export class RtcTransportProxy extends Resource implements Transport {
|
|
|
176
176
|
} catch (error) {
|
|
177
177
|
const type = signalEvent.payload.payload.data?.type;
|
|
178
178
|
if (type === 'offer' || type === 'answer') {
|
|
179
|
-
this._raiseIfOpen(
|
|
179
|
+
this._raiseIfOpen(
|
|
180
|
+
new ConnectivityError({ message: `Session establishment failed: ${type} couldn't be sent.` }),
|
|
181
|
+
);
|
|
180
182
|
}
|
|
181
183
|
}
|
|
182
184
|
}
|
|
@@ -255,11 +257,11 @@ export class RtcTransportProxyFactory implements TransportFactory {
|
|
|
255
257
|
const decodeError = (err: Error | string) => {
|
|
256
258
|
const message = typeof err === 'string' ? err : err.message;
|
|
257
259
|
if (message.includes('CONNECTION_RESET')) {
|
|
258
|
-
return new ConnectionResetError(message);
|
|
260
|
+
return new ConnectionResetError({ message });
|
|
259
261
|
} else if (message.includes('TIMEOUT')) {
|
|
260
|
-
return new TimeoutError(message);
|
|
262
|
+
return new TimeoutError({ message });
|
|
261
263
|
} else if (message.includes('CONNECTIVITY_ERROR')) {
|
|
262
|
-
return new ConnectivityError(message);
|
|
264
|
+
return new ConnectivityError({ message });
|
|
263
265
|
} else {
|
|
264
266
|
return typeof err === 'string' ? new Error(err) : err;
|
|
265
267
|
}
|
|
@@ -25,7 +25,6 @@ import { ComplexMap } from '@dxos/util';
|
|
|
25
25
|
|
|
26
26
|
import { type IceProvider } from '../../signal';
|
|
27
27
|
import { type Transport, type TransportFactory } from '../transport';
|
|
28
|
-
|
|
29
28
|
import { createRtcTransportFactory } from './rtc-transport-factory';
|
|
30
29
|
|
|
31
30
|
type TransportState = {
|
|
@@ -8,7 +8,6 @@ import { TestStream, sleep } from '@dxos/async';
|
|
|
8
8
|
import { PublicKey } from '@dxos/keys';
|
|
9
9
|
|
|
10
10
|
import { type TransportOptions } from '../transport';
|
|
11
|
-
|
|
12
11
|
import { getRtcConnectionFactory } from './rtc-connection-factory';
|
|
13
12
|
import { RtcPeerConnection } from './rtc-peer-connection';
|
|
14
13
|
import { type RtcTransportChannel } from './rtc-transport-channel';
|
package/src/wire-protocol.ts
CHANGED
|
@@ -5,16 +5,16 @@
|
|
|
5
5
|
import { type Duplex } from 'node:stream';
|
|
6
6
|
|
|
7
7
|
import { type PublicKey } from '@dxos/keys';
|
|
8
|
-
import { Teleport, type
|
|
8
|
+
import { Teleport, type TeleportProps } from '@dxos/teleport';
|
|
9
9
|
|
|
10
|
-
export type
|
|
10
|
+
export type WireProtocolProps = {
|
|
11
11
|
initiator: boolean;
|
|
12
12
|
localPeerId: PublicKey;
|
|
13
13
|
remotePeerId: PublicKey;
|
|
14
14
|
topic: PublicKey;
|
|
15
15
|
};
|
|
16
16
|
|
|
17
|
-
export type WireProtocolProvider = (params:
|
|
17
|
+
export type WireProtocolProvider = (params: WireProtocolProps) => WireProtocol;
|
|
18
18
|
|
|
19
19
|
/**
|
|
20
20
|
* Application-specific network protocol that is used when a connection to a peer is established.
|
|
@@ -31,15 +31,15 @@ export interface WireProtocol {
|
|
|
31
31
|
/**
|
|
32
32
|
* Create a wire-protocol provider backed by a teleport instance.
|
|
33
33
|
* @param onConnection Called after teleport is initialized for the session. Protocol extensions could be attached here.
|
|
34
|
-
* @param
|
|
34
|
+
* @param defaultProps Optionally provide default Teleport params that might be overridden by factory callers.
|
|
35
35
|
* @returns
|
|
36
36
|
*/
|
|
37
37
|
export const createTeleportProtocolFactory = (
|
|
38
38
|
onConnection: (teleport: Teleport) => Promise<void>,
|
|
39
|
-
|
|
39
|
+
defaultProps?: Partial<TeleportProps>,
|
|
40
40
|
): WireProtocolProvider => {
|
|
41
41
|
return (params) => {
|
|
42
|
-
const teleport = new Teleport({ ...
|
|
42
|
+
const teleport = new Teleport({ ...defaultProps, ...params });
|
|
43
43
|
return {
|
|
44
44
|
stream: teleport.stream,
|
|
45
45
|
open: async (sessionId?: PublicKey) => {
|