@livedigital/client 2.11.1 → 2.12.0-add-onissue-callback.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/constants/common.d.ts +11 -0
- package/dist/engine/DefaultEngineDependenciesFactory.d.ts +3 -4
- package/dist/engine/Logger.d.ts +10 -3
- package/dist/engine/PeerConsumer.d.ts +6 -2
- package/dist/engine/index.d.ts +10 -4
- package/dist/engine/media/index.d.ts +2 -0
- package/dist/engine/media/tracks/BaseTrack.d.ts +6 -2
- package/dist/engine/network/Socket.d.ts +5 -2
- package/dist/engine/network/index.d.ts +2 -0
- package/dist/engine/system/index.d.ts +2 -4
- package/dist/engine/wid/types.d.ts +2 -2
- package/dist/helpers/retry.d.ts +2 -0
- package/dist/index.d.ts +4 -1
- package/dist/index.es.js +1 -1
- package/dist/index.js +2 -2
- package/dist/types/common.d.ts +1 -0
- package/dist/types/engine.d.ts +15 -5
- package/package.json +1 -1
- package/src/constants/common.ts +13 -0
- package/src/engine/DefaultEngineDependenciesFactory.ts +18 -13
- package/src/engine/Logger.ts +43 -17
- package/src/engine/Peer.ts +8 -2
- package/src/engine/PeerConsumer.ts +12 -3
- package/src/engine/handlers/ChannelEventHandler.ts +4 -1
- package/src/engine/handlers/MediaSoupEventHandler.ts +4 -1
- package/src/engine/index.ts +42 -8
- package/src/engine/media/index.ts +17 -4
- package/src/engine/media/tracks/BaseTrack.ts +13 -3
- package/src/engine/media/tracks/PeerTrack.ts +5 -1
- package/src/engine/network/Socket.ts +10 -3
- package/src/engine/network/index.ts +6 -2
- package/src/engine/system/index.ts +7 -7
- package/src/engine/wid/WebRTCIssueDetector.ts +2 -2
- package/src/engine/wid/detectors/NetworkIssueDetector.ts +13 -16
- package/src/engine/wid/types.ts +2 -2
- package/src/helpers/retry.ts +4 -2
- package/src/index.ts +14 -1
- package/src/types/common.ts +2 -0
- package/src/types/engine.ts +18 -5
package/src/engine/wid/types.ts
CHANGED
|
@@ -19,7 +19,7 @@ export enum EventType {
|
|
|
19
19
|
export type EventPayload = IssueDetectorResult;
|
|
20
20
|
|
|
21
21
|
export type WebRTCIssueDetectorConstructorParams = {
|
|
22
|
-
|
|
22
|
+
onIssues?: (payload: IssueDetectorResult) => void,
|
|
23
23
|
};
|
|
24
24
|
|
|
25
25
|
export enum IssueType {
|
|
@@ -37,7 +37,7 @@ export enum IssueReason {
|
|
|
37
37
|
EncoderCPUThrottling = 'encoder-cpu-throttling',
|
|
38
38
|
DecoderCPUThrottling = 'decoder-cpu-throttling',
|
|
39
39
|
ServerIssue = 'server-issue',
|
|
40
|
-
|
|
40
|
+
MOS = 'mean-opinion-score',
|
|
41
41
|
}
|
|
42
42
|
|
|
43
43
|
export type IssuePayload = {
|
package/src/helpers/retry.ts
CHANGED
|
@@ -6,9 +6,9 @@ export type RetryOpts = {
|
|
|
6
6
|
minBackoffDelayMs?: number;
|
|
7
7
|
maxBackoffDelayMs?: number;
|
|
8
8
|
actionName?: string; // human-readable action name for debug purposes
|
|
9
|
+
logger?: Logger;
|
|
9
10
|
};
|
|
10
11
|
|
|
11
|
-
const logger = new Logger('Retry');
|
|
12
12
|
const timeProvider = new DefaultTimeProvider();
|
|
13
13
|
|
|
14
14
|
const retryAsync = async <ReturnType>(
|
|
@@ -28,7 +28,9 @@ const retryAsync = async <ReturnType>(
|
|
|
28
28
|
return await action();
|
|
29
29
|
} catch (err: unknown) {
|
|
30
30
|
lastError = err;
|
|
31
|
-
|
|
31
|
+
if (opts.logger) {
|
|
32
|
+
opts.logger.info('Action retry failed', currentAttempt, opts.actionName, err);
|
|
33
|
+
}
|
|
32
34
|
|
|
33
35
|
if (currentAttempt < maxRetries) {
|
|
34
36
|
const delay = 2 ** (currentAttempt - 1) * minBackoffDelayMs;
|
package/src/index.ts
CHANGED
|
@@ -4,6 +4,7 @@ import {
|
|
|
4
4
|
CreateMicrophoneAudioTrackOptions,
|
|
5
5
|
CreateScreenMediaOptions,
|
|
6
6
|
JoinChannelParams,
|
|
7
|
+
LogLevel,
|
|
7
8
|
LogMessageHandler,
|
|
8
9
|
Role,
|
|
9
10
|
Track,
|
|
@@ -13,13 +14,16 @@ import Engine from './engine';
|
|
|
13
14
|
import Peer from './engine/Peer';
|
|
14
15
|
import { LoadBalancerApiClientParams } from './engine/network/LoadBalancerClient';
|
|
15
16
|
import DefaultEngineDependenciesFactory from './engine/DefaultEngineDependenciesFactory';
|
|
17
|
+
import { IssuesHandler } from './types/engine';
|
|
16
18
|
|
|
17
19
|
type ClientParams = {
|
|
18
20
|
observer?: EnhancedEventEmitter;
|
|
19
21
|
network?: {
|
|
20
22
|
loadbalancer?: LoadBalancerApiClientParams;
|
|
21
23
|
},
|
|
24
|
+
logLevel: LogLevel,
|
|
22
25
|
onLogMessage?: LogMessageHandler;
|
|
26
|
+
onIssues?: IssuesHandler,
|
|
23
27
|
};
|
|
24
28
|
|
|
25
29
|
class Client {
|
|
@@ -28,7 +32,14 @@ class Client {
|
|
|
28
32
|
private readonly _observer: EnhancedEventEmitter;
|
|
29
33
|
|
|
30
34
|
constructor(params: ClientParams) {
|
|
31
|
-
const {
|
|
35
|
+
const {
|
|
36
|
+
observer,
|
|
37
|
+
network,
|
|
38
|
+
onLogMessage,
|
|
39
|
+
onIssues,
|
|
40
|
+
logLevel,
|
|
41
|
+
} = params;
|
|
42
|
+
|
|
32
43
|
this._observer = observer ?? new EnhancedEventEmitter();
|
|
33
44
|
const dependenciesFactory = new DefaultEngineDependenciesFactory();
|
|
34
45
|
this.engine = new Engine({
|
|
@@ -40,7 +51,9 @@ class Client {
|
|
|
40
51
|
customNode: network?.loadbalancer?.customNode,
|
|
41
52
|
},
|
|
42
53
|
},
|
|
54
|
+
logLevel,
|
|
43
55
|
onLogMessage,
|
|
56
|
+
onIssues,
|
|
44
57
|
});
|
|
45
58
|
}
|
|
46
59
|
|
package/src/types/common.ts
CHANGED
package/src/types/engine.ts
CHANGED
|
@@ -7,20 +7,33 @@ import ChannelEventHandler from '../engine/handlers/ChannelEventHandler';
|
|
|
7
7
|
import MediaSoupEventHandler from '../engine/handlers/MediaSoupEventHandler';
|
|
8
8
|
import WebRTCIssueDetector from '../engine/wid/WebRTCIssueDetector';
|
|
9
9
|
import { LoadBalancerApiClientParams } from '../engine/network/LoadBalancerClient';
|
|
10
|
-
import
|
|
10
|
+
import { IssueDetectorResult } from '../engine/wid/types';
|
|
11
|
+
import { LogLevel } from './common';
|
|
12
|
+
|
|
13
|
+
export type IssuesHandler = (issues: IssueDetectorResult) => void;
|
|
11
14
|
|
|
12
15
|
export interface CreateIssueDetectorParams {
|
|
13
|
-
|
|
16
|
+
onIssues?: IssuesHandler;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export interface CreateMediaParams {
|
|
20
|
+
logLevel: LogLevel;
|
|
14
21
|
}
|
|
15
22
|
|
|
16
23
|
export interface CreateNetworkParams {
|
|
24
|
+
logLevel: LogLevel;
|
|
17
25
|
loadbalancer: LoadBalancerApiClientParams;
|
|
18
26
|
}
|
|
19
27
|
|
|
28
|
+
export interface CreateSystemParams {
|
|
29
|
+
logLevel: LogLevel;
|
|
30
|
+
clientEventEmitter: EnhancedEventEmitter
|
|
31
|
+
}
|
|
32
|
+
|
|
20
33
|
export interface EngineDependenciesFactory {
|
|
21
|
-
createSystem: (
|
|
22
|
-
createMedia: () => Media;
|
|
23
|
-
createNetwork: (
|
|
34
|
+
createSystem: (params: CreateSystemParams) => System;
|
|
35
|
+
createMedia: (params: CreateMediaParams) => Media;
|
|
36
|
+
createNetwork: (params: CreateNetworkParams) => Network;
|
|
24
37
|
createChannelEventHandler: (engine: Engine) => ChannelEventHandler;
|
|
25
38
|
createMediaSoupEventHandler: (engine: Engine) => MediaSoupEventHandler;
|
|
26
39
|
createIssueDetector: (params: CreateIssueDetectorParams) => WebRTCIssueDetector;
|