@vkontakte/calls-sdk 2.6.2-dev.d52f142.0 → 2.6.2-dev.e500a34.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';
@@ -151,6 +152,7 @@ export default class Conversation extends EventEmitter {
151
152
  private _processConnection;
152
153
  private _prepareParticipants;
153
154
  private _onConversationParticipantListChunk;
155
+ private _createParticipantListChunk;
154
156
  private _participantListChunkToExternalChunk;
155
157
  private _registerConnectionParticipants;
156
158
  private _registerParticipants;
@@ -206,6 +208,9 @@ export default class Conversation extends EventEmitter {
206
208
  private _onParticipantSourcesUpdate;
207
209
  private _onParticipantPromoted;
208
210
  private _onChatRoomUpdated;
211
+ private _onSharedMovieUpdate;
212
+ private _onSharedMovieInfoStarted;
213
+ private _onSharedMovieInfoStopped;
209
214
  private _waitForStreamIfNeeded;
210
215
  private _matchStreamDescription;
211
216
  private _getWaitingTime;
@@ -229,11 +234,11 @@ export default class Conversation extends EventEmitter {
229
234
  customData(data: JSONObject, participantId?: ParticipantId | null): Promise<void>;
230
235
  createJoinLink(): Promise<string>;
231
236
  removeJoinLink(): Promise<never>;
232
- addMovie(movieId: string): Promise<{
237
+ addMovie({ movieId, gain, metadata }: IAddMovieParams): Promise<{
233
238
  movieId: string;
234
239
  streamType: string;
235
240
  }>;
236
- updateMovie(movieId: string, gain?: number, offset?: string, pause?: boolean): Promise<void>;
241
+ updateMovie(movieId: string, gain?: number, offset?: number, pause?: boolean): Promise<void>;
237
242
  removeMovie(movieId: string): Promise<void>;
238
243
  startStream(isRecord?: boolean, name?: string | null, movieId?: string | null, privacy?: 'PUBLIC' | 'FRIENDS' | 'DIRECT_LINK', groupId?: string | null): Promise<SignalingMessage>;
239
244
  stopStream(): Promise<SignalingMessage>;
@@ -4,7 +4,6 @@ export default class ScreenCaptureSender {
4
4
  private _destroyed;
5
5
  private _needKeyframe;
6
6
  private readonly DATA_SIZE;
7
- private readonly _timerWorker;
8
7
  constructor(track: MediaStreamTrack, datachannel: RTCDataChannel);
9
8
  private _requestFrame;
10
9
  private _wrapHeader;
package/default/Api.d.ts CHANGED
@@ -18,6 +18,7 @@ export default class Api extends BaseApi {
18
18
  joinConversation(conversationId: string, isVideo?: boolean, chatId?: string): Promise<ConversationResponse>;
19
19
  createConversation(conversationId: string, payload?: string, requireAuthToJoin?: boolean): Promise<ConversationResponse>;
20
20
  startConversation(conversationId: string, ids?: OkUserId[], type?: CallType, isVideo?: boolean, payload?: string, joiningAllowed?: boolean, requireAuthToJoin?: boolean): Promise<ConversationResponse>;
21
+ private _preareStartConversationData;
21
22
  private _startConversation;
22
23
  createJoinLink(conversationId: string): Promise<{
23
24
  join_link: string;
@@ -0,0 +1 @@
1
+ export {};
@@ -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>;
@@ -4,7 +4,8 @@
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"
8
9
  }
9
10
  export default ConversationOption;
10
11
  export declare function compareOptions(oldOptions: ConversationOption[], newOptions: ConversationOption[]): boolean;
@@ -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;
@@ -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.d52f142.0",
3
+ "version": "2.6.2-dev.e500a34.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 { IOnRemoteMovieData, 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';
@@ -72,10 +73,31 @@ declare namespace External {
72
73
  * Если сервер закончил стримить собеседника, вместо стрима будет передан null
73
74
  *
74
75
  * @param userId
75
- * @param streamName
76
- * @param stream
76
+ * @param data
77
+ */
78
+ function onRemoteLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
79
+ /**
80
+ * Получен собственный стрим лайв.
81
+ * Если сервер закончил стримить собеседника, вместо стрима будет передан null
82
+ *
83
+ * @param userId
84
+ * @param data
85
+ */
86
+ function onLocalLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
87
+ /**
88
+ * Получено обновление стрима или лайва от собеседника.
89
+ *
90
+ * @param userId
91
+ * @param data
92
+ */
93
+ function onRemoteLiveUpdate(userId: ExternalParticipantId, data: ISharedMovieState): void;
94
+ /**
95
+ * Получено обновление собственного стрима или лайва.
96
+ *
97
+ * @param userId
98
+ * @param data
77
99
  */
78
- function onRemoteLive(userId: ExternalParticipantId, streamName: string, stream: MediaStream | null): void;
100
+ function onLocalLiveUpdate(userId: ExternalParticipantId, data: ISharedMovieState): void;
79
101
  /**
80
102
  * Получен стрим с экрана собеседника.
81
103
  * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
@@ -106,6 +128,41 @@ declare namespace External {
106
128
  * @param markers
107
129
  */
108
130
  function onRemoteMediaSettings(userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers): void;
131
+ /**
132
+ * Изменились данные собственного стрима
133
+ *
134
+ * @param userId
135
+ * @param mediaSettings
136
+ */
137
+ function onLocalMediaSettings(userId: ExternalParticipantId, mediaSettings: MediaSettings): void;
138
+ /**
139
+ * Полученны данные по стримам (лайв/мувик) от собеседника
140
+ *
141
+ * @param userId
142
+ * @param sharedMovieInfo
143
+ */
144
+ function onRemoteSharedMovieInfo(userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo): void;
145
+ /**
146
+ * Полученны данные по остановленным стримам (лайв/мувик) от собеседника
147
+ *
148
+ * @param userId
149
+ * @param sharedMovieStoppedInfo
150
+ */
151
+ function onRemoteSharedMovieStoppedInfo(userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo): void;
152
+ /**
153
+ * Полученны данные по собственным стримам (лайв/мувик)
154
+ *
155
+ * @param userId
156
+ * @param sharedMovieInfo
157
+ */
158
+ function onLocalSharedMovieInfo(userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo): void;
159
+ /**
160
+ * Полученны данные по собственным остановленным стримам (лайв/мувик)
161
+ *
162
+ * @param userId
163
+ * @param sharedMovieStoppedInfo
164
+ */
165
+ function onLocalSharedMovieStoppedInfo(userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo): void;
109
166
  /**
110
167
  * Добавили участника
111
168
  *
@@ -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 { IOnRemoteMovieData, 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';
@@ -43,6 +44,11 @@ export declare type ParamsObject = {
43
44
  * Домен, чтобы попасть в тестовую группу. Для тестирования экспериментальных улучшений существуют отдельные сервера, чтобы собирать фидбек и уже потом раскатывать на всех юзеров. Если передать сюда специальный ключ, то конверсейшн будет обрабатываться на таком сервере.
44
45
  */
45
46
  domain: string;
47
+ /**
48
+ * Домен, куда будет ходить Ok api за данными
49
+ * @hidden
50
+ */
51
+ externalDomain: string;
46
52
  iceServers: IceServer[];
47
53
  wssBase: string;
48
54
  wssToken: string;
@@ -300,7 +306,20 @@ export declare type ParamsObject = {
300
306
  * Получен стрим трансляция или мувик от собеседника.
301
307
  * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
302
308
  */
303
- onRemoteLive?: (userId: ExternalParticipantId, streamId: string, stream: MediaStream | null) => void;
309
+ onRemoteLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
310
+ /**
311
+ * Получен собственный стрим трансляция или мувик.
312
+ * Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
313
+ */
314
+ onLocalLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
315
+ /**
316
+ * Получено обновление стрима или лайва от собеседника.
317
+ */
318
+ onRemoteLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
319
+ /**
320
+ * Получено обновление собственного стрима или лайва.
321
+ */
322
+ onLocalLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
304
323
  /**
305
324
  * Начат звонок
306
325
  */
@@ -313,6 +332,26 @@ export declare type ParamsObject = {
313
332
  * Изменились данные стрима собеседника
314
333
  */
315
334
  onRemoteMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers) => void;
335
+ /**
336
+ * Изменились данные стрима собеседника
337
+ */
338
+ onLocalMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings) => void;
339
+ /**
340
+ * Полученны данные по стримам (лайв/мувик) от собеседника
341
+ */
342
+ onRemoteSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
343
+ /**
344
+ * Полученны данные по остановленным стримам (лайв/мувик) от собеседника
345
+ */
346
+ onRemoteSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
347
+ /**
348
+ * Полученны данные по собственным стримам (лайв/мувик)
349
+ */
350
+ onLocalSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
351
+ /**
352
+ * Полученны данные по собственным остановленным стримам (лайв/мувик)
353
+ */
354
+ onLocalSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
316
355
  /**
317
356
  * Добавили участника
318
357
  */
@@ -503,6 +542,7 @@ export default abstract class Params {
503
542
  static get anonymToken(): string;
504
543
  static set anonymToken(value: string);
505
544
  static get domain(): string;
545
+ static get externalDomain(): string;
506
546
  static get iceServers(): IceServer[];
507
547
  static set iceServers(value: IceServer[]);
508
548
  static get wssBase(): string;
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,42 @@
1
+ import { OkUserId, CompositeUserId } from './Participant';
2
+ import { MediaType } from './ParticipantStreamDescription';
3
+ export interface IMoviePreview {
4
+ url: string;
5
+ width: number;
6
+ height: number;
7
+ }
8
+ export interface IAddMovieParams {
9
+ movieId: string;
10
+ gain?: number;
11
+ metadata?: {
12
+ title?: string;
13
+ thumbnails?: IMoviePreview[];
14
+ };
15
+ }
16
+ export declare type ISharedMovieStateResponse = [number, number, boolean, number, number];
17
+ export interface ISharedMovieState {
18
+ participantId: CompositeUserId;
19
+ gain?: number;
20
+ pause?: boolean;
21
+ offset?: number;
22
+ duration?: number;
23
+ }
24
+ export interface ISharedMovieInfo {
25
+ movieId: OkUserId;
26
+ initiatorId: CompositeUserId;
27
+ title: string;
28
+ source: MediaType;
29
+ externalMovieId: string;
30
+ duration: number;
31
+ thumbnails: IMoviePreview[];
32
+ }
33
+ export interface ISharedMovieStoppedInfo {
34
+ movieId: OkUserId;
35
+ initiatorId: CompositeUserId;
36
+ source: MediaType;
37
+ }
38
+ export interface IOnRemoteMovieData {
39
+ streamName: string;
40
+ stream: MediaStream | null;
41
+ mediaType: MediaType;
42
+ }
@@ -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'>>)[];
@@ -277,6 +279,14 @@ declare namespace SignalingMessage {
277
279
  export interface JoinLinkChanged extends Notification {
278
280
  joinLink: string;
279
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
+ }
280
290
  export {};
281
291
  }
282
292
  export default SignalingMessage;