dingrtc 3.8.10 → 3.8.12-dev.1

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.
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import * as _dingrtc_shared from '@dingrtc/shared';
2
- import { EventEmitter, Reporter, VideoSendReport, AudioSendReport, VideoReceiveReport, AudioReceiveReport, AudioNetEQReport, BweReport, AudioDeviceBufferReport, DingRTCError, PromiseLikeObject, ResolutionInfo as ResolutionInfo$1, TrackMediaType as TrackMediaType$1 } from '@dingrtc/shared';
2
+ import { EventEmitter, Reporter, ILogger, VideoSendReport, AudioSendReport, VideoReceiveReport, AudioReceiveReport, AudioNetEQReport, BweReport, AudioDeviceBufferReport, DingRTCError, PromiseLikeObject, ResolutionInfo as ResolutionInfo$1, TrackMediaType as TrackMediaType$1 } from '@dingrtc/shared';
3
3
  export { ErrorCodeAndMsgMap } from '@dingrtc/shared';
4
4
  import * as _dingrtc_channel from '@dingrtc/channel';
5
5
  import { DingRTCChannel, JoinParam as JoinParam$1, ISignal_msg, UserEventAction as UserEventAction$1 } from '@dingrtc/channel';
@@ -1449,11 +1449,12 @@ declare namespace signal_msg {
1449
1449
  /**
1450
1450
  * @internal
1451
1451
  */
1452
- declare class Signaling extends EventEmitter<SignalingEvent> {
1452
+ declare class RtcSignaling extends EventEmitter<SignalingEvent> {
1453
1453
  loggedIn: boolean;
1454
1454
  channel: DingRTCChannel;
1455
1455
  rpcId: number;
1456
1456
  reporter: Reporter;
1457
+ logger: ILogger;
1457
1458
  constructor(channel: DingRTCChannel);
1458
1459
  join(joinInfo: JoinParam$1, gslb?: string): Promise<{
1459
1460
  joinResponse: ISignal_msg.IJoinResponse;
@@ -1492,7 +1493,7 @@ declare class Signaling extends EventEmitter<SignalingEvent> {
1492
1493
  syncDataByIds(model: signal_msg.ISyncDataByIdsRequest): Promise<signal_msg.ISyncDataByIdsResponse>;
1493
1494
  observeAllGroups(): Promise<signal_msg.IObserveAllGroupsResponse>;
1494
1495
  unobserveAllGroups(): Promise<signal_msg.IUnobserveAllGroupsResponse>;
1495
- rpc(method: string, data: Uint8Array, param?: any): Promise<signal_msg.IResponse>;
1496
+ private rpc;
1496
1497
  }
1497
1498
 
1498
1499
  interface VideoTrackStatsInfo {
@@ -1678,13 +1679,14 @@ declare class Publication extends EventEmitter<IPublishEvents> {
1678
1679
  connection: PeerConnection;
1679
1680
  tracks: LocalTrack[];
1680
1681
  id: string;
1681
- signaling: Signaling;
1682
+ rtcSignaling: RtcSignaling;
1682
1683
  transceiver: RTCRtpTransceiver;
1683
1684
  metricsMap: Map<string, PublicationMetrics>;
1684
1685
  audioStatsMap: Map<string, LocalAudioStates>;
1685
1686
  videoStatsMap: Map<string, LocalVideoStates>;
1686
1687
  state: PubSubStates;
1687
1688
  reporter: Reporter;
1689
+ logger: ILogger;
1688
1690
  mid: string;
1689
1691
  encodings: SenderEncoding[];
1690
1692
  private feedbackIndex;
@@ -1718,10 +1720,14 @@ declare class SessionManager extends EventEmitter<SessionManagerEvent> {
1718
1720
  private uplink;
1719
1721
  private downlink;
1720
1722
  private streamIdToSessionId;
1721
- channel: ChannelManager;
1723
+ serviceManager: ServiceManager;
1722
1724
  reporter: Reporter;
1723
- constructor(client: DingRTCClient, channel: ChannelManager);
1725
+ logger: ILogger;
1726
+ constructor(client: DingRTCClient, serviceManager: ServiceManager);
1724
1727
  private getOrCreatePeerConnection;
1728
+ /**
1729
+ * TODO: 确认为什么 repub 不需要响应服务端的 reoffer 消息?
1730
+ */
1725
1731
  private handleRepulish;
1726
1732
  handleStuckResubscribe(sessions: Subscription[]): Promise<void>;
1727
1733
  private handleResubscribe;
@@ -1762,7 +1768,7 @@ interface PeerConnectionProps {
1762
1768
  declare class PeerConnection extends EventEmitter<IPeerConnectionEvents> {
1763
1769
  pc: RTCPeerConnection;
1764
1770
  private pendingTask;
1765
- signaling: Signaling;
1771
+ rtcSignaling: RtcSignaling;
1766
1772
  state: PeerConnectionState;
1767
1773
  private exchangeSdpTask;
1768
1774
  monitor: PeerConnectionMonitor;
@@ -1770,6 +1776,7 @@ declare class PeerConnection extends EventEmitter<IPeerConnectionEvents> {
1770
1776
  createPeerConnectionPromise: PromiseLikeObject;
1771
1777
  peerConnectionStats: PeerConnectionMetrics;
1772
1778
  reporter: Reporter;
1779
+ logger: ILogger;
1773
1780
  createPeerConnectionTimer: number;
1774
1781
  mcuAudioStream: MediaStream;
1775
1782
  idToTransceiverMap: Map<string, RTCRtpTransceiver>;
@@ -1804,6 +1811,10 @@ declare class PeerConnection extends EventEmitter<IPeerConnectionEvents> {
1804
1811
  getStats(): Promise<void>;
1805
1812
  private detachEvents;
1806
1813
  private onIceGatheringStateChange;
1814
+ /**
1815
+ * @deprecated 目前没有被调用,考虑删除
1816
+ * @returns
1817
+ */
1807
1818
  startTask(): Promise<unknown>;
1808
1819
  private exchangeSDP;
1809
1820
  reoffer(): Promise<void>;
@@ -1838,10 +1849,11 @@ declare class Subscription extends EventEmitter<ISubscribeEvents> {
1838
1849
  private monitor;
1839
1850
  userConfigResolution: ResolutionInfo$1;
1840
1851
  connection: PeerConnection;
1841
- private signaling;
1852
+ private rtcSignaling;
1842
1853
  private _stream;
1843
1854
  stucked: boolean;
1844
- reporter?: Reporter;
1855
+ reporter: Reporter;
1856
+ logger: ILogger;
1845
1857
  metricsMap: Map<string, SubscriptionMetrics>;
1846
1858
  audioStatsMap: Map<string, RemoteAudioStates>;
1847
1859
  videoStatsMap: Map<string, RemoteVideoStates>;
@@ -1872,7 +1884,7 @@ declare class Subscription extends EventEmitter<ISubscribeEvents> {
1872
1884
  * 如果检测到远端用户已经发布,可以将这个对象的uid传入 DingRTCClient.subscribe 中发起订阅,订阅成功后可以通过本对象的 audioTrack、videoTrack或auxiliaryTrack 字段获取远端音视频轨道对象用于播放。
1873
1885
  */
1874
1886
  declare class User extends EventEmitter {
1875
- private channel;
1887
+ private serviceManager;
1876
1888
  /**
1877
1889
  * 远端用户的用户 ID。
1878
1890
  */
@@ -1916,7 +1928,7 @@ declare class User extends EventEmitter {
1916
1928
  /**
1917
1929
  * @internal
1918
1930
  */
1919
- constructor(participant: ISignal_msg.IParticipantInfo, channel: ChannelManager);
1931
+ constructor(participant: ISignal_msg.IParticipantInfo, serviceManager: ServiceManager);
1920
1932
  get relatedStreams(): signal_msg.IStream[];
1921
1933
  /**
1922
1934
  * 远端当前是否在发送桌面共享。
@@ -2066,7 +2078,7 @@ declare class DingRTCClient extends EventEmitter<IClientEvents> {
2066
2078
  id: string;
2067
2079
  private reporter;
2068
2080
  private logger;
2069
- private channel;
2081
+ private serviceManager;
2070
2082
  private monitor;
2071
2083
  private syncStatTimer;
2072
2084
  private clientStatSync;
@@ -2247,13 +2259,14 @@ interface GroupManagerEvent {
2247
2259
  group: (action: GroupEventAction, group: Group | string, payload?: GroupUser | signal_msg.IGroupProperty | string | signal_msg.IGroupAudioInfo) => void;
2248
2260
  }
2249
2261
  declare class GroupManager extends EventEmitter<GroupManagerEvent> {
2250
- private channel;
2262
+ private serviceManager;
2251
2263
  groupIds: Set<string>;
2252
2264
  groups: Map<string, signal_msg.IGroupInfo>;
2253
2265
  default: signal_msg.IGroupInfo;
2254
2266
  listVer: number;
2255
2267
  client: DingRTCClient;
2256
- constructor(channel: ChannelManager);
2268
+ logger: ILogger;
2269
+ constructor(serviceManager: ServiceManager);
2257
2270
  get joinedIds(): Set<unknown>;
2258
2271
  private parseGroup;
2259
2272
  get groupList(): Group[];
@@ -2294,8 +2307,9 @@ declare class StreamManager extends EventEmitter<StreamManagerEvent> {
2294
2307
  streams: Map<string, signal_msg.IStream>;
2295
2308
  totalVer: number;
2296
2309
  reporter: Reporter;
2297
- signaling: Signaling;
2298
- constructor(channel: ChannelManager);
2310
+ rtcSignaling: RtcSignaling;
2311
+ logger: ILogger;
2312
+ constructor(serviceManager: ServiceManager);
2299
2313
  clear(): void;
2300
2314
  init(streams: signal_msg.IStream[], version: number): void;
2301
2315
  private add;
@@ -2310,14 +2324,15 @@ type UserEventAction = 'join' | 'leave';
2310
2324
  interface UserManagerEvent {
2311
2325
  user: (action: UserEventAction, user: User) => void;
2312
2326
  }
2313
- declare class UserManager extends EventEmitter<UserManagerEvent> {
2314
- private channel;
2327
+ declare class RtcUserManager extends EventEmitter<UserManagerEvent> {
2328
+ private serviceManager;
2315
2329
  users: Map<string, User>;
2316
2330
  currentUid: string;
2317
2331
  currentPid: string;
2318
2332
  reporter: Reporter;
2333
+ logger: ILogger;
2319
2334
  streamManager: StreamManager;
2320
- constructor(channel: ChannelManager, streamManager: StreamManager);
2335
+ constructor(serviceManager: ServiceManager, streamManager: StreamManager);
2321
2336
  get remoteUsers(): User[];
2322
2337
  init(participants: ISignal_msg.IParticipantInfo[], currentPid: string): void;
2323
2338
  clear(): void;
@@ -2328,15 +2343,16 @@ declare class UserManager extends EventEmitter<UserManagerEvent> {
2328
2343
  /**
2329
2344
  * @internal
2330
2345
  */
2331
- declare class ChannelManager extends EventEmitter<ChannelEvens> {
2332
- signaling: Signaling;
2346
+ declare class ServiceManager extends EventEmitter<ChannelEvens> {
2347
+ rtcSignaling: RtcSignaling;
2333
2348
  sessionManager: SessionManager;
2334
2349
  groupManager: GroupManager;
2335
- userManager: UserManager;
2350
+ rtcUserManager: RtcUserManager;
2336
2351
  streamManager: StreamManager;
2337
2352
  remoteAudioTrack: RemoteAudioTrack;
2338
2353
  internalChannel: DingRTCChannel;
2339
2354
  reporter: Reporter;
2355
+ logger: ILogger;
2340
2356
  roomId: string;
2341
2357
  defaultVideoStreamType: RemoteStreamType;
2342
2358
  client: DingRTCClient;
@@ -2545,6 +2561,7 @@ interface GlobalClientConfigInfo {
2545
2561
  audioSFU?: boolean;
2546
2562
  republish?: boolean;
2547
2563
  disableTransportCC?: boolean;
2564
+ highStartBitrate?: boolean;
2548
2565
  }
2549
2566
  /**
2550
2567
  * 加入频道所需信息
@@ -2948,7 +2965,7 @@ interface Group {
2948
2965
  }
2949
2966
  type GroupPropertyUpdateTypes = 'set-name' | 'remove-name';
2950
2967
  interface ISharedChannelInstance {
2951
- attach(channel: DingRTCChannel, client: ChannelManager): void;
2968
+ attach(channel: DingRTCChannel, client: ServiceManager): void;
2952
2969
  detach(channel: DingRTCChannel): void;
2953
2970
  }
2954
2971
  interface ChannelEvens {