@vkontakte/calls-sdk 2.6.2-beta.3 → 2.6.2-beta.30

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 (56) hide show
  1. package/CallsSDK.d.ts +68 -11
  2. package/abstract/BaseApi.d.ts +7 -3
  3. package/abstract/BaseSignaling.d.ts +14 -2
  4. package/calls-sdk.cjs.js +8 -8
  5. package/calls-sdk.esm.js +8 -8
  6. package/classes/Conversation.d.ts +38 -5
  7. package/classes/MediaSource.d.ts +7 -2
  8. package/classes/ProducerCommandSerializationService.d.ts +3 -1
  9. package/classes/codec/IEncoder.d.ts +3 -0
  10. package/classes/codec/LibVPxEncoder.d.ts +4 -1
  11. package/classes/codec/Types.d.ts +6 -1
  12. package/classes/codec/WebCodecsEncoder.d.ts +4 -1
  13. package/classes/screenshare/PacketHistory.d.ts +30 -0
  14. package/classes/screenshare/PacketHistory.test.d.ts +1 -0
  15. package/classes/screenshare/ScreenCaptureSender.d.ts +15 -1
  16. package/classes/screenshare/ScreenCongestionControl.d.ts +25 -0
  17. package/classes/screenshare/SharingStatReport.d.ts +6 -0
  18. package/classes/screenshare/Utils.d.ts +5 -0
  19. package/classes/transport/ServerTransport.d.ts +2 -1
  20. package/default/Api.d.ts +8 -3
  21. package/default/Api.test.d.ts +1 -0
  22. package/default/Signaling.d.ts +14 -2
  23. package/enums/ConversationFeature.d.ts +2 -1
  24. package/enums/ConversationOption.d.ts +3 -1
  25. package/enums/HangupType.d.ts +3 -1
  26. package/enums/LiveStatus.d.ts +7 -0
  27. package/enums/MediaOption.d.ts +3 -1
  28. package/enums/RoomsEventType.d.ts +6 -0
  29. package/enums/SignalingCommandType.d.ts +12 -1
  30. package/enums/SignalingNotification.d.ts +12 -1
  31. package/package.json +1 -1
  32. package/static/ApiTransport.d.ts +1 -1
  33. package/static/External.d.ts +98 -5
  34. package/static/Params.d.ts +117 -9
  35. package/static/Polyfills.d.ts +7 -0
  36. package/static/Utils.d.ts +6 -1
  37. package/static/WebRTCUtils.d.ts +44 -11
  38. package/static/WebRTCUtils.test.d.ts +1 -0
  39. package/types/Asr.d.ts +5 -0
  40. package/types/Conversation.d.ts +12 -0
  41. package/types/ConversationFeature.d.ts +3 -0
  42. package/types/ConversationParams.d.ts +1 -0
  43. package/types/ExternalId.d.ts +2 -0
  44. package/types/Feedback.d.ts +22 -0
  45. package/types/MediaSettings.d.ts +5 -1
  46. package/types/MovieShare.d.ts +58 -0
  47. package/types/Participant.d.ts +2 -0
  48. package/types/ParticipantListChunk.d.ts +2 -0
  49. package/types/ParticipantStreamDescription.d.ts +2 -1
  50. package/types/Room.d.ts +60 -0
  51. package/types/SignalingMessage.d.ts +63 -0
  52. package/types/WaitingHall.d.ts +2 -8
  53. package/utils/ArrayDequeue.d.ts +24 -0
  54. package/utils/ArrayDequeue.spec.d.ts +1 -0
  55. package/utils/Conversation.d.ts +2 -0
  56. package/worker/LibVPxEncoderWorker.d.ts +1 -1
@@ -6,12 +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';
13
+ import { IFeedbackExternal } from '../types/Feedback';
11
14
  import MediaModifiers from '../types/MediaModifiers';
12
15
  import MediaSettings from '../types/MediaSettings';
16
+ import { IOnRemoteMovieData, ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
13
17
  import MuteStates from '../types/MuteStates';
14
18
  import { ParticipantStateMapped } from '../types/Participant';
19
+ import { Room, RoomParticipantUpdate, RoomsUpdate } from '../types/Room';
15
20
  import { DebugMessageType } from './Debug';
16
21
  import { JSONObject } from './Json';
17
22
  /**
@@ -72,10 +77,31 @@ declare namespace External {
72
77
  * Если сервер закончил стримить собеседника, вместо стрима будет передан null
73
78
  *
74
79
  * @param userId
75
- * @param streamName
76
- * @param stream
80
+ * @param data
81
+ */
82
+ function onRemoteLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
83
+ /**
84
+ * Получен собственный стрим лайв.
85
+ * Если сервер закончил стримить собеседника, вместо стрима будет передан null
86
+ *
87
+ * @param userId
88
+ * @param data
77
89
  */
78
- function onRemoteLive(userId: ExternalParticipantId, streamName: string, stream: MediaStream | null): void;
90
+ function onLocalLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
91
+ /**
92
+ * Получено обновление стрима или лайва от собеседника.
93
+ *
94
+ * @param userId
95
+ * @param data
96
+ */
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;
79
105
  /**
80
106
  * Получен стрим с экрана собеседника.
81
107
  * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
@@ -91,8 +117,9 @@ declare namespace External {
91
117
  * @param mediaModifiers Текущие настройки пользовательского медиа
92
118
  * @param muteStates Состояние устройств при входе в звонок
93
119
  * @param participants Список участников звонка (при `Params.batchParticipantsOnStart = true`)
120
+ * @param rooms Список комнат в звонке
94
121
  */
95
- function onConversation(userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[]): void;
122
+ function onConversation(userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[], rooms?: Room[]): void;
96
123
  /**
97
124
  * Постраничные данные про участников при начале звонка
98
125
  * @param chunk
@@ -106,6 +133,41 @@ declare namespace External {
106
133
  * @param markers
107
134
  */
108
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;
109
171
  /**
110
172
  * Добавили участника
111
173
  *
@@ -187,8 +249,10 @@ declare namespace External {
187
249
  * @param unmute Разрешение включить устройство
188
250
  * @param userId Пользователь, для которого изменились разрешения или `null` для текущего пользователя
189
251
  * @param adminId Пользователь, который изменил разрешения
252
+ * @param stateUpdated Если `true`, значит глобальное/персональное состояние изменилось и поля `muteStates`/`unmuteOptions` содержат обновления, если `false`, значит, эти поля не имеют значения
253
+ * @param requestedMedia Какие устройства попросили влючить участника
190
254
  */
191
- function onMuteStates(muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll?: boolean, unmute?: boolean, userId?: ExternalParticipantId | null, adminId?: ExternalParticipantId | null): void;
255
+ function onMuteStates(muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll?: boolean, unmute?: boolean, userId?: ExternalParticipantId | null, adminId?: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]): void;
192
256
  /**
193
257
  * Изменились роли собеседника в звонке
194
258
  *
@@ -353,5 +417,34 @@ declare namespace External {
353
417
  * @param joinLink токен присоединения к звонку
354
418
  */
355
419
  function onJoinLinkChanged(joinLink: string): void;
420
+ /**
421
+ */
422
+ function onRoomsUpdated(updates: Partial<Record<RoomsEventType, RoomsUpdate>>): void;
423
+ /**
424
+ */
425
+ function onRoomUpdated(eventTypes: RoomsEventType[], roomId: number, room: Room | null): void;
426
+ /**
427
+ */
428
+ function onRoomParticipantsUpdated(update: RoomParticipantUpdate): void;
429
+ /**
430
+ * Получена новая реакция
431
+ */
432
+ function onFeedback(feedback: IFeedbackExternal[]): void;
433
+ /**
434
+ * Изменилось состояние пермиссий фич в звонке
435
+ *
436
+ * @param featuresPerRole Информация о доступных фичах по ролям
437
+ */
438
+ function onFeaturesPerRoleChanged(featuresPerRole: IFeaturesPerRole): void;
439
+ /**
440
+ * Начата текстовая расшифровка звонка
441
+ * @param initiatorId Id пользователя, запустившего расшифровку звонка
442
+ * @param movieId Id расшифровки
443
+ */
444
+ function onAsrStarted(initiatorId: ExternalParticipantId, movieId: number): void;
445
+ /**
446
+ * Закончена текстовая расшифровка звонка
447
+ */
448
+ function onAsrStopped(): void;
356
449
  }
357
450
  export default External;
@@ -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, 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
  *
@@ -186,6 +194,7 @@ export declare type ParamsObject = {
186
194
  * Работает только при приёме экрана через дата-канал.
187
195
  *
188
196
  * _По умолчанию: `true`_
197
+ * @deprecated
189
198
  */
190
199
  producerScreenTrack: boolean;
191
200
  /**
@@ -193,6 +202,7 @@ export declare type ParamsObject = {
193
202
  * Работает только при отправке экрана через дата-канал.
194
203
  *
195
204
  * _По умолчанию: `true`_
205
+ * @deprecated
196
206
  */
197
207
  consumerScreenTrack: boolean;
198
208
  producerNotificationDataChannel: boolean;
@@ -226,25 +236,46 @@ export declare type ParamsObject = {
226
236
  breakVideoPayloadTypes: boolean;
227
237
  /**
228
238
  * Включить постраничный вывод участников. Работает только если включено videoTracksCount (слоты)
239
+ *
240
+ * _По умолчанию: `false`_
229
241
  */
230
242
  useParticipantListChunk: boolean;
231
243
  /**
232
- * Индекс участника для первого chunk'а который придет при установки соединения с сервером
244
+ * Включить комнаты
245
+ *
246
+ * _По умолчанию: `false`_
247
+ */
248
+ useRooms: boolean;
249
+ /**
250
+ * Индекс участника для первого chunk'а который придет при установке соединения с сервером
251
+ *
252
+ * _По умолчанию: `0`_
233
253
  */
234
254
  participantListChunkInitIndex: number;
235
255
  /**
236
- * Количество участников которые придут в первом chunk'е при установки соединения с сервером
256
+ * Количество участников которые придут в первом chunk'е при установке соединения с сервером
237
257
  * если параметр не проставлен то будет использоваться значение по умолчанию установленное на сервере
238
258
  */
239
259
  participantListChunkInitCount: number | null;
240
260
  /**
241
261
  * Включать RED-extension (redundancy) для групповых звонков
262
+ *
263
+ * _По умолчанию: `false`_
242
264
  */
243
265
  serverAudioRed: boolean;
244
266
  /**
245
267
  * Включать RED-extension (redundancy) для p2p звонков
268
+ *
269
+ * _По умолчанию: `false`_
246
270
  */
247
271
  p2pAudioRed: boolean;
272
+ /**
273
+ * Добавлять флаг spsPpsIdrInKeyframe для h264 кодека. В результате ключевые фреймы без sps и pps
274
+ * не используются как ключевые. Решает проблему с артефактами на видео в случае потерь пакетов.
275
+ *
276
+ * _По умолчанию: `false`_
277
+ */
278
+ h264spsPpsIdrInKeyframe: boolean;
248
279
  /**
249
280
  * Получать список участников звонка третьим аргументом в `onConversation`
250
281
  * @hidden
@@ -268,6 +299,11 @@ export declare type ParamsObject = {
268
299
  * @hidden
269
300
  */
270
301
  preserveAudioTracks: boolean;
302
+ /**
303
+ * Использовать congestion control для шаринга
304
+ * @hidden
305
+ */
306
+ screenShareCongestionControl: boolean;
271
307
  /**
272
308
  * Получен локальный стрим с камеры/микрофона
273
309
  */
@@ -298,11 +334,24 @@ export declare type ParamsObject = {
298
334
  * Получен стрим трансляция или мувик от собеседника.
299
335
  * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
300
336
  */
301
- onRemoteLive?: (userId: ExternalParticipantId, streamId: string, stream: MediaStream | null) => void;
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;
302
351
  /**
303
352
  * Начат звонок
304
353
  */
305
- onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[]) => void;
354
+ onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[], rooms?: Room[]) => void;
306
355
  /**
307
356
  * Начальный список участников для постраничного звонка
308
357
  */
@@ -311,6 +360,26 @@ export declare type ParamsObject = {
311
360
  * Изменились данные стрима собеседника
312
361
  */
313
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;
314
383
  /**
315
384
  * Добавили участника
316
385
  */
@@ -355,7 +424,7 @@ export declare type ParamsObject = {
355
424
  /**
356
425
  * Изменились состояния устройств пользователя или разрешения включать камеру/микрофон
357
426
  */
358
- onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null) => void;
427
+ onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]) => void;
359
428
  /**
360
429
  * Изменились роли собеседника в звонке
361
430
  */
@@ -476,6 +545,39 @@ export declare type ParamsObject = {
476
545
  * @param joinLink токен присоединения к звонку
477
546
  */
478
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) => void;
560
+ /**
561
+ * Получение обновление списка участников в комнате
562
+ * @param update обновление списка участников
563
+ */
564
+ onRoomParticipantsUpdated?: (update: RoomParticipantUpdate) => void;
565
+ /**
566
+ * Получены новые реакции в звонке
567
+ * @param feedback массив с реакциями
568
+ */
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;
479
581
  };
480
582
  export default abstract class Params {
481
583
  private static _params;
@@ -492,6 +594,8 @@ export default abstract class Params {
492
594
  static set platform(value: string);
493
595
  static get clientType(): string;
494
596
  static set clientType(value: string);
597
+ static get externalUserType(): string;
598
+ static set externalUserType(value: string);
495
599
  static get device(): string;
496
600
  static get apiKey(): string;
497
601
  static get apiEnv(): string;
@@ -501,6 +605,7 @@ export default abstract class Params {
501
605
  static get anonymToken(): string;
502
606
  static set anonymToken(value: string);
503
607
  static get domain(): string;
608
+ static get externalDomain(): string;
504
609
  static get iceServers(): IceServer[];
505
610
  static set iceServers(value: IceServer[]);
506
611
  static get wssBase(): string;
@@ -559,18 +664,21 @@ export default abstract class Params {
559
664
  static get audioNack(): boolean;
560
665
  static get consumerScreenTrack(): boolean;
561
666
  static get producerScreenTrack(): boolean;
562
- static isUnifiedPlanSupported(name: string, version: number): boolean;
563
667
  static get movieShare(): boolean;
564
668
  static get videoTracksCount(): number;
565
669
  static get breakVideoPayloadTypes(): boolean;
566
670
  static get filteredMessages(): boolean;
567
671
  static get useParticipantListChunk(): boolean;
672
+ static get useRooms(): boolean;
568
673
  static get participantListChunkInitIndex(): number;
569
674
  static get participantListChunkInitCount(): number;
570
675
  static get serverAudioRed(): boolean;
571
676
  static get p2pAudioRed(): boolean;
677
+ static get h264spsPpsIdrInKeyframe(): boolean;
572
678
  static get batchParticipantsOnStart(): boolean;
573
679
  static get filterObservers(): boolean;
574
680
  static get muteMode(): boolean;
575
681
  static get preserveAudioTracks(): boolean;
682
+ static get audioShareCapabilityEnabled(): boolean;
683
+ static get screenShareCongestionControl(): boolean;
576
684
  }
@@ -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>;
@@ -60,5 +61,9 @@ declare namespace Utils {
60
61
  * https://stash.odkl.ru/projects/ODKL/repos/odnoklassniki-webrtc/browse/src/main/java/one/webrtc/domain/conversation/ParticipantIndex.java#67-78
61
62
  */
62
63
  function participantMarkerCompare(marker1: ExternalParticipantListMarker | undefined, marker2: ExternalParticipantListMarker | undefined): number;
64
+ /** убирает все ключи со значением `V` на 1 уровне */
65
+ function objectFilterOutValues<T extends Record<string, V>, V = unknown>(obj: T, value?: V | V[]): Partial<T>;
66
+ function objectReduce<R, T extends Object>(obj: T, callback: (acc: R, value: T[keyof T], key: keyof T) => R, initialValue: R): R;
67
+ const setImmediate: (fn: VoidFunction) => VoidFunction;
63
68
  }
64
69
  export default Utils;
@@ -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,5 @@
1
+ import { ParticipantId } from './Participant';
2
+ export interface AsrInfo {
3
+ movieId: number;
4
+ initiatorId: ParticipantId;
5
+ }
@@ -0,0 +1,12 @@
1
+ import MediaOption from '../enums/MediaOption';
2
+ import MediaSettings from './MediaSettings';
3
+ import { Participant } from './Participant';
4
+ export interface IProcessMuteStateParams {
5
+ mediaOptions?: MediaOption[];
6
+ muteAll?: boolean;
7
+ unmute?: boolean;
8
+ serverSettings?: MediaSettings | null;
9
+ admin?: Participant | null;
10
+ stateUpdated?: boolean;
11
+ requestedMedia?: MediaOption[];
12
+ }
@@ -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;