@vkontakte/calls-sdk 2.6.2-dev.c83d2bc.0 → 2.6.2-dev.c8d6e43.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 +76 -16
- package/abstract/BaseApi.d.ts +7 -3
- package/abstract/BaseSignaling.d.ts +16 -5
- package/calls-sdk.cjs.js +8 -8
- package/calls-sdk.esm.js +8 -8
- package/classes/Conversation.d.ts +37 -9
- package/classes/MediaSource.d.ts +7 -2
- package/classes/ProducerCommandSerializationService.d.ts +2 -0
- package/classes/codec/IEncoder.d.ts +3 -0
- package/classes/codec/LibVPxEncoder.d.ts +4 -1
- package/classes/codec/Types.d.ts +6 -1
- package/classes/codec/WebCodecsEncoder.d.ts +4 -1
- package/classes/screenshare/PacketHistory.d.ts +30 -0
- package/classes/screenshare/PacketHistory.test.d.ts +1 -0
- package/classes/screenshare/ScreenCaptureSender.d.ts +15 -1
- package/classes/screenshare/ScreenCongestionControl.d.ts +25 -0
- package/classes/screenshare/SharingStatReport.d.ts +6 -0
- package/classes/screenshare/Utils.d.ts +5 -0
- package/classes/transport/ServerTransport.d.ts +2 -1
- package/default/Api.d.ts +7 -3
- package/default/Signaling.d.ts +16 -5
- package/enums/ConversationFeature.d.ts +2 -1
- package/enums/LiveStatus.d.ts +7 -0
- package/enums/MediaOption.d.ts +3 -1
- package/enums/RoomsEventType.d.ts +6 -0
- package/enums/SignalingCommandType.d.ts +11 -1
- package/enums/SignalingNotification.d.ts +11 -1
- package/package.json +1 -1
- package/static/External.d.ts +93 -6
- package/static/Params.d.ts +97 -9
- package/static/Polyfills.d.ts +7 -0
- package/static/Utils.d.ts +2 -1
- package/static/WebRTCUtils.d.ts +44 -11
- package/static/WebRTCUtils.test.d.ts +1 -0
- package/types/Asr.d.ts +5 -0
- package/types/Conversation.d.ts +1 -0
- package/types/ConversationFeature.d.ts +3 -0
- package/types/ConversationParams.d.ts +1 -0
- package/types/ExternalId.d.ts +2 -0
- package/types/MediaSettings.d.ts +5 -1
- package/types/MovieShare.d.ts +58 -0
- package/types/Participant.d.ts +3 -0
- package/types/ParticipantListChunk.d.ts +2 -0
- package/types/ParticipantStreamDescription.d.ts +2 -1
- package/types/Room.d.ts +77 -0
- package/types/SignalingMessage.d.ts +62 -0
- package/types/WaitingHall.d.ts +2 -8
- package/utils/ArrayDequeue.d.ts +24 -0
- package/utils/ArrayDequeue.spec.d.ts +1 -0
- package/worker/LibVPxEncoderWorker.d.ts +1 -1
package/static/External.d.ts
CHANGED
|
@@ -6,13 +6,17 @@ import ChatRoomEventType from '../enums/ChatRoomEventType';
|
|
|
6
6
|
import ConversationOption from '../enums/ConversationOption';
|
|
7
7
|
import FatalError from '../enums/FatalError';
|
|
8
8
|
import MediaOption from '../enums/MediaOption';
|
|
9
|
+
import RoomsEventType from '../enums/RoomsEventType';
|
|
9
10
|
import UserRole from '../enums/UserRole';
|
|
11
|
+
import { IFeaturesPerRole } from '../types/ConversationFeature';
|
|
10
12
|
import { ExternalId, ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalParticipantListMarkers } from '../types/ExternalId';
|
|
11
13
|
import { IFeedbackExternal } from '../types/Feedback';
|
|
12
14
|
import MediaModifiers from '../types/MediaModifiers';
|
|
13
15
|
import MediaSettings from '../types/MediaSettings';
|
|
16
|
+
import { IOnRemoteMovieData, ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
|
|
14
17
|
import MuteStates from '../types/MuteStates';
|
|
15
18
|
import { ParticipantStateMapped } from '../types/Participant';
|
|
19
|
+
import { Room, RoomParticipantUpdate, Rooms, RoomsUpdate } from '../types/Room';
|
|
16
20
|
import { DebugMessageType } from './Debug';
|
|
17
21
|
import { JSONObject } from './Json';
|
|
18
22
|
/**
|
|
@@ -73,10 +77,31 @@ declare namespace External {
|
|
|
73
77
|
* Если сервер закончил стримить собеседника, вместо стрима будет передан null
|
|
74
78
|
*
|
|
75
79
|
* @param userId
|
|
76
|
-
* @param
|
|
77
|
-
|
|
80
|
+
* @param data
|
|
81
|
+
*/
|
|
82
|
+
function onRemoteLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
|
|
83
|
+
/**
|
|
84
|
+
* Получен собственный стрим лайв.
|
|
85
|
+
* Если сервер закончил стримить собеседника, вместо стрима будет передан null
|
|
86
|
+
*
|
|
87
|
+
* @param userId
|
|
88
|
+
* @param data
|
|
89
|
+
*/
|
|
90
|
+
function onLocalLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
|
|
91
|
+
/**
|
|
92
|
+
* Получено обновление стрима или лайва от собеседника.
|
|
93
|
+
*
|
|
94
|
+
* @param userId
|
|
95
|
+
* @param data
|
|
78
96
|
*/
|
|
79
|
-
function
|
|
97
|
+
function onRemoteLiveUpdate(userId: ExternalParticipantId, data: ISharedMovieState): void;
|
|
98
|
+
/**
|
|
99
|
+
* Получено обновление собственного стрима или лайва.
|
|
100
|
+
*
|
|
101
|
+
* @param userId
|
|
102
|
+
* @param data
|
|
103
|
+
*/
|
|
104
|
+
function onLocalLiveUpdate(userId: ExternalParticipantId, data: ISharedMovieState): void;
|
|
80
105
|
/**
|
|
81
106
|
* Получен стрим с экрана собеседника.
|
|
82
107
|
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
@@ -92,8 +117,9 @@ declare namespace External {
|
|
|
92
117
|
* @param mediaModifiers Текущие настройки пользовательского медиа
|
|
93
118
|
* @param muteStates Состояние устройств при входе в звонок
|
|
94
119
|
* @param participants Список участников звонка (при `Params.batchParticipantsOnStart = true`)
|
|
120
|
+
* @param rooms Список комнат в звонке
|
|
95
121
|
*/
|
|
96
|
-
function onConversation(userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[]): void;
|
|
122
|
+
function onConversation(userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[], rooms?: Rooms): void;
|
|
97
123
|
/**
|
|
98
124
|
* Постраничные данные про участников при начале звонка
|
|
99
125
|
* @param chunk
|
|
@@ -107,6 +133,41 @@ declare namespace External {
|
|
|
107
133
|
* @param markers
|
|
108
134
|
*/
|
|
109
135
|
function onRemoteMediaSettings(userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers): void;
|
|
136
|
+
/**
|
|
137
|
+
* Изменились данные собственного стрима
|
|
138
|
+
*
|
|
139
|
+
* @param userId
|
|
140
|
+
* @param mediaSettings
|
|
141
|
+
*/
|
|
142
|
+
function onLocalMediaSettings(userId: ExternalParticipantId, mediaSettings: MediaSettings): void;
|
|
143
|
+
/**
|
|
144
|
+
* Полученны данные по стримам (лайв/мувик) от собеседника
|
|
145
|
+
*
|
|
146
|
+
* @param userId
|
|
147
|
+
* @param sharedMovieInfo
|
|
148
|
+
*/
|
|
149
|
+
function onRemoteSharedMovieInfo(userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo): void;
|
|
150
|
+
/**
|
|
151
|
+
* Полученны данные по остановленным стримам (лайв/мувик) от собеседника
|
|
152
|
+
*
|
|
153
|
+
* @param userId
|
|
154
|
+
* @param sharedMovieStoppedInfo
|
|
155
|
+
*/
|
|
156
|
+
function onRemoteSharedMovieStoppedInfo(userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo): void;
|
|
157
|
+
/**
|
|
158
|
+
* Полученны данные по собственным стримам (лайв/мувик)
|
|
159
|
+
*
|
|
160
|
+
* @param userId
|
|
161
|
+
* @param sharedMovieInfo
|
|
162
|
+
*/
|
|
163
|
+
function onLocalSharedMovieInfo(userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo): void;
|
|
164
|
+
/**
|
|
165
|
+
* Полученны данные по собственным остановленным стримам (лайв/мувик)
|
|
166
|
+
*
|
|
167
|
+
* @param userId
|
|
168
|
+
* @param sharedMovieStoppedInfo
|
|
169
|
+
*/
|
|
170
|
+
function onLocalSharedMovieStoppedInfo(userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo): void;
|
|
110
171
|
/**
|
|
111
172
|
* Добавили участника
|
|
112
173
|
*
|
|
@@ -189,9 +250,10 @@ declare namespace External {
|
|
|
189
250
|
* @param userId Пользователь, для которого изменились разрешения или `null` для текущего пользователя
|
|
190
251
|
* @param adminId Пользователь, который изменил разрешения
|
|
191
252
|
* @param stateUpdated Если `true`, значит глобальное/персональное состояние изменилось и поля `muteStates`/`unmuteOptions` содержат обновления, если `false`, значит, эти поля не имеют значения
|
|
192
|
-
* @param requestedMedia Какие устройства попросили
|
|
253
|
+
* @param requestedMedia Какие устройства попросили включить участника
|
|
254
|
+
* @param roomId ID сессионного зала или ничего в случае основного зала
|
|
193
255
|
*/
|
|
194
|
-
function onMuteStates(muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll?: boolean, unmute?: boolean, userId?: ExternalParticipantId | null, adminId?: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]): void;
|
|
256
|
+
function onMuteStates(muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll?: boolean, unmute?: boolean, userId?: ExternalParticipantId | null, adminId?: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[], roomId?: number): void;
|
|
195
257
|
/**
|
|
196
258
|
* Изменились роли собеседника в звонке
|
|
197
259
|
*
|
|
@@ -356,9 +418,34 @@ declare namespace External {
|
|
|
356
418
|
* @param joinLink токен присоединения к звонку
|
|
357
419
|
*/
|
|
358
420
|
function onJoinLinkChanged(joinLink: string): void;
|
|
421
|
+
/**
|
|
422
|
+
*/
|
|
423
|
+
function onRoomsUpdated(updates: Partial<Record<RoomsEventType, RoomsUpdate>>): void;
|
|
424
|
+
/**
|
|
425
|
+
*/
|
|
426
|
+
function onRoomUpdated(eventTypes: RoomsEventType[], roomId: number, room: Room | null, deactivate: boolean | null): void;
|
|
427
|
+
/**
|
|
428
|
+
*/
|
|
429
|
+
function onRoomParticipantsUpdated(update: RoomParticipantUpdate): void;
|
|
359
430
|
/**
|
|
360
431
|
* Получена новая реакция
|
|
361
432
|
*/
|
|
362
433
|
function onFeedback(feedback: IFeedbackExternal[]): void;
|
|
434
|
+
/**
|
|
435
|
+
* Изменилось состояние пермиссий фич в звонке
|
|
436
|
+
*
|
|
437
|
+
* @param featuresPerRole Информация о доступных фичах по ролям
|
|
438
|
+
*/
|
|
439
|
+
function onFeaturesPerRoleChanged(featuresPerRole: IFeaturesPerRole): void;
|
|
440
|
+
/**
|
|
441
|
+
* Начата текстовая расшифровка звонка
|
|
442
|
+
* @param initiatorId Id пользователя, запустившего расшифровку звонка
|
|
443
|
+
* @param movieId Id расшифровки
|
|
444
|
+
*/
|
|
445
|
+
function onAsrStarted(initiatorId: ExternalParticipantId, movieId: number): void;
|
|
446
|
+
/**
|
|
447
|
+
* Закончена текстовая расшифровка звонка
|
|
448
|
+
*/
|
|
449
|
+
function onAsrStopped(): void;
|
|
363
450
|
}
|
|
364
451
|
export default External;
|
package/static/Params.d.ts
CHANGED
|
@@ -6,14 +6,18 @@ import ChatRoomEventType from '../enums/ChatRoomEventType';
|
|
|
6
6
|
import ConversationOption from '../enums/ConversationOption';
|
|
7
7
|
import FatalError from '../enums/FatalError';
|
|
8
8
|
import MediaOption from '../enums/MediaOption';
|
|
9
|
+
import RoomsEventType from '../enums/RoomsEventType';
|
|
9
10
|
import UserRole from '../enums/UserRole';
|
|
11
|
+
import { IFeaturesPerRole } from '../types/ConversationFeature';
|
|
10
12
|
import { ExternalId, ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalParticipantListMarkers } from '../types/ExternalId';
|
|
11
13
|
import { IFeedbackExternal } from '../types/Feedback';
|
|
12
14
|
import IceServer from '../types/IceServer';
|
|
13
15
|
import MediaModifiers from '../types/MediaModifiers';
|
|
14
16
|
import MediaSettings from '../types/MediaSettings';
|
|
17
|
+
import { IOnRemoteMovieData, ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
|
|
15
18
|
import MuteStates from '../types/MuteStates';
|
|
16
19
|
import { ParticipantStateMapped } from '../types/Participant';
|
|
20
|
+
import { Room, RoomParticipantUpdate, Rooms, RoomsUpdate } from '../types/Room';
|
|
17
21
|
import AuthData from './AuthData';
|
|
18
22
|
import { DebugMessageType } from './Debug';
|
|
19
23
|
import { ParticipantStatus } from './External';
|
|
@@ -25,6 +29,7 @@ import { FacingMode } from './WebRTCUtils';
|
|
|
25
29
|
export declare type ParamsObject = {
|
|
26
30
|
platform: string;
|
|
27
31
|
clientType: string;
|
|
32
|
+
externalUserType: string;
|
|
28
33
|
device: string;
|
|
29
34
|
/**
|
|
30
35
|
* API ключ приложения
|
|
@@ -170,9 +175,6 @@ export declare type ParamsObject = {
|
|
|
170
175
|
};
|
|
171
176
|
perfStatReportEnabled: boolean;
|
|
172
177
|
callStatReportEnabled: boolean;
|
|
173
|
-
unifiedPlanBrowsers: {
|
|
174
|
-
[key: string]: number;
|
|
175
|
-
};
|
|
176
178
|
/**
|
|
177
179
|
* Отдавать приоритет кодеку H264 для исходящего видео
|
|
178
180
|
*
|
|
@@ -234,28 +236,44 @@ export declare type ParamsObject = {
|
|
|
234
236
|
breakVideoPayloadTypes: boolean;
|
|
235
237
|
/**
|
|
236
238
|
* Включить постраничный вывод участников. Работает только если включено videoTracksCount (слоты)
|
|
239
|
+
*
|
|
240
|
+
* _По умолчанию: `false`_
|
|
237
241
|
*/
|
|
238
242
|
useParticipantListChunk: boolean;
|
|
239
243
|
/**
|
|
240
|
-
*
|
|
244
|
+
* Включить комнаты
|
|
245
|
+
*
|
|
246
|
+
* _По умолчанию: `false`_
|
|
247
|
+
*/
|
|
248
|
+
useRooms: boolean;
|
|
249
|
+
/**
|
|
250
|
+
* Индекс участника для первого chunk'а который придет при установке соединения с сервером
|
|
251
|
+
*
|
|
252
|
+
* _По умолчанию: `0`_
|
|
241
253
|
*/
|
|
242
254
|
participantListChunkInitIndex: number;
|
|
243
255
|
/**
|
|
244
|
-
* Количество участников которые придут в первом chunk'е при
|
|
256
|
+
* Количество участников которые придут в первом chunk'е при установке соединения с сервером
|
|
245
257
|
* если параметр не проставлен то будет использоваться значение по умолчанию установленное на сервере
|
|
246
258
|
*/
|
|
247
259
|
participantListChunkInitCount: number | null;
|
|
248
260
|
/**
|
|
249
261
|
* Включать RED-extension (redundancy) для групповых звонков
|
|
262
|
+
*
|
|
263
|
+
* _По умолчанию: `false`_
|
|
250
264
|
*/
|
|
251
265
|
serverAudioRed: boolean;
|
|
252
266
|
/**
|
|
253
267
|
* Включать RED-extension (redundancy) для p2p звонков
|
|
268
|
+
*
|
|
269
|
+
* _По умолчанию: `false`_
|
|
254
270
|
*/
|
|
255
271
|
p2pAudioRed: boolean;
|
|
256
272
|
/**
|
|
257
273
|
* Добавлять флаг spsPpsIdrInKeyframe для h264 кодека. В результате ключевые фреймы без sps и pps
|
|
258
274
|
* не используются как ключевые. Решает проблему с артефактами на видео в случае потерь пакетов.
|
|
275
|
+
*
|
|
276
|
+
* _По умолчанию: `false`_
|
|
259
277
|
*/
|
|
260
278
|
h264spsPpsIdrInKeyframe: boolean;
|
|
261
279
|
/**
|
|
@@ -281,6 +299,11 @@ export declare type ParamsObject = {
|
|
|
281
299
|
* @hidden
|
|
282
300
|
*/
|
|
283
301
|
preserveAudioTracks: boolean;
|
|
302
|
+
/**
|
|
303
|
+
* Использовать congestion control для шаринга
|
|
304
|
+
* @hidden
|
|
305
|
+
*/
|
|
306
|
+
screenShareCongestionControl: boolean;
|
|
284
307
|
/**
|
|
285
308
|
* Получен локальный стрим с камеры/микрофона
|
|
286
309
|
*/
|
|
@@ -311,11 +334,24 @@ export declare type ParamsObject = {
|
|
|
311
334
|
* Получен стрим трансляция или мувик от собеседника.
|
|
312
335
|
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
313
336
|
*/
|
|
314
|
-
onRemoteLive?: (userId: ExternalParticipantId,
|
|
337
|
+
onRemoteLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
|
|
338
|
+
/**
|
|
339
|
+
* Получен собственный стрим трансляция или мувик.
|
|
340
|
+
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
341
|
+
*/
|
|
342
|
+
onLocalLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
|
|
343
|
+
/**
|
|
344
|
+
* Получено обновление стрима или лайва от собеседника.
|
|
345
|
+
*/
|
|
346
|
+
onRemoteLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
|
|
347
|
+
/**
|
|
348
|
+
* Получено обновление собственного стрима или лайва.
|
|
349
|
+
*/
|
|
350
|
+
onLocalLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
|
|
315
351
|
/**
|
|
316
352
|
* Начат звонок
|
|
317
353
|
*/
|
|
318
|
-
onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[]) => void;
|
|
354
|
+
onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[], rooms?: Rooms) => void;
|
|
319
355
|
/**
|
|
320
356
|
* Начальный список участников для постраничного звонка
|
|
321
357
|
*/
|
|
@@ -324,6 +360,26 @@ export declare type ParamsObject = {
|
|
|
324
360
|
* Изменились данные стрима собеседника
|
|
325
361
|
*/
|
|
326
362
|
onRemoteMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers) => void;
|
|
363
|
+
/**
|
|
364
|
+
* Изменились данные стрима собеседника
|
|
365
|
+
*/
|
|
366
|
+
onLocalMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings) => void;
|
|
367
|
+
/**
|
|
368
|
+
* Полученны данные по стримам (лайв/мувик) от собеседника
|
|
369
|
+
*/
|
|
370
|
+
onRemoteSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
|
|
371
|
+
/**
|
|
372
|
+
* Полученны данные по остановленным стримам (лайв/мувик) от собеседника
|
|
373
|
+
*/
|
|
374
|
+
onRemoteSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
|
|
375
|
+
/**
|
|
376
|
+
* Полученны данные по собственным стримам (лайв/мувик)
|
|
377
|
+
*/
|
|
378
|
+
onLocalSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
|
|
379
|
+
/**
|
|
380
|
+
* Полученны данные по собственным остановленным стримам (лайв/мувик)
|
|
381
|
+
*/
|
|
382
|
+
onLocalSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
|
|
327
383
|
/**
|
|
328
384
|
* Добавили участника
|
|
329
385
|
*/
|
|
@@ -368,7 +424,7 @@ export declare type ParamsObject = {
|
|
|
368
424
|
/**
|
|
369
425
|
* Изменились состояния устройств пользователя или разрешения включать камеру/микрофон
|
|
370
426
|
*/
|
|
371
|
-
onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]) => void;
|
|
427
|
+
onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[], roomId?: number) => void;
|
|
372
428
|
/**
|
|
373
429
|
* Изменились роли собеседника в звонке
|
|
374
430
|
*/
|
|
@@ -489,11 +545,39 @@ export declare type ParamsObject = {
|
|
|
489
545
|
* @param joinLink токен присоединения к звонку
|
|
490
546
|
*/
|
|
491
547
|
onJoinLinkChanged?: (joinLink: string) => void;
|
|
548
|
+
/**
|
|
549
|
+
* Получено обновление списка комнат
|
|
550
|
+
* @param updates список обновлений по комнатам
|
|
551
|
+
*/
|
|
552
|
+
onRoomsUpdated?: (updates: Partial<Record<RoomsEventType, RoomsUpdate>>) => void;
|
|
553
|
+
/**
|
|
554
|
+
* Получено обновление комнаты
|
|
555
|
+
* @param eventTypes список событий
|
|
556
|
+
* @param roomId номер комнаты
|
|
557
|
+
* @param room комната
|
|
558
|
+
*/
|
|
559
|
+
onRoomUpdated?: (eventTypes: RoomsEventType[], roomId: number, room: Room | null, deactivate: boolean | null) => void;
|
|
560
|
+
/**
|
|
561
|
+
* Получение обновление списка участников в комнате
|
|
562
|
+
* @param update обновление списка участников
|
|
563
|
+
*/
|
|
564
|
+
onRoomParticipantsUpdated?: (update: RoomParticipantUpdate) => void;
|
|
492
565
|
/**
|
|
493
566
|
* Получены новые реакции в звонке
|
|
494
567
|
* @param feedback массив с реакциями
|
|
495
568
|
*/
|
|
496
569
|
onFeedback?: (feedback: IFeedbackExternal[]) => void;
|
|
570
|
+
/**
|
|
571
|
+
* Включать capability c аудио шарой
|
|
572
|
+
*/
|
|
573
|
+
audioShareCapabilityEnabled: boolean;
|
|
574
|
+
/**
|
|
575
|
+
* Изменился список ролей, которым доступны ConversationFeatures
|
|
576
|
+
*
|
|
577
|
+
* @param featuresPerRole Объект вида ключ: ConversationFeature = значение: UserRole[]
|
|
578
|
+
* (если ключ фичи отсутствует, или в ролях пустой массив, считаем фичу доступной для всех пользователей)
|
|
579
|
+
*/
|
|
580
|
+
onFeaturesPerRoleChanged?: (featuresPerRole: IFeaturesPerRole) => void;
|
|
497
581
|
};
|
|
498
582
|
export default abstract class Params {
|
|
499
583
|
private static _params;
|
|
@@ -510,6 +594,8 @@ export default abstract class Params {
|
|
|
510
594
|
static set platform(value: string);
|
|
511
595
|
static get clientType(): string;
|
|
512
596
|
static set clientType(value: string);
|
|
597
|
+
static get externalUserType(): string;
|
|
598
|
+
static set externalUserType(value: string);
|
|
513
599
|
static get device(): string;
|
|
514
600
|
static get apiKey(): string;
|
|
515
601
|
static get apiEnv(): string;
|
|
@@ -578,12 +664,12 @@ export default abstract class Params {
|
|
|
578
664
|
static get audioNack(): boolean;
|
|
579
665
|
static get consumerScreenTrack(): boolean;
|
|
580
666
|
static get producerScreenTrack(): boolean;
|
|
581
|
-
static isUnifiedPlanSupported(name: string, version: number): boolean;
|
|
582
667
|
static get movieShare(): boolean;
|
|
583
668
|
static get videoTracksCount(): number;
|
|
584
669
|
static get breakVideoPayloadTypes(): boolean;
|
|
585
670
|
static get filteredMessages(): boolean;
|
|
586
671
|
static get useParticipantListChunk(): boolean;
|
|
672
|
+
static get useRooms(): boolean;
|
|
587
673
|
static get participantListChunkInitIndex(): number;
|
|
588
674
|
static get participantListChunkInitCount(): number;
|
|
589
675
|
static get serverAudioRed(): boolean;
|
|
@@ -593,4 +679,6 @@ export default abstract class Params {
|
|
|
593
679
|
static get filterObservers(): boolean;
|
|
594
680
|
static get muteMode(): boolean;
|
|
595
681
|
static get preserveAudioTracks(): boolean;
|
|
682
|
+
static get audioShareCapabilityEnabled(): boolean;
|
|
683
|
+
static get screenShareCongestionControl(): boolean;
|
|
596
684
|
}
|
package/static/Utils.d.ts
CHANGED
|
@@ -6,7 +6,8 @@ import VideoSettings from '../types/VideoSettings';
|
|
|
6
6
|
export declare const PARAMETERS_SEPARATOR = ":";
|
|
7
7
|
export declare const DEVICE_IDX_PARAMETER = "d";
|
|
8
8
|
declare namespace Utils {
|
|
9
|
-
function
|
|
9
|
+
function patchLocalSDP(sdp: string, preferH264: boolean, brokenH264: boolean, preferVP9: boolean, h264spsPpsIdrInKeyframe: boolean, isAudioNack?: boolean, preferRed?: boolean): string;
|
|
10
|
+
function patchRemoteSDP(sdp: string): string;
|
|
10
11
|
function getPeerIdString(peerId: SignalingMessage.PeerId): string;
|
|
11
12
|
function comparePeerId(peerId1: SignalingMessage.PeerId, peerId2: SignalingMessage.PeerId): boolean;
|
|
12
13
|
function getPeerConnectionHostInfo(pc: RTCPeerConnection): Promise<any>;
|
package/static/WebRTCUtils.d.ts
CHANGED
|
@@ -10,6 +10,47 @@ export declare enum FacingMode {
|
|
|
10
10
|
LEFT = "left",
|
|
11
11
|
RIGHT = "right"
|
|
12
12
|
}
|
|
13
|
+
/********************* MediaConstraints *********************/
|
|
14
|
+
/**
|
|
15
|
+
* Вспомогательный класс для формирования параметров, которые нужны для запроса камеры и микрофона.
|
|
16
|
+
* @hidden
|
|
17
|
+
*/
|
|
18
|
+
declare class MediaConstraints {
|
|
19
|
+
protected audio: MediaTrackConstraints | boolean;
|
|
20
|
+
protected video: MediaTrackConstraints | boolean;
|
|
21
|
+
private readonly needVideo;
|
|
22
|
+
constructor(audioDeviceId: boolean | string, videoDeviceId?: boolean | string, videoMaxWidth?: number, videoMaxHeight?: number);
|
|
23
|
+
/**
|
|
24
|
+
* Возвращает нативные параметры для передачи в getUserMedia.
|
|
25
|
+
*/
|
|
26
|
+
getNative(): object;
|
|
27
|
+
/**
|
|
28
|
+
* Метод упрощает параметры, чтобы попробовать сделать getUserMedia еще раз при ошибке.
|
|
29
|
+
* Сначала убираются размеры, потом соотношения сторон.
|
|
30
|
+
*/
|
|
31
|
+
simplify(): MediaConstraints;
|
|
32
|
+
/**
|
|
33
|
+
* Проверяет, можно ли упростить параметры.
|
|
34
|
+
*/
|
|
35
|
+
canSimplify(): boolean;
|
|
36
|
+
/**
|
|
37
|
+
* Проверяет, есть ли параметры видео.
|
|
38
|
+
*/
|
|
39
|
+
isVideo(): boolean;
|
|
40
|
+
/**
|
|
41
|
+
* Проверяет, есть ли параметры аудио.
|
|
42
|
+
*/
|
|
43
|
+
isAudio(): boolean;
|
|
44
|
+
}
|
|
45
|
+
/********************* /MediaConstraints *********************/
|
|
46
|
+
/********************* ScreenConstraints *********************/
|
|
47
|
+
/**
|
|
48
|
+
* Вспомогательный класс для формирования параметров, которые нужны для запроса трансляции экрана.
|
|
49
|
+
* @hidden
|
|
50
|
+
*/
|
|
51
|
+
export declare class ScreenConstraints extends MediaConstraints {
|
|
52
|
+
constructor(width: number, height: number, withAudioShare: boolean);
|
|
53
|
+
}
|
|
13
54
|
declare namespace WebRTCUtils {
|
|
14
55
|
/**
|
|
15
56
|
* Инициализирует устройства. До вызова этого метода бесполезно опрашивать другие публичные методы
|
|
@@ -64,9 +105,9 @@ declare namespace WebRTCUtils {
|
|
|
64
105
|
*/
|
|
65
106
|
function getUserMedia(needVideo?: boolean, needAudio?: boolean, needEmptyTracks?: boolean): Promise<MediaStream>;
|
|
66
107
|
/**
|
|
67
|
-
* Запрашивает трансляцию экрана пользователя
|
|
108
|
+
* Запрашивает трансляцию экрана пользователя с опциональным захватом звука
|
|
68
109
|
*/
|
|
69
|
-
function getScreenMedia(): Promise<MediaStream>;
|
|
110
|
+
function getScreenMedia(withAudioShare: boolean): Promise<MediaStream>;
|
|
70
111
|
/**
|
|
71
112
|
* Запрашивает камеру пользователя
|
|
72
113
|
*
|
|
@@ -100,15 +141,6 @@ declare namespace WebRTCUtils {
|
|
|
100
141
|
* Проверяет поддержку шаринга экрана браузером
|
|
101
142
|
*/
|
|
102
143
|
function isScreenCapturingSupported(): boolean;
|
|
103
|
-
/**
|
|
104
|
-
* Проверяет доступность кодека VP8 при использовании WebRTC.
|
|
105
|
-
* Кодек может быть доступен, даже если видео VP8 в браузере не поддерживается.
|
|
106
|
-
*/
|
|
107
|
-
function canVP8(): boolean;
|
|
108
|
-
/**
|
|
109
|
-
* Проверяет используемый план (unified-plan или plan-b)
|
|
110
|
-
*/
|
|
111
|
-
function isUnifiedPlan(): boolean;
|
|
112
144
|
/**
|
|
113
145
|
* В некоторых браузерах H264 сломан
|
|
114
146
|
*/
|
|
@@ -146,5 +178,6 @@ declare namespace WebRTCUtils {
|
|
|
146
178
|
* Возвращает подверсию браузера (если она есть)
|
|
147
179
|
*/
|
|
148
180
|
function browserSubVersion(): string;
|
|
181
|
+
function isAudioShareSupported(): boolean;
|
|
149
182
|
}
|
|
150
183
|
export default WebRTCUtils;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/types/Asr.d.ts
ADDED
package/types/Conversation.d.ts
CHANGED
package/types/ExternalId.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import MediaOption from '../enums/MediaOption';
|
|
2
2
|
import { ParticipantStatus } from '../static/External';
|
|
3
3
|
import MediaSettings from './MediaSettings';
|
|
4
|
+
import { ISharedMovieInfo } from './MovieShare';
|
|
4
5
|
import MuteStates from './MuteStates';
|
|
5
6
|
import { ParticipantListMarker, ParticipantListType, ParticipantStateMapped } from './Participant';
|
|
6
7
|
import SignalingMessage from './SignalingMessage';
|
|
@@ -94,6 +95,7 @@ export interface ExternalParticipant {
|
|
|
94
95
|
*/
|
|
95
96
|
unmuteOptions: MediaOption[];
|
|
96
97
|
markers?: ExternalParticipantListMarkers;
|
|
98
|
+
movieShareInfos?: ISharedMovieInfo[];
|
|
97
99
|
}
|
|
98
100
|
export interface ExternalParticipantListChunk {
|
|
99
101
|
participants: ExternalParticipant[];
|
package/types/MediaSettings.d.ts
CHANGED
|
@@ -14,12 +14,16 @@ export declare type MediaSettings = {
|
|
|
14
14
|
* Включена ли трансляция экрана
|
|
15
15
|
*/
|
|
16
16
|
isScreenSharingEnabled: boolean;
|
|
17
|
+
/**
|
|
18
|
+
* Включена ли трансляция звука
|
|
19
|
+
*/
|
|
20
|
+
isAudioSharingEnabled: boolean;
|
|
17
21
|
videoStreams: VideoStreamInfo[];
|
|
18
22
|
};
|
|
19
23
|
export declare type VideoStreamInfo = {
|
|
20
24
|
id: string;
|
|
21
25
|
source: string;
|
|
22
|
-
|
|
26
|
+
externalMovieId?: string;
|
|
23
27
|
};
|
|
24
28
|
export default MediaSettings;
|
|
25
29
|
export declare function compareMediaSettings(ms1: MediaSettings, ms2: MediaSettings): boolean;
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import LiveStatus from '../enums/LiveStatus';
|
|
2
|
+
import { OkUserId, CompositeUserId } from './Participant';
|
|
3
|
+
import { MediaType } from './ParticipantStreamDescription';
|
|
4
|
+
export interface IMoviePreview {
|
|
5
|
+
url: string;
|
|
6
|
+
width: number;
|
|
7
|
+
height: number;
|
|
8
|
+
}
|
|
9
|
+
export interface IAddMovieParams {
|
|
10
|
+
movieId: string;
|
|
11
|
+
gain?: number;
|
|
12
|
+
metadata?: {
|
|
13
|
+
title?: string;
|
|
14
|
+
thumbnails?: IMoviePreview[];
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export declare type ISharedMovieStateResponse = [
|
|
18
|
+
number,
|
|
19
|
+
number,
|
|
20
|
+
boolean,
|
|
21
|
+
number,
|
|
22
|
+
boolean,
|
|
23
|
+
number
|
|
24
|
+
];
|
|
25
|
+
export interface ISharedMovieState {
|
|
26
|
+
participantId: CompositeUserId;
|
|
27
|
+
gain?: number;
|
|
28
|
+
pause?: boolean;
|
|
29
|
+
offset?: number;
|
|
30
|
+
mute?: boolean;
|
|
31
|
+
liveStatus?: LiveStatus;
|
|
32
|
+
}
|
|
33
|
+
export interface IUpdateMovieData {
|
|
34
|
+
movieId: string;
|
|
35
|
+
gain?: number;
|
|
36
|
+
pause?: boolean;
|
|
37
|
+
offset?: number;
|
|
38
|
+
mute?: boolean;
|
|
39
|
+
}
|
|
40
|
+
export interface ISharedMovieInfo {
|
|
41
|
+
movieId: OkUserId;
|
|
42
|
+
initiatorId: CompositeUserId;
|
|
43
|
+
title: string;
|
|
44
|
+
source: MediaType;
|
|
45
|
+
externalMovieId: string;
|
|
46
|
+
duration: number;
|
|
47
|
+
thumbnails: IMoviePreview[];
|
|
48
|
+
}
|
|
49
|
+
export interface ISharedMovieStoppedInfo {
|
|
50
|
+
movieId: OkUserId;
|
|
51
|
+
initiatorId: CompositeUserId;
|
|
52
|
+
source: MediaType;
|
|
53
|
+
}
|
|
54
|
+
export interface IOnRemoteMovieData {
|
|
55
|
+
streamName: string;
|
|
56
|
+
stream: MediaStream | null;
|
|
57
|
+
mediaType: MediaType;
|
|
58
|
+
}
|
package/types/Participant.d.ts
CHANGED
|
@@ -4,6 +4,7 @@ import UserRole from '../enums/UserRole';
|
|
|
4
4
|
import { ParticipantStatus } from '../static/External';
|
|
5
5
|
import MediaSettings from '../types/MediaSettings';
|
|
6
6
|
import { ExternalId, ExternalParticipantId, ExternalParticipantListMarkers } from './ExternalId';
|
|
7
|
+
import { ISharedMovieInfo } from './MovieShare';
|
|
7
8
|
import MuteStates from './MuteStates';
|
|
8
9
|
import ParticipantLayout from './ParticipantLayout';
|
|
9
10
|
/**
|
|
@@ -55,6 +56,8 @@ export interface Participant {
|
|
|
55
56
|
unmuteOptions: MediaOption[];
|
|
56
57
|
observedIds: CompositeUserId[];
|
|
57
58
|
markers?: ExternalParticipantListMarkers;
|
|
59
|
+
movieShareInfos?: ISharedMovieInfo[];
|
|
60
|
+
isInRoom?: boolean;
|
|
58
61
|
}
|
|
59
62
|
export interface IGetParticipantsParameters {
|
|
60
63
|
externalIds: ExternalId[];
|
|
@@ -10,4 +10,6 @@ export interface ParticipantListChunkParameters {
|
|
|
10
10
|
backward?: boolean;
|
|
11
11
|
/** If true then resulting chunk will start from Participant with specified marker, if such Participant (still) exists */
|
|
12
12
|
includeMarker?: boolean;
|
|
13
|
+
/** optional, id of the room to get chunk for, main call if unspecified */
|
|
14
|
+
roomId?: number;
|
|
13
15
|
}
|
|
@@ -6,7 +6,8 @@ export declare enum MediaType {
|
|
|
6
6
|
CAMERA = "CAMERA",
|
|
7
7
|
SCREEN = "SCREEN",
|
|
8
8
|
STREAM = "STREAM",
|
|
9
|
-
MOVIE = "MOVIE"
|
|
9
|
+
MOVIE = "MOVIE",
|
|
10
|
+
AUDIOSHARE = "AUDIOSHARE"
|
|
10
11
|
}
|
|
11
12
|
export declare function serializeParticipantStreamDescription(description: ParticipantStreamDescription): string;
|
|
12
13
|
export declare function parseParticipantStreamDescription(descriptionString: string): ParticipantStreamDescription;
|