@vkontakte/calls-sdk 2.8.11-dev.5500645b.0 → 2.8.11-dev.69b107ee.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.
Files changed (72) hide show
  1. package/CallsSDK.d.ts +52 -14
  2. package/abstract/BaseApi.d.ts +5 -5
  3. package/abstract/BaseSignaling.d.ts +2 -3
  4. package/calls-sdk.cjs.js +16 -14
  5. package/calls-sdk.esm.js +11741 -14
  6. package/classes/AudioFix.d.ts +5 -1
  7. package/classes/AudioOutput.d.ts +5 -1
  8. package/classes/Conversation.d.ts +9 -6
  9. package/classes/ConversationResponseValidator.d.ts +3 -0
  10. package/classes/DebugInfo.d.ts +3 -0
  11. package/classes/DisplayLayoutRequester.d.ts +39 -0
  12. package/classes/ExternalIdCache.d.ts +19 -0
  13. package/classes/MediaSource.d.ts +5 -1
  14. package/classes/ParticipantIdRegistry.d.ts +3 -0
  15. package/classes/ProducerCommandSerializationService.d.ts +3 -0
  16. package/classes/SignalingActor.d.ts +3 -1
  17. package/classes/SpeakerDetector.d.ts +2 -1
  18. package/classes/SpecListener.d.ts +5 -1
  19. package/classes/StatsLogger.d.ts +29 -0
  20. package/classes/VideoEffectsFpsLimiter.d.ts +3 -0
  21. package/classes/asr/AsrReceiver.d.ts +3 -1
  22. package/classes/codec/LibVPxDecoder.d.ts +3 -0
  23. package/classes/codec/LibVPxEncoder.d.ts +3 -1
  24. package/classes/codec/WebCodecsDecoder.d.ts +3 -0
  25. package/classes/codec/WebCodecsEncoder.d.ts +3 -1
  26. package/classes/codec/WorkerBase.d.ts +5 -0
  27. package/classes/screenshare/BaseStreamBuilder.d.ts +4 -1
  28. package/classes/screenshare/CanvasRenderer.d.ts +3 -1
  29. package/classes/screenshare/ScreenCaptureReceiver.d.ts +7 -1
  30. package/classes/screenshare/ScreenCaptureSender.d.ts +5 -1
  31. package/classes/screenshare/ScreenCongestionControl.d.ts +3 -1
  32. package/classes/screenshare/StreamBuilder.d.ts +5 -1
  33. package/classes/screenshare/TrackGeneratorRenderer.d.ts +3 -1
  34. package/classes/screenshare/WebmBuilder.d.ts +3 -1
  35. package/classes/stat/CodecStatsAggregator.d.ts +7 -7
  36. package/classes/stat/ConversationStats.d.ts +21 -0
  37. package/classes/stat/StatAggregator.d.ts +6 -6
  38. package/classes/stat/StatFirstMediaReceived.d.ts +6 -2
  39. package/classes/stat/StatPings.d.ts +9 -9
  40. package/classes/stat/StatScreenShareFirstFrame.d.ts +3 -1
  41. package/classes/stat/StatSignalingCommands.d.ts +8 -8
  42. package/classes/transport/BaseTransport.d.ts +1 -1
  43. package/classes/transport/DirectStatReporter.d.ts +3 -1
  44. package/classes/transport/DirectTransport.d.ts +9 -6
  45. package/classes/transport/PerfStatReporter.d.ts +5 -1
  46. package/classes/transport/ServerTransport.d.ts +10 -10
  47. package/classes/transport/Transport.d.ts +12 -30
  48. package/default/Api.d.ts +6 -14
  49. package/default/Signaling.d.ts +40 -45
  50. package/default/SignalingTransport.d.ts +68 -0
  51. package/enums/HangupType.d.ts +2 -1
  52. package/enums/TransportState.d.ts +10 -0
  53. package/enums/TransportTopology.d.ts +5 -0
  54. package/package.json +1 -1
  55. package/static/Debug.d.ts +27 -8
  56. package/static/External.d.ts +3 -4
  57. package/static/Params.d.ts +14 -17
  58. package/static/Utils.d.ts +3 -2
  59. package/static/WebRTCUtils.d.ts +7 -4
  60. package/types/Conversation.d.ts +1 -1
  61. package/types/FastStart.d.ts +1 -0
  62. package/types/ParticipantLayout.d.ts +33 -0
  63. package/types/PerfStatReporter.d.ts +2 -1
  64. package/types/PushData.d.ts +3 -0
  65. package/types/SignalingMessage.d.ts +5 -1
  66. package/types/Statistics.d.ts +1 -5
  67. package/types/WebTransport.d.ts +5 -0
  68. package/utils/DebugStorage.d.ts +100 -1
  69. package/classes/Logger.d.ts +0 -41
  70. package/classes/stat/EventMetricsService.d.ts +0 -9
  71. package/static/ConversationDebugLogger.d.ts +0 -13
  72. package/static/DebugVideoStats.d.ts +0 -22
@@ -1,12 +1,12 @@
1
1
  import { ICallStatLog } from '../../types/PerfStatReporter';
2
2
  import { IEventualStatLog } from '../../types/IEventualStatLog';
3
+ import StatsLogger from '../StatsLogger';
3
4
  export declare class StatAggregator {
4
- private static _instance;
5
+ private readonly _logger;
5
6
  private readonly _eventualLogs;
6
- static create(): void;
7
- static logCallStat(params: ICallStatLog): void;
7
+ constructor(logger: StatsLogger);
8
+ logCallStat(params: ICallStatLog): void;
8
9
  /** @link https://wiki.odkl.ru/pages/viewpage.action?pageId=100892588 */
9
- static logEventualStat(params: IEventualStatLog): void;
10
- static destroy(): void;
11
- private _destroy;
10
+ logEventualStat(params: IEventualStatLog): void;
11
+ destroy(): void;
12
12
  }
@@ -1,21 +1,25 @@
1
- import { TransportTopology } from '../transport/Transport';
1
+ import TransportTopology from '../../enums/TransportTopology';
2
+ import { StatAggregator } from './StatAggregator';
2
3
  /** связанный с операцией `first_media_received` тип логируемого звонка */
3
4
  declare enum ECallType {
4
5
  DirectOutgoing = "direct_outgoing",
5
6
  DirectIncoming = "direct_incoming",
7
+ DirectJoin = "direct_join",
6
8
  ServerIncoming = "server_incoming",
7
9
  ServerJoinServer = "server_join_server",
8
10
  ServerChangeTopology = "server_change_topology"
9
11
  }
10
12
  export declare class StatFirstMediaReceived {
13
+ private readonly _statAggregator;
11
14
  /** уже поставили засечку на приём звонка */
12
15
  protected _isCallMarked: boolean;
13
16
  protected _isFinished: boolean;
14
17
  protected _callType: ECallType | null;
18
+ constructor(statAggregator: StatAggregator);
15
19
  markAcceptCall(topology: TransportTopology): void;
16
20
  markAcceptedCall(topology?: TransportTopology): void;
17
- markParticipantJoined(topology: TransportTopology): void;
18
21
  markOnJoin(topology: TransportTopology): void;
22
+ markTopologyChanged(topology: TransportTopology): void;
19
23
  private mark;
20
24
  measure(): void;
21
25
  }
@@ -1,17 +1,17 @@
1
1
  import { SignalingTransportType } from '../../enums/SignalingTransportStat';
2
- import { TransportTopology } from '../transport/Transport';
2
+ import StatsLogger from '../StatsLogger';
3
+ import TransportTopology from '../../enums/TransportTopology';
3
4
  export declare class StatPings {
4
- private static _instance?;
5
- static create(): void;
5
+ private readonly _logger;
6
+ private trackerByTransport;
7
+ private lastSeen;
8
+ constructor(logger: StatsLogger);
6
9
  /**
7
10
  * Вызывать при входящем ping в сигналингу.
8
11
  * Будет произведен расчет времени между пингами.
9
12
  */
10
- static mark(transport: SignalingTransportType): void;
13
+ mark(transport: SignalingTransportType): void;
11
14
  /** Отправляем данные в стату */
12
- static logMetrics(topology?: TransportTopology): void;
13
- static destroy(): void;
14
- private trackerByTransport;
15
- private lastSeen;
16
- private _destroy;
15
+ logMetrics(topology?: TransportTopology): void;
16
+ destroy(): void;
17
17
  }
@@ -1,7 +1,9 @@
1
1
  import { ParticipantId } from '../../types/Participant';
2
+ import { StatAggregator } from './StatAggregator';
2
3
  export declare class StatScreenShareFirstFrame {
3
4
  protected readonly _participantId: ParticipantId;
5
+ private readonly _statAggregator;
4
6
  protected _firstFrameReceived: boolean;
5
- constructor(participantId: ParticipantId);
7
+ constructor(participantId: ParticipantId, statAggregator: StatAggregator | null);
6
8
  measure(width: number, height: number): void;
7
9
  }
@@ -1,12 +1,12 @@
1
1
  import { SignalingTransportType } from '../../enums/SignalingTransportStat';
2
- import { TransportTopology } from '../transport/Transport';
2
+ import StatsLogger from '../StatsLogger';
3
+ import TransportTopology from '../../enums/TransportTopology';
3
4
  export declare class StatSignalingCommands {
4
- private static _instance?;
5
- static create(): void;
6
- static mark(command: string, time: number, transport: SignalingTransportType): void;
7
- /** Отправляем данные в стату */
8
- static logMetrics(topology?: TransportTopology): void;
9
- static destroy(): void;
5
+ private readonly _logger;
10
6
  private trackerByCommand;
11
- private _destroy;
7
+ constructor(logger: StatsLogger);
8
+ mark(command: string, time: number, transport: SignalingTransportType): void;
9
+ /** Отправляем данные в стату */
10
+ logMetrics(topology?: TransportTopology): void;
11
+ destroy(): void;
12
12
  }
@@ -1,7 +1,7 @@
1
1
  import BaseSignaling from '../../abstract/BaseSignaling';
2
+ import TransportState from '../../enums/TransportState';
2
3
  import EventEmitter from '../EventEmitter';
3
4
  import { MediaSource } from '../MediaSource';
4
- import { TransportState } from './Transport';
5
5
  export default abstract class BaseTransport extends EventEmitter {
6
6
  protected readonly _signaling: BaseSignaling;
7
7
  protected readonly _mediaSource: MediaSource;
@@ -1,4 +1,5 @@
1
1
  import BaseSignaling from '../../abstract/BaseSignaling';
2
+ import { type DebugLogger } from '../../static/Debug';
2
3
  import { StatResult } from '../../types/Statistics';
3
4
  import EventEmitter from '../EventEmitter';
4
5
  import { WeightedAverage } from '../stat/WeightedAverage';
@@ -30,7 +31,8 @@ export default class DirectStatReporter extends EventEmitter {
30
31
  private readonly _networkLimits;
31
32
  private _lastStatSentTimestamp;
32
33
  private _currentState;
33
- constructor(signaling: BaseSignaling);
34
+ private readonly _debug;
35
+ constructor(signaling: BaseSignaling, debug?: DebugLogger);
34
36
  private _calcRttRating;
35
37
  private _calcLossRating;
36
38
  private _calcBitrateRating;
@@ -1,15 +1,16 @@
1
1
  import type { AnimojiReceiver, AnimojiSender } from '@vkontakte/calls-vmoji';
2
2
  import BaseSignaling from '../../abstract/BaseSignaling';
3
+ import { type DebugLogger } from '../../static/Debug';
3
4
  import { ParticipantId } from '../../types/Participant';
4
5
  import ServerSettings from '../../types/ServerSettings';
6
+ import StatsLogger from '../StatsLogger';
5
7
  import { MediaSource } from '../MediaSource';
8
+ import { CodecStatsAggregator } from '../stat/CodecStatsAggregator';
9
+ import { StatAggregator } from '../stat/StatAggregator';
6
10
  import BaseTransport from './BaseTransport';
7
11
  export default class DirectTransport extends BaseTransport {
8
12
  private readonly _participantId;
9
13
  private readonly _isMaster;
10
- private _hasOutboundVideoDebug;
11
- private _hasInboundVideoDebug;
12
- private _videoDebugBytes;
13
14
  private _remoteSDP;
14
15
  private _remoteCandidates;
15
16
  private _lastRemoteSDP;
@@ -37,7 +38,11 @@ export default class DirectTransport extends BaseTransport {
37
38
  private _lastBadConnection;
38
39
  private _perfStatReporter;
39
40
  private _directStatReporter;
40
- constructor(participantId: ParticipantId, isMaster: boolean, signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings);
41
+ private readonly _debug;
42
+ private readonly _logger;
43
+ private readonly _statAggregator;
44
+ private readonly _codecStatsAggregator;
45
+ constructor(participantId: ParticipantId, isMaster: boolean, signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings, debug?: DebugLogger, logger?: StatsLogger | null, statAggregator?: StatAggregator | null, codecStatsAggregator?: CodecStatsAggregator | null);
41
46
  get participantId(): ParticipantId;
42
47
  updateStatisticsInterval(): void;
43
48
  private _isDeadConnection;
@@ -70,8 +75,6 @@ export default class DirectTransport extends BaseTransport {
70
75
  private static _patchRemoteDescription;
71
76
  private _onReplacedTrack;
72
77
  private _startStatInterval;
73
- private _reportVideoStreamDebug;
74
- private _getVideoDebugBitrate;
75
78
  /**
76
79
  * Check SVC support
77
80
  * @see https://webrtc.internaut.com/mc/
@@ -1,5 +1,7 @@
1
1
  import BaseSignaling from '../../abstract/BaseSignaling';
2
+ import { type DebugLogger } from '../../static/Debug';
2
3
  import EventEmitter from '../EventEmitter';
4
+ import { StatAggregator } from '../stat/StatAggregator';
3
5
  import DirectTransport from './DirectTransport';
4
6
  import ServerTransport from './ServerTransport';
5
7
  export default class PerfStatReporter extends EventEmitter {
@@ -10,7 +12,9 @@ export default class PerfStatReporter extends EventEmitter {
10
12
  private _screenShareStats;
11
13
  private _signaling;
12
14
  private readonly _directTopology;
13
- constructor(transport: ServerTransport | DirectTransport, signaling: BaseSignaling, directTopology?: boolean);
15
+ private readonly _debug;
16
+ private readonly _statAggregator;
17
+ constructor(transport: ServerTransport | DirectTransport, signaling: BaseSignaling, statAggregator?: StatAggregator | null, directTopology?: boolean, debug?: DebugLogger);
14
18
  destroy(): void;
15
19
  static getEstimatedPerformanceIndex(): number;
16
20
  private _handleStats;
@@ -1,13 +1,14 @@
1
1
  import type { AnimojiReceiver, AnimojiSender } from '@vkontakte/calls-vmoji';
2
2
  import BaseSignaling from '../../abstract/BaseSignaling';
3
+ import { type DebugLogger } from '../../static/Debug';
3
4
  import { ParticipantId } from '../../types/Participant';
4
5
  import ServerSettings from '../../types/ServerSettings';
6
+ import StatsLogger from '../StatsLogger';
5
7
  import { MediaSource } from '../MediaSource';
8
+ import { CodecStatsAggregator } from '../stat/CodecStatsAggregator';
9
+ import { StatAggregator } from '../stat/StatAggregator';
6
10
  import BaseTransport from './BaseTransport';
7
11
  export default class ServerTransport extends BaseTransport {
8
- private _hasOutboundVideoDebug;
9
- private _inboundVideoDebugParticipants;
10
- private _videoDebugBytes;
11
12
  private _producerNotification;
12
13
  private _producerCommand;
13
14
  private _producerScreen;
@@ -39,11 +40,14 @@ export default class ServerTransport extends BaseTransport {
39
40
  private _participantIdRegistry;
40
41
  private _disabledSenders;
41
42
  private _rtpReceiversByStreamId;
42
- private _participantIdByVideoTrackId;
43
43
  private _producerSessionId;
44
44
  private _newAudioShareTrack;
45
45
  private _simulcastInfo;
46
- constructor(signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings);
46
+ private readonly _debug;
47
+ private readonly _logger;
48
+ private readonly _statAggregator;
49
+ private readonly _codecStatsAggregator;
50
+ constructor(signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings, debug?: DebugLogger, logger?: StatsLogger | null, statAggregator?: StatAggregator | null, codecStatsAggregator?: CodecStatsAggregator | null);
47
51
  updateStatisticsInterval(): void;
48
52
  open(observer?: boolean): void;
49
53
  close(error?: Error): void;
@@ -78,10 +82,6 @@ export default class ServerTransport extends BaseTransport {
78
82
  private _stopSettingsInterval;
79
83
  private _collectStat;
80
84
  private _reportStats;
81
- private _reportVideoStreamDebug;
82
- private _getVideoDebugStreamId;
83
- private _getVideoDebugTrackId;
84
- private _getVideoDebugBitrate;
85
85
  private _detectStaleTracks;
86
86
  private _allocateConsumer;
87
87
  private _processOffer;
@@ -96,7 +96,7 @@ export default class ServerTransport extends BaseTransport {
96
96
  private _onAsrTranscription;
97
97
  private _onProducerUpdated;
98
98
  private _onAddTrack;
99
- static _onSignalingStateChange(pc: RTCPeerConnection, event: any): void;
99
+ private _onSignalingStateChange;
100
100
  private _onConnectionStateChange;
101
101
  private _onReplacedTrack;
102
102
  private _onSourcesChanged;
@@ -1,10 +1,15 @@
1
1
  import type { AnimojiSvgData, RGBTuple } from '@vkontakte/calls-vmoji';
2
2
  import BaseSignaling from '../../abstract/BaseSignaling';
3
- import { VideoStreamDebugDirection } from '../../static/DebugVideoStats';
3
+ import TransportState from '../../enums/TransportState';
4
+ import TransportTopology from '../../enums/TransportTopology';
5
+ import { type DebugLogger } from '../../static/Debug';
4
6
  import { ParticipantId } from '../../types/Participant';
5
7
  import ServerSettings from '../../types/ServerSettings';
6
8
  import EventEmitter from '../EventEmitter';
9
+ import StatsLogger from '../StatsLogger';
7
10
  import { MediaSource } from '../MediaSource';
11
+ import { CodecStatsAggregator } from '../stat/CodecStatsAggregator';
12
+ import { StatAggregator } from '../stat/StatAggregator';
8
13
  export declare const enum TransportEvent {
9
14
  REMOTE_TRACK_ADDED = "REMOTE_TRACK_ADDED",
10
15
  REMOTE_TRACK_REMOVED = "REMOTE_TRACK_REMOVED",
@@ -22,34 +27,8 @@ export declare const enum TransportEvent {
22
27
  ASR_TRANSCRIPTION = "ASR_TRANSCRIPTION",
23
28
  ANIMOJI_STREAM = "ANIMOJI_STREAM",
24
29
  ANIMOJI_ERROR = "ANIMOJI_ERROR",
25
- SCREEN_SHARING_STAT = "SCREEN_SHARING_STAT",
26
- VIDEO_STREAM_DEBUG = "VIDEO_STREAM_DEBUG"
30
+ SCREEN_SHARING_STAT = "SCREEN_SHARING_STAT"
27
31
  }
28
- export declare const enum TransportState {
29
- IDLE = "IDLE",
30
- OPENED = "OPENED",
31
- CONNECTING = "CONNECTING",
32
- RECONNECTING = "RECONNECTING",
33
- CONNECTED = "CONNECTED",
34
- CLOSED = "CLOSED",
35
- FAILED = "FAILED"
36
- }
37
- export declare const enum TransportTopology {
38
- DIRECT = "DIRECT",
39
- SERVER = "SERVER"
40
- }
41
- export type VideoStreamDebugEvent = {
42
- direction: VideoStreamDebugDirection;
43
- streamId?: ParticipantId;
44
- trackId?: string;
45
- mimeType?: string;
46
- width?: number;
47
- height?: number;
48
- frameRate?: number;
49
- bitrate?: number;
50
- packetsLost?: number;
51
- clear?: boolean;
52
- };
53
32
  export declare class Transport extends EventEmitter {
54
33
  private readonly _signaling;
55
34
  private readonly _mediaSource;
@@ -65,7 +44,11 @@ export declare class Transport extends EventEmitter {
65
44
  private _localState;
66
45
  private _animojiReceiver;
67
46
  private _animojiSender;
68
- constructor(topology: TransportTopology, signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings);
47
+ private readonly _debug;
48
+ private readonly _logger;
49
+ private readonly _statAggregator;
50
+ private readonly _codecStatsAggregator;
51
+ constructor(topology: TransportTopology, signaling: BaseSignaling, mediaSource: MediaSource, serverSettings: ServerSettings, debug?: DebugLogger, logger?: StatsLogger | null, statAggregator?: StatAggregator | null, codecStatsAggregator?: CodecStatsAggregator | null);
69
52
  updateSettings(settings: ServerSettings): void;
70
53
  updateStatisticsInterval(): void;
71
54
  allocate(participantId: ParticipantId, isMaster?: boolean): void;
@@ -99,7 +82,6 @@ export declare class Transport extends EventEmitter {
99
82
  private _onPeerConnectionClosed;
100
83
  private _onServerAudioMixStall;
101
84
  private _onRemoteDataStats;
102
- private _onVideoStreamDebug;
103
85
  private _onRemoteTrackAdded;
104
86
  private _onRemoteTrackRemoved;
105
87
  private _onAsrTranscription;
package/default/Api.d.ts CHANGED
@@ -1,21 +1,19 @@
1
- import BaseApi, { ClientEvent, ClientStats, LogItem } from '../abstract/BaseApi';
1
+ import BaseApi, { ClientEvent, ClientStats } from '../abstract/BaseApi';
2
2
  import CallType from '../enums/CallType';
3
3
  import HangupType from '../enums/HangupType';
4
4
  import ConversationParams from '../types/ConversationParams';
5
5
  import ConversationResponse from '../types/ConversationResponse';
6
6
  import { ExternalId, ExternalParticipantId, ExternalUserId } from '../types/ExternalId';
7
7
  import { CompositeUserId, OkUserId, ParticipantId } from '../types/Participant';
8
+ import PushData from '../types/PushData';
8
9
  export default class Api extends BaseApi {
9
10
  private _userId;
10
11
  private _uuid;
11
- private _externalUidsCache;
12
- private _decorativeIdToInitialId;
13
- private _initialIdToDecorativeId;
12
+ private _idCache;
14
13
  private _callUnsafe;
15
14
  protected _call(method: string, data?: any, noSession?: boolean): Promise<any>;
16
15
  userId(participantId: ParticipantId): Promise<ExternalParticipantId>;
17
16
  authorize(): Promise<void>;
18
- log(items: LogItem[]): void;
19
17
  logClientStats(items: ClientStats[]): void;
20
18
  logClientEvents(items: ClientEvent[]): void;
21
19
  uploadDebugLogs(conversationId: string, startTime: number, endTime: number, log: string): Promise<void>;
@@ -26,7 +24,7 @@ export default class Api extends BaseApi {
26
24
  audioOnly?: boolean;
27
25
  waitForAdmin?: boolean;
28
26
  closedConversation?: boolean;
29
- }, speakerIds?: OkUserId[]): Promise<ConversationResponse>;
27
+ }, externalIds?: ExternalId[]): Promise<ConversationResponse>;
30
28
  startConversation(conversationId: string, ids?: OkUserId[], type?: CallType, isVideo?: boolean, payload?: string, joiningAllowed?: boolean, requireAuthToJoin?: boolean, { onlyAdminCanShareMovie, waitForAdmin }?: {
31
29
  onlyAdminCanShareMovie?: boolean;
32
30
  waitForAdmin?: boolean;
@@ -43,19 +41,13 @@ export default class Api extends BaseApi {
43
41
  }>;
44
42
  getAnonymTokenByLink(joinLink: string, username?: string): Promise<string>;
45
43
  joinConversationByLink(joinLink: string, isVideo?: boolean, observedIds?: ExternalUserId[], payload?: string): Promise<ConversationResponse>;
46
- /**
47
- * NB: Не сохраняет порядок возвращаемых ID
48
- * Этот метод принимает именно ExternalId, т.к. для OkUserId не принципиально наличие deviceIdx
49
- * @hidden
50
- */
51
- getOkIdsByExternalIds(externalIds: ExternalId[]): Promise<OkUserId[]>;
52
- getParticipantIdsByExternalIds(externalIds: ExternalId[]): Promise<Map<ExternalId, ParticipantId>>;
53
44
  /**
54
45
  * NB: Не сохраняет порядок возвращаемых ID
55
46
  * @hidden
56
47
  */
57
48
  getExternalIdsByOkIds(uids: OkUserId[]): Promise<ExternalParticipantId[]>;
58
49
  getCachedOkIdByExternalId(externalId: ExternalId): ParticipantId | null;
50
+ getCachedRawOkIdByExternalId(externalId: ExternalId): OkUserId | null;
59
51
  cacheExternalId(participantId: OkUserId | CompositeUserId | ParticipantId, externalId: ExternalParticipantId): void;
60
52
  mapDecorativeId(decorativeId: OkUserId | CompositeUserId | ParticipantId, initialId: OkUserId | CompositeUserId | ParticipantId): void;
61
53
  unmapDecorativeId(initialId: OkUserId | CompositeUserId | ParticipantId): void;
@@ -65,9 +57,9 @@ export default class Api extends BaseApi {
65
57
  getUserId(): OkUserId | null;
66
58
  setUserId(userId: OkUserId): void;
67
59
  hangupConversation(conversationId: string, reason?: HangupType): void;
68
- sendUserFeedbackStats(conversationId: string, userResponse: number, reason?: string, groupCallUsersCount?: number): void;
69
60
  removeHistoryRecords(recordIds: number[]): Promise<void>;
70
61
  cleanup(): void;
71
62
  private _getExternalIdsByOkIds;
72
63
  getServerTime(): Promise<number>;
64
+ getInbounds(): Promise<PushData[]>;
73
65
  }
@@ -1,13 +1,17 @@
1
1
  import BaseSignaling, { AddParticipantParams } from '../abstract/BaseSignaling';
2
+ import StatsLogger from '../classes/StatsLogger';
2
3
  import { ParticipantIdRegistry } from '../classes/ParticipantIdRegistry';
3
4
  import { SharingStatReport } from '../classes/screenshare/SharingStatReport';
4
- import { TransportTopology } from '../classes/transport/Transport';
5
+ import { StatAggregator } from '../classes/stat/StatAggregator';
6
+ import { StatPings } from '../classes/stat/StatPings';
7
+ import { StatSignalingCommands } from '../classes/stat/StatSignalingCommands';
8
+ import TransportTopology from '../enums/TransportTopology';
5
9
  import ConversationFeature from '../enums/ConversationFeature';
6
10
  import ConversationOption from '../enums/ConversationOption';
7
11
  import MediaOption from '../enums/MediaOption';
8
- import SignalingCommandType from '../enums/SignalingCommandType';
9
12
  import SignalingConnectionType from '../enums/SignalingConnectionType';
10
13
  import UserRole from '../enums/UserRole';
14
+ import { type DebugLogger } from '../static/Debug';
11
15
  import { JSONObject } from '../static/Json';
12
16
  import { IAsrStartParams, IAsrStopParams } from '../types/Asr';
13
17
  import { ChangeSimulcast } from '../types/ChangeSimulcast';
@@ -21,42 +25,39 @@ import ParticipantLayout, { RequestKeyFrame, StopStream } from '../types/Partici
21
25
  import { ParticipantListChunkParameters } from '../types/ParticipantListChunk';
22
26
  import { StreamDescriptionString } from '../types/ParticipantStreamDescription';
23
27
  import { PerfStatReport } from '../types/PerfStatReporter';
24
- import SignalingMessage, { GetParticipantsSignalingResponse, GetRoomsSignalingResponse, SignalingSuccessResponse } from '../types/SignalingMessage';
25
- import { IPublishStreamData, IRecordConfData, IStartStreamData, IStopStreamData } from '../types/Streams';
28
+ import SignalingMessage, { GetParticipantsSignalingResponse, GetRoomsSignalingResponse } from '../types/SignalingMessage';
29
+ import { IPublishStreamData, IStartStreamData, IStopStreamData } from '../types/Streams';
26
30
  export default class Signaling extends BaseSignaling {
27
- private socket;
28
- protected sequence: number;
31
+ private transport;
32
+ private sequence;
29
33
  private lastStamp;
30
34
  private websocketCommandsQueue;
31
35
  private datachannelCommandsQueue;
32
36
  private incomingCache;
33
37
  private responseHandlers;
34
38
  private connectionType;
35
- private reconnectCount;
36
- private endpoint;
37
- private wtEndpoint;
38
- protected conversationResolve: Function | null;
39
- protected conversationReject: Function | null;
39
+ private conversationResolve;
40
+ private conversationReject;
40
41
  private connected;
41
42
  private listenersReady;
42
- private postfix;
43
- protected peerId: number | null;
44
- protected conversationId: string | null;
45
- private reconnectTimer;
43
+ private peerId;
44
+ private conversationId;
46
45
  private connectionMessageWaitTimer;
47
- private doctorTimer;
48
46
  private participantIdRegistry;
49
47
  private producerNotificationDataChannel;
50
48
  private producerCommandDataChannel;
51
49
  private producerCommandDataChannelEnabled;
52
50
  private producerCommandSerializationService;
53
- private static get RECONNECT_DELAY();
54
- private static get RECONNECT_MAX_DELAY();
55
- private static get RECONNECT_MAX_COUNT();
51
+ private readonly _debug;
52
+ private readonly _logger;
53
+ private readonly _statAggregator;
54
+ private readonly _statPings;
55
+ private readonly _statSignalingCommands;
56
56
  private static get WAIT_CONNECTION_DELAY();
57
57
  private static get WAIT_RESPONSE_DELAY();
58
- private static get WAIT_MESSAGE_DELAY();
59
58
  get ready(): boolean;
59
+ constructor(debug?: DebugLogger, logger?: StatsLogger | null, statAggregator?: StatAggregator | null, statPings?: StatPings | null, statSignalingCommands?: StatSignalingCommands | null);
60
+ setAbortSignal(signal: AbortSignal | undefined): void;
60
61
  setEndpoint(endpoint: string): void;
61
62
  setWebTransportEndpoint(endpoint: string | null): void;
62
63
  setConversationId(conversationId: string): void;
@@ -72,15 +73,6 @@ export default class Signaling extends BaseSignaling {
72
73
  * Open a connection with a signaling server
73
74
  */
74
75
  connect(connectionType: SignalingConnectionType): Promise<SignalingMessage.Connection>;
75
- /**
76
- * Send a command to a signaling server
77
- */
78
- protected _send<T extends SignalingSuccessResponse>(command: SignalingCommandType, params?: any, needResponse?: boolean, retryCount?: number): Promise<T>;
79
- /**
80
- * Send a raw command to a signaling server
81
- */
82
- protected _sendRaw<T extends SignalingSuccessResponse>(command: SignalingCommandType, params?: any, needResponse?: boolean, retryCount?: number): Promise<T>;
83
- private _isDataChannelCommand;
84
76
  getNextCommandSequenceNumber(): number;
85
77
  hangup(reason: string): Promise<SignalingMessage | void>;
86
78
  sendCandidate(participantId: ParticipantId, candidate: RTCIceCandidate): Promise<SignalingMessage>;
@@ -120,7 +112,6 @@ export default class Signaling extends BaseSignaling {
120
112
  startStream(data: IStartStreamData): Promise<SignalingMessage>;
121
113
  stopStream(data?: IStopStreamData): Promise<SignalingMessage>;
122
114
  publishStream(data?: IPublishStreamData): Promise<SignalingMessage>;
123
- recordSetConf(conf?: IRecordConfData): Promise<SignalingMessage>;
124
115
  getRecordStatus(): Promise<SignalingMessage>;
125
116
  switchTopology(topology: TransportTopology, force?: boolean): Promise<SignalingMessage>;
126
117
  requestRealloc(): Promise<SignalingMessage>;
@@ -164,32 +155,36 @@ export default class Signaling extends BaseSignaling {
164
155
  startAsr(params: IAsrStartParams): Promise<SignalingMessage>;
165
156
  stopAsr(params?: IAsrStopParams): Promise<SignalingMessage>;
166
157
  requestAsr(request: boolean): Promise<SignalingMessage>;
167
- protected _connect(connectionType: SignalingConnectionType, useWebTransport: boolean): void;
168
- protected _disconnect(code?: number): void;
158
+ /**
159
+ * Send a command to a signaling server
160
+ */
161
+ private _send;
162
+ /**
163
+ * Send a raw command to a signaling server
164
+ */
165
+ private _sendRaw;
166
+ private _isDataChannelCommand;
169
167
  private _onOpen;
170
168
  private _onMessage;
171
- protected _handleMessage(message: SignalingMessage): void;
169
+ private _handleMessage;
172
170
  private _handleErrorMessage;
173
- protected _handleCachedMessages(): void;
171
+ private _handleCachedMessages;
174
172
  private _throwError;
175
173
  private _onError;
176
- protected _onClose(event: CloseEvent): void;
177
- protected _closeSocket(error?: Error | null): void;
178
- protected _reconnect(): void;
174
+ private _serializeErrorEvent;
175
+ private _onClose;
176
+ private _closeSocket;
179
177
  private _handleCommandResponse;
180
178
  private _handleCommandsQueue;
181
179
  private _startResponseTimer;
182
180
  private _serializeBinary;
183
181
  private _serializeJson;
184
182
  private _convertDisplayLayout;
185
- protected _waitConnectionMessage(): void;
186
- protected _stopWaitConnectionMessage(): void;
187
- /**
188
- * Отвечает за timeout логику в WebSocket, если неполучаем никаких сообщений в течении WAIT_MESSAGE_DELAY, то запускаем реконнект
189
- */
190
- private _startDoctor;
191
- private _stopDoctor;
192
- private isWebTransportAvailable;
183
+ private _waitConnectionMessage;
184
+ private _stopWaitConnectionMessage;
185
+ private _onTransportFailed;
186
+ private _onTransportReconnectScheduled;
187
+ private _onTransportConnectionDead;
193
188
  private _getSocketType;
194
189
  private _markTransportStat;
195
190
  private _logTransportStat;
@@ -0,0 +1,68 @@
1
+ import SignalingConnectionType from '../enums/SignalingConnectionType';
2
+ import { SignalingTransportType } from '../enums/SignalingTransportStat';
3
+ export declare enum SignalingTransportFailure {
4
+ EMPTY_ENDPOINT = "EMPTY_ENDPOINT",
5
+ NETWORK_ERROR = "NETWORK_ERROR",
6
+ ABORTED = "ABORTED"
7
+ }
8
+ export type SignalingTransportFailedEvent = {
9
+ failure: SignalingTransportFailure;
10
+ message: string;
11
+ remote?: boolean;
12
+ };
13
+ export type SignalingTransportReconnectEvent = {
14
+ count: number;
15
+ delay: number;
16
+ };
17
+ export type SignalingTransportHandlers = {
18
+ onOpen: () => void;
19
+ onMessage: (event: MessageEvent) => void;
20
+ onError: (event: Event) => void;
21
+ onClose: (event: CloseEvent) => void;
22
+ onFailed: (event: SignalingTransportFailedEvent) => void;
23
+ onReconnectScheduled: (event: SignalingTransportReconnectEvent) => void;
24
+ onConnectionDead: () => void;
25
+ };
26
+ export default class SignalingTransport {
27
+ private readonly handlers;
28
+ private socket;
29
+ private endpoint;
30
+ private wtEndpoint;
31
+ private peerId;
32
+ private lastStamp;
33
+ private connectionType;
34
+ private reconnectCount;
35
+ private reconnectTimer;
36
+ private doctorTimer;
37
+ private forceWebSocket;
38
+ private abortSignal;
39
+ private manualClose;
40
+ private currentType;
41
+ constructor(handlers: SignalingTransportHandlers);
42
+ get readyState(): number | null;
43
+ get type(): SignalingTransportType;
44
+ setEndpoint(endpoint: string): void;
45
+ setWebTransportEndpoint(endpoint: string | null): void;
46
+ setPeerId(peerId: number | null): void;
47
+ setLastStamp(lastStamp: number): void;
48
+ setAbortSignal(signal?: AbortSignal): void;
49
+ resetReconnectCount(): void;
50
+ connect(connectionType: SignalingConnectionType): void;
51
+ close(code?: number): void;
52
+ send(data: string | ArrayBuffer): void;
53
+ private _connect;
54
+ private _connectWebTransport;
55
+ private _connectWebSocket;
56
+ private _setSocketHandlers;
57
+ private _buildUrl;
58
+ private _canUseWebTransport;
59
+ private _onOpen;
60
+ private _onMessage;
61
+ private _onError;
62
+ private _onClose;
63
+ private _disconnect;
64
+ private _scheduleReconnect;
65
+ private _getReconnectDelay;
66
+ private _startDoctor;
67
+ private _stopDoctor;
68
+ }
@@ -53,6 +53,7 @@ declare enum HangupType {
53
53
  * - Приложение вызываемого не запущено или упало
54
54
  * - Брандмауэр или сетевые ограничения блокируют подключение
55
55
  */
56
- CALL_TIMEOUT = "CALL_TIMEOUT"
56
+ CALL_TIMEOUT = "CALL_TIMEOUT",
57
+ OBSOLETE_CLIENT = "OBSOLETE_CLIENT"
57
58
  }
58
59
  export default HangupType;
@@ -0,0 +1,10 @@
1
+ declare const enum TransportState {
2
+ IDLE = "IDLE",
3
+ OPENED = "OPENED",
4
+ CONNECTING = "CONNECTING",
5
+ RECONNECTING = "RECONNECTING",
6
+ CONNECTED = "CONNECTED",
7
+ CLOSED = "CLOSED",
8
+ FAILED = "FAILED"
9
+ }
10
+ export default TransportState;
@@ -0,0 +1,5 @@
1
+ declare const enum TransportTopology {
2
+ DIRECT = "DIRECT",
3
+ SERVER = "SERVER"
4
+ }
5
+ export default TransportTopology;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@vkontakte/calls-sdk",
3
- "version": "2.8.11-dev.5500645b.0",
3
+ "version": "2.8.11-dev.69b107ee.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",