@vkontakte/calls-sdk 2.6.2-beta.2 → 2.6.2-beta.21
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 +26 -9
- package/abstract/BaseApi.d.ts +6 -2
- package/abstract/BaseSignaling.d.ts +8 -3
- package/calls-sdk.cjs.js +8 -8
- package/calls-sdk.esm.js +8 -8
- package/classes/Conversation.d.ts +23 -7
- package/classes/MediaSource.d.ts +7 -2
- package/classes/ParticipantIdRegistry.d.ts +2 -0
- package/classes/ProducerCommandSerializationService.d.ts +17 -0
- package/classes/screenshare/ScreenCaptureSender.d.ts +1 -0
- package/classes/screenshare/Utils.d.ts +1 -0
- package/classes/transport/ServerTransport.d.ts +2 -0
- package/default/Api.d.ts +7 -2
- package/default/Api.test.d.ts +1 -0
- package/default/Signaling.d.ts +13 -4
- package/enums/ConversationFeature.d.ts +2 -1
- package/enums/ConversationOption.d.ts +3 -1
- package/enums/HangupType.d.ts +3 -1
- package/enums/MediaOption.d.ts +3 -1
- package/enums/SignalingCommandType.d.ts +3 -1
- package/enums/SignalingNotification.d.ts +7 -1
- package/package.json +1 -1
- package/static/ApiTransport.d.ts +1 -1
- package/static/External.d.ts +75 -4
- package/static/Params.d.ts +79 -2
- package/static/Utils.d.ts +5 -1
- package/static/WebRTCUtils.d.ts +2 -1
- 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/LayoutUtils.d.ts +5 -0
- package/types/MediaSettings.d.ts +5 -1
- package/types/MovieShare.d.ts +55 -0
- package/types/Participant.d.ts +2 -0
- package/types/ParticipantLayout.d.ts +7 -1
- package/types/ParticipantStreamDescription.d.ts +2 -1
- package/types/SignalingMessage.d.ts +22 -0
- package/types/WaitingHall.d.ts +2 -8
- package/utils/Conversation.d.ts +2 -0
- package/utils/MsgPackerBufferUtils.d.ts +31 -0
|
@@ -12,9 +12,11 @@ import UpdateDisplayLayoutErrorReason from '../enums/UpdateDisplayLayoutErrorRea
|
|
|
12
12
|
import UserRole from '../enums/UserRole';
|
|
13
13
|
import UserType from '../enums/UserType';
|
|
14
14
|
import { JSONObject } from '../static/Json';
|
|
15
|
+
import { IFeaturesPerRole } from '../types/ConversationFeature';
|
|
15
16
|
import { ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalUserId } from '../types/ExternalId';
|
|
16
17
|
import MediaModifiers from '../types/MediaModifiers';
|
|
17
18
|
import { IVideoDimentions } from '../types/MediaSettings';
|
|
19
|
+
import { IAddMovieParams, IUpdateMovieData } from '../types/MovieShare';
|
|
18
20
|
import MuteStates from '../types/MuteStates';
|
|
19
21
|
import { CompositeUserId, IGetParticipantsParameters, OkUserId, ParticipantId } from '../types/Participant';
|
|
20
22
|
import { ParticipantLayout } from '../types/ParticipantLayout';
|
|
@@ -37,6 +39,7 @@ export declare type ConversationData = {
|
|
|
37
39
|
*/
|
|
38
40
|
acceptTime: number | null;
|
|
39
41
|
features: ConversationFeature[];
|
|
42
|
+
featuresPerRole?: IFeaturesPerRole | null;
|
|
40
43
|
/**
|
|
41
44
|
* ID звонка
|
|
42
45
|
*/
|
|
@@ -76,6 +79,7 @@ export default class Conversation extends EventEmitter {
|
|
|
76
79
|
private readonly _signaling;
|
|
77
80
|
private _mediaSource;
|
|
78
81
|
private _conversation;
|
|
82
|
+
private _myLastRequestedLayouts;
|
|
79
83
|
private _state;
|
|
80
84
|
private _participantState;
|
|
81
85
|
private _participants;
|
|
@@ -106,7 +110,7 @@ export default class Conversation extends EventEmitter {
|
|
|
106
110
|
static current(): Conversation | null;
|
|
107
111
|
static hangupAfterInit(): void;
|
|
108
112
|
static id(): string | null;
|
|
109
|
-
onStart(opponentIds: OkUserId[], opponentType: CallType, mediaOptions: MediaOption[], payload?: string, joiningAllowed?: boolean, requireAuthToJoin?: boolean): Promise<ConversationData>;
|
|
113
|
+
onStart(opponentIds: OkUserId[], opponentType: CallType, mediaOptions: MediaOption[], payload?: string, joiningAllowed?: boolean, requireAuthToJoin?: boolean, onlyAdminCanShareMovie?: boolean): Promise<ConversationData>;
|
|
110
114
|
onJoin(joinArgs: {
|
|
111
115
|
conversationId?: string;
|
|
112
116
|
mediaOptions: MediaOption[];
|
|
@@ -151,10 +155,12 @@ export default class Conversation extends EventEmitter {
|
|
|
151
155
|
private _processConnection;
|
|
152
156
|
private _prepareParticipants;
|
|
153
157
|
private _onConversationParticipantListChunk;
|
|
158
|
+
private _createParticipantListChunk;
|
|
154
159
|
private _participantListChunkToExternalChunk;
|
|
155
160
|
private _registerConnectionParticipants;
|
|
156
161
|
private _registerParticipants;
|
|
157
|
-
|
|
162
|
+
/** Установим состояние локальных мьютов */
|
|
163
|
+
private _registerParticipantLocalMuteState;
|
|
158
164
|
private _getStatusByTransportState;
|
|
159
165
|
private _registerParticipantInCache;
|
|
160
166
|
private _getExistedParticipantByIdOrCreate;
|
|
@@ -188,7 +194,7 @@ export default class Conversation extends EventEmitter {
|
|
|
188
194
|
private _onAddParticipant;
|
|
189
195
|
private _onRemoveParticipant;
|
|
190
196
|
changeDevice(kind: MediaDeviceKind): Promise<void>;
|
|
191
|
-
toggleScreenCapturing(
|
|
197
|
+
toggleScreenCapturing(screenEnabled: boolean, audioShareEnabled: boolean): Promise<void>;
|
|
192
198
|
setVideoStream(stream: MediaStream, isScreen?: boolean): Promise<void>;
|
|
193
199
|
setAudioStream(stream: MediaStream): Promise<void>;
|
|
194
200
|
toggleLocalVideo(enabled: boolean): Promise<void>;
|
|
@@ -200,14 +206,20 @@ export default class Conversation extends EventEmitter {
|
|
|
200
206
|
requestKeyFrame(participantStreamDescription: ParticipantStreamDescription): Promise<void | SignalingMessage>;
|
|
201
207
|
requestTestMode(consumerCommand: string, producerCommand: string): Promise<void>;
|
|
202
208
|
updateDisplayLayout(layouts: ParticipantLayout[]): Promise<void>;
|
|
209
|
+
/** @async */
|
|
210
|
+
feedback(key: string): Promise<SignalingMessage>;
|
|
203
211
|
private _stopStreaming;
|
|
204
212
|
private _sendUpdateDisplayLayout;
|
|
205
213
|
private _cleanupCooldownQueue;
|
|
206
|
-
private static _isStopStreaming;
|
|
207
|
-
private static _layoutToString;
|
|
208
214
|
private _onParticipantSourcesUpdate;
|
|
209
215
|
private _onParticipantPromoted;
|
|
210
216
|
private _onChatRoomUpdated;
|
|
217
|
+
private _onSharedMovieUpdate;
|
|
218
|
+
private _onSharedMovieInfoStarted;
|
|
219
|
+
private _processSharedMovieInfo;
|
|
220
|
+
private _processConnectionSharedMovieInfo;
|
|
221
|
+
private _onSharedMovieInfoStopped;
|
|
222
|
+
private _onFeaturesPerRoleChanged;
|
|
211
223
|
private _waitForStreamIfNeeded;
|
|
212
224
|
private _matchStreamDescription;
|
|
213
225
|
private _getWaitingTime;
|
|
@@ -215,6 +227,7 @@ export default class Conversation extends EventEmitter {
|
|
|
215
227
|
private _checkAdminRole;
|
|
216
228
|
grantRoles(participantId: CompositeUserId, roles: UserRole[], revoke: boolean): Promise<void>;
|
|
217
229
|
muteParticipant(participantId: ParticipantId | null, muteStates: MuteStates, requestedMedia?: MediaOption[]): Promise<void>;
|
|
230
|
+
enableFeatureForRoles(feature: ConversationFeature, roles: UserRole[]): Promise<void>;
|
|
218
231
|
pinParticipant(participantId: ParticipantId, unpin: boolean): Promise<void>;
|
|
219
232
|
updateMediaModifiers(mediaModifiers: MediaModifiers): Promise<void>;
|
|
220
233
|
changeOptions(changes: {
|
|
@@ -231,11 +244,11 @@ export default class Conversation extends EventEmitter {
|
|
|
231
244
|
customData(data: JSONObject, participantId?: ParticipantId | null): Promise<void>;
|
|
232
245
|
createJoinLink(): Promise<string>;
|
|
233
246
|
removeJoinLink(): Promise<never>;
|
|
234
|
-
addMovie(movieId:
|
|
247
|
+
addMovie({ movieId, gain, metadata }: IAddMovieParams): Promise<{
|
|
235
248
|
movieId: string;
|
|
236
249
|
streamType: string;
|
|
237
250
|
}>;
|
|
238
|
-
updateMovie(
|
|
251
|
+
updateMovie(params: IUpdateMovieData): Promise<void>;
|
|
239
252
|
removeMovie(movieId: string): Promise<void>;
|
|
240
253
|
startStream(isRecord?: boolean, name?: string | null, movieId?: string | null, privacy?: 'PUBLIC' | 'FRIENDS' | 'DIRECT_LINK', groupId?: string | null): Promise<SignalingMessage>;
|
|
241
254
|
stopStream(): Promise<SignalingMessage>;
|
|
@@ -307,6 +320,9 @@ export default class Conversation extends EventEmitter {
|
|
|
307
320
|
private _updateDisplayLayoutFromCache;
|
|
308
321
|
private _setParticipantsStatus;
|
|
309
322
|
private _onJoinLinkChanged;
|
|
323
|
+
/** получили из сингналинга сообщение о реакции пользователей */
|
|
324
|
+
private _onFeedback;
|
|
325
|
+
private _isMe;
|
|
310
326
|
}
|
|
311
327
|
export declare class UpdateDisplayLayoutError extends Error {
|
|
312
328
|
readonly participantErrors: {
|
package/classes/MediaSource.d.ts
CHANGED
|
@@ -13,7 +13,8 @@ export declare const enum MediaSourceEvent {
|
|
|
13
13
|
export declare const enum MediaTrackKind {
|
|
14
14
|
'audio' = "audio",
|
|
15
15
|
'video' = "video",
|
|
16
|
-
'screen' = "screen"
|
|
16
|
+
'screen' = "screen",
|
|
17
|
+
'audioshare' = "audioshare"
|
|
17
18
|
}
|
|
18
19
|
export declare class MediaSource extends EventEmitter {
|
|
19
20
|
/** Стрим с камеры и микрофона пользователя */
|
|
@@ -21,6 +22,7 @@ export declare class MediaSource extends EventEmitter {
|
|
|
21
22
|
/** Последний сохраненный оригинальный видео трек с камеры */
|
|
22
23
|
private _trackVideoStreamBackup;
|
|
23
24
|
private _screenTrack;
|
|
25
|
+
private _audioShareTrack;
|
|
24
26
|
/** Трек для отправки в медиа-канал. Может отличаться при скриншаринге в дата-канал */
|
|
25
27
|
private _sendVideoTrack;
|
|
26
28
|
private _mediaSettings;
|
|
@@ -58,16 +60,19 @@ export declare class MediaSource extends EventEmitter {
|
|
|
58
60
|
private _changeAudioInput;
|
|
59
61
|
private _changeScreen;
|
|
60
62
|
private _disableScreenCapture;
|
|
63
|
+
private disableAudioShare;
|
|
64
|
+
private getSilentAudioShareTrack;
|
|
61
65
|
private _replaceLocalTrack;
|
|
62
66
|
private _stopLocalTrack;
|
|
63
67
|
private _videoEffect;
|
|
64
68
|
/** останавливает и удаляет сохраненный трек с камеры пользователя */
|
|
65
69
|
private _stopAndRemoveTrackVideoStreamBackup;
|
|
66
70
|
destroy(): void;
|
|
67
|
-
toggleScreenCapturing(
|
|
71
|
+
toggleScreenCapturing(captureScreen: boolean, captureAudio: boolean): Promise<void>;
|
|
68
72
|
toggleVideo(enabled: boolean): Promise<void>;
|
|
69
73
|
toggleAudio(enabled: boolean): Promise<void>;
|
|
70
74
|
setResolution(width: number, height: number): Promise<void>;
|
|
71
75
|
updateNoiseSuppression(): Promise<void>;
|
|
72
76
|
videoEffect(effect: IEffect | null): Promise<void>;
|
|
77
|
+
getAudioShareTrack(): MediaStreamTrack | null;
|
|
73
78
|
}
|
|
@@ -2,7 +2,9 @@ import { ParticipantStreamDescription } from '../types/ParticipantStreamDescript
|
|
|
2
2
|
import SignalingMessage from '../types/SignalingMessage';
|
|
3
3
|
export declare class ParticipantIdRegistry {
|
|
4
4
|
private streamDescriptionByCompactId;
|
|
5
|
+
private compactIdByStreamDescription;
|
|
5
6
|
getStreamDescription(compactedId: number): ParticipantStreamDescription | undefined;
|
|
7
|
+
getCompactId(streamDescription: string): number | undefined;
|
|
6
8
|
handleMessage(data: ArrayBuffer): SignalingMessage | null;
|
|
7
9
|
private _createParticipantSourcesUpdateNotification;
|
|
8
10
|
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import ParticipantLayout, { RequestKeyFrame, StopStream } from '../types/ParticipantLayout';
|
|
2
|
+
import SignalingMessage from '../types/SignalingMessage';
|
|
3
|
+
import { ParticipantIdRegistry } from './ParticipantIdRegistry';
|
|
4
|
+
import { PerfStatReport } from './transport/PerfStatReporter';
|
|
5
|
+
export declare class ProducerCommandSerializationService {
|
|
6
|
+
private participantIdRegistry;
|
|
7
|
+
setParticipantIdRegistry(participantIdRegistry: ParticipantIdRegistry): void;
|
|
8
|
+
serializeUpdateDisplayLayout(sequenceNumber: number, layouts: {
|
|
9
|
+
[key: string]: ParticipantLayout | StopStream | RequestKeyFrame;
|
|
10
|
+
}): ArrayBuffer;
|
|
11
|
+
private writeLayout;
|
|
12
|
+
private writeStreamDesc;
|
|
13
|
+
serializePerfStatReport(sequenceNumber: number, report: PerfStatReport): ArrayBuffer;
|
|
14
|
+
deserializeCommandResponse(data: BufferSource | Blob): Promise<SignalingMessage | undefined>;
|
|
15
|
+
private deserializeUpdateDisplayLayoutResponse;
|
|
16
|
+
private deserializeReportPerfStatResponse;
|
|
17
|
+
}
|
|
@@ -33,6 +33,7 @@ export default class ServerTransport extends EventEmitter {
|
|
|
33
33
|
private _disabledSenders;
|
|
34
34
|
private _rtpReceiversByStreamId;
|
|
35
35
|
private _producerSessionId;
|
|
36
|
+
private _newAudioShareTrack;
|
|
36
37
|
constructor(signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings);
|
|
37
38
|
getState(): TransportState;
|
|
38
39
|
updateStatisticsInterval(): void;
|
|
@@ -68,6 +69,7 @@ export default class ServerTransport extends EventEmitter {
|
|
|
68
69
|
private _detectStaleTracks;
|
|
69
70
|
private _allocateConsumer;
|
|
70
71
|
private _acceptProducer;
|
|
72
|
+
private handleTracks;
|
|
71
73
|
_onSignalingNotification(message: SignalingMessage): Promise<void>;
|
|
72
74
|
private _onProducerUpdated;
|
|
73
75
|
private _onAddTrack;
|
package/default/Api.d.ts
CHANGED
|
@@ -16,8 +16,13 @@ export default class Api extends BaseApi {
|
|
|
16
16
|
log(items: LogItem[]): void;
|
|
17
17
|
init(): void;
|
|
18
18
|
joinConversation(conversationId: string, isVideo?: boolean, chatId?: string): Promise<ConversationResponse>;
|
|
19
|
-
createConversation(conversationId: string, payload?: string, requireAuthToJoin?: boolean
|
|
20
|
-
|
|
19
|
+
createConversation(conversationId: string, payload?: string, requireAuthToJoin?: boolean, { onlyAdminCanShareMovie }?: {
|
|
20
|
+
onlyAdminCanShareMovie?: boolean;
|
|
21
|
+
}): Promise<ConversationResponse>;
|
|
22
|
+
startConversation(conversationId: string, ids?: OkUserId[], type?: CallType, isVideo?: boolean, payload?: string, joiningAllowed?: boolean, requireAuthToJoin?: boolean, { onlyAdminCanShareMovie }?: {
|
|
23
|
+
onlyAdminCanShareMovie?: boolean;
|
|
24
|
+
}): Promise<ConversationResponse>;
|
|
25
|
+
private _preareStartConversationData;
|
|
21
26
|
private _startConversation;
|
|
22
27
|
createJoinLink(conversationId: string): Promise<{
|
|
23
28
|
join_link: string;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/default/Signaling.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ import BaseSignaling, { AddParticipantParams } from '../abstract/BaseSignaling';
|
|
|
2
2
|
import { ParticipantIdRegistry } from '../classes/ParticipantIdRegistry';
|
|
3
3
|
import { PerfStatReport } from '../classes/transport/PerfStatReporter';
|
|
4
4
|
import { TransportTopology } from '../classes/transport/Transport';
|
|
5
|
+
import ConversationFeature from '../enums/ConversationFeature';
|
|
5
6
|
import ConversationOption from '../enums/ConversationOption';
|
|
6
7
|
import MediaOption from '../enums/MediaOption';
|
|
7
8
|
import RecordRole from '../enums/RecordRole';
|
|
@@ -11,8 +12,10 @@ import UserRole from '../enums/UserRole';
|
|
|
11
12
|
import { JSONObject } from '../static/Json';
|
|
12
13
|
import MediaModifiers from '../types/MediaModifiers';
|
|
13
14
|
import MediaSettings from '../types/MediaSettings';
|
|
15
|
+
import { IAddMovieParams, IUpdateMovieData } from '../types/MovieShare';
|
|
14
16
|
import MuteStates from '../types/MuteStates';
|
|
15
17
|
import { CompositeUserId, ParticipantId } from '../types/Participant';
|
|
18
|
+
import ParticipantLayout, { RequestKeyFrame, StopStream } from '../types/ParticipantLayout';
|
|
16
19
|
import { ParticipantListChunkParameters } from '../types/ParticipantListChunk';
|
|
17
20
|
import SignalingMessage from '../types/SignalingMessage';
|
|
18
21
|
import { WaitingParticipantId } from '../types/WaitingHall';
|
|
@@ -40,6 +43,7 @@ export default class Signaling extends BaseSignaling {
|
|
|
40
43
|
private producerNotificationDataChannel;
|
|
41
44
|
private producerCommandDataChannel;
|
|
42
45
|
private producerCommandDataChannelEnabled;
|
|
46
|
+
private producerCommandSerializationService;
|
|
43
47
|
private static readonly RECONNECT_DELAY;
|
|
44
48
|
private static readonly RECONNECT_MAX_DELAY;
|
|
45
49
|
private static readonly RECONNECT_MAX_COUNT;
|
|
@@ -91,11 +95,11 @@ export default class Signaling extends BaseSignaling {
|
|
|
91
95
|
changePriorities(priorities: {
|
|
92
96
|
[key: string]: number;
|
|
93
97
|
}): Promise<SignalingMessage | void>;
|
|
94
|
-
updateDisplayLayout(
|
|
95
|
-
[
|
|
98
|
+
updateDisplayLayout(layouts: {
|
|
99
|
+
[streamDesc: string]: ParticipantLayout | StopStream | RequestKeyFrame;
|
|
96
100
|
}): Promise<SignalingMessage>;
|
|
97
|
-
addMovie(data:
|
|
98
|
-
updateMovie(data:
|
|
101
|
+
addMovie(data: IAddMovieParams): Promise<SignalingMessage>;
|
|
102
|
+
updateMovie(data: IUpdateMovieData): Promise<SignalingMessage>;
|
|
99
103
|
removeMovie(data: any): Promise<SignalingMessage>;
|
|
100
104
|
startStream(data: any): Promise<SignalingMessage>;
|
|
101
105
|
stopStream(): Promise<SignalingMessage>;
|
|
@@ -109,6 +113,7 @@ export default class Signaling extends BaseSignaling {
|
|
|
109
113
|
customData(data: JSONObject, participantId: ParticipantId | null): Promise<SignalingMessage>;
|
|
110
114
|
grantRoles(participantId: CompositeUserId, roles: UserRole[], revoke: boolean): Promise<SignalingMessage>;
|
|
111
115
|
muteParticipant(participantId: ParticipantId | null, muteStates: MuteStates, requestedMedia: MediaOption[]): Promise<SignalingMessage>;
|
|
116
|
+
enableFeatureForRoles(feature: ConversationFeature, roles: UserRole[]): Promise<SignalingMessage>;
|
|
112
117
|
pinParticipant(participantId: ParticipantId, unpin: boolean): Promise<SignalingMessage>;
|
|
113
118
|
updateMediaModifiers(mediaModifiers: MediaModifiers): Promise<SignalingMessage>;
|
|
114
119
|
changeOptions(changes: {
|
|
@@ -116,6 +121,7 @@ export default class Signaling extends BaseSignaling {
|
|
|
116
121
|
}): Promise<SignalingMessage>;
|
|
117
122
|
getWaitingHall(fromId?: WaitingParticipantId | null, count?: number, backward?: boolean): Promise<SignalingMessage>;
|
|
118
123
|
promoteParticipant(participantId: CompositeUserId, demote?: boolean): Promise<SignalingMessage>;
|
|
124
|
+
feedback(key: string): Promise<SignalingMessage>;
|
|
119
125
|
/**
|
|
120
126
|
* Close a connection with a signaling server
|
|
121
127
|
*/
|
|
@@ -142,6 +148,9 @@ export default class Signaling extends BaseSignaling {
|
|
|
142
148
|
protected _reconnect(): void;
|
|
143
149
|
private _handleCommandResponse;
|
|
144
150
|
private _handleCommandsQueue;
|
|
151
|
+
private _serializeBinary;
|
|
152
|
+
private _serializeJson;
|
|
153
|
+
private _convertDisplayLayout;
|
|
145
154
|
protected _waitConnectionMessage(): void;
|
|
146
155
|
protected _stopWaitConnectionMessage(): void;
|
|
147
156
|
private _startDoctor;
|
|
@@ -4,7 +4,9 @@
|
|
|
4
4
|
declare enum ConversationOption {
|
|
5
5
|
REQUIRE_AUTH_TO_JOIN = "REQUIRE_AUTH_TO_JOIN",
|
|
6
6
|
AUDIENCE_MODE = "AUDIENCE_MODE",
|
|
7
|
-
WAITING_HALL = "WAITING_HALL"
|
|
7
|
+
WAITING_HALL = "WAITING_HALL",
|
|
8
|
+
ASR = "ASR",
|
|
9
|
+
FEEDBACK = "FEEDBACK"
|
|
8
10
|
}
|
|
9
11
|
export default ConversationOption;
|
|
10
12
|
export declare function compareOptions(oldOptions: ConversationOption[], newOptions: ConversationOption[]): boolean;
|
package/enums/HangupType.d.ts
CHANGED
|
@@ -16,6 +16,7 @@ declare enum HangupType {
|
|
|
16
16
|
CALLER_IS_BLOCKED = "CALLER_IS_BLOCKED",
|
|
17
17
|
NOT_FRIENDS = "NOT_FRIENDS",
|
|
18
18
|
CALLEE_IS_OFFLINE = "CALLEE_IS_OFFLINE",
|
|
19
|
+
CALLER_IS_REJECTED = "CALLER_IS_REJECTED",
|
|
19
20
|
UNKNOWN_ERROR = "UNKNOWN_ERROR",
|
|
20
21
|
UNSUPPORTED = "UNSUPPORTED",
|
|
21
22
|
OLD_VERSION = "OLD_VERSION",
|
|
@@ -23,6 +24,7 @@ declare enum HangupType {
|
|
|
23
24
|
EXTERNAL_API_ERROR = "EXTERNAL_API_ERROR",
|
|
24
25
|
SOCKET_CLOSED = "SOCKET_CLOSED",
|
|
25
26
|
ENDED = "ENDED",
|
|
26
|
-
KILLED_WITHOUT_DELETE = "KILLED_WITHOUT_DELETE"
|
|
27
|
+
KILLED_WITHOUT_DELETE = "KILLED_WITHOUT_DELETE",
|
|
28
|
+
ANOTHER_DEVICE = "ANOTHER_DEVICE"
|
|
27
29
|
}
|
|
28
30
|
export default HangupType;
|
package/enums/MediaOption.d.ts
CHANGED
|
@@ -24,6 +24,7 @@ declare enum SignalingCommandType {
|
|
|
24
24
|
CUSTOM_DATA = "custom-data",
|
|
25
25
|
GRANT_ROLES = "grant-roles",
|
|
26
26
|
MUTE_PARTICIPANT = "mute-participant",
|
|
27
|
+
ENABLE_FEATURE_FOR_ROLES = "enable-feature-for-roles",
|
|
27
28
|
PIN_PARTICIPANT = "pin-participant",
|
|
28
29
|
UPDATE_MEDIA_MODIFIERS = "update-media-modifiers",
|
|
29
30
|
CHANGE_OPTIONS = "change-options",
|
|
@@ -34,6 +35,7 @@ declare enum SignalingCommandType {
|
|
|
34
35
|
REQUEST_TEST_MODE = "request-test-mode",
|
|
35
36
|
ADD_MOVIE = "add-movie",
|
|
36
37
|
UPDATE_MOVIE = "update-movie",
|
|
37
|
-
REMOVE_MOVIE = "remove-movie"
|
|
38
|
+
REMOVE_MOVIE = "remove-movie",
|
|
39
|
+
FEEDBACK = "feedback"
|
|
38
40
|
}
|
|
39
41
|
export default SignalingCommandType;
|
|
@@ -35,6 +35,12 @@ declare enum SignalingNotification {
|
|
|
35
35
|
PROMOTE_PARTICIPANT = "promote-participant",
|
|
36
36
|
CHAT_ROOM_UPDATED = "chat-room-updated",
|
|
37
37
|
PROMOTION_APPROVED = "promotion-approved",
|
|
38
|
-
JOIN_LINK_CHANGED = "join-link-changed"
|
|
38
|
+
JOIN_LINK_CHANGED = "join-link-changed",
|
|
39
|
+
FEEDBACK = "feedback",
|
|
40
|
+
MOVIE_UPDATE_NOTIFICATION = "movie-update-notification",
|
|
41
|
+
MOVIE_SHARE_INFO = "movie-share-info",
|
|
42
|
+
MOVIE_SHARE_STARTED = "movie-share-started",
|
|
43
|
+
MOVIE_SHARE_STOPPED = "movie-share-stopped",
|
|
44
|
+
FEATURES_PER_ROLE_CHANGED = "features-per-role-changed"
|
|
39
45
|
}
|
|
40
46
|
export default SignalingNotification;
|
package/package.json
CHANGED
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
|
@@ -7,9 +7,12 @@ import ConversationOption from '../enums/ConversationOption';
|
|
|
7
7
|
import FatalError from '../enums/FatalError';
|
|
8
8
|
import MediaOption from '../enums/MediaOption';
|
|
9
9
|
import UserRole from '../enums/UserRole';
|
|
10
|
+
import { IFeaturesPerRole } from '../types/ConversationFeature';
|
|
10
11
|
import { ExternalId, ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalParticipantListMarkers } from '../types/ExternalId';
|
|
12
|
+
import { IFeedbackExternal } from '../types/Feedback';
|
|
11
13
|
import MediaModifiers from '../types/MediaModifiers';
|
|
12
14
|
import MediaSettings from '../types/MediaSettings';
|
|
15
|
+
import { IOnRemoteMovieData, ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
|
|
13
16
|
import MuteStates from '../types/MuteStates';
|
|
14
17
|
import { ParticipantStateMapped } from '../types/Participant';
|
|
15
18
|
import { DebugMessageType } from './Debug';
|
|
@@ -72,10 +75,31 @@ declare namespace External {
|
|
|
72
75
|
* Если сервер закончил стримить собеседника, вместо стрима будет передан null
|
|
73
76
|
*
|
|
74
77
|
* @param userId
|
|
75
|
-
* @param
|
|
76
|
-
|
|
78
|
+
* @param data
|
|
79
|
+
*/
|
|
80
|
+
function onRemoteLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
|
|
81
|
+
/**
|
|
82
|
+
* Получен собственный стрим лайв.
|
|
83
|
+
* Если сервер закончил стримить собеседника, вместо стрима будет передан null
|
|
84
|
+
*
|
|
85
|
+
* @param userId
|
|
86
|
+
* @param data
|
|
87
|
+
*/
|
|
88
|
+
function onLocalLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
|
|
89
|
+
/**
|
|
90
|
+
* Получено обновление стрима или лайва от собеседника.
|
|
91
|
+
*
|
|
92
|
+
* @param userId
|
|
93
|
+
* @param data
|
|
77
94
|
*/
|
|
78
|
-
function
|
|
95
|
+
function onRemoteLiveUpdate(userId: ExternalParticipantId, data: ISharedMovieState): void;
|
|
96
|
+
/**
|
|
97
|
+
* Получено обновление собственного стрима или лайва.
|
|
98
|
+
*
|
|
99
|
+
* @param userId
|
|
100
|
+
* @param data
|
|
101
|
+
*/
|
|
102
|
+
function onLocalLiveUpdate(userId: ExternalParticipantId, data: ISharedMovieState): void;
|
|
79
103
|
/**
|
|
80
104
|
* Получен стрим с экрана собеседника.
|
|
81
105
|
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
@@ -106,6 +130,41 @@ declare namespace External {
|
|
|
106
130
|
* @param markers
|
|
107
131
|
*/
|
|
108
132
|
function onRemoteMediaSettings(userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers): void;
|
|
133
|
+
/**
|
|
134
|
+
* Изменились данные собственного стрима
|
|
135
|
+
*
|
|
136
|
+
* @param userId
|
|
137
|
+
* @param mediaSettings
|
|
138
|
+
*/
|
|
139
|
+
function onLocalMediaSettings(userId: ExternalParticipantId, mediaSettings: MediaSettings): void;
|
|
140
|
+
/**
|
|
141
|
+
* Полученны данные по стримам (лайв/мувик) от собеседника
|
|
142
|
+
*
|
|
143
|
+
* @param userId
|
|
144
|
+
* @param sharedMovieInfo
|
|
145
|
+
*/
|
|
146
|
+
function onRemoteSharedMovieInfo(userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo): void;
|
|
147
|
+
/**
|
|
148
|
+
* Полученны данные по остановленным стримам (лайв/мувик) от собеседника
|
|
149
|
+
*
|
|
150
|
+
* @param userId
|
|
151
|
+
* @param sharedMovieStoppedInfo
|
|
152
|
+
*/
|
|
153
|
+
function onRemoteSharedMovieStoppedInfo(userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo): void;
|
|
154
|
+
/**
|
|
155
|
+
* Полученны данные по собственным стримам (лайв/мувик)
|
|
156
|
+
*
|
|
157
|
+
* @param userId
|
|
158
|
+
* @param sharedMovieInfo
|
|
159
|
+
*/
|
|
160
|
+
function onLocalSharedMovieInfo(userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo): void;
|
|
161
|
+
/**
|
|
162
|
+
* Полученны данные по собственным остановленным стримам (лайв/мувик)
|
|
163
|
+
*
|
|
164
|
+
* @param userId
|
|
165
|
+
* @param sharedMovieStoppedInfo
|
|
166
|
+
*/
|
|
167
|
+
function onLocalSharedMovieStoppedInfo(userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo): void;
|
|
109
168
|
/**
|
|
110
169
|
* Добавили участника
|
|
111
170
|
*
|
|
@@ -187,8 +246,10 @@ declare namespace External {
|
|
|
187
246
|
* @param unmute Разрешение включить устройство
|
|
188
247
|
* @param userId Пользователь, для которого изменились разрешения или `null` для текущего пользователя
|
|
189
248
|
* @param adminId Пользователь, который изменил разрешения
|
|
249
|
+
* @param stateUpdated Если `true`, значит глобальное/персональное состояние изменилось и поля `muteStates`/`unmuteOptions` содержат обновления, если `false`, значит, эти поля не имеют значения
|
|
250
|
+
* @param requestedMedia Какие устройства попросили влючить участника
|
|
190
251
|
*/
|
|
191
|
-
function onMuteStates(muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll?: boolean, unmute?: boolean, userId?: ExternalParticipantId | null, adminId?: ExternalParticipantId | null): void;
|
|
252
|
+
function onMuteStates(muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll?: boolean, unmute?: boolean, userId?: ExternalParticipantId | null, adminId?: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]): void;
|
|
192
253
|
/**
|
|
193
254
|
* Изменились роли собеседника в звонке
|
|
194
255
|
*
|
|
@@ -353,5 +414,15 @@ declare namespace External {
|
|
|
353
414
|
* @param joinLink токен присоединения к звонку
|
|
354
415
|
*/
|
|
355
416
|
function onJoinLinkChanged(joinLink: string): void;
|
|
417
|
+
/**
|
|
418
|
+
* Получена новая реакция
|
|
419
|
+
*/
|
|
420
|
+
function onFeedback(feedback: IFeedbackExternal[]): void;
|
|
421
|
+
/**
|
|
422
|
+
* Изменилось состояние пермиссий фич в звонке
|
|
423
|
+
*
|
|
424
|
+
* @param featuresPerRole Информация о доступных фичах по ролям
|
|
425
|
+
*/
|
|
426
|
+
function onFeaturesPerRoleChanged(featuresPerRole: IFeaturesPerRole): void;
|
|
356
427
|
}
|
|
357
428
|
export default External;
|