@vkontakte/calls-sdk 2.8.11-dev.5500645b.0 → 2.8.11-dev.69b107ee.0
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/CallsSDK.d.ts +52 -14
- package/abstract/BaseApi.d.ts +5 -5
- package/abstract/BaseSignaling.d.ts +2 -3
- package/calls-sdk.cjs.js +16 -14
- package/calls-sdk.esm.js +11741 -14
- package/classes/AudioFix.d.ts +5 -1
- package/classes/AudioOutput.d.ts +5 -1
- package/classes/Conversation.d.ts +9 -6
- package/classes/ConversationResponseValidator.d.ts +3 -0
- package/classes/DebugInfo.d.ts +3 -0
- package/classes/DisplayLayoutRequester.d.ts +39 -0
- package/classes/ExternalIdCache.d.ts +19 -0
- package/classes/MediaSource.d.ts +5 -1
- package/classes/ParticipantIdRegistry.d.ts +3 -0
- package/classes/ProducerCommandSerializationService.d.ts +3 -0
- package/classes/SignalingActor.d.ts +3 -1
- package/classes/SpeakerDetector.d.ts +2 -1
- package/classes/SpecListener.d.ts +5 -1
- package/classes/StatsLogger.d.ts +29 -0
- package/classes/VideoEffectsFpsLimiter.d.ts +3 -0
- package/classes/asr/AsrReceiver.d.ts +3 -1
- package/classes/codec/LibVPxDecoder.d.ts +3 -0
- package/classes/codec/LibVPxEncoder.d.ts +3 -1
- package/classes/codec/WebCodecsDecoder.d.ts +3 -0
- package/classes/codec/WebCodecsEncoder.d.ts +3 -1
- package/classes/codec/WorkerBase.d.ts +5 -0
- package/classes/screenshare/BaseStreamBuilder.d.ts +4 -1
- package/classes/screenshare/CanvasRenderer.d.ts +3 -1
- package/classes/screenshare/ScreenCaptureReceiver.d.ts +7 -1
- package/classes/screenshare/ScreenCaptureSender.d.ts +5 -1
- package/classes/screenshare/ScreenCongestionControl.d.ts +3 -1
- package/classes/screenshare/StreamBuilder.d.ts +5 -1
- package/classes/screenshare/TrackGeneratorRenderer.d.ts +3 -1
- package/classes/screenshare/WebmBuilder.d.ts +3 -1
- package/classes/stat/CodecStatsAggregator.d.ts +7 -7
- package/classes/stat/ConversationStats.d.ts +21 -0
- package/classes/stat/StatAggregator.d.ts +6 -6
- package/classes/stat/StatFirstMediaReceived.d.ts +6 -2
- package/classes/stat/StatPings.d.ts +9 -9
- package/classes/stat/StatScreenShareFirstFrame.d.ts +3 -1
- package/classes/stat/StatSignalingCommands.d.ts +8 -8
- package/classes/transport/BaseTransport.d.ts +1 -1
- package/classes/transport/DirectStatReporter.d.ts +3 -1
- package/classes/transport/DirectTransport.d.ts +9 -6
- package/classes/transport/PerfStatReporter.d.ts +5 -1
- package/classes/transport/ServerTransport.d.ts +10 -10
- package/classes/transport/Transport.d.ts +12 -30
- package/default/Api.d.ts +6 -14
- package/default/Signaling.d.ts +40 -45
- package/default/SignalingTransport.d.ts +68 -0
- package/enums/HangupType.d.ts +2 -1
- package/enums/TransportState.d.ts +10 -0
- package/enums/TransportTopology.d.ts +5 -0
- package/package.json +1 -1
- package/static/Debug.d.ts +27 -8
- package/static/External.d.ts +3 -4
- package/static/Params.d.ts +14 -17
- package/static/Utils.d.ts +3 -2
- package/static/WebRTCUtils.d.ts +7 -4
- package/types/Conversation.d.ts +1 -1
- package/types/FastStart.d.ts +1 -0
- package/types/ParticipantLayout.d.ts +33 -0
- package/types/PerfStatReporter.d.ts +2 -1
- package/types/PushData.d.ts +3 -0
- package/types/SignalingMessage.d.ts +5 -1
- package/types/Statistics.d.ts +1 -5
- package/types/WebTransport.d.ts +5 -0
- package/utils/DebugStorage.d.ts +100 -1
- package/classes/Logger.d.ts +0 -41
- package/classes/stat/EventMetricsService.d.ts +0 -9
- package/static/ConversationDebugLogger.d.ts +0 -13
- package/static/DebugVideoStats.d.ts +0 -22
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { ICallStatLog } from '../../types/PerfStatReporter';
|
|
2
2
|
import { IEventualStatLog } from '../../types/IEventualStatLog';
|
|
3
|
+
import StatsLogger from '../StatsLogger';
|
|
3
4
|
export declare class StatAggregator {
|
|
4
|
-
private
|
|
5
|
+
private readonly _logger;
|
|
5
6
|
private readonly _eventualLogs;
|
|
6
|
-
|
|
7
|
-
|
|
7
|
+
constructor(logger: StatsLogger);
|
|
8
|
+
logCallStat(params: ICallStatLog): void;
|
|
8
9
|
/** @link https://wiki.odkl.ru/pages/viewpage.action?pageId=100892588 */
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
private _destroy;
|
|
10
|
+
logEventualStat(params: IEventualStatLog): void;
|
|
11
|
+
destroy(): void;
|
|
12
12
|
}
|
|
@@ -1,21 +1,25 @@
|
|
|
1
|
-
import
|
|
1
|
+
import TransportTopology from '../../enums/TransportTopology';
|
|
2
|
+
import { StatAggregator } from './StatAggregator';
|
|
2
3
|
/** связанный с операцией `first_media_received` тип логируемого звонка */
|
|
3
4
|
declare enum ECallType {
|
|
4
5
|
DirectOutgoing = "direct_outgoing",
|
|
5
6
|
DirectIncoming = "direct_incoming",
|
|
7
|
+
DirectJoin = "direct_join",
|
|
6
8
|
ServerIncoming = "server_incoming",
|
|
7
9
|
ServerJoinServer = "server_join_server",
|
|
8
10
|
ServerChangeTopology = "server_change_topology"
|
|
9
11
|
}
|
|
10
12
|
export declare class StatFirstMediaReceived {
|
|
13
|
+
private readonly _statAggregator;
|
|
11
14
|
/** уже поставили засечку на приём звонка */
|
|
12
15
|
protected _isCallMarked: boolean;
|
|
13
16
|
protected _isFinished: boolean;
|
|
14
17
|
protected _callType: ECallType | null;
|
|
18
|
+
constructor(statAggregator: StatAggregator);
|
|
15
19
|
markAcceptCall(topology: TransportTopology): void;
|
|
16
20
|
markAcceptedCall(topology?: TransportTopology): void;
|
|
17
|
-
markParticipantJoined(topology: TransportTopology): void;
|
|
18
21
|
markOnJoin(topology: TransportTopology): void;
|
|
22
|
+
markTopologyChanged(topology: TransportTopology): void;
|
|
19
23
|
private mark;
|
|
20
24
|
measure(): void;
|
|
21
25
|
}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { SignalingTransportType } from '../../enums/SignalingTransportStat';
|
|
2
|
-
import
|
|
2
|
+
import StatsLogger from '../StatsLogger';
|
|
3
|
+
import TransportTopology from '../../enums/TransportTopology';
|
|
3
4
|
export declare class StatPings {
|
|
4
|
-
private
|
|
5
|
-
|
|
5
|
+
private readonly _logger;
|
|
6
|
+
private trackerByTransport;
|
|
7
|
+
private lastSeen;
|
|
8
|
+
constructor(logger: StatsLogger);
|
|
6
9
|
/**
|
|
7
10
|
* Вызывать при входящем ping в сигналингу.
|
|
8
11
|
* Будет произведен расчет времени между пингами.
|
|
9
12
|
*/
|
|
10
|
-
|
|
13
|
+
mark(transport: SignalingTransportType): void;
|
|
11
14
|
/** Отправляем данные в стату */
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
private trackerByTransport;
|
|
15
|
-
private lastSeen;
|
|
16
|
-
private _destroy;
|
|
15
|
+
logMetrics(topology?: TransportTopology): void;
|
|
16
|
+
destroy(): void;
|
|
17
17
|
}
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { ParticipantId } from '../../types/Participant';
|
|
2
|
+
import { StatAggregator } from './StatAggregator';
|
|
2
3
|
export declare class StatScreenShareFirstFrame {
|
|
3
4
|
protected readonly _participantId: ParticipantId;
|
|
5
|
+
private readonly _statAggregator;
|
|
4
6
|
protected _firstFrameReceived: boolean;
|
|
5
|
-
constructor(participantId: ParticipantId);
|
|
7
|
+
constructor(participantId: ParticipantId, statAggregator: StatAggregator | null);
|
|
6
8
|
measure(width: number, height: number): void;
|
|
7
9
|
}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { SignalingTransportType } from '../../enums/SignalingTransportStat';
|
|
2
|
-
import
|
|
2
|
+
import StatsLogger from '../StatsLogger';
|
|
3
|
+
import TransportTopology from '../../enums/TransportTopology';
|
|
3
4
|
export declare class StatSignalingCommands {
|
|
4
|
-
private
|
|
5
|
-
static create(): void;
|
|
6
|
-
static mark(command: string, time: number, transport: SignalingTransportType): void;
|
|
7
|
-
/** Отправляем данные в стату */
|
|
8
|
-
static logMetrics(topology?: TransportTopology): void;
|
|
9
|
-
static destroy(): void;
|
|
5
|
+
private readonly _logger;
|
|
10
6
|
private trackerByCommand;
|
|
11
|
-
|
|
7
|
+
constructor(logger: StatsLogger);
|
|
8
|
+
mark(command: string, time: number, transport: SignalingTransportType): void;
|
|
9
|
+
/** Отправляем данные в стату */
|
|
10
|
+
logMetrics(topology?: TransportTopology): void;
|
|
11
|
+
destroy(): void;
|
|
12
12
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import BaseSignaling from '../../abstract/BaseSignaling';
|
|
2
|
+
import TransportState from '../../enums/TransportState';
|
|
2
3
|
import EventEmitter from '../EventEmitter';
|
|
3
4
|
import { MediaSource } from '../MediaSource';
|
|
4
|
-
import { TransportState } from './Transport';
|
|
5
5
|
export default abstract class BaseTransport extends EventEmitter {
|
|
6
6
|
protected readonly _signaling: BaseSignaling;
|
|
7
7
|
protected readonly _mediaSource: MediaSource;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import BaseSignaling from '../../abstract/BaseSignaling';
|
|
2
|
+
import { type DebugLogger } from '../../static/Debug';
|
|
2
3
|
import { StatResult } from '../../types/Statistics';
|
|
3
4
|
import EventEmitter from '../EventEmitter';
|
|
4
5
|
import { WeightedAverage } from '../stat/WeightedAverage';
|
|
@@ -30,7 +31,8 @@ export default class DirectStatReporter extends EventEmitter {
|
|
|
30
31
|
private readonly _networkLimits;
|
|
31
32
|
private _lastStatSentTimestamp;
|
|
32
33
|
private _currentState;
|
|
33
|
-
|
|
34
|
+
private readonly _debug;
|
|
35
|
+
constructor(signaling: BaseSignaling, debug?: DebugLogger);
|
|
34
36
|
private _calcRttRating;
|
|
35
37
|
private _calcLossRating;
|
|
36
38
|
private _calcBitrateRating;
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import type { AnimojiReceiver, AnimojiSender } from '@vkontakte/calls-vmoji';
|
|
2
2
|
import BaseSignaling from '../../abstract/BaseSignaling';
|
|
3
|
+
import { type DebugLogger } from '../../static/Debug';
|
|
3
4
|
import { ParticipantId } from '../../types/Participant';
|
|
4
5
|
import ServerSettings from '../../types/ServerSettings';
|
|
6
|
+
import StatsLogger from '../StatsLogger';
|
|
5
7
|
import { MediaSource } from '../MediaSource';
|
|
8
|
+
import { CodecStatsAggregator } from '../stat/CodecStatsAggregator';
|
|
9
|
+
import { StatAggregator } from '../stat/StatAggregator';
|
|
6
10
|
import BaseTransport from './BaseTransport';
|
|
7
11
|
export default class DirectTransport extends BaseTransport {
|
|
8
12
|
private readonly _participantId;
|
|
9
13
|
private readonly _isMaster;
|
|
10
|
-
private _hasOutboundVideoDebug;
|
|
11
|
-
private _hasInboundVideoDebug;
|
|
12
|
-
private _videoDebugBytes;
|
|
13
14
|
private _remoteSDP;
|
|
14
15
|
private _remoteCandidates;
|
|
15
16
|
private _lastRemoteSDP;
|
|
@@ -37,7 +38,11 @@ export default class DirectTransport extends BaseTransport {
|
|
|
37
38
|
private _lastBadConnection;
|
|
38
39
|
private _perfStatReporter;
|
|
39
40
|
private _directStatReporter;
|
|
40
|
-
|
|
41
|
+
private readonly _debug;
|
|
42
|
+
private readonly _logger;
|
|
43
|
+
private readonly _statAggregator;
|
|
44
|
+
private readonly _codecStatsAggregator;
|
|
45
|
+
constructor(participantId: ParticipantId, isMaster: boolean, signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings, debug?: DebugLogger, logger?: StatsLogger | null, statAggregator?: StatAggregator | null, codecStatsAggregator?: CodecStatsAggregator | null);
|
|
41
46
|
get participantId(): ParticipantId;
|
|
42
47
|
updateStatisticsInterval(): void;
|
|
43
48
|
private _isDeadConnection;
|
|
@@ -70,8 +75,6 @@ export default class DirectTransport extends BaseTransport {
|
|
|
70
75
|
private static _patchRemoteDescription;
|
|
71
76
|
private _onReplacedTrack;
|
|
72
77
|
private _startStatInterval;
|
|
73
|
-
private _reportVideoStreamDebug;
|
|
74
|
-
private _getVideoDebugBitrate;
|
|
75
78
|
/**
|
|
76
79
|
* Check SVC support
|
|
77
80
|
* @see https://webrtc.internaut.com/mc/
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import BaseSignaling from '../../abstract/BaseSignaling';
|
|
2
|
+
import { type DebugLogger } from '../../static/Debug';
|
|
2
3
|
import EventEmitter from '../EventEmitter';
|
|
4
|
+
import { StatAggregator } from '../stat/StatAggregator';
|
|
3
5
|
import DirectTransport from './DirectTransport';
|
|
4
6
|
import ServerTransport from './ServerTransport';
|
|
5
7
|
export default class PerfStatReporter extends EventEmitter {
|
|
@@ -10,7 +12,9 @@ export default class PerfStatReporter extends EventEmitter {
|
|
|
10
12
|
private _screenShareStats;
|
|
11
13
|
private _signaling;
|
|
12
14
|
private readonly _directTopology;
|
|
13
|
-
|
|
15
|
+
private readonly _debug;
|
|
16
|
+
private readonly _statAggregator;
|
|
17
|
+
constructor(transport: ServerTransport | DirectTransport, signaling: BaseSignaling, statAggregator?: StatAggregator | null, directTopology?: boolean, debug?: DebugLogger);
|
|
14
18
|
destroy(): void;
|
|
15
19
|
static getEstimatedPerformanceIndex(): number;
|
|
16
20
|
private _handleStats;
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import type { AnimojiReceiver, AnimojiSender } from '@vkontakte/calls-vmoji';
|
|
2
2
|
import BaseSignaling from '../../abstract/BaseSignaling';
|
|
3
|
+
import { type DebugLogger } from '../../static/Debug';
|
|
3
4
|
import { ParticipantId } from '../../types/Participant';
|
|
4
5
|
import ServerSettings from '../../types/ServerSettings';
|
|
6
|
+
import StatsLogger from '../StatsLogger';
|
|
5
7
|
import { MediaSource } from '../MediaSource';
|
|
8
|
+
import { CodecStatsAggregator } from '../stat/CodecStatsAggregator';
|
|
9
|
+
import { StatAggregator } from '../stat/StatAggregator';
|
|
6
10
|
import BaseTransport from './BaseTransport';
|
|
7
11
|
export default class ServerTransport extends BaseTransport {
|
|
8
|
-
private _hasOutboundVideoDebug;
|
|
9
|
-
private _inboundVideoDebugParticipants;
|
|
10
|
-
private _videoDebugBytes;
|
|
11
12
|
private _producerNotification;
|
|
12
13
|
private _producerCommand;
|
|
13
14
|
private _producerScreen;
|
|
@@ -39,11 +40,14 @@ export default class ServerTransport extends BaseTransport {
|
|
|
39
40
|
private _participantIdRegistry;
|
|
40
41
|
private _disabledSenders;
|
|
41
42
|
private _rtpReceiversByStreamId;
|
|
42
|
-
private _participantIdByVideoTrackId;
|
|
43
43
|
private _producerSessionId;
|
|
44
44
|
private _newAudioShareTrack;
|
|
45
45
|
private _simulcastInfo;
|
|
46
|
-
|
|
46
|
+
private readonly _debug;
|
|
47
|
+
private readonly _logger;
|
|
48
|
+
private readonly _statAggregator;
|
|
49
|
+
private readonly _codecStatsAggregator;
|
|
50
|
+
constructor(signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings, debug?: DebugLogger, logger?: StatsLogger | null, statAggregator?: StatAggregator | null, codecStatsAggregator?: CodecStatsAggregator | null);
|
|
47
51
|
updateStatisticsInterval(): void;
|
|
48
52
|
open(observer?: boolean): void;
|
|
49
53
|
close(error?: Error): void;
|
|
@@ -78,10 +82,6 @@ export default class ServerTransport extends BaseTransport {
|
|
|
78
82
|
private _stopSettingsInterval;
|
|
79
83
|
private _collectStat;
|
|
80
84
|
private _reportStats;
|
|
81
|
-
private _reportVideoStreamDebug;
|
|
82
|
-
private _getVideoDebugStreamId;
|
|
83
|
-
private _getVideoDebugTrackId;
|
|
84
|
-
private _getVideoDebugBitrate;
|
|
85
85
|
private _detectStaleTracks;
|
|
86
86
|
private _allocateConsumer;
|
|
87
87
|
private _processOffer;
|
|
@@ -96,7 +96,7 @@ export default class ServerTransport extends BaseTransport {
|
|
|
96
96
|
private _onAsrTranscription;
|
|
97
97
|
private _onProducerUpdated;
|
|
98
98
|
private _onAddTrack;
|
|
99
|
-
|
|
99
|
+
private _onSignalingStateChange;
|
|
100
100
|
private _onConnectionStateChange;
|
|
101
101
|
private _onReplacedTrack;
|
|
102
102
|
private _onSourcesChanged;
|
|
@@ -1,10 +1,15 @@
|
|
|
1
1
|
import type { AnimojiSvgData, RGBTuple } from '@vkontakte/calls-vmoji';
|
|
2
2
|
import BaseSignaling from '../../abstract/BaseSignaling';
|
|
3
|
-
import
|
|
3
|
+
import TransportState from '../../enums/TransportState';
|
|
4
|
+
import TransportTopology from '../../enums/TransportTopology';
|
|
5
|
+
import { type DebugLogger } from '../../static/Debug';
|
|
4
6
|
import { ParticipantId } from '../../types/Participant';
|
|
5
7
|
import ServerSettings from '../../types/ServerSettings';
|
|
6
8
|
import EventEmitter from '../EventEmitter';
|
|
9
|
+
import StatsLogger from '../StatsLogger';
|
|
7
10
|
import { MediaSource } from '../MediaSource';
|
|
11
|
+
import { CodecStatsAggregator } from '../stat/CodecStatsAggregator';
|
|
12
|
+
import { StatAggregator } from '../stat/StatAggregator';
|
|
8
13
|
export declare const enum TransportEvent {
|
|
9
14
|
REMOTE_TRACK_ADDED = "REMOTE_TRACK_ADDED",
|
|
10
15
|
REMOTE_TRACK_REMOVED = "REMOTE_TRACK_REMOVED",
|
|
@@ -22,34 +27,8 @@ export declare const enum TransportEvent {
|
|
|
22
27
|
ASR_TRANSCRIPTION = "ASR_TRANSCRIPTION",
|
|
23
28
|
ANIMOJI_STREAM = "ANIMOJI_STREAM",
|
|
24
29
|
ANIMOJI_ERROR = "ANIMOJI_ERROR",
|
|
25
|
-
SCREEN_SHARING_STAT = "SCREEN_SHARING_STAT"
|
|
26
|
-
VIDEO_STREAM_DEBUG = "VIDEO_STREAM_DEBUG"
|
|
30
|
+
SCREEN_SHARING_STAT = "SCREEN_SHARING_STAT"
|
|
27
31
|
}
|
|
28
|
-
export declare const enum TransportState {
|
|
29
|
-
IDLE = "IDLE",
|
|
30
|
-
OPENED = "OPENED",
|
|
31
|
-
CONNECTING = "CONNECTING",
|
|
32
|
-
RECONNECTING = "RECONNECTING",
|
|
33
|
-
CONNECTED = "CONNECTED",
|
|
34
|
-
CLOSED = "CLOSED",
|
|
35
|
-
FAILED = "FAILED"
|
|
36
|
-
}
|
|
37
|
-
export declare const enum TransportTopology {
|
|
38
|
-
DIRECT = "DIRECT",
|
|
39
|
-
SERVER = "SERVER"
|
|
40
|
-
}
|
|
41
|
-
export type VideoStreamDebugEvent = {
|
|
42
|
-
direction: VideoStreamDebugDirection;
|
|
43
|
-
streamId?: ParticipantId;
|
|
44
|
-
trackId?: string;
|
|
45
|
-
mimeType?: string;
|
|
46
|
-
width?: number;
|
|
47
|
-
height?: number;
|
|
48
|
-
frameRate?: number;
|
|
49
|
-
bitrate?: number;
|
|
50
|
-
packetsLost?: number;
|
|
51
|
-
clear?: boolean;
|
|
52
|
-
};
|
|
53
32
|
export declare class Transport extends EventEmitter {
|
|
54
33
|
private readonly _signaling;
|
|
55
34
|
private readonly _mediaSource;
|
|
@@ -65,7 +44,11 @@ export declare class Transport extends EventEmitter {
|
|
|
65
44
|
private _localState;
|
|
66
45
|
private _animojiReceiver;
|
|
67
46
|
private _animojiSender;
|
|
68
|
-
|
|
47
|
+
private readonly _debug;
|
|
48
|
+
private readonly _logger;
|
|
49
|
+
private readonly _statAggregator;
|
|
50
|
+
private readonly _codecStatsAggregator;
|
|
51
|
+
constructor(topology: TransportTopology, signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings, debug?: DebugLogger, logger?: StatsLogger | null, statAggregator?: StatAggregator | null, codecStatsAggregator?: CodecStatsAggregator | null);
|
|
69
52
|
updateSettings(settings: ServerSettings): void;
|
|
70
53
|
updateStatisticsInterval(): void;
|
|
71
54
|
allocate(participantId: ParticipantId, isMaster?: boolean): void;
|
|
@@ -99,7 +82,6 @@ export declare class Transport extends EventEmitter {
|
|
|
99
82
|
private _onPeerConnectionClosed;
|
|
100
83
|
private _onServerAudioMixStall;
|
|
101
84
|
private _onRemoteDataStats;
|
|
102
|
-
private _onVideoStreamDebug;
|
|
103
85
|
private _onRemoteTrackAdded;
|
|
104
86
|
private _onRemoteTrackRemoved;
|
|
105
87
|
private _onAsrTranscription;
|
package/default/Api.d.ts
CHANGED
|
@@ -1,21 +1,19 @@
|
|
|
1
|
-
import BaseApi, { ClientEvent, ClientStats
|
|
1
|
+
import BaseApi, { ClientEvent, ClientStats } from '../abstract/BaseApi';
|
|
2
2
|
import CallType from '../enums/CallType';
|
|
3
3
|
import HangupType from '../enums/HangupType';
|
|
4
4
|
import ConversationParams from '../types/ConversationParams';
|
|
5
5
|
import ConversationResponse from '../types/ConversationResponse';
|
|
6
6
|
import { ExternalId, ExternalParticipantId, ExternalUserId } from '../types/ExternalId';
|
|
7
7
|
import { CompositeUserId, OkUserId, ParticipantId } from '../types/Participant';
|
|
8
|
+
import PushData from '../types/PushData';
|
|
8
9
|
export default class Api extends BaseApi {
|
|
9
10
|
private _userId;
|
|
10
11
|
private _uuid;
|
|
11
|
-
private
|
|
12
|
-
private _decorativeIdToInitialId;
|
|
13
|
-
private _initialIdToDecorativeId;
|
|
12
|
+
private _idCache;
|
|
14
13
|
private _callUnsafe;
|
|
15
14
|
protected _call(method: string, data?: any, noSession?: boolean): Promise<any>;
|
|
16
15
|
userId(participantId: ParticipantId): Promise<ExternalParticipantId>;
|
|
17
16
|
authorize(): Promise<void>;
|
|
18
|
-
log(items: LogItem[]): void;
|
|
19
17
|
logClientStats(items: ClientStats[]): void;
|
|
20
18
|
logClientEvents(items: ClientEvent[]): void;
|
|
21
19
|
uploadDebugLogs(conversationId: string, startTime: number, endTime: number, log: string): Promise<void>;
|
|
@@ -26,7 +24,7 @@ export default class Api extends BaseApi {
|
|
|
26
24
|
audioOnly?: boolean;
|
|
27
25
|
waitForAdmin?: boolean;
|
|
28
26
|
closedConversation?: boolean;
|
|
29
|
-
},
|
|
27
|
+
}, externalIds?: ExternalId[]): Promise<ConversationResponse>;
|
|
30
28
|
startConversation(conversationId: string, ids?: OkUserId[], type?: CallType, isVideo?: boolean, payload?: string, joiningAllowed?: boolean, requireAuthToJoin?: boolean, { onlyAdminCanShareMovie, waitForAdmin }?: {
|
|
31
29
|
onlyAdminCanShareMovie?: boolean;
|
|
32
30
|
waitForAdmin?: boolean;
|
|
@@ -43,19 +41,13 @@ export default class Api extends BaseApi {
|
|
|
43
41
|
}>;
|
|
44
42
|
getAnonymTokenByLink(joinLink: string, username?: string): Promise<string>;
|
|
45
43
|
joinConversationByLink(joinLink: string, isVideo?: boolean, observedIds?: ExternalUserId[], payload?: string): Promise<ConversationResponse>;
|
|
46
|
-
/**
|
|
47
|
-
* NB: Не сохраняет порядок возвращаемых ID
|
|
48
|
-
* Этот метод принимает именно ExternalId, т.к. для OkUserId не принципиально наличие deviceIdx
|
|
49
|
-
* @hidden
|
|
50
|
-
*/
|
|
51
|
-
getOkIdsByExternalIds(externalIds: ExternalId[]): Promise<OkUserId[]>;
|
|
52
|
-
getParticipantIdsByExternalIds(externalIds: ExternalId[]): Promise<Map<ExternalId, ParticipantId>>;
|
|
53
44
|
/**
|
|
54
45
|
* NB: Не сохраняет порядок возвращаемых ID
|
|
55
46
|
* @hidden
|
|
56
47
|
*/
|
|
57
48
|
getExternalIdsByOkIds(uids: OkUserId[]): Promise<ExternalParticipantId[]>;
|
|
58
49
|
getCachedOkIdByExternalId(externalId: ExternalId): ParticipantId | null;
|
|
50
|
+
getCachedRawOkIdByExternalId(externalId: ExternalId): OkUserId | null;
|
|
59
51
|
cacheExternalId(participantId: OkUserId | CompositeUserId | ParticipantId, externalId: ExternalParticipantId): void;
|
|
60
52
|
mapDecorativeId(decorativeId: OkUserId | CompositeUserId | ParticipantId, initialId: OkUserId | CompositeUserId | ParticipantId): void;
|
|
61
53
|
unmapDecorativeId(initialId: OkUserId | CompositeUserId | ParticipantId): void;
|
|
@@ -65,9 +57,9 @@ export default class Api extends BaseApi {
|
|
|
65
57
|
getUserId(): OkUserId | null;
|
|
66
58
|
setUserId(userId: OkUserId): void;
|
|
67
59
|
hangupConversation(conversationId: string, reason?: HangupType): void;
|
|
68
|
-
sendUserFeedbackStats(conversationId: string, userResponse: number, reason?: string, groupCallUsersCount?: number): void;
|
|
69
60
|
removeHistoryRecords(recordIds: number[]): Promise<void>;
|
|
70
61
|
cleanup(): void;
|
|
71
62
|
private _getExternalIdsByOkIds;
|
|
72
63
|
getServerTime(): Promise<number>;
|
|
64
|
+
getInbounds(): Promise<PushData[]>;
|
|
73
65
|
}
|
package/default/Signaling.d.ts
CHANGED
|
@@ -1,13 +1,17 @@
|
|
|
1
1
|
import BaseSignaling, { AddParticipantParams } from '../abstract/BaseSignaling';
|
|
2
|
+
import StatsLogger from '../classes/StatsLogger';
|
|
2
3
|
import { ParticipantIdRegistry } from '../classes/ParticipantIdRegistry';
|
|
3
4
|
import { SharingStatReport } from '../classes/screenshare/SharingStatReport';
|
|
4
|
-
import {
|
|
5
|
+
import { StatAggregator } from '../classes/stat/StatAggregator';
|
|
6
|
+
import { StatPings } from '../classes/stat/StatPings';
|
|
7
|
+
import { StatSignalingCommands } from '../classes/stat/StatSignalingCommands';
|
|
8
|
+
import TransportTopology from '../enums/TransportTopology';
|
|
5
9
|
import ConversationFeature from '../enums/ConversationFeature';
|
|
6
10
|
import ConversationOption from '../enums/ConversationOption';
|
|
7
11
|
import MediaOption from '../enums/MediaOption';
|
|
8
|
-
import SignalingCommandType from '../enums/SignalingCommandType';
|
|
9
12
|
import SignalingConnectionType from '../enums/SignalingConnectionType';
|
|
10
13
|
import UserRole from '../enums/UserRole';
|
|
14
|
+
import { type DebugLogger } from '../static/Debug';
|
|
11
15
|
import { JSONObject } from '../static/Json';
|
|
12
16
|
import { IAsrStartParams, IAsrStopParams } from '../types/Asr';
|
|
13
17
|
import { ChangeSimulcast } from '../types/ChangeSimulcast';
|
|
@@ -21,42 +25,39 @@ import ParticipantLayout, { RequestKeyFrame, StopStream } from '../types/Partici
|
|
|
21
25
|
import { ParticipantListChunkParameters } from '../types/ParticipantListChunk';
|
|
22
26
|
import { StreamDescriptionString } from '../types/ParticipantStreamDescription';
|
|
23
27
|
import { PerfStatReport } from '../types/PerfStatReporter';
|
|
24
|
-
import SignalingMessage, { GetParticipantsSignalingResponse, GetRoomsSignalingResponse
|
|
25
|
-
import { IPublishStreamData,
|
|
28
|
+
import SignalingMessage, { GetParticipantsSignalingResponse, GetRoomsSignalingResponse } from '../types/SignalingMessage';
|
|
29
|
+
import { IPublishStreamData, IStartStreamData, IStopStreamData } from '../types/Streams';
|
|
26
30
|
export default class Signaling extends BaseSignaling {
|
|
27
|
-
private
|
|
28
|
-
|
|
31
|
+
private transport;
|
|
32
|
+
private sequence;
|
|
29
33
|
private lastStamp;
|
|
30
34
|
private websocketCommandsQueue;
|
|
31
35
|
private datachannelCommandsQueue;
|
|
32
36
|
private incomingCache;
|
|
33
37
|
private responseHandlers;
|
|
34
38
|
private connectionType;
|
|
35
|
-
private
|
|
36
|
-
private
|
|
37
|
-
private wtEndpoint;
|
|
38
|
-
protected conversationResolve: Function | null;
|
|
39
|
-
protected conversationReject: Function | null;
|
|
39
|
+
private conversationResolve;
|
|
40
|
+
private conversationReject;
|
|
40
41
|
private connected;
|
|
41
42
|
private listenersReady;
|
|
42
|
-
private
|
|
43
|
-
|
|
44
|
-
protected conversationId: string | null;
|
|
45
|
-
private reconnectTimer;
|
|
43
|
+
private peerId;
|
|
44
|
+
private conversationId;
|
|
46
45
|
private connectionMessageWaitTimer;
|
|
47
|
-
private doctorTimer;
|
|
48
46
|
private participantIdRegistry;
|
|
49
47
|
private producerNotificationDataChannel;
|
|
50
48
|
private producerCommandDataChannel;
|
|
51
49
|
private producerCommandDataChannelEnabled;
|
|
52
50
|
private producerCommandSerializationService;
|
|
53
|
-
private
|
|
54
|
-
private
|
|
55
|
-
private
|
|
51
|
+
private readonly _debug;
|
|
52
|
+
private readonly _logger;
|
|
53
|
+
private readonly _statAggregator;
|
|
54
|
+
private readonly _statPings;
|
|
55
|
+
private readonly _statSignalingCommands;
|
|
56
56
|
private static get WAIT_CONNECTION_DELAY();
|
|
57
57
|
private static get WAIT_RESPONSE_DELAY();
|
|
58
|
-
private static get WAIT_MESSAGE_DELAY();
|
|
59
58
|
get ready(): boolean;
|
|
59
|
+
constructor(debug?: DebugLogger, logger?: StatsLogger | null, statAggregator?: StatAggregator | null, statPings?: StatPings | null, statSignalingCommands?: StatSignalingCommands | null);
|
|
60
|
+
setAbortSignal(signal: AbortSignal | undefined): void;
|
|
60
61
|
setEndpoint(endpoint: string): void;
|
|
61
62
|
setWebTransportEndpoint(endpoint: string | null): void;
|
|
62
63
|
setConversationId(conversationId: string): void;
|
|
@@ -72,15 +73,6 @@ export default class Signaling extends BaseSignaling {
|
|
|
72
73
|
* Open a connection with a signaling server
|
|
73
74
|
*/
|
|
74
75
|
connect(connectionType: SignalingConnectionType): Promise<SignalingMessage.Connection>;
|
|
75
|
-
/**
|
|
76
|
-
* Send a command to a signaling server
|
|
77
|
-
*/
|
|
78
|
-
protected _send<T extends SignalingSuccessResponse>(command: SignalingCommandType, params?: any, needResponse?: boolean, retryCount?: number): Promise<T>;
|
|
79
|
-
/**
|
|
80
|
-
* Send a raw command to a signaling server
|
|
81
|
-
*/
|
|
82
|
-
protected _sendRaw<T extends SignalingSuccessResponse>(command: SignalingCommandType, params?: any, needResponse?: boolean, retryCount?: number): Promise<T>;
|
|
83
|
-
private _isDataChannelCommand;
|
|
84
76
|
getNextCommandSequenceNumber(): number;
|
|
85
77
|
hangup(reason: string): Promise<SignalingMessage | void>;
|
|
86
78
|
sendCandidate(participantId: ParticipantId, candidate: RTCIceCandidate): Promise<SignalingMessage>;
|
|
@@ -120,7 +112,6 @@ export default class Signaling extends BaseSignaling {
|
|
|
120
112
|
startStream(data: IStartStreamData): Promise<SignalingMessage>;
|
|
121
113
|
stopStream(data?: IStopStreamData): Promise<SignalingMessage>;
|
|
122
114
|
publishStream(data?: IPublishStreamData): Promise<SignalingMessage>;
|
|
123
|
-
recordSetConf(conf?: IRecordConfData): Promise<SignalingMessage>;
|
|
124
115
|
getRecordStatus(): Promise<SignalingMessage>;
|
|
125
116
|
switchTopology(topology: TransportTopology, force?: boolean): Promise<SignalingMessage>;
|
|
126
117
|
requestRealloc(): Promise<SignalingMessage>;
|
|
@@ -164,32 +155,36 @@ export default class Signaling extends BaseSignaling {
|
|
|
164
155
|
startAsr(params: IAsrStartParams): Promise<SignalingMessage>;
|
|
165
156
|
stopAsr(params?: IAsrStopParams): Promise<SignalingMessage>;
|
|
166
157
|
requestAsr(request: boolean): Promise<SignalingMessage>;
|
|
167
|
-
|
|
168
|
-
|
|
158
|
+
/**
|
|
159
|
+
* Send a command to a signaling server
|
|
160
|
+
*/
|
|
161
|
+
private _send;
|
|
162
|
+
/**
|
|
163
|
+
* Send a raw command to a signaling server
|
|
164
|
+
*/
|
|
165
|
+
private _sendRaw;
|
|
166
|
+
private _isDataChannelCommand;
|
|
169
167
|
private _onOpen;
|
|
170
168
|
private _onMessage;
|
|
171
|
-
|
|
169
|
+
private _handleMessage;
|
|
172
170
|
private _handleErrorMessage;
|
|
173
|
-
|
|
171
|
+
private _handleCachedMessages;
|
|
174
172
|
private _throwError;
|
|
175
173
|
private _onError;
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
174
|
+
private _serializeErrorEvent;
|
|
175
|
+
private _onClose;
|
|
176
|
+
private _closeSocket;
|
|
179
177
|
private _handleCommandResponse;
|
|
180
178
|
private _handleCommandsQueue;
|
|
181
179
|
private _startResponseTimer;
|
|
182
180
|
private _serializeBinary;
|
|
183
181
|
private _serializeJson;
|
|
184
182
|
private _convertDisplayLayout;
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
private _startDoctor;
|
|
191
|
-
private _stopDoctor;
|
|
192
|
-
private isWebTransportAvailable;
|
|
183
|
+
private _waitConnectionMessage;
|
|
184
|
+
private _stopWaitConnectionMessage;
|
|
185
|
+
private _onTransportFailed;
|
|
186
|
+
private _onTransportReconnectScheduled;
|
|
187
|
+
private _onTransportConnectionDead;
|
|
193
188
|
private _getSocketType;
|
|
194
189
|
private _markTransportStat;
|
|
195
190
|
private _logTransportStat;
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import SignalingConnectionType from '../enums/SignalingConnectionType';
|
|
2
|
+
import { SignalingTransportType } from '../enums/SignalingTransportStat';
|
|
3
|
+
export declare enum SignalingTransportFailure {
|
|
4
|
+
EMPTY_ENDPOINT = "EMPTY_ENDPOINT",
|
|
5
|
+
NETWORK_ERROR = "NETWORK_ERROR",
|
|
6
|
+
ABORTED = "ABORTED"
|
|
7
|
+
}
|
|
8
|
+
export type SignalingTransportFailedEvent = {
|
|
9
|
+
failure: SignalingTransportFailure;
|
|
10
|
+
message: string;
|
|
11
|
+
remote?: boolean;
|
|
12
|
+
};
|
|
13
|
+
export type SignalingTransportReconnectEvent = {
|
|
14
|
+
count: number;
|
|
15
|
+
delay: number;
|
|
16
|
+
};
|
|
17
|
+
export type SignalingTransportHandlers = {
|
|
18
|
+
onOpen: () => void;
|
|
19
|
+
onMessage: (event: MessageEvent) => void;
|
|
20
|
+
onError: (event: Event) => void;
|
|
21
|
+
onClose: (event: CloseEvent) => void;
|
|
22
|
+
onFailed: (event: SignalingTransportFailedEvent) => void;
|
|
23
|
+
onReconnectScheduled: (event: SignalingTransportReconnectEvent) => void;
|
|
24
|
+
onConnectionDead: () => void;
|
|
25
|
+
};
|
|
26
|
+
export default class SignalingTransport {
|
|
27
|
+
private readonly handlers;
|
|
28
|
+
private socket;
|
|
29
|
+
private endpoint;
|
|
30
|
+
private wtEndpoint;
|
|
31
|
+
private peerId;
|
|
32
|
+
private lastStamp;
|
|
33
|
+
private connectionType;
|
|
34
|
+
private reconnectCount;
|
|
35
|
+
private reconnectTimer;
|
|
36
|
+
private doctorTimer;
|
|
37
|
+
private forceWebSocket;
|
|
38
|
+
private abortSignal;
|
|
39
|
+
private manualClose;
|
|
40
|
+
private currentType;
|
|
41
|
+
constructor(handlers: SignalingTransportHandlers);
|
|
42
|
+
get readyState(): number | null;
|
|
43
|
+
get type(): SignalingTransportType;
|
|
44
|
+
setEndpoint(endpoint: string): void;
|
|
45
|
+
setWebTransportEndpoint(endpoint: string | null): void;
|
|
46
|
+
setPeerId(peerId: number | null): void;
|
|
47
|
+
setLastStamp(lastStamp: number): void;
|
|
48
|
+
setAbortSignal(signal?: AbortSignal): void;
|
|
49
|
+
resetReconnectCount(): void;
|
|
50
|
+
connect(connectionType: SignalingConnectionType): void;
|
|
51
|
+
close(code?: number): void;
|
|
52
|
+
send(data: string | ArrayBuffer): void;
|
|
53
|
+
private _connect;
|
|
54
|
+
private _connectWebTransport;
|
|
55
|
+
private _connectWebSocket;
|
|
56
|
+
private _setSocketHandlers;
|
|
57
|
+
private _buildUrl;
|
|
58
|
+
private _canUseWebTransport;
|
|
59
|
+
private _onOpen;
|
|
60
|
+
private _onMessage;
|
|
61
|
+
private _onError;
|
|
62
|
+
private _onClose;
|
|
63
|
+
private _disconnect;
|
|
64
|
+
private _scheduleReconnect;
|
|
65
|
+
private _getReconnectDelay;
|
|
66
|
+
private _startDoctor;
|
|
67
|
+
private _stopDoctor;
|
|
68
|
+
}
|
package/enums/HangupType.d.ts
CHANGED
|
@@ -53,6 +53,7 @@ declare enum HangupType {
|
|
|
53
53
|
* - Приложение вызываемого не запущено или упало
|
|
54
54
|
* - Брандмауэр или сетевые ограничения блокируют подключение
|
|
55
55
|
*/
|
|
56
|
-
CALL_TIMEOUT = "CALL_TIMEOUT"
|
|
56
|
+
CALL_TIMEOUT = "CALL_TIMEOUT",
|
|
57
|
+
OBSOLETE_CLIENT = "OBSOLETE_CLIENT"
|
|
57
58
|
}
|
|
58
59
|
export default HangupType;
|