@vkontakte/calls-sdk 2.8.11-dev.5a5b0d53.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 +51 -13
- package/abstract/BaseApi.d.ts +4 -3
- package/abstract/BaseSignaling.d.ts +2 -3
- package/calls-sdk.cjs.js +16 -13
- package/calls-sdk.esm.js +11741 -13
- package/classes/AudioFix.d.ts +5 -1
- package/classes/AudioOutput.d.ts +5 -1
- package/classes/Conversation.d.ts +9 -2
- 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/{Logger.d.ts → StatsLogger.d.ts} +3 -10
- 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 -1
- package/classes/transport/PerfStatReporter.d.ts +5 -1
- package/classes/transport/ServerTransport.d.ts +10 -2
- package/classes/transport/Transport.d.ts +11 -14
- package/default/Api.d.ts +5 -11
- package/default/Signaling.d.ts +39 -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 -0
- package/static/Params.d.ts +14 -0
- package/static/Utils.d.ts +3 -2
- package/static/WebRTCUtils.d.ts +6 -4
- package/types/Conversation.d.ts +1 -1
- package/types/FastStart.d.ts +1 -0
- package/types/ParticipantLayout.d.ts +33 -0
- package/types/PushData.d.ts +3 -0
- package/types/SignalingMessage.d.ts +5 -1
- package/types/Statistics.d.ts +1 -1
- package/types/WebTransport.d.ts +4 -0
- package/utils/DebugStorage.d.ts +100 -1
- package/classes/stat/EventMetricsService.d.ts +0 -9
- package/static/ConversationDebugLogger.d.ts +0 -13
package/static/Utils.d.ts
CHANGED
|
@@ -3,6 +3,7 @@ import { ExternalParticipant, ExternalParticipantListMarker } from '../types/Ext
|
|
|
3
3
|
import { CompositeUserId, OkUserId, Participant, ParticipantId, ParticipantStateMapped } from '../types/Participant';
|
|
4
4
|
import SignalingMessage from '../types/SignalingMessage';
|
|
5
5
|
import VideoSettings from '../types/VideoSettings';
|
|
6
|
+
import { type DebugLogger } from './Debug';
|
|
6
7
|
export declare const PARAMETERS_SEPARATOR = ":";
|
|
7
8
|
export declare const DEVICE_IDX_PARAMETER = "d";
|
|
8
9
|
/** @hidden */
|
|
@@ -36,8 +37,8 @@ declare namespace Utils {
|
|
|
36
37
|
function delay(time: number, { signal }?: {
|
|
37
38
|
signal?: AbortSignal;
|
|
38
39
|
}): Promise<void>;
|
|
39
|
-
function applySettings(pc: RTCPeerConnection, videoSettings: VideoSettings, prevSettings: any): any;
|
|
40
|
-
function applyVideoTrackSettings(videoSettings: VideoSettings, s: RTCRtpSender, track: MediaStreamTrack | null, prevSettings: any, retSettings: any): void;
|
|
40
|
+
function applySettings(pc: RTCPeerConnection, videoSettings: VideoSettings, prevSettings: any, debug?: DebugLogger): any;
|
|
41
|
+
function applyVideoTrackSettings(videoSettings: VideoSettings, s: RTCRtpSender, track: MediaStreamTrack | null, prevSettings: any, retSettings: any, debug?: DebugLogger): void;
|
|
41
42
|
/**
|
|
42
43
|
* Проверяет, есть ли в первом массиве хотя бы один элемент из второго массива
|
|
43
44
|
* @param arr Где ищем
|
package/static/WebRTCUtils.d.ts
CHANGED
|
@@ -2,6 +2,8 @@
|
|
|
2
2
|
* Вспомогательный плагин для работы с WebRTC
|
|
3
3
|
*/
|
|
4
4
|
import { IVideoDimentions } from '../types/MediaSettings';
|
|
5
|
+
import type StatsLogger from '../classes/StatsLogger';
|
|
6
|
+
import { type DebugLogger } from './Debug';
|
|
5
7
|
/**
|
|
6
8
|
* Тип камеры мобильного устройства
|
|
7
9
|
*/
|
|
@@ -83,24 +85,24 @@ declare namespace WebRTCUtils {
|
|
|
83
85
|
* @param needAudio Нужно ли аудио
|
|
84
86
|
* @param needEmptyTracks Добавлять ли в стрим пустые треки для отключенного видео/аудио
|
|
85
87
|
*/
|
|
86
|
-
function getUserMedia(needVideo?: boolean, needAudio?: boolean, needEmptyTracks?: boolean): Promise<MediaStream>;
|
|
88
|
+
function getUserMedia(needVideo?: boolean, needAudio?: boolean, needEmptyTracks?: boolean, debug?: DebugLogger, logger?: StatsLogger | null): Promise<MediaStream>;
|
|
87
89
|
/**
|
|
88
90
|
* Запрашивает трансляцию экрана пользователя с опциональным захватом звука
|
|
89
91
|
*/
|
|
90
|
-
function getScreenMedia(fastScreenShare: boolean, withAudioShare: boolean): Promise<MediaStream>;
|
|
92
|
+
function getScreenMedia(fastScreenShare: boolean, withAudioShare: boolean, debug?: DebugLogger, logger?: StatsLogger | null): Promise<MediaStream>;
|
|
91
93
|
/**
|
|
92
94
|
* Запрашивает камеру пользователя
|
|
93
95
|
*
|
|
94
96
|
* @param deviceId ID устройства
|
|
95
97
|
* @param resolution Размеры видео
|
|
96
98
|
*/
|
|
97
|
-
function getUserVideo(deviceId?: string, resolution?: IVideoDimentions): Promise<MediaStream>;
|
|
99
|
+
function getUserVideo(deviceId?: string, resolution?: IVideoDimentions, debug?: DebugLogger, logger?: StatsLogger | null): Promise<MediaStream>;
|
|
98
100
|
/**
|
|
99
101
|
* Запрашивает микрофон пользователя
|
|
100
102
|
*
|
|
101
103
|
* @param deviceId ID устройства
|
|
102
104
|
*/
|
|
103
|
-
function getUserAudio(deviceId?: string): Promise<MediaStream>;
|
|
105
|
+
function getUserAudio(deviceId?: string, debug?: DebugLogger, logger?: StatsLogger | null): Promise<MediaStream>;
|
|
104
106
|
/**
|
|
105
107
|
* Устанавливает размер видео в стриме
|
|
106
108
|
*
|
package/types/Conversation.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
1
|
+
import TransportTopology from '../enums/TransportTopology';
|
|
2
2
|
import CallDirection from '../enums/CallDirection';
|
|
3
3
|
import CallType from '../enums/CallType';
|
|
4
4
|
import ConversationFeature from '../enums/ConversationFeature';
|
package/types/FastStart.d.ts
CHANGED
|
@@ -54,4 +54,37 @@ export type ParticipantLayout = (Layout | StopStream | RequestKeyFrame) & {
|
|
|
54
54
|
*/
|
|
55
55
|
streamName?: string;
|
|
56
56
|
};
|
|
57
|
+
/**
|
|
58
|
+
* Запрос стрима, который клиент хочет получать для отображения.
|
|
59
|
+
*/
|
|
60
|
+
export type DisplayLayoutRequest = {
|
|
61
|
+
/**
|
|
62
|
+
* Внешний ID пользователя
|
|
63
|
+
*/
|
|
64
|
+
uid: ExternalParticipantId | string;
|
|
65
|
+
/**
|
|
66
|
+
* Тип медиа (видео с камеры, картинка с экрана, лайв или мувик)
|
|
67
|
+
*/
|
|
68
|
+
mediaType: MediaType;
|
|
69
|
+
/**
|
|
70
|
+
* Ширина окошка в котором отображается видео, в пикселях
|
|
71
|
+
*/
|
|
72
|
+
width: number;
|
|
73
|
+
/**
|
|
74
|
+
* Высота окошка в котором отображается видео, в пикселях
|
|
75
|
+
*/
|
|
76
|
+
height: number;
|
|
77
|
+
/**
|
|
78
|
+
* Отображать видео как CSS object-fit: cover. По умолчанию используется contain.
|
|
79
|
+
*/
|
|
80
|
+
cover?: boolean;
|
|
81
|
+
/**
|
|
82
|
+
* Приоритет
|
|
83
|
+
*/
|
|
84
|
+
priority?: number;
|
|
85
|
+
/**
|
|
86
|
+
* ID лайва или мувика. null для камеры или скрин-шары.
|
|
87
|
+
*/
|
|
88
|
+
streamName?: string;
|
|
89
|
+
};
|
|
57
90
|
export default ParticipantLayout;
|
package/types/PushData.d.ts
CHANGED
|
@@ -1,8 +1,11 @@
|
|
|
1
|
+
import IceServer from './IceServer';
|
|
1
2
|
type PushData = {
|
|
2
3
|
caller_id: string;
|
|
3
4
|
caller_client_type?: string;
|
|
4
5
|
conversation_id: string;
|
|
5
6
|
endpoint: string;
|
|
7
|
+
wt_endpoint?: string;
|
|
8
|
+
turn_server?: IceServer;
|
|
6
9
|
is_video: boolean;
|
|
7
10
|
token: string;
|
|
8
11
|
sdp_offer?: string;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { AnimojiVersion } from '@vkontakte/calls-vmoji';
|
|
2
|
-
import
|
|
2
|
+
import TransportTopology from '../enums/TransportTopology';
|
|
3
3
|
import ChatRoomEventType from '../enums/ChatRoomEventType';
|
|
4
4
|
import ConversationFeature from '../enums/ConversationFeature';
|
|
5
5
|
import ConversationOption from '../enums/ConversationOption';
|
|
@@ -190,6 +190,7 @@ declare namespace SignalingMessage {
|
|
|
190
190
|
deviceIdx?: number;
|
|
191
191
|
peerId: PeerId;
|
|
192
192
|
reason: HangupType;
|
|
193
|
+
errorCode?: string;
|
|
193
194
|
markers?: ParticipantListMarkers;
|
|
194
195
|
}
|
|
195
196
|
export interface ClosedConversation extends Notification {
|
|
@@ -366,6 +367,9 @@ declare namespace SignalingMessage {
|
|
|
366
367
|
export interface Connection extends Notification {
|
|
367
368
|
endpoint: string;
|
|
368
369
|
conversation: Conversation;
|
|
370
|
+
conversationParams: {
|
|
371
|
+
serverTime: number;
|
|
372
|
+
};
|
|
369
373
|
isConcurrent: boolean;
|
|
370
374
|
peerId: PeerId;
|
|
371
375
|
mediaModifiers: MediaModifiers;
|
package/types/Statistics.d.ts
CHANGED
package/types/WebTransport.d.ts
CHANGED
|
@@ -7,6 +7,8 @@ declare class WebTransportEventual {
|
|
|
7
7
|
private readonly url;
|
|
8
8
|
private readonly options;
|
|
9
9
|
private readonly compression;
|
|
10
|
+
private closeRequested;
|
|
11
|
+
private closeEventEmitted;
|
|
10
12
|
private encoder;
|
|
11
13
|
private decoder;
|
|
12
14
|
onopen: ((this: WebTransportEventual, ev: Event) => any) | null;
|
|
@@ -22,6 +24,8 @@ declare class WebTransportEventual {
|
|
|
22
24
|
send(data: string): Promise<void>;
|
|
23
25
|
private createErrorEvent;
|
|
24
26
|
close(code?: number, reason?: string): void;
|
|
27
|
+
private closeConnectedTransport;
|
|
28
|
+
private emitClose;
|
|
25
29
|
static isBrowserSupported(): boolean;
|
|
26
30
|
}
|
|
27
31
|
export { WebTransportEventual as WebTransport };
|
package/utils/DebugStorage.d.ts
CHANGED
|
@@ -1,8 +1,107 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Запись отладочного лога SDK.
|
|
3
|
+
*/
|
|
1
4
|
export type CurrentLogItem = {
|
|
2
5
|
readonly t: number;
|
|
3
6
|
readonly l: string;
|
|
4
7
|
readonly d: any[];
|
|
5
8
|
readonly h: string;
|
|
6
9
|
};
|
|
7
|
-
|
|
10
|
+
/**
|
|
11
|
+
* Информация о сохраненной локальной сессии логирования.
|
|
12
|
+
*/
|
|
13
|
+
export type DebugLogSessionInfo = {
|
|
14
|
+
/**
|
|
15
|
+
* Внутренний id локальной сессии логирования.
|
|
16
|
+
*/
|
|
17
|
+
readonly sessionId: string;
|
|
18
|
+
/**
|
|
19
|
+
* Id звонка. Может быть null, если звонок не успел стартовать.
|
|
20
|
+
*/
|
|
21
|
+
readonly conversationId: string | null;
|
|
22
|
+
/**
|
|
23
|
+
* Время первой записи в ms.
|
|
24
|
+
*/
|
|
25
|
+
readonly startTime: number;
|
|
26
|
+
/**
|
|
27
|
+
* Время последней записи в ms.
|
|
28
|
+
*/
|
|
29
|
+
readonly endTime: number;
|
|
30
|
+
/**
|
|
31
|
+
* Время последнего обновления в ms.
|
|
32
|
+
*/
|
|
33
|
+
readonly updatedAt: number;
|
|
34
|
+
/**
|
|
35
|
+
* Размер сохраненных данных в байтах.
|
|
36
|
+
*/
|
|
37
|
+
readonly bytes: number;
|
|
38
|
+
/**
|
|
39
|
+
* Количество записей лога.
|
|
40
|
+
*/
|
|
41
|
+
readonly entriesCount: number;
|
|
42
|
+
};
|
|
43
|
+
/**
|
|
44
|
+
* Статистика локального хранилища отладочных логов.
|
|
45
|
+
*/
|
|
46
|
+
export type DebugLogStorageStats = {
|
|
47
|
+
/**
|
|
48
|
+
* Доступен ли IndexedDB для сохранения логов.
|
|
49
|
+
*/
|
|
50
|
+
readonly supported: boolean;
|
|
51
|
+
/**
|
|
52
|
+
* Количество сохраненных звонков.
|
|
53
|
+
*/
|
|
54
|
+
readonly callsCount: number;
|
|
55
|
+
/**
|
|
56
|
+
* Количество локальных сессий логирования.
|
|
57
|
+
*/
|
|
58
|
+
readonly sessionsCount: number;
|
|
59
|
+
/**
|
|
60
|
+
* Размер сохраненных логов SDK в байтах.
|
|
61
|
+
*/
|
|
62
|
+
readonly usedBytes: number;
|
|
63
|
+
/**
|
|
64
|
+
* Максимальный размер DebugStorage в байтах.
|
|
65
|
+
*/
|
|
66
|
+
readonly maxBytes: number;
|
|
67
|
+
/**
|
|
68
|
+
* Максимальное количество звонков в DebugStorage.
|
|
69
|
+
*/
|
|
70
|
+
readonly maxCalls: number;
|
|
71
|
+
/**
|
|
72
|
+
* Общая квота браузерного хранилища, если доступна.
|
|
73
|
+
*/
|
|
74
|
+
readonly quotaBytes?: number;
|
|
75
|
+
/**
|
|
76
|
+
* Использование браузерного хранилища, если доступно.
|
|
77
|
+
*/
|
|
78
|
+
readonly usageBytes?: number;
|
|
79
|
+
};
|
|
80
|
+
/**
|
|
81
|
+
* Параметры чтения или очистки локальных логов.
|
|
82
|
+
*/
|
|
83
|
+
export type DebugLogGetParams = {
|
|
84
|
+
/**
|
|
85
|
+
* Id звонка. Вернет все локальные сессии с этим conversationId.
|
|
86
|
+
*/
|
|
87
|
+
readonly conversationId: string;
|
|
88
|
+
readonly sessionId?: never;
|
|
89
|
+
} | {
|
|
90
|
+
/**
|
|
91
|
+
* Внутренний id локальной сессии из debugLogs.list().
|
|
92
|
+
*/
|
|
93
|
+
readonly sessionId: string;
|
|
94
|
+
readonly conversationId?: never;
|
|
95
|
+
};
|
|
96
|
+
export declare function add(level: string, args: any[], sessionId?: string): CurrentLogItem;
|
|
8
97
|
export declare function init(): void;
|
|
98
|
+
export declare function startConversationSession(): string;
|
|
99
|
+
export declare function setConversationId(conversationId: string | null, sessionId?: string): void;
|
|
100
|
+
export declare function list(): Promise<DebugLogSessionInfo[]>;
|
|
101
|
+
export declare function get(params: DebugLogGetParams): Promise<CurrentLogItem[]>;
|
|
102
|
+
export declare function getJson(params: DebugLogGetParams): Promise<string>;
|
|
103
|
+
export declare function download(params: DebugLogGetParams): Promise<string>;
|
|
104
|
+
export declare function clear(params?: DebugLogGetParams): Promise<void>;
|
|
105
|
+
export declare function stats(): Promise<DebugLogStorageStats>;
|
|
106
|
+
export declare function getAllJson(): Promise<string>;
|
|
107
|
+
export declare function downloadAll(): Promise<string>;
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import HangupReason from '../HangupReason';
|
|
2
|
-
import { TransportTopology } from '../transport/Transport';
|
|
3
|
-
/**
|
|
4
|
-
* Класс для работы с событийными метриками, обертка для правильной отправки событий
|
|
5
|
-
*/
|
|
6
|
-
export declare class EventMetricsService {
|
|
7
|
-
private static correctHangupReason;
|
|
8
|
-
static sendHangupEvent(reason: HangupReason, topology?: TransportTopology): void;
|
|
9
|
-
}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { CurrentLogItem } from '../utils/DebugStorage';
|
|
2
|
-
export declare class ConversationDebugLogger {
|
|
3
|
-
private static _list;
|
|
4
|
-
private static _conversationId;
|
|
5
|
-
static get startTime(): number;
|
|
6
|
-
static get endTime(): number;
|
|
7
|
-
static startSession(): void;
|
|
8
|
-
static get conversationId(): string | null;
|
|
9
|
-
static set conversationId(conversationId: string | null);
|
|
10
|
-
static add(item: CurrentLogItem): void;
|
|
11
|
-
private static _createContextLogs;
|
|
12
|
-
static collectLogs(): CurrentLogItem[];
|
|
13
|
-
}
|