@vkontakte/calls-sdk 2.6.2-dev.f69c395.0 → 2.6.3-dev.1fd3364.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 +82 -17
- package/abstract/BaseApi.d.ts +7 -3
- package/abstract/BaseSignaling.d.ts +24 -6
- package/calls-sdk.cjs.js +9 -9
- package/calls-sdk.esm.js +9 -9
- package/classes/Conversation.d.ts +80 -11
- package/classes/MediaSource.d.ts +7 -2
- package/classes/ProducerCommandSerializationService.d.ts +3 -1
- package/classes/asr/AsrCommandSerializer.d.ts +3 -0
- package/classes/asr/AsrReceiver.d.ts +12 -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 +6 -1
- package/classes/transport/Transport.d.ts +3 -1
- package/default/Api.d.ts +12 -3
- package/default/Api.test.d.ts +1 -0
- package/default/Signaling.d.ts +28 -6
- package/enums/ConversationFeature.d.ts +2 -1
- package/enums/ConversationOption.d.ts +3 -1
- package/enums/DataChannelLabel.d.ts +2 -1
- package/enums/HangupType.d.ts +3 -1
- package/enums/LiveStatus.d.ts +12 -0
- package/enums/MediaOption.d.ts +3 -1
- package/enums/RoomsEventType.d.ts +6 -0
- package/enums/SignalingCommandType.d.ts +12 -1
- package/enums/SignalingNotification.d.ts +12 -1
- package/package.json +1 -1
- package/static/External.d.ts +122 -8
- package/static/Params.d.ts +129 -11
- 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 +11 -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/Feedback.d.ts +22 -0
- package/types/MediaSettings.d.ts +5 -1
- package/types/MovieShare.d.ts +60 -0
- package/types/MuteStates.d.ts +15 -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 +66 -1
- package/types/Streams.d.ts +8 -0
- package/types/WaitingHall.d.ts +2 -8
- package/utils/ArrayDequeue.d.ts +24 -0
- package/utils/ArrayDequeue.spec.d.ts +1 -0
- package/utils/Conversation.d.ts +2 -0
- package/worker/LibVPxEncoderWorker.d.ts +1 -1
package/static/Params.d.ts
CHANGED
|
@@ -6,13 +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';
|
|
13
|
+
import { IFeedbackExternal } from '../types/Feedback';
|
|
11
14
|
import IceServer from '../types/IceServer';
|
|
12
15
|
import MediaModifiers from '../types/MediaModifiers';
|
|
13
16
|
import MediaSettings from '../types/MediaSettings';
|
|
17
|
+
import { IOnRemoteMovieData, ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
|
|
14
18
|
import MuteStates from '../types/MuteStates';
|
|
15
19
|
import { ParticipantStateMapped } from '../types/Participant';
|
|
20
|
+
import { Room, RoomParticipantUpdate, Rooms, RoomsUpdate } from '../types/Room';
|
|
16
21
|
import AuthData from './AuthData';
|
|
17
22
|
import { DebugMessageType } from './Debug';
|
|
18
23
|
import { ParticipantStatus } from './External';
|
|
@@ -24,6 +29,7 @@ import { FacingMode } from './WebRTCUtils';
|
|
|
24
29
|
export declare type ParamsObject = {
|
|
25
30
|
platform: string;
|
|
26
31
|
clientType: string;
|
|
32
|
+
externalUserType: string;
|
|
27
33
|
device: string;
|
|
28
34
|
/**
|
|
29
35
|
* API ключ приложения
|
|
@@ -43,6 +49,11 @@ export declare type ParamsObject = {
|
|
|
43
49
|
* Домен, чтобы попасть в тестовую группу. Для тестирования экспериментальных улучшений существуют отдельные сервера, чтобы собирать фидбек и уже потом раскатывать на всех юзеров. Если передать сюда специальный ключ, то конверсейшн будет обрабатываться на таком сервере.
|
|
44
50
|
*/
|
|
45
51
|
domain: string;
|
|
52
|
+
/**
|
|
53
|
+
* Домен, куда будет ходить Ok api за данными
|
|
54
|
+
* @hidden
|
|
55
|
+
*/
|
|
56
|
+
externalDomain: string;
|
|
46
57
|
iceServers: IceServer[];
|
|
47
58
|
wssBase: string;
|
|
48
59
|
wssToken: string;
|
|
@@ -164,9 +175,6 @@ export declare type ParamsObject = {
|
|
|
164
175
|
};
|
|
165
176
|
perfStatReportEnabled: boolean;
|
|
166
177
|
callStatReportEnabled: boolean;
|
|
167
|
-
unifiedPlanBrowsers: {
|
|
168
|
-
[key: string]: number;
|
|
169
|
-
};
|
|
170
178
|
/**
|
|
171
179
|
* Отдавать приоритет кодеку H264 для исходящего видео
|
|
172
180
|
*
|
|
@@ -201,6 +209,7 @@ export declare type ParamsObject = {
|
|
|
201
209
|
producerCommandDataChannel: boolean;
|
|
202
210
|
consumerScreenDataChannel: boolean;
|
|
203
211
|
producerScreenDataChannel: boolean;
|
|
212
|
+
asrDataChannel: boolean;
|
|
204
213
|
/**
|
|
205
214
|
* Размер пакета для отправки трансляции экрана в датаканал в байтах.
|
|
206
215
|
* Максимальный размер пакета 65536 bytes в хроме, но по стандарту лучше максимум 16 Кб.
|
|
@@ -228,25 +237,46 @@ export declare type ParamsObject = {
|
|
|
228
237
|
breakVideoPayloadTypes: boolean;
|
|
229
238
|
/**
|
|
230
239
|
* Включить постраничный вывод участников. Работает только если включено videoTracksCount (слоты)
|
|
240
|
+
*
|
|
241
|
+
* _По умолчанию: `false`_
|
|
231
242
|
*/
|
|
232
243
|
useParticipantListChunk: boolean;
|
|
233
244
|
/**
|
|
234
|
-
*
|
|
245
|
+
* Включить сессионные залы
|
|
246
|
+
*
|
|
247
|
+
* _По умолчанию: `false`_
|
|
248
|
+
*/
|
|
249
|
+
useRooms: boolean;
|
|
250
|
+
/**
|
|
251
|
+
* Индекс участника для первого chunk'а который придет при установке соединения с сервером
|
|
252
|
+
*
|
|
253
|
+
* _По умолчанию: `0`_
|
|
235
254
|
*/
|
|
236
255
|
participantListChunkInitIndex: number;
|
|
237
256
|
/**
|
|
238
|
-
* Количество участников которые придут в первом chunk'е при
|
|
257
|
+
* Количество участников которые придут в первом chunk'е при установке соединения с сервером
|
|
239
258
|
* если параметр не проставлен то будет использоваться значение по умолчанию установленное на сервере
|
|
240
259
|
*/
|
|
241
260
|
participantListChunkInitCount: number | null;
|
|
242
261
|
/**
|
|
243
262
|
* Включать RED-extension (redundancy) для групповых звонков
|
|
263
|
+
*
|
|
264
|
+
* _По умолчанию: `false`_
|
|
244
265
|
*/
|
|
245
266
|
serverAudioRed: boolean;
|
|
246
267
|
/**
|
|
247
268
|
* Включать RED-extension (redundancy) для p2p звонков
|
|
269
|
+
*
|
|
270
|
+
* _По умолчанию: `false`_
|
|
248
271
|
*/
|
|
249
272
|
p2pAudioRed: boolean;
|
|
273
|
+
/**
|
|
274
|
+
* Добавлять флаг spsPpsIdrInKeyframe для h264 кодека. В результате ключевые фреймы без sps и pps
|
|
275
|
+
* не используются как ключевые. Решает проблему с артефактами на видео в случае потерь пакетов.
|
|
276
|
+
*
|
|
277
|
+
* _По умолчанию: `false`_
|
|
278
|
+
*/
|
|
279
|
+
h264spsPpsIdrInKeyframe: boolean;
|
|
250
280
|
/**
|
|
251
281
|
* Получать список участников звонка третьим аргументом в `onConversation`
|
|
252
282
|
* @hidden
|
|
@@ -270,6 +300,11 @@ export declare type ParamsObject = {
|
|
|
270
300
|
* @hidden
|
|
271
301
|
*/
|
|
272
302
|
preserveAudioTracks: boolean;
|
|
303
|
+
/**
|
|
304
|
+
* Использовать congestion control для шаринга
|
|
305
|
+
* @hidden
|
|
306
|
+
*/
|
|
307
|
+
screenShareCongestionControl: boolean;
|
|
273
308
|
/**
|
|
274
309
|
* Получен локальный стрим с камеры/микрофона
|
|
275
310
|
*/
|
|
@@ -300,11 +335,24 @@ export declare type ParamsObject = {
|
|
|
300
335
|
* Получен стрим трансляция или мувик от собеседника.
|
|
301
336
|
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
302
337
|
*/
|
|
303
|
-
onRemoteLive?: (userId: ExternalParticipantId,
|
|
338
|
+
onRemoteLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
|
|
339
|
+
/**
|
|
340
|
+
* Получен собственный стрим трансляция или мувик.
|
|
341
|
+
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
342
|
+
*/
|
|
343
|
+
onLocalLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
|
|
344
|
+
/**
|
|
345
|
+
* Получено обновление стрима или лайва от собеседника.
|
|
346
|
+
*/
|
|
347
|
+
onRemoteLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
|
|
348
|
+
/**
|
|
349
|
+
* Получено обновление собственного стрима или лайва.
|
|
350
|
+
*/
|
|
351
|
+
onLocalLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
|
|
304
352
|
/**
|
|
305
353
|
* Начат звонок
|
|
306
354
|
*/
|
|
307
|
-
onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[]) => void;
|
|
355
|
+
onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[], rooms?: Rooms) => void;
|
|
308
356
|
/**
|
|
309
357
|
* Начальный список участников для постраничного звонка
|
|
310
358
|
*/
|
|
@@ -313,6 +361,26 @@ export declare type ParamsObject = {
|
|
|
313
361
|
* Изменились данные стрима собеседника
|
|
314
362
|
*/
|
|
315
363
|
onRemoteMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers) => void;
|
|
364
|
+
/**
|
|
365
|
+
* Изменились данные стрима собеседника
|
|
366
|
+
*/
|
|
367
|
+
onLocalMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings) => void;
|
|
368
|
+
/**
|
|
369
|
+
* Полученны данные по стримам (лайв/мувик) от собеседника
|
|
370
|
+
*/
|
|
371
|
+
onRemoteSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
|
|
372
|
+
/**
|
|
373
|
+
* Полученны данные по остановленным стримам (лайв/мувик) от собеседника
|
|
374
|
+
*/
|
|
375
|
+
onRemoteSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
|
|
376
|
+
/**
|
|
377
|
+
* Полученны данные по собственным стримам (лайв/мувик)
|
|
378
|
+
*/
|
|
379
|
+
onLocalSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
|
|
380
|
+
/**
|
|
381
|
+
* Полученны данные по собственным остановленным стримам (лайв/мувик)
|
|
382
|
+
*/
|
|
383
|
+
onLocalSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
|
|
316
384
|
/**
|
|
317
385
|
* Добавили участника
|
|
318
386
|
*/
|
|
@@ -357,7 +425,7 @@ export declare type ParamsObject = {
|
|
|
357
425
|
/**
|
|
358
426
|
* Изменились состояния устройств пользователя или разрешения включать камеру/микрофон
|
|
359
427
|
*/
|
|
360
|
-
onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]) => void;
|
|
428
|
+
onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[], roomId?: number | null) => void;
|
|
361
429
|
/**
|
|
362
430
|
* Изменились роли собеседника в звонке
|
|
363
431
|
*/
|
|
@@ -427,11 +495,11 @@ export declare type ParamsObject = {
|
|
|
427
495
|
/**
|
|
428
496
|
* Начата трансляция/запись звонка
|
|
429
497
|
*/
|
|
430
|
-
onRecordStarted?: (initiator: ExternalParticipantId, movieId: number, startTime: number, type: 'STREAM' | 'RECORD', externalMovieId?: string, externalOwnerId?: string) => void;
|
|
498
|
+
onRecordStarted?: (initiator: ExternalParticipantId, movieId: number, startTime: number, type: 'STREAM' | 'RECORD', externalMovieId?: string, externalOwnerId?: string, roomId?: number | null) => void;
|
|
431
499
|
/**
|
|
432
500
|
* Закончена трансляция/запись звонка
|
|
433
501
|
*/
|
|
434
|
-
onRecordStopped?: () => void;
|
|
502
|
+
onRecordStopped?: (roomId: number | null) => void;
|
|
435
503
|
/**
|
|
436
504
|
* Состояние своей сети
|
|
437
505
|
*
|
|
@@ -478,6 +546,49 @@ export declare type ParamsObject = {
|
|
|
478
546
|
* @param joinLink токен присоединения к звонку
|
|
479
547
|
*/
|
|
480
548
|
onJoinLinkChanged?: (joinLink: string) => void;
|
|
549
|
+
/**
|
|
550
|
+
* Получено обновление списка сессионных залов
|
|
551
|
+
* @param updates список обновлений по залам
|
|
552
|
+
*/
|
|
553
|
+
onRoomsUpdated?: (updates: Partial<Record<RoomsEventType, RoomsUpdate>>) => void;
|
|
554
|
+
/**
|
|
555
|
+
* Получено обновление сессионных зало
|
|
556
|
+
* @param eventTypes список событий
|
|
557
|
+
* @param roomId номер сессионного зала
|
|
558
|
+
* @param room сессионный зал
|
|
559
|
+
*/
|
|
560
|
+
onRoomUpdated?: (eventTypes: RoomsEventType[], roomId: number, room: Room | null, deactivate: boolean | null) => void;
|
|
561
|
+
/**
|
|
562
|
+
* Получение обновление списка участников в сессионном зале
|
|
563
|
+
* @param update обновление списка участников
|
|
564
|
+
*/
|
|
565
|
+
onRoomParticipantsUpdated?: (update: RoomParticipantUpdate) => void;
|
|
566
|
+
/**
|
|
567
|
+
* Получение информации о смене зала
|
|
568
|
+
* @param roomId номер сессионного зала
|
|
569
|
+
*/
|
|
570
|
+
onRoomSwitched?: (roomId: number | null) => void;
|
|
571
|
+
/**
|
|
572
|
+
* Установить id сессионного зала на старте звонка
|
|
573
|
+
* @param roomId номер сессионного зала
|
|
574
|
+
*/
|
|
575
|
+
onRoomStart?: (roomId: number | null) => void;
|
|
576
|
+
/**
|
|
577
|
+
* Получены новые реакции в звонке
|
|
578
|
+
* @param feedback массив с реакциями
|
|
579
|
+
*/
|
|
580
|
+
onFeedback?: (feedback: IFeedbackExternal[]) => void;
|
|
581
|
+
/**
|
|
582
|
+
* Включать capability c аудио шарой
|
|
583
|
+
*/
|
|
584
|
+
audioShareCapabilityEnabled: boolean;
|
|
585
|
+
/**
|
|
586
|
+
* Изменился список ролей, которым доступны ConversationFeatures
|
|
587
|
+
*
|
|
588
|
+
* @param featuresPerRole Объект вида ключ: ConversationFeature = значение: UserRole[]
|
|
589
|
+
* (если ключ фичи отсутствует, или в ролях пустой массив, считаем фичу доступной для всех пользователей)
|
|
590
|
+
*/
|
|
591
|
+
onFeaturesPerRoleChanged?: (featuresPerRole: IFeaturesPerRole) => void;
|
|
481
592
|
};
|
|
482
593
|
export default abstract class Params {
|
|
483
594
|
private static _params;
|
|
@@ -494,6 +605,8 @@ export default abstract class Params {
|
|
|
494
605
|
static set platform(value: string);
|
|
495
606
|
static get clientType(): string;
|
|
496
607
|
static set clientType(value: string);
|
|
608
|
+
static get externalUserType(): string;
|
|
609
|
+
static set externalUserType(value: string);
|
|
497
610
|
static get device(): string;
|
|
498
611
|
static get apiKey(): string;
|
|
499
612
|
static get apiEnv(): string;
|
|
@@ -503,6 +616,7 @@ export default abstract class Params {
|
|
|
503
616
|
static get anonymToken(): string;
|
|
504
617
|
static set anonymToken(value: string);
|
|
505
618
|
static get domain(): string;
|
|
619
|
+
static get externalDomain(): string;
|
|
506
620
|
static get iceServers(): IceServer[];
|
|
507
621
|
static set iceServers(value: IceServer[]);
|
|
508
622
|
static get wssBase(): string;
|
|
@@ -552,6 +666,7 @@ export default abstract class Params {
|
|
|
552
666
|
static get producerCommandDataChannel(): boolean;
|
|
553
667
|
static get consumerScreenDataChannel(): boolean;
|
|
554
668
|
static get producerScreenDataChannel(): boolean;
|
|
669
|
+
static get asrDataChannel(): boolean;
|
|
555
670
|
static get consumerScreenDataChannelPacketSize(): number;
|
|
556
671
|
static get screenShareWebmBuilder(): boolean;
|
|
557
672
|
static get noiseSuppression(): boolean;
|
|
@@ -561,18 +676,21 @@ export default abstract class Params {
|
|
|
561
676
|
static get audioNack(): boolean;
|
|
562
677
|
static get consumerScreenTrack(): boolean;
|
|
563
678
|
static get producerScreenTrack(): boolean;
|
|
564
|
-
static isUnifiedPlanSupported(name: string, version: number): boolean;
|
|
565
679
|
static get movieShare(): boolean;
|
|
566
680
|
static get videoTracksCount(): number;
|
|
567
681
|
static get breakVideoPayloadTypes(): boolean;
|
|
568
682
|
static get filteredMessages(): boolean;
|
|
569
683
|
static get useParticipantListChunk(): boolean;
|
|
684
|
+
static get useRooms(): boolean;
|
|
570
685
|
static get participantListChunkInitIndex(): number;
|
|
571
686
|
static get participantListChunkInitCount(): number;
|
|
572
687
|
static get serverAudioRed(): boolean;
|
|
573
688
|
static get p2pAudioRed(): boolean;
|
|
689
|
+
static get h264spsPpsIdrInKeyframe(): boolean;
|
|
574
690
|
static get batchParticipantsOnStart(): boolean;
|
|
575
691
|
static get filterObservers(): boolean;
|
|
576
692
|
static get muteMode(): boolean;
|
|
577
693
|
static get preserveAudioTracks(): boolean;
|
|
694
|
+
static get audioShareCapabilityEnabled(): boolean;
|
|
695
|
+
static get screenShareCongestionControl(): boolean;
|
|
578
696
|
}
|
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
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ParticipantId } from './Participant';
|
|
2
|
+
export interface AsrInfo {
|
|
3
|
+
movieId: number;
|
|
4
|
+
initiatorId: ParticipantId;
|
|
5
|
+
}
|
|
6
|
+
export interface AsrTranscription {
|
|
7
|
+
participantId: ParticipantId;
|
|
8
|
+
text: string;
|
|
9
|
+
timestamp: number;
|
|
10
|
+
duration: number;
|
|
11
|
+
}
|
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[];
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { CompositeUserId } from './Participant';
|
|
2
|
+
import { ExternalParticipantId } from './ExternalId';
|
|
3
|
+
interface IFeedbackItem {
|
|
4
|
+
participantId: CompositeUserId;
|
|
5
|
+
/** event timestamps for this participant, chronologically */
|
|
6
|
+
times: number[];
|
|
7
|
+
}
|
|
8
|
+
export interface IFeedbackItemExternal extends Omit<IFeedbackItem, 'participantId'> {
|
|
9
|
+
participantId: ExternalParticipantId;
|
|
10
|
+
}
|
|
11
|
+
export interface IFeedback {
|
|
12
|
+
/** feedback ID; key values should be negotiated by clients themselves, like in ParticipantState, and have just the same restrictions; on backend the values of these keys are not bound in any way to those in ParticipantState */
|
|
13
|
+
key: string;
|
|
14
|
+
/** total amount of reactions of this type from the start of this call */
|
|
15
|
+
totalCount: number;
|
|
16
|
+
/** list of items containing initiator & all related data, if any */
|
|
17
|
+
items: IFeedbackItem[];
|
|
18
|
+
}
|
|
19
|
+
export interface IFeedbackExternal extends Omit<IFeedback, 'items'> {
|
|
20
|
+
items: IFeedbackItemExternal[];
|
|
21
|
+
}
|
|
22
|
+
export {};
|
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,60 @@
|
|
|
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
|
+
number
|
|
25
|
+
];
|
|
26
|
+
export interface ISharedMovieState {
|
|
27
|
+
participantId: CompositeUserId;
|
|
28
|
+
gain?: number;
|
|
29
|
+
pause?: boolean;
|
|
30
|
+
offset?: number;
|
|
31
|
+
mute?: boolean;
|
|
32
|
+
liveStatus?: LiveStatus;
|
|
33
|
+
startTimeMs: number;
|
|
34
|
+
}
|
|
35
|
+
export interface IUpdateMovieData {
|
|
36
|
+
movieId: string;
|
|
37
|
+
gain?: number;
|
|
38
|
+
pause?: boolean;
|
|
39
|
+
offset?: number;
|
|
40
|
+
mute?: boolean;
|
|
41
|
+
}
|
|
42
|
+
export interface ISharedMovieInfo {
|
|
43
|
+
movieId: OkUserId;
|
|
44
|
+
initiatorId: CompositeUserId;
|
|
45
|
+
title: string;
|
|
46
|
+
source: MediaType;
|
|
47
|
+
externalMovieId: string;
|
|
48
|
+
duration: number;
|
|
49
|
+
thumbnails: IMoviePreview[];
|
|
50
|
+
}
|
|
51
|
+
export interface ISharedMovieStoppedInfo {
|
|
52
|
+
movieId: OkUserId;
|
|
53
|
+
initiatorId: CompositeUserId;
|
|
54
|
+
source: MediaType;
|
|
55
|
+
}
|
|
56
|
+
export interface IOnRemoteMovieData {
|
|
57
|
+
streamName: string;
|
|
58
|
+
stream: MediaStream | null;
|
|
59
|
+
mediaType: MediaType;
|
|
60
|
+
}
|
package/types/MuteStates.d.ts
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import MediaOption from '../enums/MediaOption';
|
|
2
2
|
import MuteState from '../enums/MuteState';
|
|
3
|
+
import { ExternalParticipantId } from './ExternalId';
|
|
4
|
+
import { OkUserId } from './Participant';
|
|
3
5
|
/**
|
|
4
6
|
* Состояние устройств пользователя установленное админом звонка
|
|
5
7
|
*/
|
|
@@ -7,3 +9,16 @@ declare type MuteStates = {
|
|
|
7
9
|
[key in MediaOption]?: MuteState;
|
|
8
10
|
};
|
|
9
11
|
export default MuteStates;
|
|
12
|
+
export interface IMuteParticipantParams {
|
|
13
|
+
externalId?: string | ExternalParticipantId | null;
|
|
14
|
+
muteStates: MuteStates;
|
|
15
|
+
requestedMedia?: MediaOption[];
|
|
16
|
+
roomId?: number | null;
|
|
17
|
+
}
|
|
18
|
+
export interface IMuteParticipantInternalParams {
|
|
19
|
+
uid: OkUserId | null;
|
|
20
|
+
muteStates: MuteStates;
|
|
21
|
+
requestedMedia: MediaOption[];
|
|
22
|
+
deviceIdx: number;
|
|
23
|
+
roomId: number | null;
|
|
24
|
+
}
|
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 | null;
|
|
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;
|