@vkontakte/calls-sdk 2.6.2-dev.f64ca50.0 → 2.6.2
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 +68 -11
- package/abstract/BaseApi.d.ts +7 -3
- package/abstract/BaseSignaling.d.ts +14 -2
- package/calls-sdk.cjs.js +8 -8
- package/calls-sdk.esm.js +8 -8
- package/classes/Conversation.d.ts +38 -5
- package/classes/MediaSource.d.ts +7 -2
- package/classes/ProducerCommandSerializationService.d.ts +3 -1
- 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 +16 -1
- package/classes/screenshare/ScreenCongestionControl.d.ts +25 -0
- package/classes/screenshare/SharingStatReport.d.ts +6 -0
- package/classes/screenshare/Utils.d.ts +6 -0
- package/classes/transport/ServerTransport.d.ts +2 -1
- package/default/Api.d.ts +8 -3
- package/default/Api.test.d.ts +1 -0
- package/default/Signaling.d.ts +14 -2
- package/enums/ConversationFeature.d.ts +2 -1
- package/enums/ConversationOption.d.ts +3 -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/ApiTransport.d.ts +1 -1
- package/static/External.d.ts +98 -5
- package/static/Params.d.ts +124 -9
- package/static/Polyfills.d.ts +7 -0
- package/static/Utils.d.ts +6 -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 +12 -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/Participant.d.ts +2 -0
- package/types/ParticipantListChunk.d.ts +2 -0
- package/types/ParticipantStreamDescription.d.ts +2 -1
- package/types/Room.d.ts +60 -0
- package/types/SignalingMessage.d.ts +63 -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/ApiTransport.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export declare function init(): void;
|
|
2
2
|
export declare function sendBeakon(method: string, params?: {
|
|
3
3
|
[key: string]: any;
|
|
4
|
-
}, noSession?: boolean): void
|
|
4
|
+
}, noSession?: boolean): Promise<void>;
|
|
5
5
|
export declare function request(method: string, params?: {
|
|
6
6
|
[key: string]: any;
|
|
7
7
|
}, noSession?: boolean): Promise<unknown>;
|
package/static/External.d.ts
CHANGED
|
@@ -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
|
|
76
|
-
|
|
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
|
|
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;
|
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, 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,12 +202,19 @@ export declare type ParamsObject = {
|
|
|
193
202
|
* Работает только при отправке экрана через дата-канал.
|
|
194
203
|
*
|
|
195
204
|
* _По умолчанию: `true`_
|
|
205
|
+
* @deprecated
|
|
196
206
|
*/
|
|
197
207
|
consumerScreenTrack: boolean;
|
|
198
208
|
producerNotificationDataChannel: boolean;
|
|
199
209
|
producerCommandDataChannel: boolean;
|
|
200
210
|
consumerScreenDataChannel: boolean;
|
|
201
211
|
producerScreenDataChannel: boolean;
|
|
212
|
+
/**
|
|
213
|
+
* Размер пакета для отправки трансляции экрана в датаканал в байтах.
|
|
214
|
+
* Максимальный размер пакета 65536 bytes в хроме, но по стандарту лучше максимум 16 Кб.
|
|
215
|
+
* @hidden
|
|
216
|
+
*/
|
|
217
|
+
consumerScreenDataChannelPacketSize: number;
|
|
202
218
|
screenShareWebmBuilder: boolean;
|
|
203
219
|
noiseSuppression: boolean;
|
|
204
220
|
/**
|
|
@@ -220,25 +236,46 @@ export declare type ParamsObject = {
|
|
|
220
236
|
breakVideoPayloadTypes: boolean;
|
|
221
237
|
/**
|
|
222
238
|
* Включить постраничный вывод участников. Работает только если включено videoTracksCount (слоты)
|
|
239
|
+
*
|
|
240
|
+
* _По умолчанию: `false`_
|
|
223
241
|
*/
|
|
224
242
|
useParticipantListChunk: boolean;
|
|
225
243
|
/**
|
|
226
|
-
*
|
|
244
|
+
* Включить комнаты
|
|
245
|
+
*
|
|
246
|
+
* _По умолчанию: `false`_
|
|
247
|
+
*/
|
|
248
|
+
useRooms: boolean;
|
|
249
|
+
/**
|
|
250
|
+
* Индекс участника для первого chunk'а который придет при установке соединения с сервером
|
|
251
|
+
*
|
|
252
|
+
* _По умолчанию: `0`_
|
|
227
253
|
*/
|
|
228
254
|
participantListChunkInitIndex: number;
|
|
229
255
|
/**
|
|
230
|
-
* Количество участников которые придут в первом chunk'е при
|
|
256
|
+
* Количество участников которые придут в первом chunk'е при установке соединения с сервером
|
|
231
257
|
* если параметр не проставлен то будет использоваться значение по умолчанию установленное на сервере
|
|
232
258
|
*/
|
|
233
259
|
participantListChunkInitCount: number | null;
|
|
234
260
|
/**
|
|
235
261
|
* Включать RED-extension (redundancy) для групповых звонков
|
|
262
|
+
*
|
|
263
|
+
* _По умолчанию: `false`_
|
|
236
264
|
*/
|
|
237
265
|
serverAudioRed: boolean;
|
|
238
266
|
/**
|
|
239
267
|
* Включать RED-extension (redundancy) для p2p звонков
|
|
268
|
+
*
|
|
269
|
+
* _По умолчанию: `false`_
|
|
240
270
|
*/
|
|
241
271
|
p2pAudioRed: boolean;
|
|
272
|
+
/**
|
|
273
|
+
* Добавлять флаг spsPpsIdrInKeyframe для h264 кодека. В результате ключевые фреймы без sps и pps
|
|
274
|
+
* не используются как ключевые. Решает проблему с артефактами на видео в случае потерь пакетов.
|
|
275
|
+
*
|
|
276
|
+
* _По умолчанию: `false`_
|
|
277
|
+
*/
|
|
278
|
+
h264spsPpsIdrInKeyframe: boolean;
|
|
242
279
|
/**
|
|
243
280
|
* Получать список участников звонка третьим аргументом в `onConversation`
|
|
244
281
|
* @hidden
|
|
@@ -262,6 +299,11 @@ export declare type ParamsObject = {
|
|
|
262
299
|
* @hidden
|
|
263
300
|
*/
|
|
264
301
|
preserveAudioTracks: boolean;
|
|
302
|
+
/**
|
|
303
|
+
* Использовать congestion control для шаринга
|
|
304
|
+
* @hidden
|
|
305
|
+
*/
|
|
306
|
+
screenShareCongestionControl: boolean;
|
|
265
307
|
/**
|
|
266
308
|
* Получен локальный стрим с камеры/микрофона
|
|
267
309
|
*/
|
|
@@ -292,11 +334,24 @@ export declare type ParamsObject = {
|
|
|
292
334
|
* Получен стрим трансляция или мувик от собеседника.
|
|
293
335
|
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
294
336
|
*/
|
|
295
|
-
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;
|
|
296
351
|
/**
|
|
297
352
|
* Начат звонок
|
|
298
353
|
*/
|
|
299
|
-
onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[]) => void;
|
|
354
|
+
onConversation?: (userId: ExternalParticipantId, mediaModifiers: MediaModifiers, muteStates: MuteStates, participants?: ExternalParticipant[], rooms?: Room[]) => void;
|
|
300
355
|
/**
|
|
301
356
|
* Начальный список участников для постраничного звонка
|
|
302
357
|
*/
|
|
@@ -305,6 +360,26 @@ export declare type ParamsObject = {
|
|
|
305
360
|
* Изменились данные стрима собеседника
|
|
306
361
|
*/
|
|
307
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;
|
|
308
383
|
/**
|
|
309
384
|
* Добавили участника
|
|
310
385
|
*/
|
|
@@ -349,7 +424,7 @@ export declare type ParamsObject = {
|
|
|
349
424
|
/**
|
|
350
425
|
* Изменились состояния устройств пользователя или разрешения включать камеру/микрофон
|
|
351
426
|
*/
|
|
352
|
-
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;
|
|
353
428
|
/**
|
|
354
429
|
* Изменились роли собеседника в звонке
|
|
355
430
|
*/
|
|
@@ -470,6 +545,39 @@ export declare type ParamsObject = {
|
|
|
470
545
|
* @param joinLink токен присоединения к звонку
|
|
471
546
|
*/
|
|
472
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;
|
|
473
581
|
};
|
|
474
582
|
export default abstract class Params {
|
|
475
583
|
private static _params;
|
|
@@ -486,6 +594,8 @@ export default abstract class Params {
|
|
|
486
594
|
static set platform(value: string);
|
|
487
595
|
static get clientType(): string;
|
|
488
596
|
static set clientType(value: string);
|
|
597
|
+
static get externalUserType(): string;
|
|
598
|
+
static set externalUserType(value: string);
|
|
489
599
|
static get device(): string;
|
|
490
600
|
static get apiKey(): string;
|
|
491
601
|
static get apiEnv(): string;
|
|
@@ -495,6 +605,7 @@ export default abstract class Params {
|
|
|
495
605
|
static get anonymToken(): string;
|
|
496
606
|
static set anonymToken(value: string);
|
|
497
607
|
static get domain(): string;
|
|
608
|
+
static get externalDomain(): string;
|
|
498
609
|
static get iceServers(): IceServer[];
|
|
499
610
|
static set iceServers(value: IceServer[]);
|
|
500
611
|
static get wssBase(): string;
|
|
@@ -544,6 +655,7 @@ export default abstract class Params {
|
|
|
544
655
|
static get producerCommandDataChannel(): boolean;
|
|
545
656
|
static get consumerScreenDataChannel(): boolean;
|
|
546
657
|
static get producerScreenDataChannel(): boolean;
|
|
658
|
+
static get consumerScreenDataChannelPacketSize(): number;
|
|
547
659
|
static get screenShareWebmBuilder(): boolean;
|
|
548
660
|
static get noiseSuppression(): boolean;
|
|
549
661
|
static set noiseSuppression(value: boolean);
|
|
@@ -552,18 +664,21 @@ export default abstract class Params {
|
|
|
552
664
|
static get audioNack(): boolean;
|
|
553
665
|
static get consumerScreenTrack(): boolean;
|
|
554
666
|
static get producerScreenTrack(): boolean;
|
|
555
|
-
static isUnifiedPlanSupported(name: string, version: number): boolean;
|
|
556
667
|
static get movieShare(): boolean;
|
|
557
668
|
static get videoTracksCount(): number;
|
|
558
669
|
static get breakVideoPayloadTypes(): boolean;
|
|
559
670
|
static get filteredMessages(): boolean;
|
|
560
671
|
static get useParticipantListChunk(): boolean;
|
|
672
|
+
static get useRooms(): boolean;
|
|
561
673
|
static get participantListChunkInitIndex(): number;
|
|
562
674
|
static get participantListChunkInitCount(): number;
|
|
563
675
|
static get serverAudioRed(): boolean;
|
|
564
676
|
static get p2pAudioRed(): boolean;
|
|
677
|
+
static get h264spsPpsIdrInKeyframe(): boolean;
|
|
565
678
|
static get batchParticipantsOnStart(): boolean;
|
|
566
679
|
static get filterObservers(): boolean;
|
|
567
680
|
static get muteMode(): boolean;
|
|
568
681
|
static get preserveAudioTracks(): boolean;
|
|
682
|
+
static get audioShareCapabilityEnabled(): boolean;
|
|
683
|
+
static get screenShareCongestionControl(): boolean;
|
|
569
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>;
|
|
@@ -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;
|
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,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
|
+
}
|
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;
|