livekit-client 2.18.0 → 2.18.2

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 (145) hide show
  1. package/dist/livekit-client.e2ee.worker.js +1 -1
  2. package/dist/livekit-client.e2ee.worker.js.map +1 -1
  3. package/dist/livekit-client.e2ee.worker.mjs +8 -7
  4. package/dist/livekit-client.e2ee.worker.mjs.map +1 -1
  5. package/dist/livekit-client.esm.mjs +8026 -5883
  6. package/dist/livekit-client.esm.mjs.map +1 -1
  7. package/dist/livekit-client.umd.js +1 -1
  8. package/dist/livekit-client.umd.js.map +1 -1
  9. package/dist/src/api/SignalClient.d.ts +12 -4
  10. package/dist/src/api/SignalClient.d.ts.map +1 -1
  11. package/dist/src/connectionHelper/ConnectionCheck.d.ts +1 -1
  12. package/dist/src/connectionHelper/ConnectionCheck.d.ts.map +1 -1
  13. package/dist/src/e2ee/constants.d.ts.map +1 -1
  14. package/dist/src/e2ee/types.d.ts +6 -0
  15. package/dist/src/e2ee/types.d.ts.map +1 -1
  16. package/dist/src/e2ee/utils.d.ts +2 -1
  17. package/dist/src/e2ee/utils.d.ts.map +1 -1
  18. package/dist/src/e2ee/worker/DataCryptor.d.ts.map +1 -1
  19. package/dist/src/e2ee/worker/FrameCryptor.d.ts.map +1 -1
  20. package/dist/src/index.d.ts +6 -4
  21. package/dist/src/index.d.ts.map +1 -1
  22. package/dist/src/room/PCTransport.d.ts +5 -0
  23. package/dist/src/room/PCTransport.d.ts.map +1 -1
  24. package/dist/src/room/PCTransportManager.d.ts +1 -1
  25. package/dist/src/room/PCTransportManager.d.ts.map +1 -1
  26. package/dist/src/room/RTCEngine.d.ts +28 -11
  27. package/dist/src/room/RTCEngine.d.ts.map +1 -1
  28. package/dist/src/room/Room.d.ts +14 -3
  29. package/dist/src/room/Room.d.ts.map +1 -1
  30. package/dist/src/room/data-stream/incoming/IncomingDataStreamManager.d.ts +5 -1
  31. package/dist/src/room/data-stream/incoming/IncomingDataStreamManager.d.ts.map +1 -1
  32. package/dist/src/room/data-stream/outgoing/OutgoingDataStreamManager.d.ts.map +1 -1
  33. package/dist/src/room/data-track/LocalDataTrack.d.ts +28 -5
  34. package/dist/src/room/data-track/LocalDataTrack.d.ts.map +1 -1
  35. package/dist/src/room/data-track/RemoteDataTrack.d.ts +5 -5
  36. package/dist/src/room/data-track/RemoteDataTrack.d.ts.map +1 -1
  37. package/dist/src/room/data-track/depacketizer.d.ts +4 -4
  38. package/dist/src/room/data-track/depacketizer.d.ts.map +1 -1
  39. package/dist/src/room/data-track/frame.d.ts +14 -0
  40. package/dist/src/room/data-track/frame.d.ts.map +1 -1
  41. package/dist/src/room/data-track/incoming/IncomingDataTrackManager.d.ts +19 -11
  42. package/dist/src/room/data-track/incoming/IncomingDataTrackManager.d.ts.map +1 -1
  43. package/dist/src/room/data-track/incoming/pipeline.d.ts +6 -5
  44. package/dist/src/room/data-track/incoming/pipeline.d.ts.map +1 -1
  45. package/dist/src/room/data-track/outgoing/OutgoingDataTrackManager.d.ts +57 -23
  46. package/dist/src/room/data-track/outgoing/OutgoingDataTrackManager.d.ts.map +1 -1
  47. package/dist/src/room/data-track/outgoing/errors.d.ts +16 -6
  48. package/dist/src/room/data-track/outgoing/errors.d.ts.map +1 -1
  49. package/dist/src/room/data-track/outgoing/pipeline.d.ts +7 -6
  50. package/dist/src/room/data-track/outgoing/pipeline.d.ts.map +1 -1
  51. package/dist/src/room/data-track/outgoing/types.d.ts +14 -4
  52. package/dist/src/room/data-track/outgoing/types.d.ts.map +1 -1
  53. package/dist/src/room/data-track/packet/extensions.d.ts.map +1 -1
  54. package/dist/src/room/data-track/packetizer.d.ts +4 -4
  55. package/dist/src/room/data-track/packetizer.d.ts.map +1 -1
  56. package/dist/src/room/data-track/track-interfaces.d.ts +1 -1
  57. package/dist/src/room/data-track/track-interfaces.d.ts.map +1 -1
  58. package/dist/src/room/data-track/types.d.ts +6 -1
  59. package/dist/src/room/data-track/types.d.ts.map +1 -1
  60. package/dist/src/room/events.d.ts +24 -3
  61. package/dist/src/room/events.d.ts.map +1 -1
  62. package/dist/src/room/participant/LocalParticipant.d.ts +12 -1
  63. package/dist/src/room/participant/LocalParticipant.d.ts.map +1 -1
  64. package/dist/src/room/participant/RemoteParticipant.d.ts +13 -0
  65. package/dist/src/room/participant/RemoteParticipant.d.ts.map +1 -1
  66. package/dist/src/room/utils.d.ts +1 -0
  67. package/dist/src/room/utils.d.ts.map +1 -1
  68. package/dist/src/utils/deferrable-map.d.ts +32 -0
  69. package/dist/src/utils/deferrable-map.d.ts.map +1 -0
  70. package/dist/src/utils/serializer.d.ts +48 -0
  71. package/dist/src/utils/serializer.d.ts.map +1 -0
  72. package/dist/ts4.2/api/SignalClient.d.ts +12 -4
  73. package/dist/ts4.2/connectionHelper/ConnectionCheck.d.ts +2 -1
  74. package/dist/ts4.2/e2ee/types.d.ts +6 -0
  75. package/dist/ts4.2/e2ee/utils.d.ts +2 -1
  76. package/dist/ts4.2/index.d.ts +7 -4
  77. package/dist/ts4.2/room/PCTransport.d.ts +5 -0
  78. package/dist/ts4.2/room/PCTransportManager.d.ts +1 -1
  79. package/dist/ts4.2/room/RTCEngine.d.ts +28 -11
  80. package/dist/ts4.2/room/Room.d.ts +14 -3
  81. package/dist/ts4.2/room/data-stream/incoming/IncomingDataStreamManager.d.ts +5 -1
  82. package/dist/ts4.2/room/data-track/LocalDataTrack.d.ts +27 -4
  83. package/dist/ts4.2/room/data-track/RemoteDataTrack.d.ts +4 -4
  84. package/dist/ts4.2/room/data-track/depacketizer.d.ts +4 -4
  85. package/dist/ts4.2/room/data-track/frame.d.ts +14 -0
  86. package/dist/ts4.2/room/data-track/incoming/IncomingDataTrackManager.d.ts +21 -10
  87. package/dist/ts4.2/room/data-track/incoming/pipeline.d.ts +6 -5
  88. package/dist/ts4.2/room/data-track/outgoing/OutgoingDataTrackManager.d.ts +57 -23
  89. package/dist/ts4.2/room/data-track/outgoing/errors.d.ts +16 -6
  90. package/dist/ts4.2/room/data-track/outgoing/pipeline.d.ts +7 -6
  91. package/dist/ts4.2/room/data-track/outgoing/types.d.ts +14 -4
  92. package/dist/ts4.2/room/data-track/packetizer.d.ts +4 -4
  93. package/dist/ts4.2/room/data-track/track-interfaces.d.ts +1 -1
  94. package/dist/ts4.2/room/data-track/types.d.ts +6 -1
  95. package/dist/ts4.2/room/events.d.ts +24 -3
  96. package/dist/ts4.2/room/participant/LocalParticipant.d.ts +12 -1
  97. package/dist/ts4.2/room/participant/RemoteParticipant.d.ts +13 -0
  98. package/dist/ts4.2/room/utils.d.ts +1 -0
  99. package/dist/ts4.2/utils/deferrable-map.d.ts +32 -0
  100. package/dist/ts4.2/utils/serializer.d.ts +48 -0
  101. package/package.json +1 -1
  102. package/src/api/SignalClient.test.ts +9 -4
  103. package/src/api/SignalClient.ts +116 -9
  104. package/src/connectionHelper/ConnectionCheck.ts +1 -1
  105. package/src/e2ee/constants.ts +1 -0
  106. package/src/e2ee/types.ts +6 -0
  107. package/src/e2ee/utils.ts +4 -3
  108. package/src/e2ee/worker/DataCryptor.ts +1 -4
  109. package/src/e2ee/worker/FrameCryptor.ts +1 -4
  110. package/src/e2ee/worker/ParticipantKeyHandler.ts +1 -1
  111. package/src/index.ts +13 -4
  112. package/src/room/PCTransport.ts +41 -1
  113. package/src/room/PCTransportManager.ts +1 -1
  114. package/src/room/RTCEngine.ts +312 -125
  115. package/src/room/Room.ts +168 -35
  116. package/src/room/data-stream/incoming/IncomingDataStreamManager.ts +26 -2
  117. package/src/room/data-stream/outgoing/OutgoingDataStreamManager.ts +7 -7
  118. package/src/room/data-track/LocalDataTrack.ts +83 -10
  119. package/src/room/data-track/RemoteDataTrack.ts +7 -9
  120. package/src/room/data-track/depacketizer.ts +21 -12
  121. package/src/room/data-track/frame.ts +28 -2
  122. package/src/room/data-track/incoming/IncomingDataTrackManager.test.ts +58 -73
  123. package/src/room/data-track/incoming/IncomingDataTrackManager.ts +139 -80
  124. package/src/room/data-track/incoming/pipeline.ts +29 -24
  125. package/src/room/data-track/outgoing/OutgoingDataTrackManager.test.ts +225 -32
  126. package/src/room/data-track/outgoing/OutgoingDataTrackManager.ts +150 -75
  127. package/src/room/data-track/outgoing/errors.ts +36 -7
  128. package/src/room/data-track/outgoing/pipeline.ts +23 -17
  129. package/src/room/data-track/outgoing/types.ts +12 -3
  130. package/src/room/data-track/packet/extensions.ts +17 -22
  131. package/src/room/data-track/packet/index.test.ts +22 -33
  132. package/src/room/data-track/packetizer.test.ts +2 -2
  133. package/src/room/data-track/packetizer.ts +4 -4
  134. package/src/room/data-track/track-interfaces.ts +1 -1
  135. package/src/room/data-track/types.ts +21 -1
  136. package/src/room/events.ts +26 -1
  137. package/src/room/participant/LocalParticipant.ts +74 -8
  138. package/src/room/participant/RemoteParticipant.ts +25 -0
  139. package/src/room/utils.ts +4 -0
  140. package/src/utils/deferrable-map.ts +109 -0
  141. package/src/utils/serializer.ts +72 -0
  142. package/dist/src/room/data-track/e2ee.d.ts +0 -12
  143. package/dist/src/room/data-track/e2ee.d.ts.map +0 -1
  144. package/dist/ts4.2/room/data-track/e2ee.d.ts +0 -12
  145. package/src/room/data-track/e2ee.ts +0 -15
@@ -1,15 +1,14 @@
1
1
  import type { AddTrackRequest, ConnectionQualityUpdate, JoinResponse, StreamStateUpdate, SubscriptionPermissionUpdate, SubscriptionResponse } from '@livekit/protocol';
2
- import { DataPacket, DataPacket_Kind, DisconnectReason, Encryption_Type, ParticipantInfo, RequestResponse, Room as RoomModel, RoomMovedResponse, SpeakerInfo, SubscribedQualityUpdate, TrackInfo, TrackUnpublishedResponse, Transcription } from '@livekit/protocol';
2
+ import { DataPacket, DataTrackSubscriberHandles, DisconnectReason, Encryption_Type, ParticipantInfo, PublishDataTrackResponse, RequestResponse, Room as RoomModel, RoomMovedResponse, ServerInfo, SpeakerInfo, SubscribedQualityUpdate, TrackInfo, TrackUnpublishedResponse, Transcription, UnpublishDataTrackResponse } from '@livekit/protocol';
3
3
  import type TypedEventEmitter from 'typed-emitter';
4
4
  import type { SignalOptions } from '../api/SignalClient';
5
5
  import { SignalClient } from '../api/SignalClient';
6
6
  import type { BaseE2EEManager } from '../e2ee/E2eeManager';
7
7
  import type { InternalRoomOptions } from '../options';
8
- import TypedPromise from '../utils/TypedPromise';
9
8
  import PCTransport from './PCTransport';
10
9
  import { PCTransportManager } from './PCTransportManager';
11
10
  import type { RegionUrlProvider } from './RegionUrlProvider';
12
- import { UnexpectedConnectionState } from './errors';
11
+ import { DataTrackInfo } from './data-track/types';
13
12
  import { RpcError } from './rpc';
14
13
  import type LocalTrack from './track/LocalTrack';
15
14
  import type LocalTrackPublication from './track/LocalTrackPublication';
@@ -18,6 +17,11 @@ import type { SimulcastTrackInfo } from './track/LocalVideoTrack';
18
17
  import type RemoteTrackPublication from './track/RemoteTrackPublication';
19
18
  import type { Track } from './track/Track';
20
19
  import type { TrackPublishOptions, VideoCodec } from './track/options';
20
+ export declare enum DataChannelKind {
21
+ RELIABLE = 0,
22
+ LOSSY = 1,
23
+ DATA_TRACK_LOSSY = 2
24
+ }
21
25
  declare const RTCEngine_base: new () => TypedEventEmitter<EngineEventCallbacks>;
22
26
  /** @internal */
23
27
  export default class RTCEngine extends RTCEngine_base {
@@ -43,8 +47,10 @@ export default class RTCEngine extends RTCEngine_base {
43
47
  private lossyDC?;
44
48
  private lossyDCSub?;
45
49
  private reliableDC?;
46
- private dcBufferStatus;
47
50
  private reliableDCSub?;
51
+ private dataTrackDC?;
52
+ private dataTrackDCSub?;
53
+ private dcBufferStatus;
48
54
  private subscriberPrimary;
49
55
  private pcState;
50
56
  private _isClosed;
@@ -91,7 +97,10 @@ export default class RTCEngine extends RTCEngine_base {
91
97
  };
92
98
  join(url: string, token: string, opts: SignalOptions, abortSignal?: AbortSignal,
93
99
  /** setting this to true results in dual peer connection mode being used */
94
- useV0Path?: boolean): Promise<JoinResponse>;
100
+ useV0Path?: boolean): Promise<{
101
+ joinResponse: JoinResponse;
102
+ serverInfo: Partial<ServerInfo>;
103
+ }>;
95
104
  close(): Promise<void>;
96
105
  cleanupPeerConnections(): Promise<void>;
97
106
  cleanupLossyDataStats(): void;
@@ -111,9 +120,11 @@ export default class RTCEngine extends RTCEngine_base {
111
120
  private configure;
112
121
  private setupSignalClientCallbacks;
113
122
  private makeRTCConfiguration;
123
+ private addMediaSections;
114
124
  private createDataChannels;
115
125
  private handleDataChannel;
116
126
  private handleDataMessage;
127
+ private handleDataTrackMessage;
117
128
  private handleDataError;
118
129
  private handleBufferedAmountLow;
119
130
  createSender(track: LocalTrack, opts: TrackPublishOptions, encodings?: RTCRtpEncodingParameters[]): Promise<RTCRtpSender>;
@@ -133,22 +144,23 @@ export default class RTCEngine extends RTCEngine_base {
133
144
  publishRpcResponse(destinationIdentity: string, requestId: string, payload: string | null, error: RpcError | null): Promise<void>;
134
145
  /** @internal */
135
146
  publishRpcAck(destinationIdentity: string, requestId: string): Promise<void>;
136
- sendDataPacket(packet: DataPacket, kind: DataPacket_Kind): Promise<void>;
147
+ sendDataPacket(packet: DataPacket, kind: DataChannelKind): Promise<void>;
148
+ sendLossyBytes(bytes: Uint8Array, kind: Exclude<DataChannelKind, DataChannelKind.RELIABLE>, bufferStatusLowBehavior?: 'drop' | 'wait'): Promise<void>;
137
149
  private resendReliableMessagesForResume;
138
150
  private updateAndEmitDCBufferStatus;
139
151
  private isBufferStatusLow;
140
- waitForBufferStatusLow(kind: DataPacket_Kind): TypedPromise<void, UnexpectedConnectionState>;
152
+ waitForBufferStatusLow(kind: DataChannelKind): Promise<void>;
141
153
  /**
142
154
  * @internal
143
155
  */
144
- ensureDataTransportConnected(kind: DataPacket_Kind, subscriber?: boolean): Promise<void>;
156
+ ensureDataTransportConnected(kind: DataChannelKind, subscriber?: boolean): Promise<void>;
145
157
  private ensurePublisherConnected;
146
158
  verifyTransport(): boolean;
147
159
  /** @internal */
148
160
  negotiate(): Promise<void>;
149
- dataChannelForKind(kind: DataPacket_Kind, sub?: boolean): RTCDataChannel | undefined;
161
+ dataChannelForKind(kind: DataChannelKind, sub?: boolean): RTCDataChannel | undefined;
150
162
  /** @internal */
151
- sendSyncState(remoteTracks: RemoteTrackPublication[], localTracks: LocalTrackPublication[]): void;
163
+ sendSyncState(remoteTracks: RemoteTrackPublication[], localTracks: LocalTrackPublication[], localDataTrackInfos: Array<DataTrackInfo>): void;
152
164
  failNext(): void;
153
165
  private dataChannelsInfo;
154
166
  private clearReconnectTimeout;
@@ -177,7 +189,7 @@ export type EngineEventCallbacks = {
177
189
  /** @internal */
178
190
  trackSenderAdded: (track: Track, sender: RTCRtpSender) => void;
179
191
  rtpVideoMapUpdate: (rtpMap: Map<number, VideoCodec>) => void;
180
- dcBufferStatusChanged: (isLow: boolean, kind: DataPacket_Kind) => void;
192
+ dcBufferStatusChanged: (isLow: boolean, kind: DataChannelKind) => void;
181
193
  participantUpdate: (infos: ParticipantInfo[]) => void;
182
194
  roomUpdate: (room: RoomModel) => void;
183
195
  roomMoved: (room: RoomMovedResponse) => void;
@@ -193,6 +205,11 @@ export type EngineEventCallbacks = {
193
205
  offline: () => void;
194
206
  signalRequestResponse: (response: RequestResponse) => void;
195
207
  signalConnected: (joinResp: JoinResponse) => void;
208
+ publishDataTrackResponse: (event: PublishDataTrackResponse) => void;
209
+ unPublishDataTrackResponse: (event: UnpublishDataTrackResponse) => void;
210
+ dataTrackSubscriberHandles: (event: DataTrackSubscriberHandles) => void;
211
+ dataTrackPacketReceived: (packet: Uint8Array) => void;
212
+ joined: (joinResponse: JoinResponse) => void;
196
213
  };
197
214
  export {};
198
215
  //# sourceMappingURL=RTCEngine.d.ts.map
@@ -3,11 +3,14 @@ import 'webrtc-adapter';
3
3
  import type TypedEmitter from 'typed-emitter';
4
4
  import type { InternalRoomOptions, RoomConnectOptions, RoomOptions } from '../options';
5
5
  import TypedPromise from '../utils/TypedPromise';
6
- import RTCEngine from './RTCEngine';
6
+ import RTCEngine, { DataChannelKind } from './RTCEngine';
7
7
  import type { ByteStreamHandler, TextStreamHandler } from './data-stream/incoming/StreamReader';
8
+ import type LocalDataTrack from './data-track/LocalDataTrack';
9
+ import type RemoteDataTrack from './data-track/RemoteDataTrack';
10
+ import type { DataTrackSid } from './data-track/types';
8
11
  import { UnexpectedConnectionState } from './errors';
9
12
  import LocalParticipant from './participant/LocalParticipant';
10
- import type Participant from './participant/Participant';
13
+ import Participant from './participant/Participant';
11
14
  import type { ConnectionQuality } from './participant/Participant';
12
15
  import RemoteParticipant from './participant/RemoteParticipant';
13
16
  import type { RpcInvocationData } from './rpc';
@@ -65,6 +68,7 @@ declare class Room extends Room_base {
65
68
  private connectFuture?;
66
69
  private disconnectLock;
67
70
  private e2eeManager;
71
+ private e2eeStateMutex;
68
72
  private connectionReconcileInterval?;
69
73
  private regionUrlProvider?;
70
74
  private regionUrl?;
@@ -78,6 +82,8 @@ declare class Room extends Room_base {
78
82
  private transcriptionReceivedTimes;
79
83
  private incomingDataStreamManager;
80
84
  private outgoingDataStreamManager;
85
+ private incomingDataTrackManager;
86
+ private outgoingDataTrackManager;
81
87
  private rpcHandlers;
82
88
  get hasE2EESetup(): boolean;
83
89
  /**
@@ -216,6 +222,7 @@ declare class Room extends Room_base {
216
222
  private recreateEngine;
217
223
  private onTrackAdded;
218
224
  private handleRestarting;
225
+ private handleRestarted;
219
226
  private handleSignalRestarted;
220
227
  private handleDisconnect;
221
228
  private handleParticipantUpdates;
@@ -323,11 +330,15 @@ export type RoomEventCallbacks = {
323
330
  recordingStatusChanged: (recording: boolean) => void;
324
331
  participantEncryptionStatusChanged: (encrypted: boolean, participant?: Participant) => void;
325
332
  encryptionError: (error: Error, participant?: Participant) => void;
326
- dcBufferStatusChanged: (isLow: boolean, kind: DataPacket_Kind) => void;
333
+ dcBufferStatusChanged: (isLow: boolean, kind: DataChannelKind) => void;
327
334
  activeDeviceChanged: (kind: MediaDeviceKind, deviceId: string) => void;
328
335
  chatMessage: (message: ChatMessage, participant?: RemoteParticipant | LocalParticipant) => void;
329
336
  localTrackSubscribed: (publication: LocalTrackPublication, participant: LocalParticipant) => void;
330
337
  metricsReceived: (metrics: MetricsBatch, participant?: Participant) => void;
331
338
  participantActive: (participant: Participant) => void;
339
+ dataTrackPublished: (track: RemoteDataTrack) => void;
340
+ dataTrackUnpublished: (sid: DataTrackSid) => void;
341
+ localDataTrackPublished: (track: LocalDataTrack) => void;
342
+ localDataTrackUnpublished: (sid: DataTrackSid) => void;
332
343
  };
333
344
  //# sourceMappingURL=Room.d.ts.map
@@ -7,13 +7,17 @@ export default class IncomingDataStreamManager {
7
7
  private textStreamControllers;
8
8
  private byteStreamHandlers;
9
9
  private textStreamHandlers;
10
+ private isConnected;
11
+ private bufferedPackets;
12
+ setConnected(connected: boolean): void;
13
+ private flushBufferedPackets;
10
14
  registerTextStreamHandler(topic: string, callback: TextStreamHandler): void;
11
15
  unregisterTextStreamHandler(topic: string): void;
12
16
  registerByteStreamHandler(topic: string, callback: ByteStreamHandler): void;
13
17
  unregisterByteStreamHandler(topic: string): void;
14
18
  clearControllers(): void;
15
19
  validateParticipantHasNoActiveDataStreams(participantIdentity: string): void;
16
- handleDataStreamPacket(packet: DataPacket, encryptionType: Encryption_Type): Promise<void>;
20
+ handleDataStreamPacket(packet: DataPacket, encryptionType: Encryption_Type): void;
17
21
  private handleStreamHeader;
18
22
  private handleStreamChunk;
19
23
  private handleStreamTrailer;
@@ -1,18 +1,36 @@
1
+ import type { StructuredLogger } from '../../logger';
1
2
  import type { DataTrackFrame } from './frame';
3
+ import type { DataTrackHandle } from './handle';
2
4
  import type OutgoingDataTrackManager from './outgoing/OutgoingDataTrackManager';
5
+ import { DataTrackPushFrameError } from './outgoing/errors';
6
+ import type { DataTrackOptions } from './outgoing/types';
3
7
  import type { IDataTrack, ILocalTrack } from './track-interfaces';
4
8
  import type { DataTrackInfo } from './types';
5
9
  export default class LocalDataTrack implements ILocalTrack, IDataTrack {
6
10
  readonly trackSymbol: symbol;
7
11
  readonly isLocal = true;
8
12
  readonly typeSymbol: symbol;
9
- info: DataTrackInfo;
13
+ protected options: DataTrackOptions;
14
+ /** Represents the currently active {@link DataTrackHandle} for the publication. */
15
+ protected handle: DataTrackHandle | null;
10
16
  protected manager: OutgoingDataTrackManager;
17
+ protected log: StructuredLogger;
11
18
  /** @internal */
12
- constructor(info: DataTrackInfo, manager: OutgoingDataTrackManager);
19
+ constructor(options: DataTrackOptions, manager: OutgoingDataTrackManager);
20
+ /** @internal */
21
+ static withExplicitHandle(options: DataTrackOptions, manager: OutgoingDataTrackManager, handle: DataTrackHandle): LocalDataTrack;
22
+ /** Metrics about the data track publication. */
23
+ get info(): DataTrackInfo | undefined;
13
24
  /** The raw descriptor from the manager containing the internal state for this local track. */
14
25
  protected get descriptor(): import("./outgoing/OutgoingDataTrackManager").Descriptor | null;
15
- isPublished(): boolean;
26
+ /**
27
+ * Publish the track to the SFU. This must be done before calling {@link tryPush} for the first time.
28
+ * @internal
29
+ * */
30
+ publish(signal?: AbortSignal): Promise<void>;
31
+ isPublished(): this is {
32
+ info: DataTrackInfo;
33
+ };
16
34
  /** Try pushing a frame to subscribers of the track.
17
35
  *
18
36
  * Pushing a frame can fail for several reasons:
@@ -20,6 +38,11 @@ export default class LocalDataTrack implements ILocalTrack, IDataTrack {
20
38
  * - The track has been unpublished by the local participant or SFU
21
39
  * - The room is no longer connected
22
40
  */
23
- tryPush(payload: DataTrackFrame['payload']): import("@livekit/throws-transformer/throws").Throws<void, import("./outgoing/errors").DataTrackPushFrameError<import("./outgoing/errors").DataTrackPushFrameErrorReason.Dropped> | import("./outgoing/errors").DataTrackPushFrameError<import("./outgoing/errors").DataTrackPushFrameErrorReason.TrackUnpublished>>;
41
+ tryPush(frame: DataTrackFrame): Promise<import("@livekit/throws-transformer/throws").Throws<void, DataTrackPushFrameError<import("./outgoing/errors").DataTrackPushFrameErrorReason.TrackUnpublished> | DataTrackPushFrameError<import("./outgoing/errors").DataTrackPushFrameErrorReason.Dropped>>>;
42
+ /**
43
+ * Unpublish the track from the SFU. Once this is called, any further calls to {@link tryPush}
44
+ * will fail.
45
+ * */
46
+ unpublish(): Promise<void>;
24
47
  }
25
48
  //# sourceMappingURL=LocalDataTrack.d.ts.map
@@ -6,11 +6,11 @@ import type { DataTrackInfo } from './types';
6
6
  type RemoteDataTrackOptions = {
7
7
  publisherIdentity: Participant['identity'];
8
8
  };
9
- export type RemoteDataTrackSubscribeOptions = {
9
+ export type DataTrackSubscribeOptions = {
10
10
  signal?: AbortSignal;
11
11
  /** The number of {@link DataTrackFrame}s to hold in the ReadableStream before disgarding extra
12
- * frames. Defaults to 4, but this may not be good enough for especially high frequency data. */
13
- highWaterMark?: number;
12
+ * frames. Defaults to 16, but this may not be good enough for especially high frequency data. */
13
+ bufferSize?: number;
14
14
  };
15
15
  export default class RemoteDataTrack implements IRemoteTrack, IDataTrack {
16
16
  readonly trackSymbol: symbol;
@@ -40,7 +40,7 @@ export default class RemoteDataTrack implements IRemoteTrack, IDataTrack {
40
40
  * Note that newly created subscriptions only receive frames published after
41
41
  * the initial subscription is established.
42
42
  */
43
- subscribe(options?: RemoteDataTrackSubscribeOptions): Promise<ReadableStream<DataTrackFrame>>;
43
+ subscribe(options?: DataTrackSubscribeOptions): ReadableStream<DataTrackFrame>;
44
44
  }
45
45
  export {};
46
46
  //# sourceMappingURL=RemoteDataTrack.d.ts.map
@@ -1,6 +1,6 @@
1
1
  import type { Throws } from '@livekit/throws-transformer/throws';
2
2
  import { LivekitReasonedError } from '../errors';
3
- import type { DataTrackFrame } from './frame';
3
+ import type { DataTrackFrameInternal } from './frame';
4
4
  import { DataTrackPacket } from './packet';
5
5
  /** An error indicating a frame was dropped. */
6
6
  export declare class DataTrackDepacketizerDropError<Reason extends DataTrackDepacketizerDropReason = DataTrackDepacketizerDropReason> extends LivekitReasonedError<Reason> {
@@ -11,7 +11,7 @@ export declare class DataTrackDepacketizerDropError<Reason extends DataTrackDepa
11
11
  constructor(message: string, reason: Reason, frameNumber: number, options?: {
12
12
  cause?: unknown;
13
13
  });
14
- static interrupted(frameNumber: number): DataTrackDepacketizerDropError<DataTrackDepacketizerDropReason.Interrupted>;
14
+ static interrupted(frameNumber: number, newFrameNumber: number): DataTrackDepacketizerDropError<DataTrackDepacketizerDropReason.Interrupted>;
15
15
  static unknownFrame(frameNumber: number): DataTrackDepacketizerDropError<DataTrackDepacketizerDropReason.UnknownFrame>;
16
16
  static bufferFull(frameNumber: number): DataTrackDepacketizerDropError<DataTrackDepacketizerDropReason.BufferFull>;
17
17
  static incomplete(frameNumber: number, receivedPackets: number, expectedPackets: number): DataTrackDepacketizerDropError<DataTrackDepacketizerDropReason.Incomplete>;
@@ -35,9 +35,9 @@ export default class DataTrackDepacketizer {
35
35
  /** Should be repeatedly called with received {@link DataTrackPacket}s - intermediate calls
36
36
  * aggregate the packet's state internally, and return null.
37
37
  *
38
- * Once this method is called with the final packet to form a frame, a new {@link DataTrackFrame}
38
+ * Once this method is called with the final packet to form a frame, a new {@link DataTrackFrameInternal}
39
39
  * is returned.*/
40
- push(packet: DataTrackPacket, options?: PushOptions): Throws<DataTrackFrame | null, DataTrackDepacketizerDropError>;
40
+ push(packet: DataTrackPacket, options?: PushOptions): Throws<DataTrackFrameInternal | null, DataTrackDepacketizerDropError>;
41
41
  reset(): void;
42
42
  private frameFromSingle;
43
43
  /** Begin assembling a new packet. */
@@ -1,7 +1,21 @@
1
1
  import { DataTrackExtensions } from './packet/extensions';
2
2
  /** A pair of payload bytes and packet extensions which can be fed into a {@link DataTrackPacketizer}. */
3
3
  export type DataTrackFrame = {
4
+ payload: Uint8Array;
5
+ userTimestamp?: bigint;
6
+ };
7
+ /** An internal representation o data track frame which contains all SFU metadata. */
8
+ export type DataTrackFrameInternal = {
4
9
  payload: Uint8Array;
5
10
  extensions: DataTrackExtensions;
6
11
  };
12
+ export declare const DataTrackFrameInternal: {
13
+ from(frame: DataTrackFrame): {
14
+ payload: Uint8Array<ArrayBufferLike>;
15
+ extensions: DataTrackExtensions;
16
+ };
17
+ /** Converts from a DataTrackFrameInternal -> DataTrackFrame. Some internal information is
18
+ * discarded like e2ee encrption extension data. */
19
+ lossyIntoFrame(frame: DataTrackFrameInternal): DataTrackFrame;
20
+ };
7
21
  //# sourceMappingURL=frame.d.ts.map
@@ -1,9 +1,9 @@
1
1
  import type { Throws } from '@livekit/throws-transformer/throws';
2
2
  import type TypedEmitter from 'typed-emitter';
3
+ import type { BaseE2EEManager } from '../../../e2ee/E2eeManager';
3
4
  import type Participant from '../../participant/Participant';
4
5
  import type RemoteParticipant from '../../participant/RemoteParticipant';
5
6
  import { DataTrackDepacketizerDropError } from '../depacketizer';
6
- import type { DecryptionProvider } from '../e2ee';
7
7
  import type { DataTrackFrame } from '../frame';
8
8
  import { DataTrackHandle } from '../handle';
9
9
  import type { DataTrackInfo, DataTrackSid } from '../types';
@@ -14,20 +14,20 @@ export type DataTrackIncomingManagerCallbacks = {
14
14
  sfuUpdateSubscription: (event: EventSfuUpdateSubscription) => void;
15
15
  /** A track has been published by a remote participant and is available to be
16
16
  * subscribed to. */
17
- trackAvailable: (event: EventTrackAvailable) => void;
17
+ trackPublished: (event: EventTrackAvailable) => void;
18
18
  /** A track has been unpublished by a remote participant and can no longer be subscribed to. */
19
- trackUnavailable: (event: EventTrackUnavailable) => void;
19
+ trackUnpublished: (event: EventTrackUnavailable) => void;
20
20
  };
21
21
  type IncomingDataTrackManagerOptions = {
22
22
  /** Provider to use for decrypting incoming frame payloads.
23
23
  * If none, remote tracks using end-to-end encryption will not be available
24
24
  * for subscription.
25
25
  */
26
- decryptionProvider: DecryptionProvider | null;
26
+ e2eeManager?: BaseE2EEManager;
27
27
  };
28
28
  declare const IncomingDataTrackManager_base: new () => TypedEmitter<DataTrackIncomingManagerCallbacks>;
29
29
  export default class IncomingDataTrackManager extends IncomingDataTrackManager_base {
30
- private decryptionProvider;
30
+ private e2eeManager;
31
31
  /** Mapping between track SID and descriptor. */
32
32
  private descriptors;
33
33
  /** Mapping between subscriber handle and track SID.
@@ -38,6 +38,20 @@ export default class IncomingDataTrackManager extends IncomingDataTrackManager_b
38
38
  */
39
39
  private subscriptionHandles;
40
40
  constructor(options?: IncomingDataTrackManagerOptions);
41
+ /** @internal */
42
+ updateE2eeManager(e2eeManager: BaseE2EEManager | null): void;
43
+ /** Allocates a ReadableStream which emits when a new {@link DataTrackFrame} is received from the
44
+ * SFU. The SFU subscription is initiated lazily when the stream is created.
45
+ *
46
+ * @returns A tuple of the ReadableStream and a Promise that resolves once the SFU subscription
47
+ * is fully established / the stream is ready to receive frames.
48
+ *
49
+ * @internal
50
+ **/
51
+ openSubscriptionStream(sid: DataTrackSid, signal?: AbortSignal, bufferSize?: number): [
52
+ ReadableStream<DataTrackFrame>,
53
+ Promise<Throws<void, DataTrackSubscribeError>>
54
+ ];
41
55
  /** Client requested to subscribe to a data track.
42
56
  *
43
57
  * This is sent when the user calls {@link RemoteDataTrack.subscribe}.
@@ -46,10 +60,7 @@ export default class IncomingDataTrackManager extends IncomingDataTrackManager_b
46
60
  * requests simply attach an additional receiver to the broadcast channel, allowing them to consume
47
61
  * frames from the existing subscription pipeline.
48
62
  */
49
- subscribeRequest(sid: DataTrackSid, signal?: AbortSignal, highWaterMark?: number): Promise<Throws<ReadableStream<DataTrackFrame>, DataTrackSubscribeError>>;
50
- /** Allocates a ReadableStream which emits when a new {@link DataTrackFrame} is received from the
51
- * SFU. */
52
- private createReadableStream;
63
+ subscribeRequest(sid: DataTrackSid, signal?: AbortSignal): Promise<Throws<void, DataTrackSubscribeError>>;
53
64
  /**
54
65
  * Get information about all currently subscribed tracks.
55
66
  * @internal */
@@ -82,7 +93,7 @@ export default class IncomingDataTrackManager extends IncomingDataTrackManager_b
82
93
  mapping: Map<DataTrackHandle, DataTrackSid>): void;
83
94
  private registerSubscriberHandle;
84
95
  /** Packet has been received over the transport. */
85
- packetReceived(bytes: Uint8Array): Throws<void, DataTrackDepacketizerDropError>;
96
+ packetReceived(bytes: Uint8Array): Promise<Throws<void, DataTrackDepacketizerDropError>>;
86
97
  /** Resend all subscription updates.
87
98
  *
88
99
  * This must be sent after a full reconnect to ensure the SFU knows which
@@ -1,7 +1,7 @@
1
1
  import type { Throws } from '@livekit/throws-transformer/throws';
2
+ import type { BaseE2EEManager } from '../../../e2ee/E2eeManager';
2
3
  import { DataTrackDepacketizerDropError } from '../depacketizer';
3
- import type { DecryptionProvider } from '../e2ee';
4
- import type { DataTrackFrame } from '../frame';
4
+ import type { DataTrackFrameInternal } from '../frame';
5
5
  import { DataTrackPacket } from '../packet';
6
6
  import type { DataTrackInfo } from '../types';
7
7
  /**
@@ -10,20 +10,21 @@ import type { DataTrackInfo } from '../types';
10
10
  type Options = {
11
11
  info: DataTrackInfo;
12
12
  publisherIdentity: string;
13
- decryptionProvider: DecryptionProvider | null;
13
+ e2eeManager: BaseE2EEManager | null;
14
14
  };
15
15
  /**
16
16
  * Pipeline for an individual data track subscription.
17
17
  */
18
18
  export default class IncomingDataTrackPipeline {
19
19
  private publisherIdentity;
20
- private e2eeProvider;
20
+ private e2eeManager;
21
21
  private depacketizer;
22
22
  /**
23
23
  * Creates a new pipeline with the given options.
24
24
  */
25
25
  constructor(options: Options);
26
- processPacket(packet: DataTrackPacket): Throws<DataTrackFrame | null, DataTrackDepacketizerDropError>;
26
+ updateE2eeManager(e2eeManager: BaseE2EEManager | null): void;
27
+ processPacket(packet: DataTrackPacket): Promise<Throws<DataTrackFrameInternal | null, DataTrackDepacketizerDropError>>;
27
28
  /**
28
29
  * Depacketize the given frame, log if a drop occurs.
29
30
  */
@@ -1,20 +1,22 @@
1
1
  import type { Throws } from '@livekit/throws-transformer/throws';
2
2
  import type TypedEmitter from 'typed-emitter';
3
+ import type { BaseE2EEManager } from '../../../e2ee/E2eeManager';
3
4
  import { Future } from '../../utils';
4
- import LocalDataTrack from '../LocalDataTrack';
5
- import type { EncryptionProvider } from '../e2ee';
5
+ import type { DataTrackFrameInternal } from '../frame';
6
6
  import { DataTrackHandle } from '../handle';
7
7
  import type { DataTrackInfo } from '../types';
8
- import { DataTrackPublishError, DataTrackPublishErrorReason, DataTrackPushFrameError, DataTrackPushFrameErrorReason } from './errors';
8
+ import { DataTrackPublishError, DataTrackPushFrameError, DataTrackPushFrameErrorReason } from './errors';
9
9
  import DataTrackOutgoingPipeline from './pipeline';
10
- import type { DataTrackOptions, EventPacketsAvailable, EventSfuPublishRequest, EventSfuUnpublishRequest, SfuPublishResponseResult } from './types';
10
+ import type { DataTrackOptions, EventPacketAvailable, EventSfuPublishRequest, EventSfuUnpublishRequest, EventTrackPublished, EventTrackUnpublished, SfuPublishResponseResult } from './types';
11
11
  export type PendingDescriptor = {
12
12
  type: 'pending';
13
- completionFuture: Future<LocalDataTrack, DataTrackPublishError<DataTrackPublishErrorReason.NotAllowed> | DataTrackPublishError<DataTrackPublishErrorReason.DuplicateName> | DataTrackPublishError<DataTrackPublishErrorReason.Timeout> | DataTrackPublishError<DataTrackPublishErrorReason.LimitReached> | DataTrackPublishError<DataTrackPublishErrorReason.Disconnected> | DataTrackPublishError<DataTrackPublishErrorReason.Cancelled>>;
13
+ /** Resolves when the descriptor is fully published. */
14
+ completionFuture: Future<void, DataTrackPublishError>;
14
15
  };
15
16
  export type ActiveDescriptor = {
16
17
  type: 'active';
17
18
  info: DataTrackInfo;
19
+ publishState: 'published' | 'republishing' | 'unpublished';
18
20
  pipeline: DataTrackOutgoingPipeline;
19
21
  /** Resolves when the descriptor is unpublished. */
20
22
  unpublishingFuture: Future<void, never>;
@@ -22,55 +24,87 @@ export type ActiveDescriptor = {
22
24
  export type Descriptor = PendingDescriptor | ActiveDescriptor;
23
25
  export declare const Descriptor: {
24
26
  pending(): PendingDescriptor;
25
- active(info: DataTrackInfo, encryptionProvider: EncryptionProvider | null): ActiveDescriptor;
27
+ active(info: DataTrackInfo, e2eeManager: BaseE2EEManager | null): ActiveDescriptor;
26
28
  };
27
29
  export type DataTrackOutgoingManagerCallbacks = {
28
30
  /** Request sent to the SFU to publish a track. */
29
31
  sfuPublishRequest: (event: EventSfuPublishRequest) => void;
30
32
  /** Request sent to the SFU to unpublish a track. */
31
33
  sfuUnpublishRequest: (event: EventSfuUnpublishRequest) => void;
32
- /** Serialized packets are ready to be sent over the transport. */
33
- packetsAvailable: (event: EventPacketsAvailable) => void;
34
+ /** A serialized packet is ready to be sent over the transport. */
35
+ packetAvailable: (event: EventPacketAvailable) => void;
36
+ /** A new {@link LocalDataTrack} has been published */
37
+ trackPublished: (event: EventTrackPublished) => void;
38
+ /** A {@link LocalDataTrack} has been unpublished */
39
+ trackUnpublished: (event: EventTrackUnpublished) => void;
34
40
  };
35
41
  type OutgoingDataTrackManagerOptions = {
36
42
  /**
37
43
  * Provider to use for encrypting outgoing frame payloads.
38
44
  *
39
- * If none, end-to-end encryption will be disabled for all published tracks.
45
+ * If null, end-to-end encryption will be disabled for all published tracks.
40
46
  */
41
- encryptionProvider?: EncryptionProvider;
47
+ e2eeManager?: BaseE2EEManager;
42
48
  };
43
49
  declare const OutgoingDataTrackManager_base: new () => TypedEmitter<DataTrackOutgoingManagerCallbacks>;
44
50
  export default class OutgoingDataTrackManager extends OutgoingDataTrackManager_base {
45
- private encryptionProvider;
51
+ private e2eeManager;
46
52
  private handleAllocator;
47
53
  private descriptors;
48
54
  constructor(options?: OutgoingDataTrackManagerOptions);
49
55
  static withDescriptors(descriptors: Map<DataTrackHandle, Descriptor>): OutgoingDataTrackManager;
56
+ /** @internal */
57
+ updateE2eeManager(e2eeManager: BaseE2EEManager | null): void;
50
58
  /**
51
59
  * Used by attached {@link LocalDataTrack} instances to query their associated descriptor info.
52
60
  * @internal
53
61
  */
54
62
  getDescriptor(handle: DataTrackHandle): Descriptor | null;
55
- createLocalDataTrack(handle: DataTrackHandle): LocalDataTrack | null;
56
63
  /** Used by attached {@link LocalDataTrack} instances to broadcast data track packets to other
57
64
  * subscribers.
58
65
  * @internal
59
66
  */
60
- tryProcessAndSend(handle: DataTrackHandle, payload: Uint8Array): Throws<void, DataTrackPushFrameError<DataTrackPushFrameErrorReason.Dropped> | DataTrackPushFrameError<DataTrackPushFrameErrorReason.TrackUnpublished>>;
61
- /** Client requested to publish a track. */
62
- publishRequest(options: DataTrackOptions, signal?: AbortSignal): Promise<LocalDataTrack & {
63
- readonly __throws?: DataTrackPublishError<DataTrackPublishErrorReason.NotAllowed> | DataTrackPublishError<DataTrackPublishErrorReason.DuplicateName> | DataTrackPublishError<DataTrackPublishErrorReason.Timeout> | DataTrackPublishError<DataTrackPublishErrorReason.LimitReached> | DataTrackPublishError<DataTrackPublishErrorReason.Disconnected> | DataTrackPublishError<DataTrackPublishErrorReason.Cancelled> | undefined;
64
- }>;
65
- /** Get information about all currently published tracks. */
66
- queryPublished(): Promise<DataTrackInfo[]>;
67
- /** Client request to unpublish a track. */
67
+ tryProcessAndSend(handle: DataTrackHandle, frame: DataTrackFrameInternal): Promise<Throws<void, DataTrackPushFrameError<DataTrackPushFrameErrorReason.Dropped> | DataTrackPushFrameError<DataTrackPushFrameErrorReason.TrackUnpublished>>>;
68
+ /**
69
+ * Client requested to publish a track.
70
+ *
71
+ * If the LiveKit server is too old and doesn't support data tracks, a
72
+ * {@link DataTrackPublishError#timeout} will be thrown.
73
+ *
74
+ * @internal
75
+ **/
76
+ publishRequest(options: DataTrackOptions, signal?: AbortSignal): Promise<Throws<DataTrackHandle, DataTrackPublishError>>;
77
+ /**
78
+ * Get information about all currently published tracks.
79
+ * @internal
80
+ **/
81
+ queryPublished(): DataTrackInfo[];
82
+ /**
83
+ * Client request to unpublish a track.
84
+ * @internal
85
+ **/
68
86
  unpublishRequest(handle: DataTrackHandle): Promise<void>;
69
- /** SFU responded to a request to publish a data track. */
87
+ /**
88
+ * SFU responded to a request to publish a data track.
89
+ * @internal
90
+ **/
70
91
  receivedSfuPublishResponse(handle: DataTrackHandle, result: SfuPublishResponseResult): void;
71
- /** SFU notification that a track has been unpublished. */
92
+ /**
93
+ * SFU notification that a track has been unpublished.
94
+ * @internal
95
+ **/
72
96
  receivedSfuUnpublishResponse(handle: DataTrackHandle): void;
73
- /** Shuts down the manager and all associated tracks. */
97
+ /** Republish all tracks.
98
+ *
99
+ * This must be sent after a full reconnect in order for existing publications
100
+ * to be recognized by the SFU. Each republished track will be assigned a new SID.
101
+ * @internal
102
+ */
103
+ sfuWillRepublishTracks(): void;
104
+ /**
105
+ * Shuts down the manager and all associated tracks.
106
+ * @internal
107
+ **/
74
108
  shutdown(): Promise<void>;
75
109
  }
76
110
  export {};
@@ -15,19 +15,29 @@ export declare enum DataTrackPublishErrorReason {
15
15
  LimitReached = 3,
16
16
  /** Cannot publish data track when the room is disconnected. */
17
17
  Disconnected = 4,
18
- Cancelled = 5
18
+ Cancelled = 5,
19
+ /** The name requested is not able to be used when creating the data track. */
20
+ InvalidName = 6,
21
+ /** There was an error publishing, but it was not something that could be sorted into a known
22
+ * category. */
23
+ Unknown = 7
19
24
  }
20
- export declare class DataTrackPublishError<Reason extends DataTrackPublishErrorReason> extends LivekitReasonedError<Reason> {
25
+ export declare class DataTrackPublishError<Reason extends DataTrackPublishErrorReason = DataTrackPublishErrorReason> extends LivekitReasonedError<Reason> {
21
26
  readonly name = "DataTrackPublishError";
22
27
  reason: Reason;
23
28
  reasonName: string;
29
+ /** Underling message from the SFU, if one was provided */
30
+ rawMessage?: string;
24
31
  constructor(message: string, reason: Reason, options?: {
32
+ rawMessage?: string;
25
33
  cause?: unknown;
26
34
  });
27
- static notAllowed(): DataTrackPublishError<DataTrackPublishErrorReason.NotAllowed>;
28
- static duplicateName(): DataTrackPublishError<DataTrackPublishErrorReason.DuplicateName>;
35
+ static notAllowed(rawMessage?: string): DataTrackPublishError<DataTrackPublishErrorReason.NotAllowed>;
36
+ static duplicateName(rawMessage?: string): DataTrackPublishError<DataTrackPublishErrorReason.DuplicateName>;
37
+ static invalidName(rawMessage?: string): DataTrackPublishError<DataTrackPublishErrorReason.InvalidName>;
29
38
  static timeout(): DataTrackPublishError<DataTrackPublishErrorReason.Timeout>;
30
- static limitReached(): DataTrackPublishError<DataTrackPublishErrorReason.LimitReached>;
39
+ static limitReached(rawMessage?: string): DataTrackPublishError<DataTrackPublishErrorReason.LimitReached>;
40
+ static unknown(reason: number, message: string): DataTrackPublishError<DataTrackPublishErrorReason.Unknown>;
31
41
  static disconnected(): DataTrackPublishError<DataTrackPublishErrorReason.Disconnected>;
32
42
  static cancelled(): DataTrackPublishError<DataTrackPublishErrorReason.Cancelled>;
33
43
  }
@@ -45,7 +55,7 @@ export declare class DataTrackPushFrameError<Reason extends DataTrackPushFrameEr
45
55
  cause?: unknown;
46
56
  });
47
57
  static trackUnpublished(): DataTrackPushFrameError<DataTrackPushFrameErrorReason.TrackUnpublished>;
48
- static dropped(cause: unknown): DataTrackPushFrameError<DataTrackPushFrameErrorReason.Dropped>;
58
+ static dropped(cause?: unknown): DataTrackPushFrameError<DataTrackPushFrameErrorReason.Dropped>;
49
59
  }
50
60
  export declare enum DataTrackOutgoingPipelineErrorReason {
51
61
  Packetizer = 0,