@vkontakte/calls-sdk 2.8.11-dev.3d9bb708.0 → 2.8.11-dev.3de63af6.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 (64) hide show
  1. package/CallsSDK.d.ts +49 -13
  2. package/abstract/BaseApi.d.ts +1 -2
  3. package/abstract/BaseSignaling.d.ts +1 -1
  4. package/calls-sdk.cjs.js +16 -13
  5. package/calls-sdk.esm.js +11414 -13
  6. package/classes/AudioFix.d.ts +5 -1
  7. package/classes/AudioOutput.d.ts +5 -1
  8. package/classes/Conversation.d.ts +11 -12
  9. package/classes/DebugInfo.d.ts +3 -0
  10. package/classes/MediaSource.d.ts +6 -5
  11. package/classes/ParticipantIdRegistry.d.ts +3 -0
  12. package/classes/ProducerCommandSerializationService.d.ts +3 -0
  13. package/classes/SignalingActor.d.ts +3 -1
  14. package/classes/SpeakerDetector.d.ts +2 -1
  15. package/classes/SpecListener.d.ts +5 -1
  16. package/classes/StatsLogger.d.ts +29 -0
  17. package/classes/VideoEffectsFpsLimiter.d.ts +3 -0
  18. package/classes/asr/AsrReceiver.d.ts +3 -1
  19. package/classes/codec/LibVPxDecoder.d.ts +3 -0
  20. package/classes/codec/LibVPxEncoder.d.ts +3 -1
  21. package/classes/codec/WebCodecsDecoder.d.ts +3 -0
  22. package/classes/codec/WebCodecsEncoder.d.ts +3 -1
  23. package/classes/codec/WorkerBase.d.ts +5 -0
  24. package/classes/screenshare/BaseStreamBuilder.d.ts +4 -1
  25. package/classes/screenshare/CanvasRenderer.d.ts +3 -1
  26. package/classes/screenshare/ScreenCaptureReceiver.d.ts +7 -1
  27. package/classes/screenshare/ScreenCaptureSender.d.ts +5 -1
  28. package/classes/screenshare/ScreenCongestionControl.d.ts +3 -1
  29. package/classes/screenshare/StreamBuilder.d.ts +5 -1
  30. package/classes/screenshare/TrackGeneratorRenderer.d.ts +3 -1
  31. package/classes/screenshare/WebmBuilder.d.ts +3 -1
  32. package/classes/stat/CodecStatsAggregator.d.ts +7 -7
  33. package/classes/stat/ConversationStats.d.ts +21 -0
  34. package/classes/stat/StatAggregator.d.ts +6 -6
  35. package/classes/stat/StatFirstMediaReceived.d.ts +4 -1
  36. package/classes/stat/StatPings.d.ts +9 -9
  37. package/classes/stat/StatScreenShareFirstFrame.d.ts +3 -1
  38. package/classes/stat/StatSignalingCommands.d.ts +8 -8
  39. package/classes/transport/BaseTransport.d.ts +1 -1
  40. package/classes/transport/DirectStatReporter.d.ts +3 -1
  41. package/classes/transport/DirectTransport.d.ts +9 -1
  42. package/classes/transport/PerfStatReporter.d.ts +5 -1
  43. package/classes/transport/ServerTransport.d.ts +10 -2
  44. package/classes/transport/Transport.d.ts +11 -14
  45. package/default/Api.d.ts +1 -3
  46. package/default/Signaling.d.ts +14 -2
  47. package/enums/TransportState.d.ts +10 -0
  48. package/enums/TransportTopology.d.ts +5 -0
  49. package/package.json +1 -1
  50. package/static/Debug.d.ts +27 -8
  51. package/static/External.d.ts +17 -38
  52. package/static/Params.d.ts +20 -22
  53. package/static/Utils.d.ts +3 -2
  54. package/static/WebRTCUtils.d.ts +6 -4
  55. package/types/Conversation.d.ts +1 -1
  56. package/types/PerfStatReporter.d.ts +2 -1
  57. package/types/SignalingMessage.d.ts +4 -1
  58. package/types/Statistics.d.ts +1 -1
  59. package/types/WebTransport.d.ts +1 -0
  60. package/utils/DebugStorage.d.ts +100 -1
  61. package/classes/CallRegistry.d.ts +0 -18
  62. package/classes/Logger.d.ts +0 -41
  63. package/classes/stat/EventMetricsService.d.ts +0 -9
  64. package/static/ConversationDebugLogger.d.ts +0 -13
@@ -1,3 +1,5 @@
1
+ import { type DebugLogger } from '../static/Debug';
2
+ import StatsLogger from './StatsLogger';
1
3
  import { MediaSource } from './MediaSource';
2
4
  export default class AudioFix {
3
5
  private _fixNoPacketsApplied;
@@ -7,11 +9,13 @@ export default class AudioFix {
7
9
  private _fixTooManyPacketsFailed;
8
10
  private _fixTooManyPacketsTime;
9
11
  private _mediaSource;
12
+ private readonly _debug;
13
+ private readonly _logger;
10
14
  private _lastPacketsSent;
11
15
  private _lastPacketsSentTime;
12
16
  private _toggleAudioPromise;
13
17
  private _fixNoPacketsAppliedVideo;
14
- constructor(mediaSource: MediaSource);
18
+ constructor(mediaSource: MediaSource, debug?: DebugLogger, logger?: StatsLogger | null);
15
19
  private _fixAudioDeviceNoPackets;
16
20
  private _fixAudioDeviceTooManyPackets;
17
21
  fix(rtps: any[]): void;
@@ -1,4 +1,6 @@
1
+ import { type DebugLogger } from '../static/Debug';
1
2
  import { ParticipantId } from '../types/Participant';
3
+ import StatsLogger from './StatsLogger';
2
4
  import { StatFirstMediaReceived } from './stat/StatFirstMediaReceived';
3
5
  /**
4
6
  * Единый AudioOutput поддерживающий p2p, audioMix и transparent-audio
@@ -10,7 +12,9 @@ export default class AudioOutput {
10
12
  private _volume;
11
13
  private readonly _features;
12
14
  private readonly _statFirstMediaReceived;
13
- constructor(statFirstMediaReceived: StatFirstMediaReceived, allowMultipleTracks?: boolean);
15
+ protected readonly _debug: DebugLogger;
16
+ private readonly _logger;
17
+ constructor(statFirstMediaReceived: StatFirstMediaReceived, allowMultipleTracks?: boolean, debug?: DebugLogger, logger?: StatsLogger | null);
14
18
  add(participantId: ParticipantId, track: MediaStreamTrack): void;
15
19
  remove(participantId: ParticipantId, track: MediaStreamTrack): void;
16
20
  get volume(): number;
@@ -16,7 +16,7 @@ import { ConversationData, ConversationOnStartParams } from '../types/Conversati
16
16
  import { ExternalId, ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalUserId } from '../types/ExternalId';
17
17
  import type { FastJoinHandler } from '../types/FastJoin';
18
18
  import MediaModifiers from '../types/MediaModifiers';
19
- import MediaSettings, { IVideoDimentions } from '../types/MediaSettings';
19
+ import { IVideoDimentions } from '../types/MediaSettings';
20
20
  import { IAddMovieParams, IUpdateMovieData } from '../types/MovieShare';
21
21
  import MuteStates from '../types/MuteStates';
22
22
  import { CompositeUserId, IGetParticipantsParameters, ParticipantId, ParticipantStateData } from '../types/Participant';
@@ -27,7 +27,6 @@ import { ParticipantStreamDescription } from '../types/ParticipantStreamDescript
27
27
  import { ScreenCaptureSettings } from '../types/ScreenCaptureSettings';
28
28
  import SignalingMessage from '../types/SignalingMessage';
29
29
  import { WaitingHallResponse } from '../types/WaitingHall';
30
- import { CallRegistry } from './CallRegistry';
31
30
  import EventEmitter from './EventEmitter';
32
31
  export default class Conversation extends EventEmitter {
33
32
  private readonly _api;
@@ -42,6 +41,7 @@ export default class Conversation extends EventEmitter {
42
41
  private _pendingParticipants;
43
42
  private _transport;
44
43
  private _debugInfo;
44
+ private readonly _debug;
45
45
  private _volumesDetector;
46
46
  private _speakerDetector;
47
47
  private _localVolumeDetector;
@@ -50,10 +50,14 @@ export default class Conversation extends EventEmitter {
50
50
  private _lastSignalledActiveSpeakerId;
51
51
  private _isRealTimeAsrRequested;
52
52
  private _serverSettings;
53
- private _delayedHangup;
54
- private _abortController;
53
+ private _serverTimeOffset;
54
+ private static _current;
55
+ private static _activationMutex;
56
+ private static _delayedHangup;
57
+ private static _abortController;
55
58
  private readonly _onUnload;
56
59
  private readonly _audioOutput;
60
+ private readonly _stats;
57
61
  private _lastStalled;
58
62
  private _audioMixStalled;
59
63
  private _audioFix;
@@ -68,10 +72,9 @@ export default class Conversation extends EventEmitter {
68
72
  static current(): Conversation | null;
69
73
  static hangupAfterInit(): void;
70
74
  static id(): string | null;
71
- get id(): string;
72
- get externalId(): ExternalParticipantId | undefined;
73
- get mediaSettings(): MediaSettings | undefined;
74
- get isCallHeld(): boolean;
75
+ static debugSessionId(): string | null;
76
+ static getSyncedTime(): number;
77
+ get debugSessionId(): string | null;
75
78
  onStart({ opponentIds, opponentType, mediaOptions, payload, joiningAllowed, requireAuthToJoin, onlyAdminCanShareMovie, externalIds, onFastStart, conversationId, }: ConversationOnStartParams): Promise<ConversationData>;
76
79
  onJoin(joinArgs: {
77
80
  conversationId?: string;
@@ -405,10 +408,6 @@ export default class Conversation extends EventEmitter {
405
408
  private _getParticipants;
406
409
  private _getParticipant;
407
410
  }
408
- declare const _callRegistry: CallRegistry;
409
- export { _callRegistry };
410
- declare function _resetPendingInstance(): void;
411
- export { _resetPendingInstance };
412
411
  export declare class UpdateDisplayLayoutError extends Error {
413
412
  readonly participantErrors: {
414
413
  externalId: ExternalParticipantId;
@@ -1,8 +1,11 @@
1
+ import { type DebugLogger } from '../static/Debug';
1
2
  import { Participant, ParticipantId } from '../types/Participant';
2
3
  import { StatResult } from '../types/Statistics';
3
4
  import EventEmitter from './EventEmitter';
4
5
  export default class DebugInfo extends EventEmitter {
5
6
  private _lastMemoryStat;
7
+ private readonly _debug;
8
+ constructor(debug?: DebugLogger);
6
9
  onRemoteDataStats(stats: StatResult, participants: Record<ParticipantId, Participant>): void;
7
10
  _calcMemory(): void;
8
11
  }
@@ -1,8 +1,10 @@
1
1
  import type { IEffect } from '@vkontakte/calls-video-effects';
2
2
  import EventEmitter from '../classes/EventEmitter';
3
3
  import MediaOption from '../enums/MediaOption';
4
+ import { type DebugLogger } from '../static/Debug';
4
5
  import MediaSettings, { IVideoDimentions } from '../types/MediaSettings';
5
6
  import { ScreenCaptureSettings } from '../types/ScreenCaptureSettings';
7
+ import StatsLogger from './StatsLogger';
6
8
  export declare const enum MediaSourceEvent {
7
9
  SOURCE_CHANGED = "SOURCE_CHANGED",
8
10
  SOURCE_READY = "SOURCE_READY",
@@ -45,7 +47,6 @@ export declare class MediaSource extends EventEmitter {
45
47
  /** Трек аудио эффектов. Не изменяется на протяжении всего времени */
46
48
  private _audioEffectsTrack;
47
49
  private _mediaSettings;
48
- private _lastMediaSettings;
49
50
  private _videoStatusOnScreenCapturingEnabled;
50
51
  private _effect;
51
52
  private _audioEffectParams;
@@ -54,7 +55,9 @@ export declare class MediaSource extends EventEmitter {
54
55
  private _animojiEnabled;
55
56
  /** вычисляем низкую производительность видео эффектов */
56
57
  private readonly _videoEffectsFpsLimiter?;
57
- constructor();
58
+ private readonly _debug;
59
+ private readonly _logger;
60
+ constructor(debug?: DebugLogger, logger?: StatsLogger | null);
58
61
  get cameraVideoTrack(): MediaStreamTrack | null;
59
62
  set cameraVideoTrack(track: MediaStreamTrack | null);
60
63
  request(mediaOptions?: MediaOption[], needEmptyTracks?: boolean): Promise<void>;
@@ -64,7 +67,7 @@ export declare class MediaSource extends EventEmitter {
64
67
  getSendAudioTrack(): MediaStreamTrack | null;
65
68
  get isAnimojiRequested(): boolean;
66
69
  addTrackToPeerConnection(pc: RTCPeerConnection, observer: boolean, noDataChannel: boolean): void;
67
- get mediaSettings(): MediaSettings;
70
+ getMediaSettings(): MediaSettings;
68
71
  changeDevice(kind: MediaDeviceKind): Promise<void>;
69
72
  /**
70
73
  * Установка кастомного стрима для видео, например внешний шаринг экрана
@@ -92,8 +95,6 @@ export declare class MediaSource extends EventEmitter {
92
95
  private _setEffect;
93
96
  private _stopEffect;
94
97
  destroy(): void;
95
- stopLocalMedia(): void;
96
- resumeLocalMedia(): Promise<void>;
97
98
  toggleScreenCapturing(settings: ScreenCaptureSettings): Promise<void>;
98
99
  disableScreenCapturing(): Promise<void>;
99
100
  private videoTrackMuteHandler;
@@ -1,8 +1,11 @@
1
+ import { type DebugLogger } from '../static/Debug';
1
2
  import { ParticipantStreamDescription } from '../types/ParticipantStreamDescription';
2
3
  import SignalingMessage from '../types/SignalingMessage';
3
4
  export declare class ParticipantIdRegistry {
4
5
  private streamDescriptionByCompactId;
5
6
  private compactIdByStreamDescription;
7
+ private readonly _debug;
8
+ constructor(debug?: DebugLogger);
6
9
  getStreamDescription(compactedId: number): ParticipantStreamDescription | undefined;
7
10
  getCompactId(streamDescription: string): number | undefined;
8
11
  handleMessage(data: ArrayBuffer): SignalingMessage | null;
@@ -1,3 +1,4 @@
1
+ import { type DebugLogger } from '../static/Debug';
1
2
  import { NetworkStatReport } from '../types/NetworkStatReport';
2
3
  import ParticipantLayout, { RequestKeyFrame, StopStream } from '../types/ParticipantLayout';
3
4
  import { RequestAsr } from '../types/RequestAsr';
@@ -10,6 +11,8 @@ import { SharingStatReport } from './screenshare/SharingStatReport';
10
11
  import { ParticipantIdRegistry } from './ParticipantIdRegistry';
11
12
  export declare class ProducerCommandSerializationService {
12
13
  private participantIdRegistry;
14
+ private readonly _debug;
15
+ constructor(debug?: DebugLogger);
13
16
  setParticipantIdRegistry(participantIdRegistry: ParticipantIdRegistry): void;
14
17
  serializeUpdateDisplayLayout(sequenceNumber: number, layouts: {
15
18
  [key: string]: ParticipantLayout | StopStream | RequestKeyFrame;
@@ -1,9 +1,11 @@
1
+ import { type DebugLogger } from '../static/Debug';
1
2
  import SignalingMessage from '../types/SignalingMessage';
2
3
  export declare class SignalingActor {
3
4
  private processor;
4
5
  private queue;
5
6
  private isProcessing;
6
- constructor(processor: (message: SignalingMessage) => Promise<unknown> | unknown);
7
+ private readonly _debug;
8
+ constructor(processor: (message: SignalingMessage) => Promise<unknown> | unknown, debug?: DebugLogger);
7
9
  add(message: SignalingMessage): void;
8
10
  private processQueue;
9
11
  }
@@ -1,6 +1,7 @@
1
1
  import { ParticipantId } from '../types/Participant';
2
2
  import EventEmitter from './EventEmitter';
3
- import { Transport, TransportTopology } from './transport/Transport';
3
+ import TransportTopology from '../enums/TransportTopology';
4
+ import { Transport } from './transport/Transport';
4
5
  import { VolumeLevel } from './VolumeDetector';
5
6
  import { VolumesDetector } from './VolumesDetector';
6
7
  export declare const enum SpeakerDetectorEvent {
@@ -1,15 +1,19 @@
1
+ import { type DebugLogger } from '../static/Debug';
1
2
  import MediaSettings from '../types/MediaSettings';
2
3
  import { Participant, ParticipantId } from '../types/Participant';
3
4
  import EventEmitter from './EventEmitter';
5
+ import StatsLogger from './StatsLogger';
4
6
  import { Transport } from './transport/Transport';
5
7
  import { VolumesDetector } from './VolumesDetector';
6
8
  export default class SpecListener extends EventEmitter {
7
9
  private _transport;
8
10
  private _volumes;
9
11
  private readonly _participants;
12
+ private readonly _debug;
13
+ private readonly _logger;
10
14
  private _connectionTimeout;
11
15
  private _volumeTimeout;
12
- constructor(transport: Transport, volumesDetector: VolumesDetector, participants: Record<ParticipantId, Participant>);
16
+ constructor(transport: Transport, volumesDetector: VolumesDetector, participants: Record<ParticipantId, Participant>, debug?: DebugLogger, logger?: StatsLogger | null);
13
17
  destroy(): void;
14
18
  onChangeRemoteMediaSettings(participantId: ParticipantId, mediaSettings: MediaSettings): void;
15
19
  private _onTransportStateChanged;
@@ -0,0 +1,29 @@
1
+ import BaseApi from '../abstract/BaseApi';
2
+ import BaseLogger from '../abstract/BaseLogger';
3
+ import StatLog from '../enums/StatLog';
4
+ /**
5
+ * Класс отвечает за отправку различной информации в сервис статистики (события, статистика и подобное)
6
+ */
7
+ export default class StatsLogger extends BaseLogger {
8
+ private readonly _externalLogger;
9
+ private readonly _api;
10
+ private readonly _conversationIdProvider;
11
+ private readonly _batchInterval;
12
+ private _batchedClientStats;
13
+ private _batchedClientEvents;
14
+ private _batchTimeout;
15
+ private _serverTimeDelta;
16
+ constructor(api: BaseApi, externalLogger: BaseLogger | null, conversationIdProvider: () => string | null);
17
+ log(name: StatLog, value?: string, immediately?: boolean): void;
18
+ logClientStats(data: Record<string, string | number | boolean | undefined | null>, immediately?: boolean): void;
19
+ logClientEvent(data: Record<string, string | number | boolean | undefined | null>, immediately?: boolean): void;
20
+ destroy(): void;
21
+ private _getConversationId;
22
+ private _sendBatch;
23
+ private _startTimeout;
24
+ private _stopTimeout;
25
+ private _sendClientStats;
26
+ private _sendClientEvents;
27
+ private _calculateServerTimeDelta;
28
+ private _now;
29
+ }
@@ -1,4 +1,5 @@
1
1
  import type { VideoEffects } from '@vkontakte/calls-video-effects';
2
+ import { type DebugLogger } from '../static/Debug';
2
3
  import EventEmitter from './EventEmitter';
3
4
  export declare enum VideoEffectsFpsLimiterEvent {
4
5
  FpsLimit = "fps-limit"
@@ -10,6 +11,8 @@ export declare class VideoEffectsFpsLimiter extends EventEmitter {
10
11
  private _fpsMeterUnsubscribe;
11
12
  private readonly _fpsHistory;
12
13
  private _fpsLimitCursor;
14
+ private readonly _debug;
15
+ constructor(debug?: DebugLogger);
13
16
  get fpsLimit(): number;
14
17
  watch(videoEffect: VideoEffects | null): void;
15
18
  private _handleFpsMeter;
@@ -1,3 +1,4 @@
1
+ import { type DebugLogger } from '../../static/Debug';
1
2
  import { AsrTranscription } from '../../types/Asr';
2
3
  import { ParticipantIdRegistry } from '../ParticipantIdRegistry';
3
4
  export declare class AsrReceiver {
@@ -5,7 +6,8 @@ export declare class AsrReceiver {
5
6
  private readonly _participantIdRegistry;
6
7
  private readonly _asrCallback;
7
8
  private readonly _textDecoder;
8
- constructor(datachannel: RTCDataChannel, participantIdRegistry: ParticipantIdRegistry, callback: (asr: AsrTranscription) => void);
9
+ private readonly _debug;
10
+ constructor(datachannel: RTCDataChannel, participantIdRegistry: ParticipantIdRegistry, callback: (asr: AsrTranscription) => void, debug?: DebugLogger);
9
11
  private static parse;
10
12
  private _onDataChannelMessage;
11
13
  destroy(): void;
@@ -1,6 +1,9 @@
1
+ import { type DebugLogger } from '../../static/Debug';
2
+ import StatsLogger from '../StatsLogger';
1
3
  import IDecoder from './IDecoder';
2
4
  import WorkerBase from './WorkerBase';
3
5
  export default class LibVPxDecoder extends WorkerBase implements IDecoder {
6
+ constructor(debug?: DebugLogger, logger?: StatsLogger | null);
4
7
  init(onFrameImage: (image: ImageData) => void, onFrameError: (error: unknown) => void, onKeyFrameRequested: () => void): Promise<void>;
5
8
  decodeFrame(timestamp: number, data: Uint8Array, isVP9: boolean, keyFrame?: boolean): void;
6
9
  destroy(): void;
@@ -1,3 +1,5 @@
1
+ import { type DebugLogger } from '../../static/Debug';
2
+ import StatsLogger from '../StatsLogger';
1
3
  import IEncoder from './IEncoder';
2
4
  import { OnFrameCallback } from './Types';
3
5
  import WorkerBase from './WorkerBase';
@@ -13,7 +15,7 @@ export default class LibVPxEncoder extends WorkerBase implements IEncoder {
13
15
  private _canvasCtx;
14
16
  private _frameReadTimeout;
15
17
  private _lastFrame;
16
- constructor(sourceTrack: MediaStreamTrack, onFrame: OnFrameCallback, useCongestionControl: boolean, maxBitrate: number);
18
+ constructor(sourceTrack: MediaStreamTrack, onFrame: OnFrameCallback, useCongestionControl: boolean, maxBitrate: number, debug?: DebugLogger, logger?: StatsLogger | null);
17
19
  private _createDom;
18
20
  private _removeDom;
19
21
  private _createStream;
@@ -1,6 +1,9 @@
1
+ import { type DebugLogger } from '../../static/Debug';
2
+ import StatsLogger from '../StatsLogger';
1
3
  import IDecoder from './IDecoder';
2
4
  import WorkerBase from './WorkerBase';
3
5
  export default class WebCodecsDecoder extends WorkerBase implements IDecoder {
6
+ constructor(debug?: DebugLogger, logger?: StatsLogger | null);
4
7
  init(onFrameImage: (frame: VideoFrame) => void, onFrameError: (error: unknown) => void, onKeyFrameRequested: () => void): Promise<void>;
5
8
  decodeFrame(timestamp: number, data: Uint8Array, isVP9: boolean, keyFrame?: boolean): void;
6
9
  destroy(): void;
@@ -1,3 +1,5 @@
1
+ import { type DebugLogger } from '../../static/Debug';
2
+ import StatsLogger from '../StatsLogger';
1
3
  import IEncoder from './IEncoder';
2
4
  import { OnFrameCallback } from './Types';
3
5
  import WorkerBase from './WorkerBase';
@@ -9,7 +11,7 @@ export default class WebCodecsEncoder extends WorkerBase implements IEncoder {
9
11
  private readonly _maxBitrate;
10
12
  private readonly _useCbr;
11
13
  private readonly _frameRate;
12
- constructor(sourceTrack: MediaStreamTrack, onFrame: OnFrameCallback, useCongestionControl: boolean, maxBitrate: number, useCbr: boolean, frameRate: number);
14
+ constructor(sourceTrack: MediaStreamTrack, onFrame: OnFrameCallback, useCongestionControl: boolean, maxBitrate: number, useCbr: boolean, frameRate: number, debug?: DebugLogger, logger?: StatsLogger | null);
13
15
  init(): Promise<void>;
14
16
  requestFrame(keyFrame?: boolean): void;
15
17
  setBitrate(bitrate: number, useCbr: boolean, fps: number): void;
@@ -1,5 +1,10 @@
1
+ import { type DebugLogger } from '../../static/Debug';
2
+ import StatsLogger from '../StatsLogger';
1
3
  export default abstract class WorkerBase {
2
4
  protected _worker: Worker | null;
5
+ protected readonly _debug: DebugLogger;
6
+ protected readonly _logger: StatsLogger | null;
7
+ protected constructor(debug?: DebugLogger, logger?: StatsLogger | null);
3
8
  protected _createWorker(workerFunctionData: string, onFrame: (data: any) => void, workerArgs?: any[], initArgs?: {
4
9
  [key: string]: any;
5
10
  }, transfer?: any[]): Promise<void>;
@@ -1,6 +1,8 @@
1
+ import { type DebugLogger } from '../../static/Debug';
1
2
  import { ParticipantId } from '../../types/Participant';
2
3
  import { IScreenShareStat } from '../../types/ScreenSharingStat';
3
4
  import { StatScreenShareFirstFrame } from '../stat/StatScreenShareFirstFrame';
5
+ import { StatAggregator } from '../stat/StatAggregator';
4
6
  import { FrameChunk } from './Utils';
5
7
  export type IOnStat = (stat: IScreenShareStat) => void;
6
8
  export type IOnStream = (stream: MediaStream) => void;
@@ -10,8 +12,9 @@ export declare abstract class BaseStreamBuilder {
10
12
  protected readonly _onStat: IOnStat;
11
13
  protected readonly _onKeyFrameRequested?: VoidFunction;
12
14
  protected readonly _statScreenShareFirstFrame: StatScreenShareFirstFrame;
15
+ protected readonly _debug: DebugLogger;
13
16
  protected _chunks: FrameChunk[];
14
- protected constructor(participantId: ParticipantId, onStream: IOnStream, onStat: IOnStat, onKeyFrameRequested?: VoidFunction);
17
+ protected constructor(participantId: ParticipantId, onStream: IOnStream, onStat: IOnStat, statAggregator: StatAggregator | null, onKeyFrameRequested?: VoidFunction, debug?: DebugLogger);
15
18
  appendChunk(chunk: FrameChunk): void;
16
19
  destroy(): void;
17
20
  protected abstract _processFrame(frame: FrameData): void;
@@ -1,3 +1,4 @@
1
+ import { type DebugLogger } from '../../static/Debug';
1
2
  import BaseRenderer from './BaseRenderer';
2
3
  export default class CanvasRenderer extends BaseRenderer {
3
4
  private readonly _useImageBitmap;
@@ -5,7 +6,8 @@ export default class CanvasRenderer extends BaseRenderer {
5
6
  private _canvasContext;
6
7
  private _stream;
7
8
  private _track;
8
- constructor(onStream: (stream: MediaStream) => void);
9
+ private readonly _debug;
10
+ constructor(onStream: (stream: MediaStream) => void, debug?: DebugLogger);
9
11
  private _createStream;
10
12
  private _removeStream;
11
13
  private _requestCanvasFrame;
@@ -1,5 +1,8 @@
1
+ import { type DebugLogger } from '../../static/Debug';
1
2
  import { ParticipantId } from '../../types/Participant';
3
+ import StatsLogger from '../StatsLogger';
2
4
  import { ParticipantIdRegistry } from '../ParticipantIdRegistry';
5
+ import { StatAggregator } from '../stat/StatAggregator';
3
6
  import { IOnStat } from './BaseStreamBuilder';
4
7
  export default class ScreenCaptureReceiver {
5
8
  private readonly _datachannel;
@@ -8,7 +11,10 @@ export default class ScreenCaptureReceiver {
8
11
  private _onStream;
9
12
  private _onEos;
10
13
  private _onStat;
11
- constructor(datachannel: RTCDataChannel, participantIdRegistry: ParticipantIdRegistry, onStream: (streamId: string, stream: MediaStream) => void, onEos: (streamId: string) => void, onStat: IOnStat);
14
+ private readonly _debug;
15
+ private readonly _logger;
16
+ private readonly _statAggregator;
17
+ constructor(datachannel: RTCDataChannel, participantIdRegistry: ParticipantIdRegistry, onStream: (streamId: string, stream: MediaStream) => void, onEos: (streamId: string) => void, onStat: IOnStat, statAggregator?: StatAggregator | null, debug?: DebugLogger, logger?: StatsLogger | null);
12
18
  private _onDataChannelMessage;
13
19
  /**
14
20
  * Отправить запрос ключевого кадра в datachannel.
@@ -1,4 +1,6 @@
1
1
  import BaseSignaling from '../../abstract/BaseSignaling';
2
+ import { type DebugLogger } from '../../static/Debug';
3
+ import StatsLogger from '../StatsLogger';
2
4
  export default class ScreenCaptureSender {
3
5
  private readonly _encoder;
4
6
  private readonly _datachannel;
@@ -21,7 +23,9 @@ export default class ScreenCaptureSender {
21
23
  private readonly _queue;
22
24
  private readonly _fpsMeter;
23
25
  private readonly _maxFrameDelay;
24
- constructor(track: MediaStreamTrack, datachannel: RTCDataChannel, signaling: BaseSignaling, fastSharing: boolean);
26
+ private readonly _debug;
27
+ private readonly _logger;
28
+ constructor(track: MediaStreamTrack, datachannel: RTCDataChannel, signaling: BaseSignaling, fastSharing: boolean, debug?: DebugLogger, logger?: StatsLogger | null);
25
29
  private _handleQueue;
26
30
  /**
27
31
  * Очищает очередь до опорного кадра
@@ -1,3 +1,4 @@
1
+ import { type DebugLogger } from '../../static/Debug';
1
2
  import { OnCongestionCallback } from '../codec/Types';
2
3
  import { SharingStatReport } from './SharingStatReport';
3
4
  export default class ScreenCongestionControl {
@@ -24,7 +25,8 @@ export default class ScreenCongestionControl {
24
25
  private _lastFpsCalcMs;
25
26
  private _frames;
26
27
  private _fps;
27
- constructor(onCongestion: OnCongestionCallback, minBitrate: number, maxBitrate: number, ccEnabled: boolean, fastSharing: boolean, delayThreshold: number, targetFps: number);
28
+ private readonly _debug;
29
+ constructor(onCongestion: OnCongestionCallback, minBitrate: number, maxBitrate: number, ccEnabled: boolean, fastSharing: boolean, delayThreshold: number, targetFps: number, debug?: DebugLogger);
28
30
  checkDelay(frameNum: number, delay: number, bitrateK: number): void;
29
31
  private _setBitrate;
30
32
  private _calcDelay;
@@ -1,4 +1,7 @@
1
+ import { type DebugLogger } from '../../static/Debug';
1
2
  import { ParticipantId } from '../../types/Participant';
3
+ import StatsLogger from '../StatsLogger';
4
+ import { StatAggregator } from '../stat/StatAggregator';
2
5
  import { BaseStreamBuilder, FrameData, IOnStat, IOnStream } from './BaseStreamBuilder';
3
6
  export default class StreamBuilder extends BaseStreamBuilder {
4
7
  private _renderer;
@@ -7,7 +10,8 @@ export default class StreamBuilder extends BaseStreamBuilder {
7
10
  private _decoderBusy;
8
11
  private _decoderQueue;
9
12
  private _fpsMeter;
10
- constructor(participantId: ParticipantId, onStream: IOnStream, onStat: IOnStat, onKeyFrameRequested: VoidFunction);
13
+ private readonly _logger;
14
+ constructor(participantId: ParticipantId, onStream: IOnStream, onStat: IOnStat, statAggregator: StatAggregator | null, onKeyFrameRequested: VoidFunction, debug?: DebugLogger, logger?: StatsLogger | null);
11
15
  protected _processFrame(frame: FrameData): void;
12
16
  private _initFpsMeter;
13
17
  /**
@@ -1,9 +1,11 @@
1
+ import { type DebugLogger } from '../../static/Debug';
1
2
  import BaseRenderer from './BaseRenderer';
2
3
  export default class TrackGeneratorRenderer extends BaseRenderer {
3
4
  private readonly _generator;
4
5
  private readonly _writer;
5
6
  private readonly _stream;
6
- constructor(onStream: (stream: MediaStream) => void);
7
+ private readonly _debug;
8
+ constructor(onStream: (stream: MediaStream) => void, debug?: DebugLogger);
7
9
  drawFrame(frame: VideoFrame): Promise<void>;
8
10
  destroy(): void;
9
11
  static isBrowserSupported(): boolean;
@@ -1,4 +1,6 @@
1
+ import { type DebugLogger } from '../../static/Debug';
1
2
  import { ParticipantId } from '../../types/Participant';
3
+ import { StatAggregator } from '../stat/StatAggregator';
2
4
  import { BaseStreamBuilder, FrameData, IOnStat, IOnStream } from './BaseStreamBuilder';
3
5
  export default class WebmBuilder extends BaseStreamBuilder {
4
6
  private _mediaBuffer;
@@ -7,7 +9,7 @@ export default class WebmBuilder extends BaseStreamBuilder {
7
9
  private _earliestTimestamp;
8
10
  private _clusterStartTime;
9
11
  private _lastFrameTimestamp;
10
- constructor(participantId: ParticipantId, onStream: IOnStream, onStat: IOnStat);
12
+ constructor(participantId: ParticipantId, onStream: IOnStream, onStat: IOnStat, statAggregator: StatAggregator | null, debug?: DebugLogger);
11
13
  private static _intToU16BE;
12
14
  private static _genWebmHeader;
13
15
  private static _genSegmentHeader;
@@ -1,5 +1,6 @@
1
1
  import { StatItem } from '../../types/Statistics';
2
- import { TransportTopology } from '../transport/Transport';
2
+ import StatsLogger from '../StatsLogger';
3
+ import TransportTopology from '../../enums/TransportTopology';
3
4
  export type CodecKind = 'audio' | 'video';
4
5
  /**
5
6
  * Собирает стату по использованию кодеков в webrtc
@@ -7,13 +8,12 @@ export type CodecKind = 'audio' | 'video';
7
8
  * отправляется репорт об использовании кодеков
8
9
  */
9
10
  export declare class CodecStatsAggregator {
10
- private static _instance;
11
+ private readonly _logger;
11
12
  private readonly _codecUsages;
12
- private getCurrentTransportTopology;
13
- static create(getCurrentTransportTopology: () => TransportTopology | undefined): void;
14
- static reportUsage(stat: StatItem): void;
13
+ private readonly getCurrentTransportTopology;
14
+ constructor(logger: StatsLogger, getCurrentTransportTopology: () => TransportTopology | undefined);
15
+ reportUsage(stat: StatItem): void;
15
16
  private saveUsage;
16
17
  private report;
17
- static destroy(): void;
18
- private _destroy;
18
+ destroy(): void;
19
19
  }
@@ -0,0 +1,21 @@
1
+ import BaseApi from '../../abstract/BaseApi';
2
+ import BaseLogger from '../../abstract/BaseLogger';
3
+ import HangupReason from '../HangupReason';
4
+ import StatsLogger from '../StatsLogger';
5
+ import TransportTopology from '../../enums/TransportTopology';
6
+ import { CodecStatsAggregator } from './CodecStatsAggregator';
7
+ import { StatAggregator } from './StatAggregator';
8
+ import { StatPings } from './StatPings';
9
+ import { StatSignalingCommands } from './StatSignalingCommands';
10
+ export declare class ConversationStats {
11
+ readonly logger: StatsLogger;
12
+ readonly statAggregator: StatAggregator;
13
+ readonly codecStatsAggregator: CodecStatsAggregator;
14
+ readonly pings: StatPings;
15
+ readonly signalingCommands: StatSignalingCommands;
16
+ constructor(api: BaseApi, externalLogger: BaseLogger | null, getConversationId: () => string | null, getTopology: () => TransportTopology | undefined);
17
+ logHangup(reason: HangupReason, topology?: TransportTopology): void;
18
+ flushCallMetrics(topology?: TransportTopology): void;
19
+ destroy(): void;
20
+ private static correctHangupReason;
21
+ }
@@ -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,4 +1,5 @@
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",
@@ -8,10 +9,12 @@ declare enum ECallType {
8
9
  ServerChangeTopology = "server_change_topology"
9
10
  }
10
11
  export declare class StatFirstMediaReceived {
12
+ private readonly _statAggregator;
11
13
  /** уже поставили засечку на приём звонка */
12
14
  protected _isCallMarked: boolean;
13
15
  protected _isFinished: boolean;
14
16
  protected _callType: ECallType | null;
17
+ constructor(statAggregator: StatAggregator);
15
18
  markAcceptCall(topology: TransportTopology): void;
16
19
  markAcceptedCall(topology?: TransportTopology): void;
17
20
  markParticipantJoined(topology: TransportTopology): void;
@@ -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
  }