@vkontakte/calls-sdk 2.6.2-dev.c05fdf6.0 → 2.6.2-dev.c4e9bf0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -15,6 +15,7 @@ import { JSONObject } from '../static/Json';
15
15
  import { ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalUserId } from '../types/ExternalId';
16
16
  import MediaModifiers from '../types/MediaModifiers';
17
17
  import { IVideoDimentions } from '../types/MediaSettings';
18
+ import { IAddMovieParams } from '../types/MovieShare';
18
19
  import MuteStates from '../types/MuteStates';
19
20
  import { CompositeUserId, IGetParticipantsParameters, OkUserId, ParticipantId } from '../types/Participant';
20
21
  import { ParticipantLayout } from '../types/ParticipantLayout';
@@ -206,6 +207,9 @@ export default class Conversation extends EventEmitter {
206
207
  private _onParticipantSourcesUpdate;
207
208
  private _onParticipantPromoted;
208
209
  private _onChatRoomUpdated;
210
+ private _onSharedMovieUpdate;
211
+ private _onSharedMovieInfoStarted;
212
+ private _onSharedMovieInfoStopped;
209
213
  private _waitForStreamIfNeeded;
210
214
  private _matchStreamDescription;
211
215
  private _getWaitingTime;
@@ -229,11 +233,11 @@ export default class Conversation extends EventEmitter {
229
233
  customData(data: JSONObject, participantId?: ParticipantId | null): Promise<void>;
230
234
  createJoinLink(): Promise<string>;
231
235
  removeJoinLink(): Promise<never>;
232
- addMovie(movieId: string): Promise<{
236
+ addMovie({ movieId, gain }: IAddMovieParams): Promise<{
233
237
  movieId: string;
234
238
  streamType: string;
235
239
  }>;
236
- updateMovie(movieId: string, gain?: number, offset?: string, pause?: boolean): Promise<void>;
240
+ updateMovie(movieId: string, gain?: number, offset?: number, pause?: boolean): Promise<void>;
237
241
  removeMovie(movieId: string): Promise<void>;
238
242
  startStream(isRecord?: boolean, name?: string | null, movieId?: string | null, privacy?: 'PUBLIC' | 'FRIENDS' | 'DIRECT_LINK', groupId?: string | null): Promise<SignalingMessage>;
239
243
  stopStream(): Promise<SignalingMessage>;
@@ -11,6 +11,7 @@ import UserRole from '../enums/UserRole';
11
11
  import { JSONObject } from '../static/Json';
12
12
  import MediaModifiers from '../types/MediaModifiers';
13
13
  import MediaSettings from '../types/MediaSettings';
14
+ import { IAddMovieParams, ISharedMovieState } from '../types/MovieShare';
14
15
  import MuteStates from '../types/MuteStates';
15
16
  import { CompositeUserId, ParticipantId } from '../types/Participant';
16
17
  import ParticipantLayout, { RequestKeyFrame, StopStream } from '../types/ParticipantLayout';
@@ -96,8 +97,8 @@ export default class Signaling extends BaseSignaling {
96
97
  updateDisplayLayout(layouts: {
97
98
  [streamDesc: string]: ParticipantLayout | StopStream | RequestKeyFrame;
98
99
  }): Promise<SignalingMessage>;
99
- addMovie(data: any): Promise<SignalingMessage>;
100
- updateMovie(data: any): Promise<SignalingMessage>;
100
+ addMovie(data: IAddMovieParams): Promise<SignalingMessage>;
101
+ updateMovie(data: ISharedMovieState): Promise<SignalingMessage>;
101
102
  removeMovie(data: any): Promise<SignalingMessage>;
102
103
  startStream(data: any): Promise<SignalingMessage>;
103
104
  stopStream(): Promise<SignalingMessage>;
@@ -35,6 +35,10 @@ 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
+ MOVIE_UPDATE_NOTIFICATION = "movie-update-notification",
40
+ MOVIE_SHARE_INFO = "movie-share-info",
41
+ MOVIE_SHARE_STARTED = "movie-share-started",
42
+ MOVIE_SHARE_STOPPED = "movie-share-stopped"
39
43
  }
40
44
  export default SignalingNotification;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vkontakte/calls-sdk",
3
- "version": "2.6.2-dev.c05fdf6.0",
3
+ "version": "2.6.2-dev.c4e9bf0.0",
4
4
  "author": "vk.com",
5
5
  "description": "Library for video calls based on the vk.com platform",
6
6
  "homepage": "https://vk.com",
@@ -10,6 +10,7 @@ import UserRole from '../enums/UserRole';
10
10
  import { ExternalId, ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalParticipantListMarkers } from '../types/ExternalId';
11
11
  import MediaModifiers from '../types/MediaModifiers';
12
12
  import MediaSettings from '../types/MediaSettings';
13
+ import { ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
13
14
  import MuteStates from '../types/MuteStates';
14
15
  import { ParticipantStateMapped } from '../types/Participant';
15
16
  import { DebugMessageType } from './Debug';
@@ -76,6 +77,29 @@ declare namespace External {
76
77
  * @param stream
77
78
  */
78
79
  function onRemoteLive(userId: ExternalParticipantId, streamName: string, stream: MediaStream | null): void;
80
+ /**
81
+ * Получен собственный стрим лайв.
82
+ * Если сервер закончил стримить собеседника, вместо стрима будет передан null
83
+ *
84
+ * @param userId
85
+ * @param streamName
86
+ * @param stream
87
+ */
88
+ function onLocalLive(userId: ExternalParticipantId, streamName: string, stream: MediaStream | null): void;
89
+ /**
90
+ * Получено обновление стрима или лайва от собеседника.
91
+ *
92
+ * @param userId
93
+ * @param data
94
+ */
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,10 +246,8 @@ declare namespace External {
187
246
  * @param unmute Разрешение включить устройство
188
247
  * @param userId Пользователь, для которого изменились разрешения или `null` для текущего пользователя
189
248
  * @param adminId Пользователь, который изменил разрешения
190
- * @param stateUpdated Если `true`, значит глобальное/персональное состояние изменилось и поля `muteStates`/`unmuteOptions` содержат обновления, если `false`, значит, эти поля не имеют значения
191
- * @param requestedMedia Какие устройства попросили влючить участника
192
249
  */
193
- function onMuteStates(muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll?: boolean, unmute?: boolean, userId?: ExternalParticipantId | null, adminId?: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]): void;
250
+ function onMuteStates(muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll?: boolean, unmute?: boolean, userId?: ExternalParticipantId | null, adminId?: ExternalParticipantId | null): void;
194
251
  /**
195
252
  * Изменились роли собеседника в звонке
196
253
  *
@@ -11,6 +11,7 @@ import { ExternalId, ExternalParticipant, ExternalParticipantId, ExternalPartici
11
11
  import IceServer from '../types/IceServer';
12
12
  import MediaModifiers from '../types/MediaModifiers';
13
13
  import MediaSettings from '../types/MediaSettings';
14
+ import { ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
14
15
  import MuteStates from '../types/MuteStates';
15
16
  import { ParticipantStateMapped } from '../types/Participant';
16
17
  import AuthData from './AuthData';
@@ -301,6 +302,19 @@ export declare type ParamsObject = {
301
302
  * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
302
303
  */
303
304
  onRemoteLive?: (userId: ExternalParticipantId, streamId: string, stream: MediaStream | null) => void;
305
+ /**
306
+ * Получен собственный стрим трансляция или мувик.
307
+ * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
308
+ */
309
+ onLocalLive?: (userId: ExternalParticipantId, streamId: string, stream: MediaStream | null) => void;
310
+ /**
311
+ * Получено обновление стрима или лайва от собеседника.
312
+ */
313
+ onRemoteLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
314
+ /**
315
+ * Получено обновление собственного стрима или лайва.
316
+ */
317
+ onLocalLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
304
318
  /**
305
319
  * Начат звонок
306
320
  */
@@ -313,6 +327,26 @@ export declare type ParamsObject = {
313
327
  * Изменились данные стрима собеседника
314
328
  */
315
329
  onRemoteMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers) => void;
330
+ /**
331
+ * Изменились данные стрима собеседника
332
+ */
333
+ onLocalMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings) => void;
334
+ /**
335
+ * Полученны данные по стримам (лайв/мувик) от собеседника
336
+ */
337
+ onRemoteSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
338
+ /**
339
+ * Полученны данные по остановленным стримам (лайв/мувик) от собеседника
340
+ */
341
+ onRemoteSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
342
+ /**
343
+ * Полученны данные по собственным стримам (лайв/мувик)
344
+ */
345
+ onLocalSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
346
+ /**
347
+ * Полученны данные по собственным остановленным стримам (лайв/мувик)
348
+ */
349
+ onLocalSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
316
350
  /**
317
351
  * Добавили участника
318
352
  */
@@ -357,7 +391,7 @@ export declare type ParamsObject = {
357
391
  /**
358
392
  * Изменились состояния устройств пользователя или разрешения включать камеру/микрофон
359
393
  */
360
- onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null, stateUpdated?: boolean, requestedMedia?: MediaOption[]) => void;
394
+ onMuteStates?: (muteStates: MuteStates, unmuteOptions: MediaOption[], mediaOptions: MediaOption[], muteAll: boolean, unmute: boolean, userId: ExternalParticipantId | null, adminId: ExternalParticipantId | null) => void;
361
395
  /**
362
396
  * Изменились роли собеседника в звонке
363
397
  */
package/static/Utils.d.ts CHANGED
@@ -62,5 +62,6 @@ declare namespace Utils {
62
62
  function participantMarkerCompare(marker1: ExternalParticipantListMarker | undefined, marker2: ExternalParticipantListMarker | undefined): number;
63
63
  /** убирает все ключи со значением `V` на 1 уровне */
64
64
  function objectFilterOutValues<T extends Record<string, V>, V = unknown>(obj: T, value?: V | V[]): Partial<T>;
65
+ const setImmediate: (fn: VoidFunction) => VoidFunction;
65
66
  }
66
67
  export default Utils;
@@ -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[];
@@ -19,7 +19,7 @@ export declare type MediaSettings = {
19
19
  export declare type VideoStreamInfo = {
20
20
  id: string;
21
21
  source: string;
22
- vkMovieId?: string;
22
+ externalMovieId?: string;
23
23
  };
24
24
  export default MediaSettings;
25
25
  export declare function compareMediaSettings(ms1: MediaSettings, ms2: MediaSettings): boolean;
@@ -0,0 +1,32 @@
1
+ import { OkUserId, CompositeUserId } from './Participant';
2
+ import { MediaType } from './ParticipantStreamDescription';
3
+ export interface IAddMovieParams {
4
+ movieId: string;
5
+ gain?: number;
6
+ }
7
+ export declare type ISharedMovieStateResponse = [number, number, boolean, number, number];
8
+ export interface ISharedMovieState {
9
+ participantId: CompositeUserId;
10
+ gain?: number;
11
+ pause?: boolean;
12
+ offset?: number;
13
+ duration?: number;
14
+ }
15
+ export interface ISharedMovieInfo {
16
+ movieId: OkUserId;
17
+ initiatorId: CompositeUserId;
18
+ title: string;
19
+ source: MediaType;
20
+ externalMovieId: string;
21
+ duration: number;
22
+ thumbnailNormal: string;
23
+ thumbnailMedium: string;
24
+ thumbnailBig: string;
25
+ thumbnailHigh: string;
26
+ thumbnailHd: string;
27
+ }
28
+ export interface ISharedMovieStoppedInfo {
29
+ movieId: OkUserId;
30
+ initiatorId: CompositeUserId;
31
+ source: MediaType;
32
+ }
@@ -4,6 +4,7 @@ import UserRole from '../enums/UserRole';
4
4
  import { ParticipantStatus } from '../static/External';
5
5
  import MediaSettings from '../types/MediaSettings';
6
6
  import { ExternalId, ExternalParticipantId, ExternalParticipantListMarkers } from './ExternalId';
7
+ import { ISharedMovieInfo } from './MovieShare';
7
8
  import MuteStates from './MuteStates';
8
9
  import ParticipantLayout from './ParticipantLayout';
9
10
  /**
@@ -55,6 +56,7 @@ export interface Participant {
55
56
  unmuteOptions: MediaOption[];
56
57
  observedIds: CompositeUserId[];
57
58
  markers?: ExternalParticipantListMarkers;
59
+ movieShareInfos?: ISharedMovieInfo[];
58
60
  }
59
61
  export interface IGetParticipantsParameters {
60
62
  externalIds: ExternalId[];
@@ -9,6 +9,7 @@ import UserRole from '../enums/UserRole';
9
9
  import UserType from '../enums/UserType';
10
10
  import MediaModifiers from './MediaModifiers';
11
11
  import MediaSettings from './MediaSettings';
12
+ import { ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from './MovieShare';
12
13
  import MuteStates from './MuteStates';
13
14
  import { CompositeUserId, OkUserId, ParticipantId, ParticipantListMarker as ParticipantParticipantListMarker, ParticipantListMarkers, ParticipantListType as ParticipantParticipantListType } from './Participant';
14
15
  import VideoSettings from './VideoSettings';
@@ -54,6 +55,7 @@ declare namespace SignalingMessage {
54
55
  unmuteOptions?: MediaOption[];
55
56
  markers?: ParticipantListMarkers;
56
57
  observedIds?: CompositeUserId[];
58
+ movieShareInfos?: ISharedMovieInfo[];
57
59
  }
58
60
  export interface ParticipantListChunk extends Notification {
59
61
  participants: (Participant & Required<Pick<Participant, 'markers'>>)[];
@@ -148,8 +150,6 @@ declare namespace SignalingMessage {
148
150
  muteStates: MuteStates;
149
151
  unmuteOptions?: MediaOption[];
150
152
  mediaOptions: MediaOption[];
151
- requestedMedia?: MediaOption[];
152
- stateUpdated?: boolean;
153
153
  unmute?: boolean;
154
154
  muteAll?: boolean;
155
155
  }
@@ -279,6 +279,14 @@ declare namespace SignalingMessage {
279
279
  export interface JoinLinkChanged extends Notification {
280
280
  joinLink: string;
281
281
  }
282
+ export interface SharedMovieState extends Notification {
283
+ data: ISharedMovieState[];
284
+ }
285
+ export interface SharedMovieInfo extends Notification {
286
+ movieShareInfo: ISharedMovieInfo;
287
+ }
288
+ export interface SharedMovieStoppedInfo extends Notification, ISharedMovieStoppedInfo {
289
+ }
282
290
  export {};
283
291
  }
284
292
  export default SignalingMessage;