@vkontakte/calls-sdk 2.6.2-dev.f69c395.0 → 2.6.3-beta.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.
Files changed (61) hide show
  1. package/CallsSDK.d.ts +85 -20
  2. package/abstract/BaseApi.d.ts +7 -3
  3. package/abstract/BaseSignaling.d.ts +22 -6
  4. package/calls-sdk.cjs.js +9 -9
  5. package/calls-sdk.esm.js +9 -9
  6. package/classes/Conversation.d.ts +80 -14
  7. package/classes/MediaSource.d.ts +7 -2
  8. package/classes/ProducerCommandSerializationService.d.ts +3 -1
  9. package/classes/asr/AsrCommandSerializer.d.ts +3 -0
  10. package/classes/asr/AsrReceiver.d.ts +12 -0
  11. package/classes/codec/IEncoder.d.ts +3 -0
  12. package/classes/codec/LibVPxEncoder.d.ts +4 -1
  13. package/classes/codec/Types.d.ts +6 -1
  14. package/classes/codec/WebCodecsEncoder.d.ts +4 -1
  15. package/classes/screenshare/PacketHistory.d.ts +30 -0
  16. package/classes/screenshare/PacketHistory.test.d.ts +1 -0
  17. package/classes/screenshare/ScreenCaptureSender.d.ts +15 -1
  18. package/classes/screenshare/ScreenCongestionControl.d.ts +25 -0
  19. package/classes/screenshare/SharingStatReport.d.ts +6 -0
  20. package/classes/screenshare/Utils.d.ts +5 -0
  21. package/classes/transport/ServerTransport.d.ts +6 -1
  22. package/classes/transport/Transport.d.ts +3 -1
  23. package/default/Api.d.ts +12 -3
  24. package/default/Api.test.d.ts +1 -0
  25. package/default/Signaling.d.ts +26 -6
  26. package/enums/ConversationFeature.d.ts +2 -1
  27. package/enums/ConversationOption.d.ts +3 -1
  28. package/enums/DataChannelLabel.d.ts +2 -1
  29. package/enums/HangupType.d.ts +3 -1
  30. package/enums/LiveStatus.d.ts +12 -0
  31. package/enums/MediaOption.d.ts +3 -1
  32. package/enums/RoomsEventType.d.ts +6 -0
  33. package/enums/SignalingCommandType.d.ts +12 -1
  34. package/enums/SignalingNotification.d.ts +12 -1
  35. package/package.json +1 -1
  36. package/static/External.d.ts +124 -9
  37. package/static/Params.d.ts +141 -12
  38. package/static/Polyfills.d.ts +7 -0
  39. package/static/Utils.d.ts +2 -1
  40. package/static/WebRTCUtils.d.ts +44 -11
  41. package/static/WebRTCUtils.test.d.ts +1 -0
  42. package/types/Asr.d.ts +11 -0
  43. package/types/Conversation.d.ts +1 -0
  44. package/types/ConversationFeature.d.ts +3 -0
  45. package/types/ConversationParams.d.ts +1 -0
  46. package/types/ExternalId.d.ts +2 -0
  47. package/types/Feedback.d.ts +22 -0
  48. package/types/MediaSettings.d.ts +5 -1
  49. package/types/MovieShare.d.ts +189 -0
  50. package/types/MuteStates.d.ts +15 -0
  51. package/types/Participant.d.ts +3 -0
  52. package/types/ParticipantListChunk.d.ts +2 -0
  53. package/types/ParticipantStreamDescription.d.ts +2 -1
  54. package/types/Room.d.ts +77 -0
  55. package/types/SignalingMessage.d.ts +67 -1
  56. package/types/Streams.d.ts +11 -0
  57. package/types/WaitingHall.d.ts +2 -8
  58. package/utils/ArrayDequeue.d.ts +24 -0
  59. package/utils/ArrayDequeue.spec.d.ts +1 -0
  60. package/utils/Conversation.d.ts +2 -0
  61. package/worker/LibVPxEncoderWorker.d.ts +1 -1
@@ -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
- * Индекс участника для первого chunk'а который придет при установки соединения с сервером
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,18 @@ export declare type ParamsObject = {
270
300
  * @hidden
271
301
  */
272
302
  preserveAudioTracks: boolean;
303
+ /**
304
+ * Использовать congestion control для шаринга
305
+ * @hidden
306
+ */
307
+ screenShareCongestionControl: boolean;
308
+ /**
309
+ * Настройки api
310
+ */
311
+ api: {
312
+ /** таймаут для батчинга на получение externalId */
313
+ userIdsByOkBatchedTimeout: number;
314
+ };
273
315
  /**
274
316
  * Получен локальный стрим с камеры/микрофона
275
317
  */
@@ -300,11 +342,24 @@ export declare type ParamsObject = {
300
342
  * Получен стрим трансляция или мувик от собеседника.
301
343
  * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
302
344
  */
303
- onRemoteLive?: (userId: ExternalParticipantId, streamId: string, stream: MediaStream | null) => void;
345
+ onRemoteLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
346
+ /**
347
+ * Получен собственный стрим трансляция или мувик.
348
+ * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
349
+ */
350
+ onLocalLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
351
+ /**
352
+ * Получено обновление стрима или лайва от собеседника.
353
+ */
354
+ onRemoteLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
355
+ /**
356
+ * Получено обновление собственного стрима или лайва.
357
+ */
358
+ onLocalLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
304
359
  /**
305
360
  * Начат звонок
306
361
  */
307
- onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[]) => void;
362
+ onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[], rooms?: Rooms) => void;
308
363
  /**
309
364
  * Начальный список участников для постраничного звонка
310
365
  */
@@ -313,6 +368,26 @@ export declare type ParamsObject = {
313
368
  * Изменились данные стрима собеседника
314
369
  */
315
370
  onRemoteMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers) => void;
371
+ /**
372
+ * Изменились данные стрима собеседника
373
+ */
374
+ onLocalMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings) => void;
375
+ /**
376
+ * Полученны данные по стримам (лайв/мувик) от собеседника
377
+ */
378
+ onRemoteSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
379
+ /**
380
+ * Полученны данные по остановленным стримам (лайв/мувик) от собеседника
381
+ */
382
+ onRemoteSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
383
+ /**
384
+ * Полученны данные по собственным стримам (лайв/мувик)
385
+ */
386
+ onLocalSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
387
+ /**
388
+ * Полученны данные по собственным остановленным стримам (лайв/мувик)
389
+ */
390
+ onLocalSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
316
391
  /**
317
392
  * Добавили участника
318
393
  */
@@ -341,7 +416,7 @@ export declare type ParamsObject = {
341
416
  /**
342
417
  * Ошибка получения трека с камеры или микрофона
343
418
  */
344
- onPermissionsError?: (error: FatalError) => void;
419
+ onPermissionsError?: (error: FatalError, original: Error) => void;
345
420
  /**
346
421
  * Пользователь отключился от звонка
347
422
  */
@@ -357,7 +432,7 @@ export declare type ParamsObject = {
357
432
  /**
358
433
  * Изменились состояния устройств пользователя или разрешения включать камеру/микрофон
359
434
  */
360
- onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]) => void;
435
+ 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
436
  /**
362
437
  * Изменились роли собеседника в звонке
363
438
  */
@@ -427,11 +502,11 @@ export declare type ParamsObject = {
427
502
  /**
428
503
  * Начата трансляция/запись звонка
429
504
  */
430
- onRecordStarted?: (initiator: ExternalParticipantId, movieId: number, startTime: number, type: 'STREAM' | 'RECORD', externalMovieId?: string, externalOwnerId?: string) => void;
505
+ onRecordStarted?: (initiator: ExternalParticipantId, movieId: number, startTime: number, type: 'STREAM' | 'RECORD', externalMovieId?: string, externalOwnerId?: string, roomId?: number | null) => void;
431
506
  /**
432
507
  * Закончена трансляция/запись звонка
433
508
  */
434
- onRecordStopped?: () => void;
509
+ onRecordStopped?: (roomId: number | null) => void;
435
510
  /**
436
511
  * Состояние своей сети
437
512
  *
@@ -478,6 +553,49 @@ export declare type ParamsObject = {
478
553
  * @param joinLink токен присоединения к звонку
479
554
  */
480
555
  onJoinLinkChanged?: (joinLink: string) => void;
556
+ /**
557
+ * Получено обновление списка сессионных залов
558
+ * @param updates список обновлений по залам
559
+ */
560
+ onRoomsUpdated?: (updates: Partial<Record<RoomsEventType, RoomsUpdate>>) => void;
561
+ /**
562
+ * Получено обновление сессионных зало
563
+ * @param eventTypes список событий
564
+ * @param roomId номер сессионного зала
565
+ * @param room сессионный зал
566
+ */
567
+ onRoomUpdated?: (eventTypes: RoomsEventType[], roomId: number, room: Room | null, deactivate: boolean | null) => void;
568
+ /**
569
+ * Получение обновление списка участников в сессионном зале
570
+ * @param update обновление списка участников
571
+ */
572
+ onRoomParticipantsUpdated?: (update: RoomParticipantUpdate) => void;
573
+ /**
574
+ * Получение информации о смене зала
575
+ * @param roomId номер сессионного зала
576
+ */
577
+ onRoomSwitched?: (roomId: number | null) => void;
578
+ /**
579
+ * Установить id сессионного зала на старте звонка
580
+ * @param roomId номер сессионного зала
581
+ */
582
+ onRoomStart?: (roomId: number | null) => void;
583
+ /**
584
+ * Получены новые реакции в звонке
585
+ * @param feedback массив с реакциями
586
+ */
587
+ onFeedback?: (feedback: IFeedbackExternal[], roomId: number | null) => void;
588
+ /**
589
+ * Включать capability c аудио шарой
590
+ */
591
+ audioShareCapabilityEnabled: boolean;
592
+ /**
593
+ * Изменился список ролей, которым доступны ConversationFeatures
594
+ *
595
+ * @param featuresPerRole Объект вида ключ: ConversationFeature = значение: UserRole[]
596
+ * (если ключ фичи отсутствует, или в ролях пустой массив, считаем фичу доступной для всех пользователей)
597
+ */
598
+ onFeaturesPerRoleChanged?: (featuresPerRole: IFeaturesPerRole) => void;
481
599
  };
482
600
  export default abstract class Params {
483
601
  private static _params;
@@ -494,6 +612,8 @@ export default abstract class Params {
494
612
  static set platform(value: string);
495
613
  static get clientType(): string;
496
614
  static set clientType(value: string);
615
+ static get externalUserType(): string;
616
+ static set externalUserType(value: string);
497
617
  static get device(): string;
498
618
  static get apiKey(): string;
499
619
  static get apiEnv(): string;
@@ -503,6 +623,7 @@ export default abstract class Params {
503
623
  static get anonymToken(): string;
504
624
  static set anonymToken(value: string);
505
625
  static get domain(): string;
626
+ static get externalDomain(): string;
506
627
  static get iceServers(): IceServer[];
507
628
  static set iceServers(value: IceServer[]);
508
629
  static get wssBase(): string;
@@ -552,6 +673,7 @@ export default abstract class Params {
552
673
  static get producerCommandDataChannel(): boolean;
553
674
  static get consumerScreenDataChannel(): boolean;
554
675
  static get producerScreenDataChannel(): boolean;
676
+ static get asrDataChannel(): boolean;
555
677
  static get consumerScreenDataChannelPacketSize(): number;
556
678
  static get screenShareWebmBuilder(): boolean;
557
679
  static get noiseSuppression(): boolean;
@@ -561,18 +683,25 @@ export default abstract class Params {
561
683
  static get audioNack(): boolean;
562
684
  static get consumerScreenTrack(): boolean;
563
685
  static get producerScreenTrack(): boolean;
564
- static isUnifiedPlanSupported(name: string, version: number): boolean;
565
686
  static get movieShare(): boolean;
566
687
  static get videoTracksCount(): number;
567
688
  static get breakVideoPayloadTypes(): boolean;
568
689
  static get filteredMessages(): boolean;
569
690
  static get useParticipantListChunk(): boolean;
691
+ static get useRooms(): boolean;
570
692
  static get participantListChunkInitIndex(): number;
571
693
  static get participantListChunkInitCount(): number;
572
694
  static get serverAudioRed(): boolean;
573
695
  static get p2pAudioRed(): boolean;
696
+ static get h264spsPpsIdrInKeyframe(): boolean;
574
697
  static get batchParticipantsOnStart(): boolean;
575
698
  static get filterObservers(): boolean;
576
699
  static get muteMode(): boolean;
577
700
  static get preserveAudioTracks(): boolean;
701
+ static get audioShareCapabilityEnabled(): boolean;
702
+ static get screenShareCongestionControl(): boolean;
703
+ static get api(): {
704
+ /** таймаут для батчинга на получение externalId */
705
+ userIdsByOkBatchedTimeout: number;
706
+ };
578
707
  }
@@ -0,0 +1,7 @@
1
+ export declare const fromEntries: {
2
+ <T = any>(entries: Iterable<readonly [PropertyKey, T]>): {
3
+ [k: string]: T;
4
+ };
5
+ (entries: Iterable<readonly any[]>): any;
6
+ };
7
+ export declare function blobToArrayBuffer(data: Blob): Promise<ArrayBuffer>;
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 patchSDP(sdp: string, preferH264: boolean, brokenH264: boolean, preferVP9: boolean, isAudioNack?: boolean, preferRed?: boolean): string;
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>;
@@ -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
+ }
@@ -9,4 +9,5 @@ export interface IProcessMuteStateParams {
9
9
  admin?: Participant | null;
10
10
  stateUpdated?: boolean;
11
11
  requestedMedia?: MediaOption[];
12
+ roomId?: number | null;
12
13
  }
@@ -0,0 +1,3 @@
1
+ import ConversationFeature from '../enums/ConversationFeature';
2
+ import UserRole from '../enums/UserRole';
3
+ export declare type IFeaturesPerRole = Partial<Record<ConversationFeature, UserRole[]>>;
@@ -10,5 +10,6 @@ declare type ConversationParams = {
10
10
  isp_as_org?: string;
11
11
  loc_cc?: string;
12
12
  loc_reg?: string;
13
+ external_user_type: string;
13
14
  };
14
15
  export default ConversationParams;
@@ -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 {};
@@ -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
- vkMovieId?: string;
26
+ externalMovieId?: string;
23
27
  };
24
28
  export default MediaSettings;
25
29
  export declare function compareMediaSettings(ms1: MediaSettings, ms2: MediaSettings): boolean;