@whereby.com/media 1.1.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.
@@ -0,0 +1,1300 @@
1
+ import EventEmitter, { EventEmitter as EventEmitter$1 } from 'events';
2
+ import * as mediasoup_client_lib_Device from 'mediasoup-client/lib/Device';
3
+
4
+ declare const getIssuesAndMetrics: () => any;
5
+ declare function subscribeIssues(subscription: any): {
6
+ stop(): void;
7
+ };
8
+
9
+ declare function startPerformanceMonitor({ onMetricsUpdated, onTerminated, isHidden, }: {
10
+ onMetricsUpdated: (aggregatedMetrics: any) => void;
11
+ onTerminated: () => void;
12
+ isHidden: () => boolean;
13
+ }): {
14
+ registerDecodedFps: (fpsData: any) => void;
15
+ terminate: () => void;
16
+ updateHidden: () => void;
17
+ };
18
+
19
+ declare const setClientProvider: (provider: any) => any;
20
+ declare const getStats: () => any;
21
+ declare const getUpdatedStats: () => any;
22
+ declare function subscribeStats(subscription: any): {
23
+ stop(): void;
24
+ };
25
+
26
+ declare function captureCandidatePairInfoMetrics(cpMetrics: any, currentCptats: any, prevCptats: any, timeDiff: any, report: any): void;
27
+ declare function captureSsrcInfo(ssrcMetrics: any, currentSsrcStats: any, prevSsrcStats: any, timeDiff: any, report: any): void;
28
+ declare function captureCommonSsrcMetrics(ssrcMetrics: any, currentSsrcStats: any, prevSsrcStats: any, timeDiff: any, report: any): void;
29
+ declare function captureAudioSsrcMetrics(ssrcMetrics: any, currentSsrcStats: any, prevSsrcStats: any, timeDiff: any, report: any): void;
30
+ declare function captureVideoSsrcMetrics(ssrcMetrics: any, currentSsrcStats: any, prevSsrcStats: any, timeDiff: any, report: any): void;
31
+
32
+ declare const removePeerConnection: (pc: any) => void;
33
+ declare const getCurrentPeerConnections: () => any;
34
+ declare const getPeerConnectionIndex: (pc: any) => any;
35
+ declare const setPeerConnectionsForTests: (pcs: any) => any;
36
+
37
+ declare class BandwidthTester extends EventEmitter {
38
+ closed: boolean;
39
+ _features: any;
40
+ _vegaConnection: any;
41
+ _mediasoupDevice: any;
42
+ _routerRtpCapabilities: any;
43
+ _sendTransport: any;
44
+ _receiveTransport: any;
45
+ _producer: any;
46
+ _consumers: Map<any, any>;
47
+ _startTime: any;
48
+ _connectTime: any;
49
+ _mediaEstablishedTime: any;
50
+ _runTime: any;
51
+ _endTime: any;
52
+ _timeout: any;
53
+ _canvas: any;
54
+ _drawInterval: any;
55
+ _resultTimeout: any;
56
+ _reportTimeout: any;
57
+ constructor({ features }?: {
58
+ features?: any;
59
+ });
60
+ start(runTime?: number): void;
61
+ close(): void;
62
+ _start(): Promise<void>;
63
+ _createTransport(send: any): Promise<void>;
64
+ _getTestTrack(): any;
65
+ _createProducer(): Promise<void>;
66
+ _onMessage(message: any): Promise<void>;
67
+ _onConsumerReady(options: any): Promise<void>;
68
+ _onConsumerClosed({ consumerId }: {
69
+ consumerId: any;
70
+ }): void;
71
+ _reportResults(): Promise<void>;
72
+ _startTimeout(seconds?: number): void;
73
+ _clearTimeouts(): void;
74
+ }
75
+
76
+ declare function detectMicrophoneNotWorking(pc: any): any;
77
+
78
+ declare const MAXIMUM_TURN_BANDWIDTH = 1280;
79
+ declare const MAXIMUM_TURN_BANDWIDTH_UNLIMITED = -1;
80
+ declare const MEDIA_JITTER_BUFFER_TARGET = 400;
81
+
82
+ declare enum RtcEventNames {
83
+ rtc_manager_created = "rtc_manager_created",
84
+ stream_added = "stream_added"
85
+ }
86
+ interface RtcManager {
87
+ acceptNewStream: ({ activeBreakout, clientId, shouldAddLocalVideo, streamId, }: {
88
+ activeBreakout: boolean;
89
+ clientId: string;
90
+ shouldAddLocalVideo: boolean;
91
+ streamId: string;
92
+ }) => void;
93
+ addNewStream(streamId: string, stream: MediaStream, isAudioEnabled: boolean, isVideoEnabled: boolean): void;
94
+ disconnect(streamId: string, activeBreakout: boolean | null, eventClaim?: string): void;
95
+ disconnectAll(): void;
96
+ replaceTrack(oldTrack: MediaStreamTrack, newTrack: MediaStreamTrack): void;
97
+ removeStream(streamId: string, _stream: MediaStream, requestedByClientId: string | null): void;
98
+ shouldAcceptStreamsFromBothSides?: () => boolean;
99
+ updateStreamResolution(streamId: string, ignored: null, resolution: {
100
+ width: number;
101
+ height: number;
102
+ }): void;
103
+ sendStatsCustomEvent(eventName: string, data: unknown): void;
104
+ isInitializedWith({ selfId, roomName, isSfu }: {
105
+ selfId: string;
106
+ roomName: string;
107
+ isSfu: boolean;
108
+ }): boolean;
109
+ setEventClaim?(eventClaim: string): void;
110
+ hasClient(clientId: string): boolean;
111
+ }
112
+ interface RtcManagerCreatedPayload {
113
+ rtcManager: RtcManager;
114
+ }
115
+ interface RtcStreamAddedPayload {
116
+ clientId: string;
117
+ stream: MediaStream;
118
+ streamId: string | undefined;
119
+ streamType: "webcam" | "screenshare" | undefined;
120
+ }
121
+ interface RtcClientConnectionStatusChangedPayload {
122
+ streamIds: string[];
123
+ clientId: string;
124
+ status: string;
125
+ previous: string;
126
+ }
127
+ interface RtcLocalStreamTrackAddedPayload {
128
+ streamId: string;
129
+ tracks: MediaStreamTrack[];
130
+ screenShare: boolean;
131
+ }
132
+ interface RtcLocalStreamTrackRemovedPayload {
133
+ stream: MediaStream;
134
+ track: MediaStreamTrack;
135
+ }
136
+ type RtcEvents = {
137
+ client_connection_status_changed: RtcClientConnectionStatusChangedPayload;
138
+ stream_added: RtcStreamAddedPayload;
139
+ rtc_manager_created: RtcManagerCreatedPayload;
140
+ rtc_manager_destroyed: void;
141
+ local_stream_track_added: RtcLocalStreamTrackAddedPayload;
142
+ local_stream_track_removed: RtcLocalStreamTrackRemovedPayload;
143
+ remote_stream_track_added: void;
144
+ remote_stream_track_removed: void;
145
+ };
146
+ type GetMediaConstraintsOptions = {
147
+ disableAEC: boolean;
148
+ disableAGC: boolean;
149
+ hd: boolean;
150
+ lax: boolean;
151
+ lowDataMode: boolean;
152
+ preferredDeviceIds: {
153
+ audioId?: boolean | string | null | {
154
+ ideal?: string | null;
155
+ exact?: string | null;
156
+ };
157
+ videoId?: boolean | string | null | {
158
+ ideal?: string | null;
159
+ exact?: string | null;
160
+ };
161
+ };
162
+ resolution?: string;
163
+ simulcast: boolean;
164
+ widescreen: boolean;
165
+ usingAspectRatio16x9: boolean;
166
+ };
167
+ type GetConstraintsOptions = {
168
+ devices: MediaDeviceInfo[];
169
+ audioId?: boolean | string;
170
+ videoId?: boolean | string;
171
+ type?: "ideal" | "exact";
172
+ options: Omit<GetMediaConstraintsOptions, "preferredDeviceIds">;
173
+ };
174
+ type GetStreamOptions = {
175
+ replaceStream?: MediaStream;
176
+ fallback?: boolean;
177
+ };
178
+ type GetStreamResult = {
179
+ error?: unknown;
180
+ replacedTracks?: MediaStreamTrack[];
181
+ stream: MediaStream;
182
+ };
183
+ type GetUpdatedDevicesResult = {
184
+ addedDevices: {
185
+ audioinput?: {
186
+ deviceId: string;
187
+ label: string;
188
+ kind: string;
189
+ };
190
+ videoinput?: {
191
+ deviceId: string;
192
+ label: string;
193
+ kind: string;
194
+ };
195
+ audiooutput?: {
196
+ deviceId: string;
197
+ label: string;
198
+ kind: string;
199
+ };
200
+ };
201
+ changedDevices: {
202
+ audioinput?: {
203
+ deviceId: string;
204
+ label: string;
205
+ kind: string;
206
+ };
207
+ videoinput?: {
208
+ deviceId: string;
209
+ label: string;
210
+ kind: string;
211
+ };
212
+ audiooutput?: {
213
+ deviceId: string;
214
+ label: string;
215
+ kind: string;
216
+ };
217
+ };
218
+ };
219
+ type GetDeviceDataResult = {
220
+ audio: {
221
+ deviceId: string;
222
+ label: string;
223
+ kind: string;
224
+ };
225
+ video: {
226
+ deviceId: string;
227
+ label: string;
228
+ kind: string;
229
+ };
230
+ };
231
+
232
+ declare function getMediaConstraints({ disableAEC, disableAGC, hd, lax, lowDataMode, preferredDeviceIds, resolution, simulcast, widescreen, }: GetMediaConstraintsOptions): any;
233
+ declare function getConstraints({ devices, videoId, audioId, options, type }: GetConstraintsOptions): any;
234
+
235
+ declare const isMobile: boolean;
236
+ declare class NoDevicesError extends Error {
237
+ constructor(...args: any);
238
+ }
239
+ declare function enumerate(): Promise<MediaDeviceInfo[]>;
240
+ declare function buildDeviceList({ busyDeviceIds, devices, kind }: any): any;
241
+ declare function getUserMedia(constraints: any): Promise<MediaStream>;
242
+ declare function getDeviceData({ audioTrack, videoTrack, devices, stoppedVideoTrack, lastAudioId, lastVideoId, }: {
243
+ audioTrack?: MediaStreamTrack | null;
244
+ videoTrack?: MediaStreamTrack | null;
245
+ devices: MediaDeviceInfo[];
246
+ stoppedVideoTrack?: boolean;
247
+ lastAudioId?: string | undefined;
248
+ lastVideoId?: string | undefined;
249
+ }): GetDeviceDataResult;
250
+ declare function stopStreamTracks(stream: MediaStream, only?: "audio" | "video" | false): void;
251
+ declare function replaceTracksInStream(stream: MediaStream, newStream: MediaStream, only: "audio" | "video" | false): MediaStreamTrack[];
252
+ declare function getStream2(constraintOpt: GetConstraintsOptions, additionalOpts?: GetStreamOptions): Promise<GetStreamResult>;
253
+ declare function getStream(constraintOpt: any, { replaceStream, fallback }?: GetStreamOptions): Promise<GetStreamResult>;
254
+ declare function hasGetDisplayMedia(): boolean;
255
+ declare function getDisplayMedia(constraints?: {
256
+ video: {
257
+ width: {
258
+ max: number;
259
+ };
260
+ height: {
261
+ max: number;
262
+ };
263
+ };
264
+ }, contentHint?: string): Promise<MediaStream>;
265
+ declare function compareLocalDevices(before: any, after: any): any;
266
+ declare function getUpdatedDevices({ oldDevices, newDevices, currentAudioId, currentVideoId, currentSpeakerId, }: {
267
+ oldDevices: MediaDeviceInfo[];
268
+ newDevices: MediaDeviceInfo[];
269
+ currentAudioId?: string | undefined;
270
+ currentVideoId?: string | undefined;
271
+ currentSpeakerId?: string | undefined;
272
+ }): GetUpdatedDevicesResult;
273
+
274
+ declare class P2pRtcManager implements RtcManager {
275
+ _selfId: any;
276
+ _roomName: any;
277
+ _roomSessionId: any;
278
+ peerConnections: any;
279
+ localStreams: any;
280
+ enabledLocalStreamIds: any[];
281
+ _screenshareVideoTrackIds: any[];
282
+ _socketListenerDeregisterFunctions: any[];
283
+ _localStreamDeregisterFunction: any;
284
+ _emitter: any;
285
+ _serverSocket: any;
286
+ _webrtcProvider: any;
287
+ _features: any;
288
+ _isAudioOnlyMode: boolean;
289
+ offerOptions: {
290
+ offerToReceiveAudio: boolean;
291
+ offerToReceiveVideo: boolean;
292
+ };
293
+ _pendingActionsForConnectedPeerConnections: any[];
294
+ _audioTrackOnEnded: () => void;
295
+ totalSessionsCreated: number;
296
+ _iceServers: any;
297
+ _sfuServer: any;
298
+ _mediaserverConfigTtlSeconds: any;
299
+ _fetchMediaServersTimer: any;
300
+ _wasScreenSharing: any;
301
+ ipv6HostCandidateTeredoSeen: any;
302
+ ipv6HostCandidate6to4Seen: any;
303
+ mdnsHostCandidateSeen: any;
304
+ _lastReverseDirectionAttemptByClientId: any;
305
+ _stoppedVideoTrack: any;
306
+ icePublicIPGatheringTimeoutID: any;
307
+ constructor({ selfId, room, emitter, serverSocket, webrtcProvider, features, }: {
308
+ selfId: any;
309
+ room: any;
310
+ emitter: any;
311
+ serverSocket: any;
312
+ webrtcProvider: any;
313
+ features: any;
314
+ });
315
+ numberOfPeerconnections(): number;
316
+ isInitializedWith({ selfId, roomName, isSfu }: {
317
+ selfId: any;
318
+ roomName: any;
319
+ isSfu: any;
320
+ }): boolean;
321
+ supportsScreenShareAudio(): boolean;
322
+ maybeRestrictRelayBandwidth(session: any): void;
323
+ addNewStream(streamId: string, stream: MediaStream): void;
324
+ replaceTrack(oldTrack: MediaStreamTrack, newTrack: MediaStreamTrack): Promise<any[]>;
325
+ accept({ clientId, shouldAddLocalVideo }: {
326
+ clientId: string;
327
+ shouldAddLocalVideo?: boolean;
328
+ }): any;
329
+ disconnectAll(): void;
330
+ fixChromeAudio(constraints: any): Promise<any[]> | undefined;
331
+ setupSocketListeners(): void;
332
+ sendAudioMutedStats(muted: boolean): void;
333
+ sendVideoMutedStats(muted: boolean): void;
334
+ sendStatsCustomEvent(eventName: string, data: any): void;
335
+ rtcStatsDisconnect(): void;
336
+ rtcStatsReconnect(): void;
337
+ setAudioOnly(audioOnly: any): void;
338
+ setRemoteScreenshareVideoTrackIds(remoteScreenshareVideoTrackIds?: never[]): void;
339
+ setRoomSessionId(roomSessionId: string): void;
340
+ _setConnectionStatus(session: any, newStatus: any, clientId: string): void;
341
+ _setJitterBufferTarget(pc: any): void;
342
+ _emitServerEvent(eventName: string, data?: any, callback?: any): void;
343
+ _emit(eventName: string, data?: any): void;
344
+ _addEnabledLocalStreamId(streamId: string): void;
345
+ _deleteEnabledLocalStreamId(streamId: string): void;
346
+ _getSession(peerConnectionId: string): any;
347
+ _getOrCreateSession(peerConnectionId: string, initialBandwidth: any): any;
348
+ _getLocalCameraStream(): any;
349
+ _getNonLocalCameraStreamIds(): string[];
350
+ _isScreensharingLocally(): boolean;
351
+ _getFirstLocalNonCameraStream(): any;
352
+ _transformIncomingSdp(original: any, _: any): {
353
+ type: any;
354
+ sdp: any;
355
+ };
356
+ _transformOutgoingSdp(original: any): {
357
+ type: any;
358
+ sdpU: any;
359
+ };
360
+ _createSession({ clientId, initialBandwidth, isOfferer, peerConnectionId, shouldAddLocalVideo, }: {
361
+ clientId: string;
362
+ initialBandwidth: any;
363
+ isOfferer: any;
364
+ peerConnectionId: string;
365
+ shouldAddLocalVideo: boolean;
366
+ }): any;
367
+ _cleanup(peerConnectionId: string): void;
368
+ _forEachPeerConnection(func: any): void;
369
+ _addStreamToPeerConnections(stream: any): void;
370
+ _addTrackToPeerConnections(track: any, stream?: any): void;
371
+ _replaceTrackToPeerConnections(oldTrack: any, newTrack: any): Promise<any[]>;
372
+ _removeStreamFromPeerConnections(stream: any): void;
373
+ _removeTrackFromPeerConnections(track: any): void;
374
+ _addLocalStream(streamId: string, stream: any): void;
375
+ _removeLocalStream(streamId: string): void;
376
+ _updateAndScheduleMediaServersRefresh({ iceServers, sfuServer, mediaserverConfigTtlSeconds }: any): void;
377
+ _clearMediaServersRefresh(): void;
378
+ _startMonitoringAudioTrack(track: any): void;
379
+ _stopMonitoringAudioTrack(track: any): void;
380
+ _connect(clientId: string): Promise<any>;
381
+ _maybeRestartIce(clientId: string, session: any): void;
382
+ _setCodecPreferences(pc: any, vp9On: any, av1On: any, redOn: any): void;
383
+ _negotiatePeerConnection(clientId: string, session: any, constraints?: any): void;
384
+ _withForcedRenegotiation(session: any, action: any): void;
385
+ _changeBandwidthForAllClients(isJoining: boolean): number;
386
+ _createP2pSession(clientId: string, initialBandwidth: any, shouldAddLocalVideo: any, isOfferer?: any): any;
387
+ acceptNewStream({ streamId, clientId, shouldAddLocalVideo, }: {
388
+ streamId: string;
389
+ clientId: string;
390
+ shouldAddLocalVideo?: boolean;
391
+ }): any;
392
+ disconnect(clientId: string): void;
393
+ updateStreamResolution(): void;
394
+ stopOrResumeAudio(): void;
395
+ _handleStopOrResumeVideo({ enable, track }: {
396
+ enable: boolean;
397
+ track: any;
398
+ }): void;
399
+ stopOrResumeVideo(localStream: any, enable: boolean): void;
400
+ _shareScreen(streamId: string, stream: any): void;
401
+ removeStream(streamId: string, stream: any, requestedByClientId: any): void;
402
+ hasClient(clientId: string): boolean;
403
+ }
404
+
405
+ declare const assert: {
406
+ fail: (message?: string | Error) => void;
407
+ ok: (value: any, message?: string | Error) => void;
408
+ equal?: (actual: any, expected: any, message?: string | Error) => void;
409
+ notEqual?: (actual: any, expected: any, message?: string | Error) => void;
410
+ };
411
+
412
+ declare const createWorker: (fn: Function) => Worker;
413
+ declare const generateByteString: (count: number) => string;
414
+
415
+ declare const getHandler: () => mediasoup_client_lib_Device.BuiltinHandlerName | undefined;
416
+
417
+ declare const ipRegex: {
418
+ (options: {
419
+ exact: boolean;
420
+ includeBoundaries?: boolean;
421
+ }): RegExp;
422
+ v4(options: {
423
+ exact: boolean;
424
+ includeBoundaries?: boolean;
425
+ }): RegExp;
426
+ v6(options: {
427
+ exact: boolean;
428
+ includeBoundaries?: boolean;
429
+ }): RegExp;
430
+ };
431
+
432
+ declare class Logger {
433
+ _isEnabled: boolean;
434
+ _debugger: any;
435
+ constructor();
436
+ isEnabled(): boolean;
437
+ enable(): void;
438
+ disable(): void;
439
+ info(...params: any[]): void;
440
+ warn(...params: any[]): void;
441
+ error(...params: any[]): void;
442
+ withDebugLogger(myDebugger?: null): this;
443
+ debug(...params: any[]): void;
444
+ }
445
+
446
+ declare const getMediaSettings: (kind: string, isScreenShare: boolean, features: any) => {
447
+ encodings: {}[];
448
+ };
449
+ declare const modifyMediaCapabilities: (routerRtpCapabilities: any, features: any) => void;
450
+
451
+ declare function getOptimalBitrate(width: number, height: number, frameRate: number): number;
452
+
453
+ declare class ReconnectManager extends EventEmitter {
454
+ _socket: any;
455
+ _clients: any;
456
+ _signalDisconnectTime?: number;
457
+ rtcManager?: RtcManager;
458
+ metrics: {
459
+ roomJoinedLate: number;
460
+ pendingClientCanceled: number;
461
+ evaluationFailed: number;
462
+ roomJoined: number;
463
+ };
464
+ constructor(socket: any);
465
+ _onRoomJoined(payload: any): Promise<void>;
466
+ _onClientLeft(payload: any): void;
467
+ _onPendingClientLeft(payload: any): void;
468
+ _onNewClient(payload: any): void;
469
+ _abortIfNotActive(payload: any): Promise<void>;
470
+ _checkIsActive(clientId: string): Promise<boolean>;
471
+ _isClientMediaActive(stats: any, clientId: string): boolean;
472
+ _onAudioEnabled(payload: any): void;
473
+ _onVideoEnabled(payload: any): void;
474
+ _onScreenshareChanged(payload: any, action: boolean): void;
475
+ _hasClientStateChanged({ clientId, webcam, mic, screenShare, }: {
476
+ clientId: string;
477
+ webcam: boolean;
478
+ mic: boolean;
479
+ screenShare: boolean;
480
+ }): boolean;
481
+ _addClientToState(newClient: any): void;
482
+ _wasClientSendingMedia(clientId: string): any;
483
+ _getPendingClientsByDeviceId(deviceId: string): unknown[];
484
+ _resetClientState(payload: any): void;
485
+ }
486
+
487
+ declare class ServerSocket {
488
+ _socket: any;
489
+ _reconnectManager?: ReconnectManager | null;
490
+ noopKeepaliveInterval: any;
491
+ _wasConnectedUsingWebsocket?: boolean;
492
+ constructor(hostName: string, optionsOverrides?: any, glitchFree?: boolean);
493
+ setRtcManager(rtcManager?: RtcManager): void;
494
+ connect(): void;
495
+ disconnect(): void;
496
+ disconnectOnConnect(): void;
497
+ emit(eventName: string, ...args: any[]): void;
498
+ emitIfConnected(eventName: string, data: any): void;
499
+ getTransport(): any;
500
+ getManager(): any;
501
+ isConnecting(): any;
502
+ isConnected(): any;
503
+ on(eventName: string, handler: Function): () => void;
504
+ once(eventName: string, handler: Function): void;
505
+ off(eventName: string, handler: Function): void;
506
+ _interceptEvent(eventName: string, handler: any): () => void;
507
+ getGlitchFreeMetrics(): {
508
+ roomJoinedLate: number;
509
+ pendingClientCanceled: number;
510
+ evaluationFailed: number;
511
+ roomJoined: number;
512
+ } | undefined;
513
+ }
514
+
515
+ declare const maybeTurnOnly: (transportConfig: any, features: {
516
+ useOnlyTURN: string;
517
+ }) => void;
518
+
519
+ interface Credentials {
520
+ credentials: {
521
+ uuid: string;
522
+ };
523
+ hmac: string;
524
+ userId: string;
525
+ }
526
+ interface SocketConf {
527
+ host?: string;
528
+ path?: string;
529
+ reconnectionDelay?: number;
530
+ reconnectionDelayMax?: number;
531
+ timeout?: number;
532
+ autoConnect?: boolean;
533
+ }
534
+ interface SocketManager {
535
+ on: (eventName: string, callback: (args: unknown) => void) => void;
536
+ }
537
+ interface ClientRole {
538
+ roleName: string;
539
+ }
540
+ interface SignalKnocker {
541
+ clientId: string;
542
+ displayName: string | null;
543
+ imageUrl: string | null;
544
+ liveVideo: boolean;
545
+ userAvatarUrl: string | null;
546
+ userId: string | null;
547
+ }
548
+ interface SignalClient {
549
+ displayName: string;
550
+ id: string;
551
+ streams: string[];
552
+ isAudioEnabled: boolean;
553
+ isVideoEnabled: boolean;
554
+ role: ClientRole;
555
+ startedCloudRecordingAt: string | null;
556
+ }
557
+ interface AudioEnabledEvent {
558
+ clientId: string;
559
+ isAudioEnabled: boolean;
560
+ }
561
+ interface ChatMessage {
562
+ id: string;
563
+ messageType: "text";
564
+ roomName: string;
565
+ senderId: string;
566
+ sig: string;
567
+ text: string;
568
+ timestamp: string;
569
+ userId: string;
570
+ }
571
+ interface CloudRecordingStartedEvent {
572
+ error?: string;
573
+ startedAt?: string;
574
+ }
575
+ interface ClientLeftEvent {
576
+ clientId: string;
577
+ }
578
+ interface NewClientEvent {
579
+ client: SignalClient;
580
+ room?: {
581
+ session: {
582
+ createdAt: string;
583
+ id: string;
584
+ } | null;
585
+ };
586
+ }
587
+ interface ClientKickedEvent {
588
+ clientId: string;
589
+ }
590
+ interface KnockerLeftEvent {
591
+ clientId: string;
592
+ }
593
+ interface KnockAcceptedEvent {
594
+ clientId: string;
595
+ metadata: {
596
+ roomKey: string;
597
+ roomName: string;
598
+ };
599
+ resolution: "accepted";
600
+ }
601
+ interface KnockRejectedEvent {
602
+ clientId: string;
603
+ resolution: "rejected";
604
+ }
605
+ interface RoomJoinedEvent {
606
+ error?: string;
607
+ isLocked: boolean;
608
+ room?: {
609
+ clients: SignalClient[];
610
+ knockers: SignalKnocker[];
611
+ session: {
612
+ createdAt: string;
613
+ id: string;
614
+ } | null;
615
+ };
616
+ selfId: string;
617
+ }
618
+ interface RoomKnockedEvent {
619
+ clientId: string;
620
+ displayName: string | null;
621
+ imageUrl: string | null;
622
+ liveVideo: boolean;
623
+ }
624
+ interface RoomSessionEndedEvent {
625
+ roomSessionId: string;
626
+ }
627
+ interface ScreenshareStartedEvent {
628
+ clientId: string;
629
+ streamId: string;
630
+ hasAudioTrack: boolean;
631
+ }
632
+ interface ScreenshareStoppedEvent {
633
+ clientId: string;
634
+ streamId: string;
635
+ }
636
+ interface VideoEnabledEvent {
637
+ clientId: string;
638
+ isVideoEnabled: boolean;
639
+ }
640
+ interface ClientMetadataReceivedEvent {
641
+ type: string;
642
+ payload: {
643
+ clientId: string;
644
+ displayName: string;
645
+ };
646
+ }
647
+ interface SignalEvents {
648
+ audio_enabled: AudioEnabledEvent;
649
+ client_left: ClientLeftEvent;
650
+ client_kicked: ClientKickedEvent;
651
+ client_metadata_received: ClientMetadataReceivedEvent;
652
+ cloud_recording_started: CloudRecordingStartedEvent;
653
+ cloud_recording_stopped: void;
654
+ chat_message: ChatMessage;
655
+ connect: void;
656
+ connect_error: void;
657
+ device_identified: void;
658
+ disconnect: void;
659
+ knock_handled: KnockAcceptedEvent | KnockRejectedEvent;
660
+ knocker_left: KnockerLeftEvent;
661
+ new_client: NewClientEvent;
662
+ room_joined: RoomJoinedEvent;
663
+ room_knocked: RoomKnockedEvent;
664
+ room_left: void;
665
+ room_session_ended: RoomSessionEndedEvent;
666
+ screenshare_started: ScreenshareStartedEvent;
667
+ screenshare_stopped: ScreenshareStoppedEvent;
668
+ streaming_stopped: void;
669
+ video_enabled: VideoEnabledEvent;
670
+ }
671
+ interface IdentifyDeviceRequest {
672
+ deviceCredentials: Credentials;
673
+ }
674
+ interface JoinRoomRequest {
675
+ config: {
676
+ isAudioEnabled: boolean;
677
+ isVideoEnabled: boolean;
678
+ };
679
+ organizationId: string;
680
+ roomName: string;
681
+ displayName?: string;
682
+ }
683
+ interface KnockRoomRequest {
684
+ displayName: string;
685
+ imageUrl: string | null;
686
+ kickFromOtherRooms: boolean;
687
+ liveVideo: boolean;
688
+ organizationId: string;
689
+ roomKey: string | null;
690
+ roomName: string;
691
+ }
692
+ interface SignalRequests {
693
+ chat_message: {
694
+ text: string;
695
+ };
696
+ enable_audio: {
697
+ enabled: boolean;
698
+ };
699
+ enable_video: {
700
+ enabled: boolean;
701
+ };
702
+ handle_knock: {
703
+ action: "accept" | "reject";
704
+ clientId: string;
705
+ response: unknown;
706
+ };
707
+ identify_device: IdentifyDeviceRequest;
708
+ join_room: JoinRoomRequest;
709
+ knock_room: KnockRoomRequest;
710
+ leave_room: void;
711
+ send_client_metadata: {
712
+ type: string;
713
+ payload: {
714
+ displayName?: string;
715
+ };
716
+ };
717
+ start_recording: {
718
+ recording: string;
719
+ };
720
+ stop_recording: void;
721
+ }
722
+
723
+ declare function fromLocation({ host, protocol }?: {
724
+ host?: string | undefined;
725
+ protocol?: string | undefined;
726
+ }): {
727
+ domain: string;
728
+ domainWithSeparator: string;
729
+ organizationDomain: string;
730
+ organization: string;
731
+ service: string;
732
+ subdomain: string;
733
+ };
734
+
735
+ declare class RtcManagerDispatcher {
736
+ emitter: {
737
+ emit: <K extends keyof RtcEvents>(eventName: K, args?: RtcEvents[K]) => void;
738
+ };
739
+ currentManager: RtcManager | null;
740
+ constructor({ emitter, serverSocket, webrtcProvider, features, }: {
741
+ emitter: {
742
+ emit: <K extends keyof RtcEvents>(eventName: K, args?: RtcEvents[K]) => void;
743
+ };
744
+ serverSocket: ServerSocket;
745
+ webrtcProvider: any;
746
+ features: any;
747
+ });
748
+ stopRtcManager(): void;
749
+ }
750
+
751
+ declare const _default: {
752
+ CAMERA_NOT_WORKING: string;
753
+ CONNECTION_BLOCKED_BY_NETWORK: string;
754
+ ICE_IPV6_SEEN: string;
755
+ ICE_MDNS_SEEN: string;
756
+ ICE_NO_PUBLIC_IP_GATHERED: string;
757
+ ICE_NO_PUBLIC_IP_GATHERED_3SEC: string;
758
+ ICE_RESTART: string;
759
+ MICROPHONE_NOT_WORKING: string;
760
+ MICROPHONE_STOPPED_WORKING: string;
761
+ NEW_PC: string;
762
+ SFU_CONNECTION_OPEN: string;
763
+ SFU_CONNECTION_CLOSED: string;
764
+ COLOCATION_SPEAKER: string;
765
+ DOMINANT_SPEAKER: string;
766
+ };
767
+
768
+ declare function setVideoBandwidthUsingSetParameters(pc: any, bandwidth: any, logger?: any): any;
769
+
770
+ declare const rtcStats: {
771
+ sendEvent: (type: any, value: any) => void;
772
+ sendAudioMuted: (muted: boolean) => void;
773
+ sendVideoMuted: (muted: boolean) => void;
774
+ server: {
775
+ connected: boolean;
776
+ trace: (...args: any) => void;
777
+ close: () => void;
778
+ connect: () => void;
779
+ };
780
+ };
781
+
782
+ declare function setCodecPreferenceSDP(sdp: any, vp9On: any, redOn: any): string | undefined;
783
+ declare function maybeRejectNoH264(sdp: any): any;
784
+ declare function deprioritizeH264(sdp: any): string;
785
+ declare function replaceSSRCs(currentDescription: any, newDescription: any): any;
786
+ declare function filterMidExtension(sdp: any): any;
787
+ declare function filterMsidSemantic(sdp: any): any;
788
+ declare function changeMediaDirection(sdp: any, active: any): string;
789
+ declare function addExtMap(sdp: any, extmapUri: any, modifyAudio?: any, modifyVideo?: any): any;
790
+ declare function addAbsCaptureTimeExtMap(sdp: any): any;
791
+
792
+ declare class Session {
793
+ peerConnectionId: any;
794
+ relayCandidateSeen: boolean;
795
+ serverReflexiveCandidateSeen: boolean;
796
+ publicHostCandidateSeen: boolean;
797
+ ipv6HostCandidateSeen: boolean;
798
+ ipv6HostCandidateTeredoSeen: boolean;
799
+ ipv6HostCandidate6to4Seen: boolean;
800
+ mdnsHostCandidateSeen: boolean;
801
+ pc: any;
802
+ wasEverConnected: boolean;
803
+ connectionStatus: any;
804
+ stats: {
805
+ totalSent: number;
806
+ totalRecv: number;
807
+ };
808
+ bandwidth: any;
809
+ maximumTurnBandwidth: any;
810
+ pending: any[];
811
+ isOperationPending: boolean;
812
+ streamIds: any[];
813
+ streams: any[];
814
+ earlyIceCandidates: any[];
815
+ afterConnected: Promise<unknown>;
816
+ registerConnected: any;
817
+ offerOptions: {
818
+ offerToReceiveAudio: boolean;
819
+ offerToReceiveVideo: boolean;
820
+ };
821
+ _deprioritizeH264Encoding: any;
822
+ clientId: any;
823
+ peerConnectionConfig: any;
824
+ shouldAddLocalVideo: any;
825
+ signalingState: any;
826
+ srdComplete: any;
827
+ pendingOffer: any;
828
+ constructor({ peerConnectionId, bandwidth, maximumTurnBandwidth, deprioritizeH264Encoding, }: {
829
+ peerConnectionId: any;
830
+ bandwidth: any;
831
+ maximumTurnBandwidth: any;
832
+ deprioritizeH264Encoding: any;
833
+ });
834
+ setAndGetPeerConnection({ clientId, constraints, peerConnectionConfig, shouldAddLocalVideo, }: {
835
+ clientId: any;
836
+ constraints: any;
837
+ peerConnectionConfig: any;
838
+ shouldAddLocalVideo: any;
839
+ }): any;
840
+ addStream(stream: MediaStream): void;
841
+ addTrack(track: MediaStreamTrack, stream?: MediaStream): void;
842
+ removeTrack(track: MediaStreamTrack): void;
843
+ removeStream(stream: MediaStream): void;
844
+ _setRemoteDescription(desc: any): any;
845
+ handleOffer(message: any): any;
846
+ handleAnswer(message: any): any;
847
+ addIceCandidate(candidate: any): void;
848
+ canModifyPeerConnection(): boolean;
849
+ close(): void;
850
+ hasConnectedPeerConnection(): any;
851
+ replaceTrack(oldTrack: MediaStreamTrack, newTrack: MediaStreamTrack): any;
852
+ maybeRestrictRelayBandwidth(): void;
853
+ changeBandwidth(bandwidth: any): void;
854
+ setAudioOnly(enable: boolean, excludedTrackIds?: any[]): void;
855
+ }
856
+
857
+ declare class SfuV2Parser {
858
+ static parse(raw: any): any;
859
+ static _handleRequest(rawMessage: any): any;
860
+ static _handleResponse(rawMessage: any): any;
861
+ static _handleMessage(rawMessage: any): any;
862
+ static createRequest(method: any, data: any): {
863
+ request: boolean;
864
+ id: number;
865
+ method: any;
866
+ data: any;
867
+ };
868
+ static createSuccessResponse(request: any, data: any): {
869
+ response: boolean;
870
+ id: any;
871
+ ok: boolean;
872
+ data: any;
873
+ };
874
+ static createErrorResponse(request: any, errorCode: any, errorReason: any): {
875
+ response: boolean;
876
+ id: any;
877
+ errorCode: any;
878
+ errorReason: any;
879
+ };
880
+ static createMessage(method: any, data: any): {
881
+ message: boolean;
882
+ method: any;
883
+ data: any;
884
+ };
885
+ }
886
+
887
+ declare function isRelayed(pc: any): any;
888
+
889
+ declare class VegaConnection extends EventEmitter$1 {
890
+ wsUrl: string;
891
+ protocol: string;
892
+ socket: WebSocket | null;
893
+ sents: Map<any, any>;
894
+ constructor(wsUrl: string, protocol?: string);
895
+ _setupSocket(): void;
896
+ _tearDown(): void;
897
+ close(): void;
898
+ _onOpen(): void;
899
+ _onMessage(event: any): void;
900
+ _onClose(): void;
901
+ _onError(error: any): void;
902
+ _handleResponse(socketMessage: any): void;
903
+ send(message: any): void;
904
+ message(method: any, data?: any): void;
905
+ request(method: any, data?: any, timeout?: number): Promise<unknown>;
906
+ }
907
+
908
+ declare class VegaMediaQualityMonitor extends EventEmitter {
909
+ _clients: any;
910
+ _producers: any;
911
+ _intervalHandle: any;
912
+ constructor();
913
+ close(): void;
914
+ _startMonitor(): void;
915
+ _evaluateClient(clientId: string, producers: any): void;
916
+ _evaluateProducer(clientId: string, producers: any, kind: string): void;
917
+ _updateTrend(newQuality: any, state: any): boolean;
918
+ addProducer(clientId: string, producerId: string): void;
919
+ removeProducer(clientId: string, producerId: string): void;
920
+ addConsumer(clientId: string, consumerId: string): void;
921
+ removeConsumer(clientId: string, consumerId: string): void;
922
+ addProducerScore(clientId: string, producerId: string, kind: string, score: any): void;
923
+ addConsumerScore(clientId: string, consumerId: string, kind: string, score: any): void;
924
+ _evaluateScore(score: number): "critical" | "ok" | "warning";
925
+ _calcAvgProducerScore(scores: any): number;
926
+ }
927
+
928
+ declare function createMicAnalyser({ micTrack, params, onScoreUpdated, }: {
929
+ micTrack: MediaStreamTrack;
930
+ params?: any;
931
+ onScoreUpdated: (data: any) => void;
932
+ }): {
933
+ setParams: (newParams: any) => void;
934
+ setTrack: (track: MediaStreamTrack | null) => Promise<void>;
935
+ close(): void;
936
+ };
937
+
938
+ declare class KalmanFilter {
939
+ R: number;
940
+ Q: number;
941
+ A: number;
942
+ C: number;
943
+ B: number;
944
+ cov: number;
945
+ x: number;
946
+ constructor({ R, Q, A, B, C }?: {
947
+ R?: number;
948
+ Q?: number;
949
+ A?: number;
950
+ B?: number;
951
+ C?: number;
952
+ });
953
+ filter(z: number, u?: number): number;
954
+ predict(u?: number): number;
955
+ uncertainty(): number;
956
+ lastMeasurement(): number;
957
+ setMeasurementNoise(noise: number): void;
958
+ setProcessNoise(noise: number): void;
959
+ }
960
+ declare const createACFCalculator: () => (arr: any[]) => number;
961
+ declare const calculateStd: (arr: any[]) => number;
962
+ declare const standardDeviation: (arr: any[]) => {
963
+ mean: number;
964
+ SD: number;
965
+ };
966
+ declare const variance: (arr: any[], usePopulation?: boolean) => number;
967
+
968
+ declare class VegaRtcManager implements RtcManager {
969
+ _selfId: any;
970
+ _room: any;
971
+ _roomSessionId: any;
972
+ _emitter: any;
973
+ _serverSocket: any;
974
+ _webrtcProvider: any;
975
+ _features: any;
976
+ _eventClaim?: any;
977
+ _vegaConnection: any;
978
+ _micAnalyser: any;
979
+ _micAnalyserDebugger: any;
980
+ _mediasoupDevice: any;
981
+ _routerRtpCapabilities: any;
982
+ _sendTransport: any;
983
+ _receiveTransport: any;
984
+ _clientStates: any;
985
+ _streamIdToVideoConsumerId: any;
986
+ _consumers: any;
987
+ _dataConsumers: any;
988
+ _localStreamDeregisterFunction: any;
989
+ _micTrack: any;
990
+ _webcamTrack: any;
991
+ _screenVideoTrack: any;
992
+ _screenAudioTrack: any;
993
+ _micProducer: any;
994
+ _micProducerPromise: any;
995
+ _micPaused: any;
996
+ _micScoreProducer: any;
997
+ _micScoreProducerPromise: any;
998
+ _webcamProducer: any;
999
+ _webcamProducerPromise: any;
1000
+ _webcamPaused: any;
1001
+ _screenVideoProducer: any;
1002
+ _screenVideoProducerPromise: any;
1003
+ _screenAudioProducer: any;
1004
+ _screenAudioProducerPromise: any;
1005
+ _sndTransportIceRestartPromise: any;
1006
+ _rcvTransportIceRestartPromise: any;
1007
+ _colocation: any;
1008
+ _stopCameraTimeout: any;
1009
+ _audioTrackOnEnded: any;
1010
+ _socketListenerDeregisterFunctions: any;
1011
+ _reconnect: any;
1012
+ _reconnectTimeOut: any;
1013
+ _qualityMonitor: any;
1014
+ _fetchMediaServersTimer: any;
1015
+ _iceServers: any;
1016
+ _sfuServer: any;
1017
+ _mediaserverConfigTtlSeconds: any;
1018
+ constructor({ selfId, room, emitter, serverSocket, webrtcProvider, features, eventClaim, deviceHandlerFactory, }: {
1019
+ selfId: any;
1020
+ room: any;
1021
+ emitter: any;
1022
+ serverSocket: any;
1023
+ webrtcProvider: any;
1024
+ features?: any;
1025
+ eventClaim?: string;
1026
+ deviceHandlerFactory?: any;
1027
+ });
1028
+ _updateAndScheduleMediaServersRefresh({ iceServers, sfuServer, mediaserverConfigTtlSeconds, }: {
1029
+ iceServers: any;
1030
+ sfuServer: any;
1031
+ mediaserverConfigTtlSeconds: any;
1032
+ }): void;
1033
+ _clearMediaServersRefresh(): void;
1034
+ setupSocketListeners(): void;
1035
+ _emitScreenshareStarted(): void;
1036
+ _connect(): void;
1037
+ _onClose(): void;
1038
+ _join(): Promise<void>;
1039
+ _createTransport(send: any): Promise<void>;
1040
+ _restartIce(transport: any, retried?: number): Promise<void>;
1041
+ _internalSendMic(): Promise<void>;
1042
+ _internalSetupMicScore(): Promise<void>;
1043
+ _stopMicScoreProducer(): void;
1044
+ _replaceMicTrack(): Promise<void>;
1045
+ _pauseResumeMic(): void;
1046
+ _sendMic(track: MediaStreamTrack): Promise<void>;
1047
+ _sendMicScore(score: number): void;
1048
+ _internalSendWebcam(): Promise<void>;
1049
+ _replaceWebcamTrack(): Promise<void>;
1050
+ _pauseResumeWebcam(): void;
1051
+ _sendWebcam(track: MediaStreamTrack): Promise<void>;
1052
+ _internalSendScreenVideo(): Promise<void>;
1053
+ _replaceScreenVideoTrack(): Promise<void>;
1054
+ _sendScreenVideo(track: MediaStreamTrack): Promise<void>;
1055
+ _internalSendScreenAudio(): Promise<void>;
1056
+ _replaceScreenAudioTrack(): Promise<void>;
1057
+ _sendScreenAudio(track: MediaStreamTrack): Promise<void>;
1058
+ _stopProducer(producer: any): void;
1059
+ isInitializedWith({ selfId, roomName, isSfu }: {
1060
+ selfId: string;
1061
+ roomName: string;
1062
+ isSfu: boolean;
1063
+ }): boolean;
1064
+ setEventClaim(eventClaim: string): void;
1065
+ setColocation(colocation: any): void;
1066
+ setAudioOnly(audioOnly: boolean): void;
1067
+ setRemoteScreenshareVideoTrackIds(): void;
1068
+ setRoomSessionId(roomSessionId: string): void;
1069
+ disconnect(clientIdOrStreamId: string, _activeBreakout: any, eventClaim?: string): void;
1070
+ replaceTrack(oldTrack: MediaStreamTrack | null, track: MediaStreamTrack): void;
1071
+ removeStream(streamId: string, _stream: MediaStream, requestedByClientId: string): void;
1072
+ _onMicAnalyserScoreUpdated(data: any): void;
1073
+ addNewStream(streamId: string, stream: MediaStream, audioPaused: boolean, videoPaused: boolean): void;
1074
+ _syncMicAnalyser(): void;
1075
+ stopOrResumeAudio(stream: MediaStream, enabled: boolean): void;
1076
+ _handleStopOrResumeVideo({ enable, track }: {
1077
+ enable: boolean;
1078
+ track: MediaStreamTrack;
1079
+ }): void;
1080
+ stopOrResumeVideo(localStream: MediaStream, enable: boolean): void;
1081
+ supportsScreenShareAudio(): boolean;
1082
+ acceptNewStream({ streamId, clientId }: {
1083
+ streamId: string;
1084
+ clientId: string;
1085
+ }): void;
1086
+ updateStreamResolution(streamId: string, _ignored: any, { width, height, }: {
1087
+ width: number;
1088
+ height: number;
1089
+ }): void;
1090
+ disconnectAll(): void;
1091
+ sendAudioMutedStats(muted: boolean): void;
1092
+ sendVideoMutedStats(muted: boolean): void;
1093
+ sendStatsCustomEvent(eventName: string, data?: any): void;
1094
+ rtcStatsDisconnect(): void;
1095
+ rtcStatsReconnect(): void;
1096
+ _startMonitoringAudioTrack(track: MediaStreamTrack): void;
1097
+ _stopMonitoringAudioTrack(track: MediaStreamTrack): void;
1098
+ _onMessage(message: any): Promise<void>;
1099
+ _onConsumerReady(options: any): Promise<void>;
1100
+ _onConsumerClosed({ consumerId, reason }: {
1101
+ consumerId: string;
1102
+ reason: string;
1103
+ }): Promise<void>;
1104
+ _onConsumerPaused({ consumerId }: {
1105
+ consumerId: string;
1106
+ }): void;
1107
+ _onConsumerResumed({ consumerId }: {
1108
+ consumerId: string;
1109
+ }): void;
1110
+ _onConsumerScore({ consumerId, kind, score }: {
1111
+ consumerId: string;
1112
+ kind: string;
1113
+ score: number;
1114
+ }): void;
1115
+ _onProducerScore({ producerId, kind, score }: {
1116
+ producerId: string;
1117
+ kind: string;
1118
+ score: number;
1119
+ }): void;
1120
+ _onDataConsumerReady(options: any): Promise<void>;
1121
+ _onDataConsumerClosed({ dataConsumerId, reason }: {
1122
+ dataConsumerId: string;
1123
+ reason: string;
1124
+ }): Promise<void>;
1125
+ _onDominantSpeaker({ consumerId }: {
1126
+ consumerId: string;
1127
+ }): void;
1128
+ _consumerClosedCleanup(consumer: any): void;
1129
+ _syncIncomingStreamsWithPWA(clientId: string): void;
1130
+ _getOrCreateClientState(clientId: string): any;
1131
+ _emitToPWA(eventName: string, data?: any): void;
1132
+ _emitToSignal(eventName: string, data?: any, callback?: any): void;
1133
+ shouldAcceptStreamsFromBothSides(): boolean;
1134
+ setMicAnalyserDebugger(analyserDebugger: any): void;
1135
+ setMicAnalyserParams(params: any): void;
1136
+ hasClient(clientId: string): any;
1137
+ }
1138
+
1139
+ declare const EVENTS: Record<string, keyof RtcEvents>;
1140
+ declare const TYPES: {
1141
+ CONNECTING: string;
1142
+ CONNECTION_FAILED: string;
1143
+ CONNECTION_SUCCESSFUL: string;
1144
+ CONNECTION_DISCONNECTED: string;
1145
+ };
1146
+
1147
+ declare const PROTOCOL_REQUESTS: {
1148
+ BLOCK_CLIENT: string;
1149
+ CLAIM_ROOM: string;
1150
+ CLEAR_CHAT_HISTORY: string;
1151
+ ENABLE_AUDIO: string;
1152
+ ENABLE_VIDEO: string;
1153
+ END_STREAM: string;
1154
+ FETCH_MEDIASERVER_CONFIG: string;
1155
+ HANDLE_KNOCK: string;
1156
+ IDENTIFY_DEVICE: string;
1157
+ INVITE_CLIENT_AS_MEMBER: string;
1158
+ JOIN_ROOM: string;
1159
+ KICK_CLIENT: string;
1160
+ KNOCK_ROOM: string;
1161
+ LEAVE_ROOM: string;
1162
+ SEND_CLIENT_METADATA: string;
1163
+ SET_LOCK: string;
1164
+ SHARE_MEDIA: string;
1165
+ START_NEW_STREAM: string;
1166
+ START_SCREENSHARE: string;
1167
+ STOP_SCREENSHARE: string;
1168
+ START_URL_EMBED: string;
1169
+ STOP_URL_EMBED: string;
1170
+ START_RECORDING: string;
1171
+ STOP_RECORDING: string;
1172
+ SFU_TOKEN: string;
1173
+ };
1174
+ declare const PROTOCOL_RESPONSES: {
1175
+ AUDIO_ENABLED: string;
1176
+ BACKGROUND_IMAGE_CHANGED: string;
1177
+ BLOCK_ADDED: string;
1178
+ BLOCK_REMOVED: string;
1179
+ CHAT_HISTORY_CLEARED: string;
1180
+ CLIENT_BLOCKED: string;
1181
+ CLIENT_INVITED_AS_MEMBER: string;
1182
+ CLIENT_KICKED: string;
1183
+ CLIENT_LEFT: string;
1184
+ CLIENT_METADATA_RECEIVED: string;
1185
+ CLIENT_READY: string;
1186
+ CLIENT_ROLE_CHANGED: string;
1187
+ CLIENT_USER_ID_CHANGED: string;
1188
+ CONTACTS_UPDATED: string;
1189
+ DEVICE_IDENTIFIED: string;
1190
+ ROOM_ROLES_UPDATED: string;
1191
+ KNOCK_HANDLED: string;
1192
+ KNOCK_PAGE_BACKGROUND_CHANGED: string;
1193
+ KNOCKER_LEFT: string;
1194
+ MEDIASERVER_CONFIG: string;
1195
+ MEDIA_SHARED: string;
1196
+ MEMBER_INVITE: string;
1197
+ NEW_CLIENT: string;
1198
+ NEW_STREAM_STARTED: string;
1199
+ SCREENSHARE_STARTED: string;
1200
+ SCREENSHARE_STOPPED: string;
1201
+ OWNER_NOTIFIED: string;
1202
+ OWNERS_CHANGED: string;
1203
+ PLAY_CLIENT_STICKER: string;
1204
+ ROOM_INTEGRATION_ENABLED: string;
1205
+ ROOM_INTEGRATION_DISABLED: string;
1206
+ ROOM_JOINED: string;
1207
+ ROOM_KNOCKED: string;
1208
+ ROOM_LEFT: string;
1209
+ ROOM_LOCKED: string;
1210
+ ROOM_PERMISSIONS_CHANGED: string;
1211
+ ROOM_LOGO_CHANGED: string;
1212
+ ROOM_TYPE_CHANGED: string;
1213
+ ROOM_MODE_CHANGED: string;
1214
+ SOCKET_USER_ID_CHANGED: string;
1215
+ STICKERS_UNLOCKED: string;
1216
+ STREAM_ENDED: string;
1217
+ URL_EMBED_STARTED: string;
1218
+ URL_EMBED_STOPPED: string;
1219
+ RECORDING_STARTED: string;
1220
+ RECORDING_STOPPED: string;
1221
+ USER_NOTIFIED: string;
1222
+ VIDEO_ENABLED: string;
1223
+ CLIENT_UNABLE_TO_JOIN: string;
1224
+ };
1225
+ declare const PROTOCOL_ERRORS: {
1226
+ CANNOT_INVITE_YOURSELF: string;
1227
+ CLIENT_MISSING_DEVICE_ID: string;
1228
+ FORBIDDEN: string;
1229
+ INTERNAL_SERVER_ERROR: string;
1230
+ INVALID_AVATAR: string;
1231
+ INVALID_PARAMETERS: string;
1232
+ INVALID_ROOM_NAME: string;
1233
+ MISSING_PARAMETERS: string;
1234
+ MISSING_ROOM_NAME: string;
1235
+ NOT_AN_OWNER: string;
1236
+ NOT_IN_A_ROOM: string;
1237
+ ROOM_ALREADY_CLAIMED: string;
1238
+ ROOM_EMAIL_MISSING: string;
1239
+ ROOM_FULL: string;
1240
+ ROOM_UNCLAIMED: string;
1241
+ CLIENT_BLOCKED: string;
1242
+ ROOM_LOCKED: string;
1243
+ TOO_LONG_TEXT: string;
1244
+ VIDEO_STICKER_DOES_NOT_EXIST: string;
1245
+ VIDEO_STICKER_FORMAT_ERROR: string;
1246
+ UNSUPPORTED_VIDEO_ENCODING: string;
1247
+ };
1248
+ declare const RELAY_MESSAGES: {
1249
+ CHAT_MESSAGE: string;
1250
+ CHAT_READ_STATE: string;
1251
+ CHAT_STATE: string;
1252
+ ICE_CANDIDATE: string;
1253
+ ICE_END_OF_CANDIDATES: string;
1254
+ READY_TO_RECEIVE_OFFER: string;
1255
+ REMOTE_CLIENT_MEDIA_REQUEST: string;
1256
+ SDP_ANSWER: string;
1257
+ SDP_OFFER: string;
1258
+ VIDEO_STICKER: string;
1259
+ };
1260
+ declare const KNOCK_MESSAGES: {
1261
+ actions: {
1262
+ ACCEPT: string;
1263
+ HOLD: string;
1264
+ REJECT: string;
1265
+ };
1266
+ resolutions: {
1267
+ ACCEPTED: string;
1268
+ ON_HOLD: string;
1269
+ REJECTED: string;
1270
+ };
1271
+ };
1272
+ declare const PROTOCOL_EVENTS: {
1273
+ PENDING_CLIENT_LEFT: string;
1274
+ MEDIA_QUALITY_CHANGED: string;
1275
+ };
1276
+
1277
+ declare const STREAM_TYPES: {
1278
+ CAMERA: string;
1279
+ SCREEN_SHARE: string;
1280
+ };
1281
+ declare class RtcStream {
1282
+ id: string;
1283
+ type: string;
1284
+ isEnabled: boolean;
1285
+ hasSupportForAutoSuperSize: boolean;
1286
+ isAudioEnabled: boolean;
1287
+ isVideoEnabled: boolean;
1288
+ status: string;
1289
+ stream: MediaStream | null;
1290
+ streamId: string | null;
1291
+ constructor(id: string | number, type: string);
1292
+ setup(stream: MediaStream): this;
1293
+ setStatus(status: string): this;
1294
+ setVideoEnabled(isEnabled: boolean): void;
1295
+ setAudioEnabled(isEnabled: boolean): void;
1296
+ static getCameraId(): string;
1297
+ static getTypeFromId(id: string): string;
1298
+ }
1299
+
1300
+ export { type AudioEnabledEvent, BandwidthTester, type ChatMessage, type ClientKickedEvent, type ClientLeftEvent, type ClientMetadataReceivedEvent, type ClientRole, type CloudRecordingStartedEvent, type Credentials, EVENTS, type GetConstraintsOptions, type GetDeviceDataResult, type GetMediaConstraintsOptions, type GetStreamOptions, type GetStreamResult, type GetUpdatedDevicesResult, type IdentifyDeviceRequest, type JoinRoomRequest, KNOCK_MESSAGES, KalmanFilter, type KnockAcceptedEvent, type KnockRejectedEvent, type KnockRoomRequest, type KnockerLeftEvent, Logger, MAXIMUM_TURN_BANDWIDTH, MAXIMUM_TURN_BANDWIDTH_UNLIMITED, MEDIA_JITTER_BUFFER_TARGET, type NewClientEvent, NoDevicesError, P2pRtcManager, PROTOCOL_ERRORS, PROTOCOL_EVENTS, PROTOCOL_REQUESTS, PROTOCOL_RESPONSES, RELAY_MESSAGES, ReconnectManager, type RoomJoinedEvent, type RoomKnockedEvent, type RoomSessionEndedEvent, type RtcClientConnectionStatusChangedPayload, RtcEventNames, type RtcEvents, type RtcLocalStreamTrackAddedPayload, type RtcLocalStreamTrackRemovedPayload, type RtcManager, type RtcManagerCreatedPayload, RtcManagerDispatcher, RtcStream, type RtcStreamAddedPayload, STREAM_TYPES, type ScreenshareStartedEvent, type ScreenshareStoppedEvent, ServerSocket, Session, SfuV2Parser, type SignalClient, type SignalEvents, type SignalKnocker, type SignalRequests, type SocketConf, type SocketManager, TYPES, VegaConnection, VegaMediaQualityMonitor, VegaRtcManager, type VideoEnabledEvent, addAbsCaptureTimeExtMap, addExtMap, assert, buildDeviceList, calculateStd, captureAudioSsrcMetrics, captureCandidatePairInfoMetrics, captureCommonSsrcMetrics, captureSsrcInfo, captureVideoSsrcMetrics, changeMediaDirection, compareLocalDevices, createACFCalculator, createMicAnalyser, createWorker, deprioritizeH264, detectMicrophoneNotWorking, enumerate, filterMidExtension, filterMsidSemantic, fromLocation, generateByteString, getConstraints, getCurrentPeerConnections, getDeviceData, getDisplayMedia, getHandler, getIssuesAndMetrics, getMediaConstraints, getMediaSettings, getOptimalBitrate, getPeerConnectionIndex, getStats, getStream, getStream2, getUpdatedDevices, getUpdatedStats, getUserMedia, hasGetDisplayMedia, ipRegex, isMobile, isRelayed, maybeRejectNoH264, maybeTurnOnly, modifyMediaCapabilities, removePeerConnection, replaceSSRCs, replaceTracksInStream, _default as rtcManagerEvents, rtcStats, setClientProvider, setCodecPreferenceSDP, setPeerConnectionsForTests, setVideoBandwidthUsingSetParameters, standardDeviation, startPerformanceMonitor, stopStreamTracks, subscribeIssues, subscribeStats, variance };