@rongcloud/plugin-rtc 5.34.0-alpha.3 → 5.36.0-alpha.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.cjs.js +1 -1
- package/dist/index.d.ts +1616 -1228
- package/dist/index.esm.js +2 -2
- package/package.json +2 -2
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as _rongcloud_engine from '@rongcloud/engine';
|
|
2
|
-
import { EventEmitter, BasicLogger, INaviInfo,
|
|
2
|
+
import { EventEmitter, BasicLogger, INaviInfo, RTCPluginContext, Codec, IPromiseResult, ErrorCode, KVString, IRuntime, IAsyncRes, RCConnectionStatus, ConversationType, ISendMsgOptions, IReceivedMessage, LogL, EnableLogL, RTCMode as RTCMode$1, IPluginGenerator } from '@rongcloud/engine';
|
|
3
3
|
|
|
4
4
|
/**
|
|
5
5
|
* 错误码,与移动端对齐
|
|
@@ -28,6 +28,10 @@ declare enum RCRTCCode {
|
|
|
28
28
|
SERVICE_INVALID = 50004,
|
|
29
29
|
/** RTC Token 无效 */
|
|
30
30
|
RTC_TOKEN_INVALID = 50006,
|
|
31
|
+
/** 后台未开通语音识别服务 */
|
|
32
|
+
ASR_NOT_AVAILABLE = 50034,
|
|
33
|
+
/** 此房间未开启语音识别服务 */
|
|
34
|
+
ASR_NOT_START = 50035,
|
|
31
35
|
/** 底层信令调用错误 */
|
|
32
36
|
SIGNAL_ERROR = 53001,
|
|
33
37
|
/** 创建 Offer 失败 */
|
|
@@ -598,6 +602,24 @@ declare enum RTCMode {
|
|
|
598
602
|
CALL = 5
|
|
599
603
|
}
|
|
600
604
|
|
|
605
|
+
/**
|
|
606
|
+
* ASR 状态枚举
|
|
607
|
+
*/
|
|
608
|
+
declare enum RCRTCASRStatus {
|
|
609
|
+
/**
|
|
610
|
+
* 无效值
|
|
611
|
+
*/
|
|
612
|
+
VOID = "0",
|
|
613
|
+
/**
|
|
614
|
+
* 打开
|
|
615
|
+
*/
|
|
616
|
+
OPEN = "2",
|
|
617
|
+
/**
|
|
618
|
+
* 关闭
|
|
619
|
+
*/
|
|
620
|
+
CLOSE = "1"
|
|
621
|
+
}
|
|
622
|
+
|
|
601
623
|
/**
|
|
602
624
|
* 与 MediaServer 交互所需的 Request Header 信息
|
|
603
625
|
*/
|
|
@@ -702,6 +724,10 @@ interface IExchangeReqBody {
|
|
|
702
724
|
* 是否支持 ipv6
|
|
703
725
|
*/
|
|
704
726
|
ipType: number;
|
|
727
|
+
/**
|
|
728
|
+
* asr 开关状态
|
|
729
|
+
*/
|
|
730
|
+
asr_status: RCRTCASRStatus;
|
|
705
731
|
}
|
|
706
732
|
interface ILiveUrls {
|
|
707
733
|
/**
|
|
@@ -890,6 +916,11 @@ interface ICDNUris {
|
|
|
890
916
|
'pull_safe': boolean;
|
|
891
917
|
}
|
|
892
918
|
|
|
919
|
+
declare enum RCRTCAISwitchType {
|
|
920
|
+
OPEN = 1,
|
|
921
|
+
CLOSE = 0
|
|
922
|
+
}
|
|
923
|
+
|
|
893
924
|
/**
|
|
894
925
|
* 设置 RTC 人员 inner、outer 数据
|
|
895
926
|
*/
|
|
@@ -1078,6 +1109,15 @@ interface IRTCNaviInfo extends INaviInfo {
|
|
|
1078
1109
|
* openGzip 开启标识,默认是false,开启使用true
|
|
1079
1110
|
*/
|
|
1080
1111
|
openGzip?: boolean;
|
|
1112
|
+
/**
|
|
1113
|
+
* AI 开关是否打开,1: 打开,0: 关闭
|
|
1114
|
+
*/
|
|
1115
|
+
rtcAISwitch?: RCRTCAISwitchType;
|
|
1116
|
+
}
|
|
1117
|
+
|
|
1118
|
+
declare enum RCRTCOperateSummarizationType {
|
|
1119
|
+
OPEN = "2",
|
|
1120
|
+
CLOSE = "1"
|
|
1081
1121
|
}
|
|
1082
1122
|
|
|
1083
1123
|
declare abstract class ReadableStore {
|
|
@@ -1124,6 +1164,40 @@ declare abstract class ReadableStore {
|
|
|
1124
1164
|
protected _trackIdSSRCMap: Map<number, string>;
|
|
1125
1165
|
protected _roomStatusVersion: number;
|
|
1126
1166
|
protected _supportNtf: boolean;
|
|
1167
|
+
/**
|
|
1168
|
+
* asr 的打开状态
|
|
1169
|
+
*/
|
|
1170
|
+
protected _asrStatus: RCRTCASRStatus;
|
|
1171
|
+
/**
|
|
1172
|
+
* asr 是否被启用
|
|
1173
|
+
*/
|
|
1174
|
+
protected _asrEnable: boolean;
|
|
1175
|
+
/**
|
|
1176
|
+
* asr 输入语言,用于精准识别语音
|
|
1177
|
+
*/
|
|
1178
|
+
protected _srcLanguage: string;
|
|
1179
|
+
/**
|
|
1180
|
+
* asr sei uris 信息
|
|
1181
|
+
*/
|
|
1182
|
+
protected _asrSeiUris: {
|
|
1183
|
+
[userId: string]: IPublishedResource[];
|
|
1184
|
+
};
|
|
1185
|
+
/**
|
|
1186
|
+
* 是否开启实时翻译
|
|
1187
|
+
*/
|
|
1188
|
+
protected _isStartRealTranslate: boolean;
|
|
1189
|
+
/**
|
|
1190
|
+
* 翻译目标语言
|
|
1191
|
+
*/
|
|
1192
|
+
protected _translationLang: string;
|
|
1193
|
+
/**
|
|
1194
|
+
* 会议纪要开关状态、任务ID
|
|
1195
|
+
*/
|
|
1196
|
+
protected _summarizationStatusData: ISummarizationStatusData | null;
|
|
1197
|
+
/**
|
|
1198
|
+
* 语音识别中本地用户的昵称
|
|
1199
|
+
*/
|
|
1200
|
+
protected _nickName: string;
|
|
1127
1201
|
constructor(_logger: BasicLogger, clientSessionId: string, appkey: string, roomId: string, crtUserId: string, roomMode: RTCMode, isUpgrade?: boolean | undefined, isMainRoom?: boolean | undefined);
|
|
1128
1202
|
getResourcesByUserId(userId: string): IPublishedResource[] | undefined;
|
|
1129
1203
|
getRemoteTrack(trackId: string): RCRemoteAudioTrack | RCRemoteVideoTrack | undefined;
|
|
@@ -1144,6 +1218,15 @@ declare abstract class ReadableStore {
|
|
|
1144
1218
|
getTrackIdBySSRC(ssrc: number): string | undefined;
|
|
1145
1219
|
getRTCRequestHeader(): IRTCReqHeader;
|
|
1146
1220
|
getSupportNtf(): boolean;
|
|
1221
|
+
getASRIsAvailable(): boolean;
|
|
1222
|
+
getASRStatus(): RCRTCASRStatus;
|
|
1223
|
+
getASREnable(): boolean;
|
|
1224
|
+
getSrcLanguage(): string;
|
|
1225
|
+
getASRSeiUris(): IPublishedResource[];
|
|
1226
|
+
getIsStartRealTranslate(): boolean;
|
|
1227
|
+
getTranslationLang(): string;
|
|
1228
|
+
getSummarizationStatusData(): ISummarizationStatusData | null;
|
|
1229
|
+
getNickName(): string;
|
|
1147
1230
|
}
|
|
1148
1231
|
declare class Store extends ReadableStore {
|
|
1149
1232
|
/**
|
|
@@ -1164,6 +1247,202 @@ declare class Store extends ReadableStore {
|
|
|
1164
1247
|
resetSubscribedList(subscribeList: ISubscribeAttr[]): void;
|
|
1165
1248
|
resetCollectSubscribeList(collectSubscribeList: ISubscribeAttr[]): void;
|
|
1166
1249
|
setRoomStatusVersion(version: number): void;
|
|
1250
|
+
setASRStatus(status: RCRTCASRStatus): void;
|
|
1251
|
+
setASREnable(enable: boolean): void;
|
|
1252
|
+
setSrcLanguage(srcLanguage: string): void;
|
|
1253
|
+
setASRSeiUris(uris: IPublishedResource[]): void;
|
|
1254
|
+
addSeiRemoteTrack(uris: IPublishedResource[]): void;
|
|
1255
|
+
removeSeiRemoteTrack(): void;
|
|
1256
|
+
setIsStartRealTranslate(isStart: boolean): void;
|
|
1257
|
+
setTranslationLang(lang: string): void;
|
|
1258
|
+
setSummarizationStatusData(summarizationStatusData: {
|
|
1259
|
+
taskId?: string;
|
|
1260
|
+
status: RCRTCOperateSummarizationType;
|
|
1261
|
+
}): void;
|
|
1262
|
+
setNickName(nickName: string): void;
|
|
1263
|
+
}
|
|
1264
|
+
|
|
1265
|
+
/**
|
|
1266
|
+
* 多端登录时,加入房间时的踢人策略
|
|
1267
|
+
*/
|
|
1268
|
+
declare enum RTCJoinType {
|
|
1269
|
+
/**
|
|
1270
|
+
* 踢出已存在于房间的设备,以便于当前设备加入房间
|
|
1271
|
+
*/
|
|
1272
|
+
KICK = 0,
|
|
1273
|
+
/**
|
|
1274
|
+
* 保持已存在于房间的设备,拒绝当前设备加入房间
|
|
1275
|
+
*/
|
|
1276
|
+
REFUSE = 1
|
|
1277
|
+
}
|
|
1278
|
+
|
|
1279
|
+
declare enum RTCApiType {
|
|
1280
|
+
ROOM = 1,
|
|
1281
|
+
PERSON = 2
|
|
1282
|
+
}
|
|
1283
|
+
|
|
1284
|
+
declare enum RTCIdentityChangeType {
|
|
1285
|
+
AnchorToViewer = 1,
|
|
1286
|
+
ViewerToAnchor = 2
|
|
1287
|
+
}
|
|
1288
|
+
|
|
1289
|
+
declare const keymaps: {
|
|
1290
|
+
readonly RtcInput: readonly ["roomType", "broadcastType", "extraInnerData", "needSysChatroom", "identityChangeType", "joinType", "innerDatas", "outerDatas", "supportNtf"];
|
|
1291
|
+
readonly RtcOutput: readonly ["version"];
|
|
1292
|
+
readonly RtcUserListOutput: readonly ["users", "token", "sessionId", "roomInfo", "version"];
|
|
1293
|
+
readonly SetUserStatusInput: readonly ["status"];
|
|
1294
|
+
readonly RtcSetDataInput: readonly ["interior", "target", "key", "value", "objectName", "content"];
|
|
1295
|
+
readonly RtcUserSetDataInput: readonly ["valueInfo", "objectName", "content"];
|
|
1296
|
+
readonly RtcDataInput: readonly ["interior", "target", "key", "objectName", "content"];
|
|
1297
|
+
readonly RtcSetOutDataInput: readonly ["target", "valueInfo", "objectName", "content"];
|
|
1298
|
+
readonly MCFollowInput: readonly ["state"];
|
|
1299
|
+
readonly RtcTokenOutput: readonly ["rtcToken"];
|
|
1300
|
+
readonly RtcQryOutput: readonly ["outInfo"];
|
|
1301
|
+
readonly RtcQryUserOutDataInput: readonly ["userId"];
|
|
1302
|
+
readonly RtcUserOutDataOutput: readonly ["user"];
|
|
1303
|
+
readonly RtcQueryListInput: readonly ["order"];
|
|
1304
|
+
readonly RtcRoomInfoOutput: readonly ["roomId", "roomData", "userCount", "list"];
|
|
1305
|
+
readonly RtcValueInfo: readonly ["key", "value"];
|
|
1306
|
+
readonly RtcKeyDeleteInput: readonly ["key"];
|
|
1307
|
+
readonly RtcNotifyMsg: readonly ["type", "time", "roomId"];
|
|
1308
|
+
readonly RtcPullKV: readonly ["timestamp", "roomId"];
|
|
1309
|
+
readonly RtcKVOutput: readonly ["entries", "bFullUpdate", "syncTime"];
|
|
1310
|
+
readonly RtcQueryUserJoinedInput: readonly ["userId"];
|
|
1311
|
+
readonly RtcQueryUserJoinedOutput: readonly ["info"];
|
|
1312
|
+
readonly RtcInviteInput: readonly ["invitedUserId", "timeoutTime", "invitedRoomId", "inviteInfo", "inviteSessionId"];
|
|
1313
|
+
readonly RtcCancelInviteInput: readonly ["invitedUserId", "invitedRoomId", "inviteInfo", "inviteSessionId"];
|
|
1314
|
+
readonly RtcInviteAnswerInput: readonly ["inviteUserId", "answerCode", "inviteRoomId", "inviteSessionId", "content", "key", "value"];
|
|
1315
|
+
readonly RtcEndInviteInput: readonly ["inviteRoomId", "inviteSessionId", "inviteContent", "inviteRoomKeys"];
|
|
1316
|
+
readonly RtcRoomStatusInput: readonly ["version"];
|
|
1317
|
+
readonly RtcRoomStatusOutput: readonly ["bFullStatus", "version", "usersData", "roomStatus"];
|
|
1318
|
+
readonly RtcReportSDKInput: readonly ["sdkInfo"];
|
|
1319
|
+
readonly RCRTCPBPolaris: readonly ["type", "appKey", "sessionId", "roomId", "roomCreateTime", "userId", "userRole", "joinTime", "signalDataCenter", "r1Info", "r2Info", "r3Info", "r4Info"];
|
|
1320
|
+
readonly RCRTCPBR1Info: readonly ["joinTime", "rtcVersion", "imVersion", "platform", "device", "os", "browserName", "browserVersion"];
|
|
1321
|
+
readonly RCRTCPBR2Info: readonly ["joinTime", "sendTime", "rtcActionType", "rtcActionStatus", "trackId"];
|
|
1322
|
+
readonly RCRTCPBR3Info: readonly ["info"];
|
|
1323
|
+
readonly RCRTCPBR4Info: readonly ["info"];
|
|
1324
|
+
readonly RCRTCPBStatusInfo: readonly ["joinTime", "receiveTime", "totalBitRate", "appCPUUsage", "systemCPUUsage", "systemCPUFrequency", "networkStatus", "googleRTTNetwork", "ipAddress", "useReceiveBroadBand", "useSendBroadBand", "packetLossCount", "streams"];
|
|
1325
|
+
readonly RCRTCPBStreamInfo: readonly ["trackId", "codeName", "volume", "samplingRate", "bitRate", "packetLossRate", "frameRate", "resolution", "blockTime", "jitterData", "nAckCount", "pliCount", "googleRTTTotalTime", "isReceiveFirstFrameRate", "codeType", "isEnabled"];
|
|
1326
|
+
readonly AsrTextMsg: readonly ["bms", "t", "isEnd", "msgId", "lang"];
|
|
1327
|
+
readonly AsrResTextMsg: readonly ["type", "uid", "asr"];
|
|
1328
|
+
};
|
|
1329
|
+
declare type RTCKeyMaps = typeof keymaps;
|
|
1330
|
+
|
|
1331
|
+
/**
|
|
1332
|
+
* 自定义上报北极星数据响应 code
|
|
1333
|
+
*/
|
|
1334
|
+
declare enum RCSendCode {
|
|
1335
|
+
NOT_REPORT = -1,
|
|
1336
|
+
REPORT_SUCCESS = 10000,
|
|
1337
|
+
REPORT_FAIL = 0,
|
|
1338
|
+
PB_ERROR = 40001
|
|
1339
|
+
}
|
|
1340
|
+
|
|
1341
|
+
declare class RTCContext {
|
|
1342
|
+
private context;
|
|
1343
|
+
logger: BasicLogger;
|
|
1344
|
+
private codec;
|
|
1345
|
+
roomCreateTime: number | undefined;
|
|
1346
|
+
userJoinTime: number | undefined;
|
|
1347
|
+
constructor(context: RTCPluginContext, logger: BasicLogger, codec: Codec<RTCKeyMaps>);
|
|
1348
|
+
joinRTCRoom(roomId: string, mode: RTCMode, broadcastType?: number, joinType?: RTCJoinType, innerUserDatas?: IRTCUserData, outerUserDatas?: IRTCUserData, supportNtf?: boolean): IPromiseResult<IJoinRTCRoomData>;
|
|
1349
|
+
quitRTCRoom(roomId: string): Promise<ErrorCode>;
|
|
1350
|
+
getRTCRoomInfo(roomId: string): IPromiseResult<IRTCRoomInfo>;
|
|
1351
|
+
/**
|
|
1352
|
+
* 移动端用来获取副房间资源
|
|
1353
|
+
*/
|
|
1354
|
+
getRTCUserInfoList(roomId: string): IPromiseResult<IRTCUsers>;
|
|
1355
|
+
getRTCUserInfo(roomId: string): IPromiseResult<unknown>;
|
|
1356
|
+
removeRTCUserInfo(roomId: string, keys: string[]): Promise<ErrorCode>;
|
|
1357
|
+
setRTCData(roomId: string, key: string, value: string, isInner: boolean, apiType: RTCApiType, message?: {
|
|
1358
|
+
name: string;
|
|
1359
|
+
content: string;
|
|
1360
|
+
}): Promise<ErrorCode>;
|
|
1361
|
+
/**
|
|
1362
|
+
* 全量订阅资源修改
|
|
1363
|
+
* @param roomId 房间 Id
|
|
1364
|
+
* @param message 向前兼容的消息内容
|
|
1365
|
+
* @param valueInfo 全量资源数据
|
|
1366
|
+
* @param objectName 全量 URI 消息名
|
|
1367
|
+
*/
|
|
1368
|
+
setRTCTotalRes(roomId: string, messageList: {
|
|
1369
|
+
name: string;
|
|
1370
|
+
content: string;
|
|
1371
|
+
}[], valueInfo: string, objectName: string, mcuValInfo?: string, cdnValInfo?: string): Promise<ErrorCode>;
|
|
1372
|
+
setRTCCDNUris(roomId: string, objectName: string, CDNUris: string): Promise<ErrorCode>;
|
|
1373
|
+
getRTCData(roomId: string, keys: string[], isInner: boolean, apiType: RTCApiType): IPromiseResult<KVString>;
|
|
1374
|
+
removeRTCData(roomId: string, keys: string[], isInner: boolean, apiType: RTCApiType, message?: {
|
|
1375
|
+
name: string;
|
|
1376
|
+
content: string;
|
|
1377
|
+
}): Promise<ErrorCode>;
|
|
1378
|
+
setRTCOutData(roomId: string, rtcData: unknown, type: number, message: unknown): Promise<ErrorCode>;
|
|
1379
|
+
getRTCOutData(roomId: string, userIds: string[]): IPromiseResult<unknown>;
|
|
1380
|
+
getRTCToken(roomId: string, mode: number, broadcastType?: number): IPromiseResult<IRtcTokenData>;
|
|
1381
|
+
setRTCState(roomId: string, report: string): Promise<ErrorCode>;
|
|
1382
|
+
/**
|
|
1383
|
+
* 通过 http 方式上报 rtc state
|
|
1384
|
+
*/
|
|
1385
|
+
setRTCStateByHttp(logServer: string, runtime: IRuntime, report: IRCRTCReportData, reportType: string): Promise<RCSendCode | RCRTCCode>;
|
|
1386
|
+
getRTCUserList(roomId: string): IPromiseResult<IRTCUsers>;
|
|
1387
|
+
joinLivingRoomAsAudience(roomId: string, mode: RTCMode, broadcastType?: number): Promise<IAsyncRes<{
|
|
1388
|
+
token: string;
|
|
1389
|
+
kvEntries: IServerRTCRoomEntry[];
|
|
1390
|
+
}>>;
|
|
1391
|
+
quitLivingRoomAsAudience(roomId: string): Promise<ErrorCode>;
|
|
1392
|
+
rtcIdentityChange(roomId: string, changeType: RTCIdentityChangeType, broadcastType?: number): Promise<IAsyncRes<IJoinRTCRoomData>>;
|
|
1393
|
+
requestRoomPK(options: IReqRoomPKOptions): Promise<ErrorCode>;
|
|
1394
|
+
cancelRoomPK(options: ICancelRoomPKOptions): Promise<ErrorCode>;
|
|
1395
|
+
responseRoomPK(options: IResRoomPKOptions): Promise<ErrorCode>;
|
|
1396
|
+
endRoomPK(options: IEndRoomPKOptions): Promise<ErrorCode>;
|
|
1397
|
+
getRTCJoinedUserInfo(userId: string): Promise<IAsyncRes<IRTCJoinedInfo[]>>;
|
|
1398
|
+
pullRTCRoomEntry(roomId: string): Promise<IAsyncRes<IChrmKVPullData>>;
|
|
1399
|
+
/**
|
|
1400
|
+
* 通知拉取房间数据
|
|
1401
|
+
* @param roomId 房间 id
|
|
1402
|
+
* @param version 本地最大得房间数据版本号
|
|
1403
|
+
*/
|
|
1404
|
+
pullRTCRoomStatus(roomId: string, version: number): Promise<{
|
|
1405
|
+
code: ErrorCode;
|
|
1406
|
+
data?: IPullRTCRoomStatus;
|
|
1407
|
+
}>;
|
|
1408
|
+
decodeRtcNotify(buffer: Uint8Array): {
|
|
1409
|
+
time: number;
|
|
1410
|
+
type: any;
|
|
1411
|
+
roomId: any;
|
|
1412
|
+
};
|
|
1413
|
+
getCurrentId(): string;
|
|
1414
|
+
getNaviInfo(): IRTCNaviInfo | null;
|
|
1415
|
+
getConnectionStatus(): RCConnectionStatus;
|
|
1416
|
+
getAppkey(): string;
|
|
1417
|
+
/** web 端发 rtcPing */
|
|
1418
|
+
webRtcPing(roomId: string, roomMode: RTCMode, broadcastType?: number): Promise<{
|
|
1419
|
+
code: ErrorCode;
|
|
1420
|
+
data?: {
|
|
1421
|
+
version: number;
|
|
1422
|
+
};
|
|
1423
|
+
}>;
|
|
1424
|
+
/**
|
|
1425
|
+
* 协议栈 rtcping 依赖 imlib 编解码数据
|
|
1426
|
+
* web 单独走 imlib 提供的 rtcSignaling 方法,减少对 imlib 的依赖
|
|
1427
|
+
*/
|
|
1428
|
+
rtcPing(roomId: string, roomMode: RTCMode, broadcastType?: number): Promise<_rongcloud_engine.RCResult<any>> | Promise<{
|
|
1429
|
+
code: ErrorCode;
|
|
1430
|
+
data?: {
|
|
1431
|
+
version: number;
|
|
1432
|
+
} | undefined;
|
|
1433
|
+
}>;
|
|
1434
|
+
sendMessage(conversationType: ConversationType, targetId: string, options: ISendMsgOptions): IPromiseResult<IReceivedMessage>;
|
|
1435
|
+
registerRTCSignalListener(listener?: ((buffer: Uint8Array) => void) | undefined): void;
|
|
1436
|
+
registerConnectionStateChangeListener(listener: (status: RCConnectionStatus, code: ErrorCode) => void): void;
|
|
1437
|
+
registerDisconnectListener(listener: () => void): void;
|
|
1438
|
+
registerDestroyListener(listener: () => void): void;
|
|
1439
|
+
registerMessageListener(listener: (message: IReceivedMessage) => boolean): void;
|
|
1440
|
+
getCoreVersion(): string;
|
|
1441
|
+
getPluginContext(): RTCPluginContext;
|
|
1442
|
+
reportSDKInfo(versionInfo: {
|
|
1443
|
+
[name: string]: string;
|
|
1444
|
+
}): void;
|
|
1445
|
+
decodeAsrText(buffer: Uint8Array): (RCRTCASRContent | RCRTCRealtimeTranslationContent)[];
|
|
1167
1446
|
}
|
|
1168
1447
|
|
|
1169
1448
|
declare type ISdpSemantics = 'plan-b' | 'unified-plan';
|
|
@@ -1277,6 +1556,17 @@ interface IRCEncryptorHooks {
|
|
|
1277
1556
|
encodeVideo: RCEncryptFunction;
|
|
1278
1557
|
}
|
|
1279
1558
|
|
|
1559
|
+
declare enum RCRTCGenerateSummarizationFormat {
|
|
1560
|
+
/**
|
|
1561
|
+
* 输出 MarkDown 格式
|
|
1562
|
+
*/
|
|
1563
|
+
MARK_DOWN = 0,
|
|
1564
|
+
/**
|
|
1565
|
+
* 输出 JSON 格式
|
|
1566
|
+
*/
|
|
1567
|
+
JSON = 1
|
|
1568
|
+
}
|
|
1569
|
+
|
|
1280
1570
|
interface IRCTrackBitrate {
|
|
1281
1571
|
/**
|
|
1282
1572
|
* 最大码率
|
|
@@ -1925,6 +2215,38 @@ interface IRoomEventListener extends IRCRTCTrackEventListener {
|
|
|
1925
2215
|
* 主播和观众切换身份通知
|
|
1926
2216
|
*/
|
|
1927
2217
|
onSwitchRole?(userId: string, role: RCRTCLiveRole): void;
|
|
2218
|
+
/**
|
|
2219
|
+
* 语音识别服务开启通知
|
|
2220
|
+
* 如需要语音识别内容和语音实时翻译,可在此时机依次调用 room 的
|
|
2221
|
+
* setSrcLanguageCode 方法,设置输入语言代码,用于语音识别精准识别
|
|
2222
|
+
* setEnableASR 方法,设置房间内的语音识别资源为可用,语音识别内容通过 `onReceiveASRContent` 回调给业务层
|
|
2223
|
+
* startRealtimeTranslation 方法,开启语音实时翻译,实时翻译内容通过 `onReceiveRealtimeTranslationContent` 回调给业务层
|
|
2224
|
+
*/
|
|
2225
|
+
onReceiveStartASR?(): void;
|
|
2226
|
+
/**
|
|
2227
|
+
* 语音识别服务停止通知
|
|
2228
|
+
*/
|
|
2229
|
+
onReceiveStopASR?(): void;
|
|
2230
|
+
/**
|
|
2231
|
+
* 语音识别内容回调
|
|
2232
|
+
* @param asrContent
|
|
2233
|
+
*/
|
|
2234
|
+
onReceiveASRContent?(asrContent: RCRTCASRContent): void;
|
|
2235
|
+
/**
|
|
2236
|
+
* 语音翻译结果回调
|
|
2237
|
+
* @param content
|
|
2238
|
+
*/
|
|
2239
|
+
onReceiveRealtimeTranslationContent?(content: RCRTCRealtimeTranslationContent): void;
|
|
2240
|
+
/**
|
|
2241
|
+
* 开始智能总结
|
|
2242
|
+
* @param taskId 可用于获取会议纪要、会议语音转文字内容
|
|
2243
|
+
*/
|
|
2244
|
+
onReceiveStartSummarization?(taskId: string): void;
|
|
2245
|
+
/**
|
|
2246
|
+
* 结束智能总结
|
|
2247
|
+
* @param taskId
|
|
2248
|
+
*/
|
|
2249
|
+
onReceiveStopSummarization?(taskId: string): void;
|
|
1928
2250
|
}
|
|
1929
2251
|
/**
|
|
1930
2252
|
* RTCClient 初始化配置
|
|
@@ -2220,40 +2542,118 @@ interface IPullRTCRoomUsersData {
|
|
|
2220
2542
|
value: string;
|
|
2221
2543
|
}[];
|
|
2222
2544
|
}
|
|
2223
|
-
|
|
2224
2545
|
/**
|
|
2225
|
-
*
|
|
2546
|
+
* ASR 内容
|
|
2226
2547
|
*/
|
|
2227
|
-
|
|
2548
|
+
interface RCRTCASRContent {
|
|
2228
2549
|
/**
|
|
2229
|
-
*
|
|
2550
|
+
* 当前语音识别关联用户的 ID,
|
|
2230
2551
|
*/
|
|
2231
|
-
|
|
2552
|
+
userID: string;
|
|
2232
2553
|
/**
|
|
2233
|
-
*
|
|
2554
|
+
* 当前语音识别的 ID, 用于关联当前语音识别结果
|
|
2234
2555
|
*/
|
|
2235
|
-
|
|
2556
|
+
msgId: string;
|
|
2236
2557
|
/**
|
|
2237
|
-
*
|
|
2558
|
+
* 当前语音识别的时间戳, 单位为秒
|
|
2238
2559
|
*/
|
|
2239
|
-
|
|
2240
|
-
}
|
|
2241
|
-
|
|
2242
|
-
/**
|
|
2243
|
-
* 合流布局对视频的填充模式
|
|
2244
|
-
*/
|
|
2245
|
-
declare enum MixVideoRenderMode {
|
|
2560
|
+
timeUTC: number;
|
|
2246
2561
|
/**
|
|
2247
|
-
*
|
|
2562
|
+
* 当前语音识别结果
|
|
2248
2563
|
*/
|
|
2249
|
-
|
|
2564
|
+
msg: string;
|
|
2250
2565
|
/**
|
|
2251
|
-
*
|
|
2566
|
+
* 当前语音识别是否结束, 如果为 true, 则表示当前语音识别已结束
|
|
2252
2567
|
*/
|
|
2253
|
-
|
|
2568
|
+
isEnd: boolean;
|
|
2254
2569
|
}
|
|
2255
|
-
|
|
2256
|
-
|
|
2570
|
+
interface RCRTCRealtimeTranslationContent extends RCRTCASRContent {
|
|
2571
|
+
/**
|
|
2572
|
+
* 当前语音翻译的目标语言码
|
|
2573
|
+
*/
|
|
2574
|
+
destLangCode: string;
|
|
2575
|
+
}
|
|
2576
|
+
interface IRCRTCGenerateSummarizationConfig {
|
|
2577
|
+
/**
|
|
2578
|
+
* 自定义提示词,最大长度100
|
|
2579
|
+
*/
|
|
2580
|
+
customPrompt?: string;
|
|
2581
|
+
/**
|
|
2582
|
+
* 输出智能总结的目标语言代码
|
|
2583
|
+
*/
|
|
2584
|
+
destLang?: string;
|
|
2585
|
+
/**
|
|
2586
|
+
* 是否输出总结摘要。即对整个会议的高度概括,默认 false
|
|
2587
|
+
*/
|
|
2588
|
+
enableSummarization?: boolean;
|
|
2589
|
+
/**
|
|
2590
|
+
* 是否为输出总结整体,默认为 false
|
|
2591
|
+
*/
|
|
2592
|
+
enableSummarizationDetails?: boolean;
|
|
2593
|
+
/**
|
|
2594
|
+
* 是否输出章节摘要,即按时间线或话题划分的会议段落总结,默认为 false
|
|
2595
|
+
*/
|
|
2596
|
+
enableChapterSummary?: boolean;
|
|
2597
|
+
/**
|
|
2598
|
+
* 是否输出待办事项提取,自动识别会议中达成的共识和分配的任务,默认为 false
|
|
2599
|
+
*/
|
|
2600
|
+
enableTodoList?: boolean;
|
|
2601
|
+
/**
|
|
2602
|
+
* 是否输出话题提取,默认为 false
|
|
2603
|
+
*/
|
|
2604
|
+
enableHashtag?: boolean;
|
|
2605
|
+
/**
|
|
2606
|
+
* 输出格式,默认为 markdown
|
|
2607
|
+
*/
|
|
2608
|
+
format?: RCRTCGenerateSummarizationFormat;
|
|
2609
|
+
}
|
|
2610
|
+
/**
|
|
2611
|
+
* 智能总结状态数据
|
|
2612
|
+
*/
|
|
2613
|
+
interface ISummarizationStatusData {
|
|
2614
|
+
/**
|
|
2615
|
+
* 智能总结开关状态
|
|
2616
|
+
*/
|
|
2617
|
+
status: RCRTCOperateSummarizationType;
|
|
2618
|
+
/**
|
|
2619
|
+
* 智能总结任务 ID
|
|
2620
|
+
*/
|
|
2621
|
+
taskId?: string;
|
|
2622
|
+
}
|
|
2623
|
+
|
|
2624
|
+
/**
|
|
2625
|
+
* 直播布局模式定义
|
|
2626
|
+
*/
|
|
2627
|
+
declare enum MixLayoutMode {
|
|
2628
|
+
/**
|
|
2629
|
+
* 自定义布局
|
|
2630
|
+
*/
|
|
2631
|
+
CUSTOMIZE = 1,
|
|
2632
|
+
/**
|
|
2633
|
+
* 悬浮布局(默认)
|
|
2634
|
+
*/
|
|
2635
|
+
SUSPENSION = 2,
|
|
2636
|
+
/**
|
|
2637
|
+
* 自适应布局
|
|
2638
|
+
*/
|
|
2639
|
+
ADAPTATION = 3
|
|
2640
|
+
}
|
|
2641
|
+
|
|
2642
|
+
/**
|
|
2643
|
+
* 合流布局对视频的填充模式
|
|
2644
|
+
*/
|
|
2645
|
+
declare enum MixVideoRenderMode {
|
|
2646
|
+
/**
|
|
2647
|
+
* 裁剪(默认)
|
|
2648
|
+
*/
|
|
2649
|
+
CROP = 1,
|
|
2650
|
+
/**
|
|
2651
|
+
* 不裁剪
|
|
2652
|
+
*/
|
|
2653
|
+
WHOLE = 2
|
|
2654
|
+
}
|
|
2655
|
+
|
|
2656
|
+
declare enum RCInnerCDNModel {
|
|
2257
2657
|
OPEN = 1,
|
|
2258
2658
|
STOP = 2
|
|
2259
2659
|
}
|
|
@@ -2497,186 +2897,6 @@ interface ISetEnableCDN {
|
|
|
2497
2897
|
};
|
|
2498
2898
|
}
|
|
2499
2899
|
|
|
2500
|
-
/**
|
|
2501
|
-
* 多端登录时,加入房间时的踢人策略
|
|
2502
|
-
*/
|
|
2503
|
-
declare enum RTCJoinType {
|
|
2504
|
-
/**
|
|
2505
|
-
* 踢出已存在于房间的设备,以便于当前设备加入房间
|
|
2506
|
-
*/
|
|
2507
|
-
KICK = 0,
|
|
2508
|
-
/**
|
|
2509
|
-
* 保持已存在于房间的设备,拒绝当前设备加入房间
|
|
2510
|
-
*/
|
|
2511
|
-
REFUSE = 1
|
|
2512
|
-
}
|
|
2513
|
-
|
|
2514
|
-
declare enum RTCApiType {
|
|
2515
|
-
ROOM = 1,
|
|
2516
|
-
PERSON = 2
|
|
2517
|
-
}
|
|
2518
|
-
|
|
2519
|
-
declare enum RTCIdentityChangeType {
|
|
2520
|
-
AnchorToViewer = 1,
|
|
2521
|
-
ViewerToAnchor = 2
|
|
2522
|
-
}
|
|
2523
|
-
|
|
2524
|
-
declare const keymaps: {
|
|
2525
|
-
readonly RtcInput: readonly ["roomType", "broadcastType", "extraInnerData", "needSysChatroom", "identityChangeType", "joinType", "innerDatas", "outerDatas", "supportNtf"];
|
|
2526
|
-
readonly RtcOutput: readonly ["version"];
|
|
2527
|
-
readonly RtcUserListOutput: readonly ["users", "token", "sessionId", "roomInfo", "version"];
|
|
2528
|
-
readonly SetUserStatusInput: readonly ["status"];
|
|
2529
|
-
readonly RtcSetDataInput: readonly ["interior", "target", "key", "value", "objectName", "content"];
|
|
2530
|
-
readonly RtcUserSetDataInput: readonly ["valueInfo", "objectName", "content"];
|
|
2531
|
-
readonly RtcDataInput: readonly ["interior", "target", "key", "objectName", "content"];
|
|
2532
|
-
readonly RtcSetOutDataInput: readonly ["target", "valueInfo", "objectName", "content"];
|
|
2533
|
-
readonly MCFollowInput: readonly ["state"];
|
|
2534
|
-
readonly RtcTokenOutput: readonly ["rtcToken"];
|
|
2535
|
-
readonly RtcQryOutput: readonly ["outInfo"];
|
|
2536
|
-
readonly RtcQryUserOutDataInput: readonly ["userId"];
|
|
2537
|
-
readonly RtcUserOutDataOutput: readonly ["user"];
|
|
2538
|
-
readonly RtcQueryListInput: readonly ["order"];
|
|
2539
|
-
readonly RtcRoomInfoOutput: readonly ["roomId", "roomData", "userCount", "list"];
|
|
2540
|
-
readonly RtcValueInfo: readonly ["key", "value"];
|
|
2541
|
-
readonly RtcKeyDeleteInput: readonly ["key"];
|
|
2542
|
-
readonly RtcNotifyMsg: readonly ["type", "time", "roomId"];
|
|
2543
|
-
readonly RtcPullKV: readonly ["timestamp", "roomId"];
|
|
2544
|
-
readonly RtcKVOutput: readonly ["entries", "bFullUpdate", "syncTime"];
|
|
2545
|
-
readonly RtcQueryUserJoinedInput: readonly ["userId"];
|
|
2546
|
-
readonly RtcQueryUserJoinedOutput: readonly ["info"];
|
|
2547
|
-
readonly RtcInviteInput: readonly ["invitedUserId", "timeoutTime", "invitedRoomId", "inviteInfo", "inviteSessionId"];
|
|
2548
|
-
readonly RtcCancelInviteInput: readonly ["invitedUserId", "invitedRoomId", "inviteInfo", "inviteSessionId"];
|
|
2549
|
-
readonly RtcInviteAnswerInput: readonly ["inviteUserId", "answerCode", "inviteRoomId", "inviteSessionId", "content", "key", "value"];
|
|
2550
|
-
readonly RtcEndInviteInput: readonly ["inviteRoomId", "inviteSessionId", "inviteContent", "inviteRoomKeys"];
|
|
2551
|
-
readonly RtcRoomStatusInput: readonly ["version"];
|
|
2552
|
-
readonly RtcRoomStatusOutput: readonly ["bFullStatus", "version", "usersData", "roomStatus"];
|
|
2553
|
-
readonly RtcReportSDKInput: readonly ["sdkInfo"];
|
|
2554
|
-
readonly RCRTCPBPolaris: readonly ["type", "appKey", "sessionId", "roomId", "roomCreateTime", "userId", "userRole", "joinTime", "signalDataCenter", "r1Info", "r2Info", "r3Info", "r4Info"];
|
|
2555
|
-
readonly RCRTCPBR1Info: readonly ["joinTime", "rtcVersion", "imVersion", "platform", "device", "os", "browserName", "browserVersion"];
|
|
2556
|
-
readonly RCRTCPBR2Info: readonly ["joinTime", "sendTime", "rtcActionType", "rtcActionStatus", "trackId"];
|
|
2557
|
-
readonly RCRTCPBR3Info: readonly ["info"];
|
|
2558
|
-
readonly RCRTCPBR4Info: readonly ["info"];
|
|
2559
|
-
readonly RCRTCPBStatusInfo: readonly ["joinTime", "receiveTime", "totalBitRate", "appCPUUsage", "systemCPUUsage", "systemCPUFrequency", "networkStatus", "googleRTTNetwork", "ipAddress", "useReceiveBroadBand", "useSendBroadBand", "packetLossCount", "streams"];
|
|
2560
|
-
readonly RCRTCPBStreamInfo: readonly ["trackId", "codeName", "volume", "samplingRate", "bitRate", "packetLossRate", "frameRate", "resolution", "blockTime", "jitterData", "nAckCount", "pliCount", "googleRTTTotalTime", "isReceiveFirstFrameRate", "codeType", "isEnabled"];
|
|
2561
|
-
};
|
|
2562
|
-
declare type RTCKeyMaps = typeof keymaps;
|
|
2563
|
-
|
|
2564
|
-
/**
|
|
2565
|
-
* 自定义上报北极星数据响应 code
|
|
2566
|
-
*/
|
|
2567
|
-
declare enum RCSendCode {
|
|
2568
|
-
NOT_REPORT = -1,
|
|
2569
|
-
REPORT_SUCCESS = 10000,
|
|
2570
|
-
REPORT_FAIL = 0,
|
|
2571
|
-
PB_ERROR = 40001
|
|
2572
|
-
}
|
|
2573
|
-
|
|
2574
|
-
declare class RTCContext {
|
|
2575
|
-
private context;
|
|
2576
|
-
logger: BasicLogger;
|
|
2577
|
-
private codec;
|
|
2578
|
-
roomCreateTime: number | undefined;
|
|
2579
|
-
userJoinTime: number | undefined;
|
|
2580
|
-
constructor(context: RTCPluginContext, logger: BasicLogger, codec: Codec<RTCKeyMaps>);
|
|
2581
|
-
joinRTCRoom(roomId: string, mode: RTCMode, broadcastType?: number, joinType?: RTCJoinType, innerUserDatas?: IRTCUserData, outerUserDatas?: IRTCUserData, supportNtf?: boolean): IPromiseResult<IJoinRTCRoomData>;
|
|
2582
|
-
quitRTCRoom(roomId: string): Promise<ErrorCode>;
|
|
2583
|
-
getRTCRoomInfo(roomId: string): IPromiseResult<IRTCRoomInfo>;
|
|
2584
|
-
/**
|
|
2585
|
-
* 移动端用来获取副房间资源
|
|
2586
|
-
*/
|
|
2587
|
-
getRTCUserInfoList(roomId: string): IPromiseResult<IRTCUsers>;
|
|
2588
|
-
getRTCUserInfo(roomId: string): IPromiseResult<unknown>;
|
|
2589
|
-
removeRTCUserInfo(roomId: string, keys: string[]): Promise<ErrorCode>;
|
|
2590
|
-
setRTCData(roomId: string, key: string, value: string, isInner: boolean, apiType: RTCApiType, message?: {
|
|
2591
|
-
name: string;
|
|
2592
|
-
content: string;
|
|
2593
|
-
}): Promise<ErrorCode>;
|
|
2594
|
-
/**
|
|
2595
|
-
* 全量订阅资源修改
|
|
2596
|
-
* @param roomId 房间 Id
|
|
2597
|
-
* @param message 向前兼容的消息内容
|
|
2598
|
-
* @param valueInfo 全量资源数据
|
|
2599
|
-
* @param objectName 全量 URI 消息名
|
|
2600
|
-
*/
|
|
2601
|
-
setRTCTotalRes(roomId: string, messageList: {
|
|
2602
|
-
name: string;
|
|
2603
|
-
content: string;
|
|
2604
|
-
}[], valueInfo: string, objectName: string, mcuValInfo?: string, cdnValInfo?: string): Promise<ErrorCode>;
|
|
2605
|
-
setRTCCDNUris(roomId: string, objectName: string, CDNUris: string): Promise<ErrorCode>;
|
|
2606
|
-
getRTCData(roomId: string, keys: string[], isInner: boolean, apiType: RTCApiType): IPromiseResult<KVString>;
|
|
2607
|
-
removeRTCData(roomId: string, keys: string[], isInner: boolean, apiType: RTCApiType, message?: {
|
|
2608
|
-
name: string;
|
|
2609
|
-
content: string;
|
|
2610
|
-
}): Promise<ErrorCode>;
|
|
2611
|
-
setRTCOutData(roomId: string, rtcData: unknown, type: number, message: unknown): Promise<ErrorCode>;
|
|
2612
|
-
getRTCOutData(roomId: string, userIds: string[]): IPromiseResult<unknown>;
|
|
2613
|
-
getRTCToken(roomId: string, mode: number, broadcastType?: number): IPromiseResult<IRtcTokenData>;
|
|
2614
|
-
setRTCState(roomId: string, report: string): Promise<ErrorCode>;
|
|
2615
|
-
/**
|
|
2616
|
-
* 通过 http 方式上报 rtc state
|
|
2617
|
-
*/
|
|
2618
|
-
setRTCStateByHttp(logServer: string, runtime: IRuntime, report: IRCRTCReportData, reportType: string): Promise<RCSendCode | RCRTCCode>;
|
|
2619
|
-
getRTCUserList(roomId: string): IPromiseResult<IRTCUsers>;
|
|
2620
|
-
joinLivingRoomAsAudience(roomId: string, mode: RTCMode, broadcastType?: number): Promise<IAsyncRes<{
|
|
2621
|
-
token: string;
|
|
2622
|
-
kvEntries: IServerRTCRoomEntry[];
|
|
2623
|
-
}>>;
|
|
2624
|
-
quitLivingRoomAsAudience(roomId: string): Promise<ErrorCode>;
|
|
2625
|
-
rtcIdentityChange(roomId: string, changeType: RTCIdentityChangeType, broadcastType?: number): Promise<IAsyncRes<IJoinRTCRoomData>>;
|
|
2626
|
-
requestRoomPK(options: IReqRoomPKOptions): Promise<ErrorCode>;
|
|
2627
|
-
cancelRoomPK(options: ICancelRoomPKOptions): Promise<ErrorCode>;
|
|
2628
|
-
responseRoomPK(options: IResRoomPKOptions): Promise<ErrorCode>;
|
|
2629
|
-
endRoomPK(options: IEndRoomPKOptions): Promise<ErrorCode>;
|
|
2630
|
-
getRTCJoinedUserInfo(userId: string): Promise<IAsyncRes<IRTCJoinedInfo[]>>;
|
|
2631
|
-
pullRTCRoomEntry(roomId: string): Promise<IAsyncRes<IChrmKVPullData>>;
|
|
2632
|
-
/**
|
|
2633
|
-
* 通知拉取房间数据
|
|
2634
|
-
* @param roomId 房间 id
|
|
2635
|
-
* @param version 本地最大得房间数据版本号
|
|
2636
|
-
*/
|
|
2637
|
-
pullRTCRoomStatus(roomId: string, version: number): Promise<{
|
|
2638
|
-
code: ErrorCode;
|
|
2639
|
-
data?: IPullRTCRoomStatus;
|
|
2640
|
-
}>;
|
|
2641
|
-
decodeRtcNotify(buffer: Uint8Array): {
|
|
2642
|
-
time: number;
|
|
2643
|
-
type: any;
|
|
2644
|
-
roomId: any;
|
|
2645
|
-
};
|
|
2646
|
-
getCurrentId(): string;
|
|
2647
|
-
getNaviInfo(): IRTCNaviInfo | null;
|
|
2648
|
-
getConnectionStatus(): RCConnectionStatus;
|
|
2649
|
-
getAppkey(): string;
|
|
2650
|
-
/** web 端发 rtcPing */
|
|
2651
|
-
webRtcPing(roomId: string, roomMode: RTCMode, broadcastType?: number): Promise<{
|
|
2652
|
-
code: ErrorCode;
|
|
2653
|
-
data?: {
|
|
2654
|
-
version: number;
|
|
2655
|
-
};
|
|
2656
|
-
}>;
|
|
2657
|
-
/**
|
|
2658
|
-
* 协议栈 rtcping 依赖 imlib 编解码数据
|
|
2659
|
-
* web 单独走 imlib 提供的 rtcSignaling 方法,减少对 imlib 的依赖
|
|
2660
|
-
*/
|
|
2661
|
-
rtcPing(roomId: string, roomMode: RTCMode, broadcastType?: number): Promise<{
|
|
2662
|
-
code: ErrorCode;
|
|
2663
|
-
data?: {
|
|
2664
|
-
version: number;
|
|
2665
|
-
} | undefined;
|
|
2666
|
-
}> | Promise<_rongcloud_engine.RCResult<any>>;
|
|
2667
|
-
sendMessage(conversationType: ConversationType, targetId: string, options: ISendMsgOptions): IPromiseResult<IReceivedMessage>;
|
|
2668
|
-
registerRTCSignalListener(listener?: ((buffer: Uint8Array) => void) | undefined): void;
|
|
2669
|
-
registerConnectionStateChangeListener(listener: (status: RCConnectionStatus, code: ErrorCode) => void): void;
|
|
2670
|
-
registerDisconnectListener(listener: () => void): void;
|
|
2671
|
-
registerDestroyListener(listener: () => void): void;
|
|
2672
|
-
registerMessageListener(listener: (message: IReceivedMessage) => boolean): void;
|
|
2673
|
-
getCoreVersion(): string;
|
|
2674
|
-
getPluginContext(): RTCPluginContext;
|
|
2675
|
-
reportSDKInfo(versionInfo: {
|
|
2676
|
-
[name: string]: string;
|
|
2677
|
-
}): void;
|
|
2678
|
-
}
|
|
2679
|
-
|
|
2680
2900
|
/**
|
|
2681
2901
|
* mediaServer 交互数据
|
|
2682
2902
|
*/
|
|
@@ -2700,152 +2920,19 @@ declare enum RCRTCResourceAction {
|
|
|
2700
2920
|
UNSUB = "unsub"
|
|
2701
2921
|
}
|
|
2702
2922
|
|
|
2703
|
-
declare
|
|
2704
|
-
private readonly _runtime;
|
|
2705
|
-
private readonly _context;
|
|
2923
|
+
declare enum RCCommandKind {
|
|
2706
2924
|
/**
|
|
2707
|
-
*
|
|
2925
|
+
* 发信令取消加入房间之前的资源
|
|
2708
2926
|
*/
|
|
2709
|
-
|
|
2927
|
+
UNPUBLISH_PREV = "UnpublishPrevCommand",
|
|
2710
2928
|
/**
|
|
2711
|
-
*
|
|
2929
|
+
* 拉取房间内数据
|
|
2712
2930
|
*/
|
|
2713
|
-
|
|
2931
|
+
PULL_RTCROOM_STATUS = "PullRTCRoomStatusCommand",
|
|
2714
2932
|
/**
|
|
2715
|
-
*
|
|
2933
|
+
* 加入房间
|
|
2716
2934
|
*/
|
|
2717
|
-
|
|
2718
|
-
/**
|
|
2719
|
-
* 服务器指纹数据,客户端不得修改,直接透传
|
|
2720
|
-
*/
|
|
2721
|
-
private _rtcFinger;
|
|
2722
|
-
/**
|
|
2723
|
-
* 服务器接口返回的 clusterId 数据,当此数据有值时,后续所有请求向此服务发送
|
|
2724
|
-
*/
|
|
2725
|
-
private _clusterId;
|
|
2726
|
-
/**
|
|
2727
|
-
* MCU 服务地址
|
|
2728
|
-
*/
|
|
2729
|
-
private _configUrl;
|
|
2730
|
-
/**
|
|
2731
|
-
* 排好序的探测地址
|
|
2732
|
-
*/
|
|
2733
|
-
private static msInDetector;
|
|
2734
|
-
private static detectorTime;
|
|
2735
|
-
private static detectValidMinute;
|
|
2736
|
-
private _msList;
|
|
2737
|
-
private _qualityMsList;
|
|
2738
|
-
private readonly _logger;
|
|
2739
|
-
constructor(_runtime: IRuntime, _context: RTCContext,
|
|
2740
|
-
/**
|
|
2741
|
-
* 自定义 MediaServer 地址,当有值时,不再使用导航内的地址
|
|
2742
|
-
*/
|
|
2743
|
-
_msUrl?: string | undefined,
|
|
2744
|
-
/**
|
|
2745
|
-
* 请求超时时长
|
|
2746
|
-
*/
|
|
2747
|
-
_timeout?: number);
|
|
2748
|
-
/**
|
|
2749
|
-
* 是否需要嗅探
|
|
2750
|
-
* im 未连接,无 navi 数据时,不需要嗅探
|
|
2751
|
-
* 客户端手动配置 mediaServer 时,不需要嗅探
|
|
2752
|
-
* navi 数据中 detectionServer 为空时,不需要嗅探
|
|
2753
|
-
* navi 数据中 jwt 为空时,不需要嗅探
|
|
2754
|
-
* 在探测有效期内不需要嗅探
|
|
2755
|
-
* RCMediaService.detectorTime 为 0 时,代表未探测过,需要嗅探
|
|
2756
|
-
*/
|
|
2757
|
-
isNededDetector(): boolean;
|
|
2758
|
-
detectorMediaSever(): void;
|
|
2759
|
-
/**
|
|
2760
|
-
* 地址探测
|
|
2761
|
-
* RTC 初始化时检测是否可以拿到 navi,可以拿到开始嗅探
|
|
2762
|
-
* 拿不到等 IM 链接成功后,再回调中调用开始嗅探
|
|
2763
|
-
*/
|
|
2764
|
-
private _startDetector;
|
|
2765
|
-
/**
|
|
2766
|
-
* 清空 msList 列表,重新请求导航后需清空 msList 列表
|
|
2767
|
-
*/
|
|
2768
|
-
clearMSList(): void;
|
|
2769
|
-
getMsList(): string[];
|
|
2770
|
-
/**
|
|
2771
|
-
* _mslist 列表排序:[_clusterId, ping1DetectorUrl, 主域名, ping2DetectorUrl, ..., pingNDetectorUrl, 备用域名list ]
|
|
2772
|
-
* ping1 :ping 结果返回最快值
|
|
2773
|
-
*/
|
|
2774
|
-
private _sortMediaServiceList;
|
|
2775
|
-
/**
|
|
2776
|
-
* 配置 gzip 请求头和请求体
|
|
2777
|
-
*/
|
|
2778
|
-
private _openGzip;
|
|
2779
|
-
/**
|
|
2780
|
-
* 处理 request 成功的结果
|
|
2781
|
-
*/
|
|
2782
|
-
private _dealRequestSuccessResult;
|
|
2783
|
-
/**
|
|
2784
|
-
* 发送请求,请求发送若失败,会继续尝试使用后续可用地址直到无地址可用,此时认为请求失败
|
|
2785
|
-
* @param path
|
|
2786
|
-
* @param header
|
|
2787
|
-
* @param body
|
|
2788
|
-
*/
|
|
2789
|
-
private _request;
|
|
2790
|
-
/**
|
|
2791
|
-
* 资源协商接口,订阅、发布、变更资源均可以使用此接口。该接口通过 sdp 字段交换 SDP 信息,
|
|
2792
|
-
* 并通过 subscribeList 和 publishList 表明最终发布和订阅的资源。本端产出 offer,服务器产出 answer
|
|
2793
|
-
* 每次接口调用,都会全量覆盖发布和订阅的资源。
|
|
2794
|
-
* @param header
|
|
2795
|
-
* @param body
|
|
2796
|
-
*/
|
|
2797
|
-
exchange(headers: IRTCReqHeader, body: IExchangeReqBody, traceId: string, isNeedUpdateMsas?: boolean): Promise<{
|
|
2798
|
-
code: RCRTCCode;
|
|
2799
|
-
data?: IExchangeResponse | undefined;
|
|
2800
|
-
qualityMsList?: IMediaServerQualityData[] | undefined;
|
|
2801
|
-
}>;
|
|
2802
|
-
/**
|
|
2803
|
-
* 退出房间
|
|
2804
|
-
*/
|
|
2805
|
-
exit(headers: IRTCReqHeader): Promise<RCRTCCode>;
|
|
2806
|
-
/**
|
|
2807
|
-
* 观众端订阅主播资源
|
|
2808
|
-
*/
|
|
2809
|
-
broadcastSubscribe(headers: IRTCReqHeader, body: IBroadcastSubReqBody): Promise<{
|
|
2810
|
-
code: RCRTCCode;
|
|
2811
|
-
data?: IBroadcastSubRespBody | undefined;
|
|
2812
|
-
qualityMsList?: IMediaServerQualityData[] | undefined;
|
|
2813
|
-
}>;
|
|
2814
|
-
/**
|
|
2815
|
-
* 观众端退出订阅
|
|
2816
|
-
*/
|
|
2817
|
-
broadcastExit(headers: IRTCReqHeader): Promise<{
|
|
2818
|
-
code: RCRTCCode;
|
|
2819
|
-
}>;
|
|
2820
|
-
/**
|
|
2821
|
-
* 直播推流、自定义布局配置
|
|
2822
|
-
*/
|
|
2823
|
-
setMcuConfig(headers: IMCUReqHeaders, body: IMCUConfig | ISetEnableCDN): Promise<{
|
|
2824
|
-
code: RCRTCCode;
|
|
2825
|
-
res?: any;
|
|
2826
|
-
}>;
|
|
2827
|
-
/**
|
|
2828
|
-
* 房间内观众获取 CDN 资源信息、拉流地址
|
|
2829
|
-
*/
|
|
2830
|
-
getCDNResourceInfo(headers: ICDNPlayUrlReqHeaders, url: string, traceId: string): Promise<{
|
|
2831
|
-
code: RCRTCCode;
|
|
2832
|
-
res?: ICDNPlayUrlResponse;
|
|
2833
|
-
}>;
|
|
2834
|
-
}
|
|
2835
|
-
|
|
2836
|
-
declare enum RCCommandKind {
|
|
2837
|
-
/**
|
|
2838
|
-
* 发信令取消加入房间之前的资源
|
|
2839
|
-
*/
|
|
2840
|
-
UNPUBLISH_PREV = "UnpublishPrevCommand",
|
|
2841
|
-
/**
|
|
2842
|
-
* 拉取房间内数据
|
|
2843
|
-
*/
|
|
2844
|
-
PULL_RTCROOM_STATUS = "PullRTCRoomStatusCommand",
|
|
2845
|
-
/**
|
|
2846
|
-
* 加入房间
|
|
2847
|
-
*/
|
|
2848
|
-
JOINROOM = "JoinRoomCommand",
|
|
2935
|
+
JOINROOM = "JoinRoomCommand",
|
|
2849
2936
|
/**
|
|
2850
2937
|
* 解析远端资源数据
|
|
2851
2938
|
*/
|
|
@@ -2964,306 +3051,374 @@ declare class ReportMediaActionLogger {
|
|
|
2964
3051
|
recordQualityIceStatusData(iceCandidatePair: IRCCandidatePairStat, status: RTCIceConnectionState, time: number): void;
|
|
2965
3052
|
}
|
|
2966
3053
|
|
|
2967
|
-
declare class RCLocalMediaStream {
|
|
2968
|
-
readonly msid: string;
|
|
2969
|
-
readonly mediaStream: MediaStream;
|
|
2970
|
-
readonly tinyStream: MediaStream;
|
|
2971
|
-
readonly tag: string;
|
|
2972
|
-
constructor(msid: string);
|
|
2973
|
-
}
|
|
2974
|
-
|
|
2975
3054
|
/**
|
|
2976
|
-
*
|
|
3055
|
+
* RTC 消息类型常量
|
|
3056
|
+
* @private
|
|
2977
3057
|
*/
|
|
2978
|
-
declare enum
|
|
3058
|
+
declare enum RCRTCMessageType {
|
|
2979
3059
|
/**
|
|
2980
|
-
*
|
|
3060
|
+
* 增量资源发布消息
|
|
3061
|
+
* @deprecated
|
|
2981
3062
|
*/
|
|
2982
|
-
|
|
3063
|
+
PUBLISH = "RCRTC:PublishResource",
|
|
2983
3064
|
/**
|
|
2984
|
-
*
|
|
3065
|
+
* 增量资源取消发布消息
|
|
3066
|
+
* @deprecated
|
|
2985
3067
|
*/
|
|
2986
|
-
|
|
2987
|
-
}
|
|
2988
|
-
|
|
2989
|
-
interface IAudienceRoomEventListener extends IRCRTCTrackEventListener {
|
|
3068
|
+
UNPUBLISH = "RCRTC:UnpublishResource",
|
|
2990
3069
|
/**
|
|
2991
|
-
*
|
|
2992
|
-
* @
|
|
3070
|
+
* 增量资源状态变更消息
|
|
3071
|
+
* @deprecated
|
|
2993
3072
|
*/
|
|
2994
|
-
|
|
3073
|
+
MODIFY = "RCRTC:ModifyResource",
|
|
2995
3074
|
/**
|
|
2996
|
-
*
|
|
2997
|
-
* @param userIds 退出主播的 id 列表
|
|
3075
|
+
* 全量资源变更消息
|
|
2998
3076
|
*/
|
|
2999
|
-
|
|
3077
|
+
TOTAL_CONTENT_RESOURCE = "RCRTC:TotalContentResources",
|
|
3000
3078
|
/**
|
|
3001
|
-
*
|
|
3002
|
-
* @param tracks 新发布的合流音轨与视轨数据列表,包含新发布的 RCRemoteAudioTrack 与 RCRemoteVideoTrack 实例
|
|
3003
|
-
* @description
|
|
3004
|
-
* 当房间内某个主播第一次发布资源时触发
|
|
3079
|
+
* 房间人员变更
|
|
3005
3080
|
*/
|
|
3006
|
-
|
|
3081
|
+
STATE = "RCRTC:state",
|
|
3007
3082
|
/**
|
|
3008
|
-
*
|
|
3009
|
-
* @param tracks 被取消发布的合流音轨与视轨数据列表
|
|
3010
|
-
* @description
|
|
3011
|
-
* 当房间内全部主播退出房间时,SDK 内部会取消对资源的订阅,业务层仅需处理 UI 业务
|
|
3083
|
+
* 房间属性变更
|
|
3012
3084
|
*/
|
|
3013
|
-
|
|
3085
|
+
ROOM_NOTIFY = "RCRTC:RoomNtf",
|
|
3014
3086
|
/**
|
|
3015
|
-
*
|
|
3016
|
-
* @param tracks 主播新发布的音轨与视轨数据列表,包含新发布的 RCRemoteAudioTrack 与 RCRemoteVideoTrack 实例
|
|
3087
|
+
* 房间用户属性变更
|
|
3017
3088
|
*/
|
|
3018
|
-
|
|
3089
|
+
USER_NOTIFY = "RCRTC:UserNtf",
|
|
3019
3090
|
/**
|
|
3020
|
-
*
|
|
3021
|
-
* @param tracks 被主播取消发布的音轨与视轨数据列表
|
|
3022
|
-
* @description 当资源被取消发布时,SDK 内部会取消对相关资源的订阅,业务层仅需处理 UI 业务
|
|
3091
|
+
* 被服务踢出房间
|
|
3023
3092
|
*/
|
|
3024
|
-
|
|
3093
|
+
KICK = "RCRTC:kick",
|
|
3025
3094
|
/**
|
|
3026
|
-
*
|
|
3027
|
-
* @param audioTrack RCRemoteAudioTrack 类实例
|
|
3095
|
+
* 跨房间连麦 PK 请求消息
|
|
3028
3096
|
*/
|
|
3029
|
-
|
|
3030
|
-
/**
|
|
3031
|
-
* 房间主播禁用/启用视频
|
|
3032
|
-
* @param videoTrack RCRemoteVideoTrack 类实例对象
|
|
3033
|
-
*/
|
|
3034
|
-
onVideoMuteChange?(videoTrack: RCRemoteVideoTrack): void;
|
|
3097
|
+
PK_INVITE = "RCRTC:invite",
|
|
3035
3098
|
/**
|
|
3036
|
-
*
|
|
3099
|
+
* 连麦请求超时
|
|
3037
3100
|
*/
|
|
3038
|
-
|
|
3039
|
-
resolution: RCResolution;
|
|
3040
|
-
fps: RCFrameRate;
|
|
3041
|
-
}): void;
|
|
3101
|
+
PK_INVITE_TIMEOUT = "RCRTC:inviteTimeout",
|
|
3042
3102
|
/**
|
|
3043
|
-
*
|
|
3103
|
+
* 跨房间连麦 PK 取消请求消息
|
|
3044
3104
|
*/
|
|
3045
|
-
|
|
3105
|
+
PK_CANCEL_INVITE = "RCRTC:cancelInvite",
|
|
3046
3106
|
/**
|
|
3047
|
-
*
|
|
3107
|
+
* 跨房间连麦 PK 请求响应消息
|
|
3048
3108
|
*/
|
|
3049
|
-
|
|
3050
|
-
resolution: RCResolution;
|
|
3051
|
-
fps: RCFrameRate;
|
|
3052
|
-
}): void;
|
|
3053
|
-
}
|
|
3054
|
-
/**
|
|
3055
|
-
* 观众直播房间类
|
|
3056
|
-
* 处理:
|
|
3057
|
-
* 1、通知观众房间内 人员变更、资源变更
|
|
3058
|
-
* 2、观众订阅、取消订阅资源
|
|
3059
|
-
*/
|
|
3060
|
-
declare class RCAudienceLivingRoom {
|
|
3061
|
-
private readonly _context;
|
|
3062
|
-
private readonly _runtime;
|
|
3063
|
-
private readonly _initOptions;
|
|
3064
|
-
private readonly _roomId;
|
|
3065
|
-
private readonly _joinResData;
|
|
3066
|
-
readonly livingType: RCLivingType;
|
|
3067
|
-
protected readonly _clientSessionId: string;
|
|
3068
|
-
private readonly _service;
|
|
3109
|
+
PK_INVITE_ANSWER = "RCRTC:answerInvite",
|
|
3069
3110
|
/**
|
|
3070
|
-
*
|
|
3111
|
+
* 结束跨房间连麦 PK 消息
|
|
3071
3112
|
*/
|
|
3072
|
-
|
|
3113
|
+
PK_END = "RCRTC:endInvite",
|
|
3073
3114
|
/**
|
|
3074
|
-
*
|
|
3115
|
+
* 连麦的房间不再了或离线了,主直播房间会收到的消息通知
|
|
3075
3116
|
*/
|
|
3076
|
-
|
|
3117
|
+
OTHER_ROOM_OFFLINE = "RCRTC:otherRoomOffline",
|
|
3077
3118
|
/**
|
|
3078
|
-
*
|
|
3119
|
+
* 订阅、取消订阅动作成功
|
|
3079
3120
|
*/
|
|
3080
|
-
|
|
3121
|
+
ROOM_TASK_FINISH = "RCRTC:roomTaskFinish",
|
|
3081
3122
|
/**
|
|
3082
|
-
*
|
|
3123
|
+
* ASR 状态变更
|
|
3083
3124
|
*/
|
|
3084
|
-
|
|
3085
|
-
private _appListener;
|
|
3086
|
-
private readonly _pc;
|
|
3087
|
-
private _subscribedList;
|
|
3088
|
-
private _sessionId;
|
|
3089
|
-
private _destroyed;
|
|
3125
|
+
ASR_STATUS = "RCRTC:AsrStatus",
|
|
3090
3126
|
/**
|
|
3091
|
-
*
|
|
3127
|
+
* ASR SEI 变更
|
|
3092
3128
|
*/
|
|
3093
|
-
|
|
3129
|
+
ASR_SEI = "RCRTC:PublishSeiAi"
|
|
3130
|
+
}
|
|
3131
|
+
|
|
3132
|
+
/**
|
|
3133
|
+
* 直播间类型
|
|
3134
|
+
*/
|
|
3135
|
+
declare enum RCLivingType {
|
|
3094
3136
|
/**
|
|
3095
|
-
*
|
|
3137
|
+
* 音视频直播
|
|
3096
3138
|
*/
|
|
3097
|
-
|
|
3139
|
+
VIDEO = 0,
|
|
3098
3140
|
/**
|
|
3099
|
-
*
|
|
3141
|
+
* 音频直播
|
|
3100
3142
|
*/
|
|
3101
|
-
|
|
3102
|
-
|
|
3103
|
-
|
|
3104
|
-
|
|
3105
|
-
|
|
3106
|
-
private readonly _reportMediaActionLogger;
|
|
3143
|
+
AUDIO = 1
|
|
3144
|
+
}
|
|
3145
|
+
|
|
3146
|
+
declare type IOnRecvPKMsg = (msg: IReceivedMessage) => void;
|
|
3147
|
+
interface IRoomPKEventListener {
|
|
3107
3148
|
/**
|
|
3108
|
-
*
|
|
3149
|
+
* 收到连麦邀请
|
|
3109
3150
|
*/
|
|
3110
|
-
|
|
3111
|
-
private readonly _logger;
|
|
3112
|
-
constructor(_context: RTCContext, _runtime: IRuntime, _initOptions: IRCRTCInitOptions, _roomId: string, _joinResData: {
|
|
3113
|
-
token: string;
|
|
3114
|
-
kvEntries: IServerRTCRoomEntry[];
|
|
3115
|
-
}, livingType: RCLivingType, _clientSessionId?: string);
|
|
3116
|
-
private _startPull;
|
|
3151
|
+
onRequestJoinOtherRoom: (info: IPKInviteInfo) => {};
|
|
3117
3152
|
/**
|
|
3118
|
-
*
|
|
3153
|
+
* 收到取消连麦邀请
|
|
3119
3154
|
*/
|
|
3120
|
-
|
|
3121
|
-
protected _assertRoomDestroyed(): RCRTCCode | undefined;
|
|
3155
|
+
onCancelRequestOtherRoom: (info: IPKInviteInfo) => {};
|
|
3122
3156
|
/**
|
|
3123
|
-
*
|
|
3124
|
-
* @param roomId 数据对应的房间 Id
|
|
3125
|
-
* @param singalData 拉取到的数据
|
|
3126
|
-
* * key RC_ANCHOR_LIST value: 为主播 ID 集合
|
|
3127
|
-
* * key RC_RES_`userId` value: 为主播发布的资源
|
|
3128
|
-
* * key RC_RTC_SESSIONID value: sessionId
|
|
3129
|
-
* * key RC_CDN value: CDN 资源数据
|
|
3157
|
+
* 收到连麦 PK 请求响应结果
|
|
3130
3158
|
*/
|
|
3131
|
-
|
|
3159
|
+
onResponseJoinOtherRoom: (info: IPKInviteAnswerInfo) => {};
|
|
3132
3160
|
/**
|
|
3133
|
-
*
|
|
3161
|
+
* 收到 PK 结束
|
|
3134
3162
|
*/
|
|
3135
|
-
|
|
3136
|
-
|
|
3137
|
-
|
|
3163
|
+
onFinishOtherRoom: (info: IPKEndInfo) => {};
|
|
3164
|
+
}
|
|
3165
|
+
declare class RCLivingPKHandler {
|
|
3166
|
+
private _invoker;
|
|
3167
|
+
private _PKInfo;
|
|
3168
|
+
private readonly _context;
|
|
3169
|
+
private readonly _runtime;
|
|
3170
|
+
private readonly _service;
|
|
3171
|
+
private readonly _initOptions;
|
|
3138
3172
|
/**
|
|
3139
|
-
*
|
|
3173
|
+
* 主直播房间
|
|
3140
3174
|
*/
|
|
3141
|
-
private
|
|
3175
|
+
private readonly _mainLivingRoom;
|
|
3176
|
+
private readonly _registerPKMsgListener;
|
|
3142
3177
|
/**
|
|
3143
|
-
*
|
|
3178
|
+
* 加入 PK 房间回调
|
|
3144
3179
|
*/
|
|
3145
|
-
private
|
|
3180
|
+
private readonly _onJoinedPKRoom;
|
|
3181
|
+
protected readonly _clientSessionId?: string | undefined;
|
|
3146
3182
|
/**
|
|
3147
|
-
*
|
|
3183
|
+
* PK 邀请超时时间,默认 30s
|
|
3148
3184
|
*/
|
|
3149
|
-
private
|
|
3185
|
+
private readonly _inviteTimeout;
|
|
3186
|
+
private _appListener;
|
|
3187
|
+
private _mainRoomId;
|
|
3150
3188
|
/**
|
|
3151
|
-
*
|
|
3189
|
+
* 跨房间连麦加入的 PK 房间
|
|
3152
3190
|
*/
|
|
3153
|
-
private
|
|
3191
|
+
private _joinedPKRooms;
|
|
3192
|
+
private readonly _logger;
|
|
3193
|
+
constructor(_invoker: Invoker, _PKInfo: IPKInfo, _context: RTCContext, _runtime: IRuntime, _service: RCMediaService, _initOptions: IRCRTCInitOptions,
|
|
3154
3194
|
/**
|
|
3155
|
-
*
|
|
3156
|
-
|
|
3157
|
-
|
|
3158
|
-
|
|
3195
|
+
* 主直播房间
|
|
3196
|
+
*/
|
|
3197
|
+
_mainLivingRoom: RCLivingRoom, _registerPKMsgListener: (listener: IOnRecvPKMsg) => void,
|
|
3198
|
+
/**
|
|
3199
|
+
* 加入 PK 房间回调
|
|
3200
|
+
*/
|
|
3201
|
+
_onJoinedPKRoom: (roomId: string, traceId: string) => Promise<void>, _clientSessionId?: string | undefined);
|
|
3159
3202
|
private _callAppListener;
|
|
3160
3203
|
/**
|
|
3161
|
-
*
|
|
3162
|
-
|
|
3163
|
-
private
|
|
3204
|
+
* 收到连麦邀请
|
|
3205
|
+
*/
|
|
3206
|
+
private _onInvite;
|
|
3164
3207
|
/**
|
|
3165
|
-
*
|
|
3166
|
-
* @param subscribeList 订阅清单
|
|
3167
|
-
* @param publishedStreams 已发布流
|
|
3168
|
-
* @param iceRestart
|
|
3208
|
+
* 收到取消连麦
|
|
3169
3209
|
*/
|
|
3170
|
-
|
|
3171
|
-
|
|
3172
|
-
}, iceRestart: boolean): Promise<{
|
|
3173
|
-
reqBody: IBroadcastSubReqBody;
|
|
3174
|
-
offer: RTCSessionDescriptionInit;
|
|
3175
|
-
dynamicBitrate: {
|
|
3176
|
-
min: number;
|
|
3177
|
-
max: number;
|
|
3178
|
-
};
|
|
3179
|
-
}>;
|
|
3180
|
-
private _subscribeHandle;
|
|
3210
|
+
private _onCancelInvite;
|
|
3211
|
+
private _onInviteTimeout;
|
|
3181
3212
|
/**
|
|
3182
|
-
*
|
|
3213
|
+
* 收到响应连麦
|
|
3183
3214
|
*/
|
|
3184
|
-
private
|
|
3185
|
-
private
|
|
3186
|
-
private _exchangeHandle;
|
|
3187
|
-
private _dealSubscribeResult;
|
|
3215
|
+
private _onInviteAnswer;
|
|
3216
|
+
private createLeaveOtherRoomCommand;
|
|
3188
3217
|
/**
|
|
3189
|
-
*
|
|
3218
|
+
* 收到连麦结束
|
|
3190
3219
|
*/
|
|
3191
|
-
private
|
|
3192
|
-
private _reportPubOrSubQualityData;
|
|
3193
|
-
private _updateSubListHandle;
|
|
3220
|
+
private _onPKEnd;
|
|
3194
3221
|
/**
|
|
3195
|
-
*
|
|
3196
|
-
* @param newCDNUris 新的 cdn_uris 数据
|
|
3222
|
+
* 处理跨房间连麦相关消息
|
|
3197
3223
|
*/
|
|
3198
|
-
private
|
|
3224
|
+
private _onRecvPKMsg;
|
|
3199
3225
|
/**
|
|
3200
|
-
*
|
|
3201
|
-
* _CDNUris 无 url 时,说明未开启 CDN 推送
|
|
3202
|
-
* @returns CDNPlayUrl
|
|
3226
|
+
* 注册跨房间连麦监听事件
|
|
3203
3227
|
*/
|
|
3204
|
-
|
|
3228
|
+
registerRoomPKEventListener(listener: IRoomPKEventListener): void;
|
|
3205
3229
|
/**
|
|
3206
|
-
*
|
|
3207
|
-
* @
|
|
3230
|
+
* 发起跨房间连麦请求
|
|
3231
|
+
* @param inviteeRoomId 被邀请者所处的房间 roomId
|
|
3232
|
+
* @param inviteeUserId 被邀请者 userId
|
|
3233
|
+
* @param options.autoMix 是否将本房间资源合并到被邀请者所处房间的 MCU 合流中
|
|
3234
|
+
* @param options.extra 拓展字段,可随邀请连麦消息透传给被邀请者
|
|
3208
3235
|
*/
|
|
3209
|
-
|
|
3210
|
-
code: RCRTCCode;
|
|
3211
|
-
CDNPlayUrl?: string;
|
|
3236
|
+
requestJoinOtherRoom(inviteeRoomId: string, inviteeUserId: string, options?: IReqResPKOptions): Promise<{
|
|
3237
|
+
code: RCRTCCode | ErrorCode;
|
|
3212
3238
|
}>;
|
|
3213
3239
|
/**
|
|
3214
|
-
*
|
|
3215
|
-
* @param
|
|
3240
|
+
* 取消跨房间连麦请求
|
|
3241
|
+
* @param inviteeRoomId 被邀请者所处的房间 roomId
|
|
3242
|
+
* @param inviteeUserId 被邀请者 userId
|
|
3243
|
+
* @param extra 附加信息,可随取消邀请连麦消息透传给被邀请者
|
|
3216
3244
|
*/
|
|
3217
|
-
|
|
3245
|
+
cancelRequestJoinOtherRoom(inviteeRoomId: string, inviteeUserId: string, extra?: string): Promise<{
|
|
3246
|
+
code: RCRTCCode | ErrorCode;
|
|
3247
|
+
}>;
|
|
3248
|
+
/**
|
|
3249
|
+
* 响应跨房间连麦请求
|
|
3250
|
+
* @param inviterRoomId 邀请者所处的房间 roomId
|
|
3251
|
+
* @param inviterUserId 邀请者 userId
|
|
3252
|
+
* @param agree 是否同意连麦
|
|
3253
|
+
* @param options.autoMix 是否将本房间资源合并到邀请者所处房间的 MCU 合流中
|
|
3254
|
+
* @param options.extra 附加信息,可随响应连麦消息透传给邀请者
|
|
3255
|
+
*/
|
|
3256
|
+
responseJoinOtherRoom(inviterRoomId: string, inviterUserId: string, agree: boolean, options?: IReqResPKOptions): Promise<{
|
|
3257
|
+
code: RCRTCCode | ErrorCode;
|
|
3258
|
+
}>;
|
|
3259
|
+
/**
|
|
3260
|
+
* 加入副直播房间
|
|
3261
|
+
* @roomId 副房间的 roomId
|
|
3262
|
+
*/
|
|
3263
|
+
joinOtherRoom(roomId: string): Promise<{
|
|
3218
3264
|
code: RCRTCCode;
|
|
3219
|
-
|
|
3265
|
+
room?: RCLivingRoom;
|
|
3266
|
+
userIds?: string[];
|
|
3267
|
+
tracks?: RCRemoteTrack[];
|
|
3268
|
+
CDNEnable?: boolean;
|
|
3220
3269
|
}>;
|
|
3221
|
-
private __unsubscribe;
|
|
3222
3270
|
/**
|
|
3223
|
-
*
|
|
3224
|
-
* @param
|
|
3271
|
+
* 退出副房间
|
|
3272
|
+
* @param room 要退出的副房间的 room 实例
|
|
3273
|
+
* @param isQuitPK 是否要结束连麦
|
|
3225
3274
|
*/
|
|
3226
|
-
|
|
3275
|
+
leaveOtherRoom(room: RCLivingRoom, isQuitPK?: boolean): Promise<{
|
|
3227
3276
|
code: RCRTCCode;
|
|
3228
|
-
failedList?: ISubscribeAttr[];
|
|
3229
3277
|
}>;
|
|
3230
3278
|
/**
|
|
3231
|
-
*
|
|
3232
|
-
* @
|
|
3279
|
+
* 获取连麦信息
|
|
3280
|
+
* @param roomId 连麦房间的 roomId
|
|
3233
3281
|
*/
|
|
3234
|
-
|
|
3282
|
+
getPKInfo(roomId: string): {
|
|
3283
|
+
inviteSessionId: string;
|
|
3284
|
+
inviterRoomId: string;
|
|
3285
|
+
inviterUserId: string;
|
|
3286
|
+
inviterUserAutoMix?: boolean | undefined;
|
|
3287
|
+
inviteeRoomId: string;
|
|
3288
|
+
inviteeUserAutoMix?: boolean | undefined;
|
|
3289
|
+
};
|
|
3235
3290
|
/**
|
|
3236
|
-
*
|
|
3237
|
-
* @param trackId
|
|
3291
|
+
* 获取所有连麦信息
|
|
3238
3292
|
*/
|
|
3239
|
-
|
|
3293
|
+
getAllPKInfo(): IPKInfo;
|
|
3240
3294
|
/**
|
|
3241
|
-
*
|
|
3242
|
-
* @param trackId
|
|
3295
|
+
* 获取已加入的副房间
|
|
3243
3296
|
*/
|
|
3244
|
-
|
|
3297
|
+
getJoinedPKRooms(): {
|
|
3298
|
+
[roomId: string]: RCLivingRoom;
|
|
3299
|
+
};
|
|
3300
|
+
}
|
|
3301
|
+
|
|
3302
|
+
declare type ResourceMsgContent = {
|
|
3245
3303
|
/**
|
|
3246
|
-
*
|
|
3247
|
-
*
|
|
3304
|
+
* 旧版本兼容参数,当收到非 `RTCMessageName.TOTAL_CONTENT_RESOURCE` 时:
|
|
3305
|
+
* * ignore 值为 `true` 表示该消息由 signal server 向旧版本 RTCLib 提供的兼容消息,无需处理
|
|
3306
|
+
* * 否则认为该消息是由旧版本 RTCLib 主动发出的增量变更消息,需要处理
|
|
3248
3307
|
*/
|
|
3249
|
-
|
|
3308
|
+
ignore?: boolean;
|
|
3250
3309
|
/**
|
|
3251
|
-
*
|
|
3252
|
-
* @param tag 参数描述
|
|
3310
|
+
* 发布到房间内的资源列表,`RTCMessageName.TOTAL_CONTENT_RESOURCE` 消息携带全量数据,否则为增量数据
|
|
3253
3311
|
*/
|
|
3254
|
-
|
|
3312
|
+
uris: IPublishedResource[];
|
|
3313
|
+
cdn_uris?: ICDNUris[];
|
|
3314
|
+
};
|
|
3315
|
+
|
|
3316
|
+
/**
|
|
3317
|
+
* 房间抽象基类
|
|
3318
|
+
*/
|
|
3319
|
+
declare abstract class RCAbstractRoom extends EventEmitter {
|
|
3320
|
+
protected readonly _context: RTCContext;
|
|
3321
|
+
protected readonly _runtime: IRuntime;
|
|
3322
|
+
readonly _roomId: string;
|
|
3323
|
+
protected readonly _service: RCMediaService;
|
|
3324
|
+
protected readonly _initOptions: IRCRTCInitOptions;
|
|
3325
|
+
protected readonly _clientSessionId: string;
|
|
3255
3326
|
/**
|
|
3256
|
-
*
|
|
3257
|
-
* @param handler 业务端传入的音量上报事件
|
|
3258
|
-
* @param _ - 参数已废弃
|
|
3327
|
+
* 房间保活 rtcPing
|
|
3259
3328
|
*/
|
|
3260
|
-
|
|
3261
|
-
private _reportListener;
|
|
3329
|
+
private readonly _pinger;
|
|
3262
3330
|
/**
|
|
3263
|
-
*
|
|
3264
|
-
* @param listener
|
|
3331
|
+
* 北极星上报实例
|
|
3265
3332
|
*/
|
|
3266
|
-
|
|
3333
|
+
protected readonly _polarisReport: PolarisReporter;
|
|
3334
|
+
/**
|
|
3335
|
+
* 音量上报实例
|
|
3336
|
+
*/
|
|
3337
|
+
private readonly _audioLevelReport;
|
|
3338
|
+
protected readonly _peerConnection: RCRTCPeerConnection;
|
|
3339
|
+
protected readonly _invoker: Invoker;
|
|
3340
|
+
protected readonly _store: ReadableStore;
|
|
3341
|
+
private readonly _reportMediaActionLogger;
|
|
3342
|
+
protected readonly _logger: BasicLogger;
|
|
3343
|
+
protected readonly _executeCtx: CommandExecuteContext;
|
|
3344
|
+
/**
|
|
3345
|
+
* RCRTCRoom 类的构造函数。
|
|
3346
|
+
* @param {RTCContext} _context - RTC上下文,
|
|
3347
|
+
* @param {IRuntime} _runtime - 运行时
|
|
3348
|
+
* @param {string} _roomId - 房间号
|
|
3349
|
+
* @param {RTCMode} _roomMode - RTC模式,
|
|
3350
|
+
* @param {RCMediaService} _service - RCMediaService
|
|
3351
|
+
* @param {IRCRTCInitOptions} _initOptions - IRCRTCInitOptions
|
|
3352
|
+
* @param {boolean} [isUpgrade] - 是否是升级,如果是升级则不会创建新的peerConnection
|
|
3353
|
+
* @param {boolean} [isMainRoom] - 无论是主房间,主房间都是用户创建的房间,子房间是用户创建的房间。
|
|
3354
|
+
* @param {string} _clientSessionId - 客户端会话 ID,用于标识客户端。
|
|
3355
|
+
*/
|
|
3356
|
+
constructor(_context: RTCContext, _runtime: IRuntime, _roomId: string, _roomMode: RTCMode, _service: RCMediaService, _initOptions: IRCRTCInitOptions, isUpgrade?: boolean, isMainRoom?: boolean, _clientSessionId?: string, encrypt?: boolean);
|
|
3357
|
+
/**
|
|
3358
|
+
* 注册 RCRTCPeerConnection 事件监听器
|
|
3359
|
+
*/
|
|
3360
|
+
private _setPeerConnectionListener;
|
|
3361
|
+
/** 注册命令执行中的事件监听器 */
|
|
3362
|
+
private setCommandEventListener;
|
|
3363
|
+
/**
|
|
3364
|
+
* 拉取房间数据
|
|
3365
|
+
* @param roomId 房间 id
|
|
3366
|
+
*/
|
|
3367
|
+
private _startPullRTCRoomStatus;
|
|
3368
|
+
/**
|
|
3369
|
+
* @private
|
|
3370
|
+
*/
|
|
3371
|
+
__innerInit(mode: RTCMode, joinType?: RTCJoinType, livingType?: RCLivingType, innerUserDatas?: IRTCUserData, outerUserDatas?: IRTCUserData, traceId?: string, nickName?: string): Promise<{
|
|
3372
|
+
code: RCRTCCode | ErrorCode;
|
|
3373
|
+
data?: IJoinRTCRoomData;
|
|
3374
|
+
}>;
|
|
3375
|
+
protected _initWithRoomData(offlineKickTime: number): void;
|
|
3376
|
+
private _handlePingResult;
|
|
3377
|
+
/**
|
|
3378
|
+
* 设置房间上行资源的总码率配置
|
|
3379
|
+
* @deprecated use RCLocalTrack.setBitrate instead of setBitrate
|
|
3380
|
+
* @description
|
|
3381
|
+
* * 自 v5.1.0 版本开始,推荐使用 `RCLocalTrack.setBitrate` 对不同流分别指定码率。
|
|
3382
|
+
* * 该方法仅在 SDP `plan-b` 协议下(Chrome 92 与 Safari 11 之前的版本)有效。
|
|
3383
|
+
* @param max 音视频发送码率上限,不可小于 200 且不可小于 `min`
|
|
3384
|
+
* @param min 音视频发送码率下限,默认值为 1,且不可小于 1,不可大于 `max`
|
|
3385
|
+
* @param start 起始码率,默认为码率上限的 70%
|
|
3386
|
+
*/
|
|
3387
|
+
setBitrate(max: number, min: number, start?: number): void;
|
|
3388
|
+
private _onTrackReady;
|
|
3389
|
+
protected _callAppListener(eventType: keyof IRoomEventListener, ...attrs: any[]): void;
|
|
3390
|
+
private _onTrackUnpublish;
|
|
3391
|
+
/**
|
|
3392
|
+
* @private
|
|
3393
|
+
*/
|
|
3394
|
+
__parseInnerMessage(message: IReceivedMessage, traceId: string): void;
|
|
3395
|
+
/**
|
|
3396
|
+
* 被踢出房间通知
|
|
3397
|
+
* @param byServer
|
|
3398
|
+
* * 当值为 false 时,说明本端 rtcPing 超时
|
|
3399
|
+
* * 当值为 true 时,说明本端收到被踢出房间通知
|
|
3400
|
+
* @private
|
|
3401
|
+
*/
|
|
3402
|
+
__kickoff(byServer: boolean, content?: IRCRTCKickContent): Promise<void>;
|
|
3403
|
+
private _rtcpeerClosed;
|
|
3404
|
+
private _onReceiveAsrSeiContent;
|
|
3405
|
+
/**
|
|
3406
|
+
* 处理资源变更事件
|
|
3407
|
+
* @param content
|
|
3408
|
+
* @param messageType 消息类型
|
|
3409
|
+
* @param userId 消息发送者
|
|
3410
|
+
*/
|
|
3411
|
+
protected _resourceHandle(content: ResourceMsgContent, messageType: RCRTCMessageType.PUBLISH | RCRTCMessageType.UNPUBLISH | RCRTCMessageType.MODIFY | RCRTCMessageType.TOTAL_CONTENT_RESOURCE, userId: string, sentTime: number, traceId: string): Promise<void>;
|
|
3412
|
+
private _onTrackPublish;
|
|
3413
|
+
/**
|
|
3414
|
+
* 处理 `RCRTCMessageType.STATE` 消息
|
|
3415
|
+
* @param content
|
|
3416
|
+
*/
|
|
3417
|
+
private _stateHandle;
|
|
3418
|
+
/**
|
|
3419
|
+
* 处理人员应用层事件
|
|
3420
|
+
*/
|
|
3421
|
+
private _dealUserAppListener;
|
|
3267
3422
|
/**
|
|
3268
3423
|
* 获取房间 Id
|
|
3269
3424
|
*/
|
|
@@ -3273,13 +3428,14 @@ declare class RCAudienceLivingRoom {
|
|
|
3273
3428
|
*/
|
|
3274
3429
|
getCrtUserId(): string;
|
|
3275
3430
|
/**
|
|
3276
|
-
*
|
|
3431
|
+
* 获取远程用户列表,不包含当前用户
|
|
3277
3432
|
*/
|
|
3278
|
-
|
|
3433
|
+
getRemoteUserIds(): string[];
|
|
3279
3434
|
/**
|
|
3280
|
-
*
|
|
3435
|
+
* 获取所有房间已发布的远端资源列表
|
|
3436
|
+
* @returns
|
|
3281
3437
|
*/
|
|
3282
|
-
|
|
3438
|
+
getRemoteTracks(): RCRemoteTrack[];
|
|
3283
3439
|
/**
|
|
3284
3440
|
* 获取远端用户的资源列表
|
|
3285
3441
|
* @param userId
|
|
@@ -3287,1001 +3443,1203 @@ declare class RCAudienceLivingRoom {
|
|
|
3287
3443
|
*/
|
|
3288
3444
|
getRemoteTracksByUserId(userId: string): RCRemoteTrack[];
|
|
3289
3445
|
/**
|
|
3290
|
-
*
|
|
3446
|
+
* 获取房间当前会话 Id,当房间内已无成员时房间会回收,重新加入时 sessionId 将更新
|
|
3447
|
+
*/
|
|
3448
|
+
getSessionId(): string;
|
|
3449
|
+
/**
|
|
3450
|
+
* 向房间内发消息
|
|
3451
|
+
* @param name 消息名称
|
|
3452
|
+
* @param content 消息内容
|
|
3453
|
+
*/
|
|
3454
|
+
sendMessage(name: string, content: any): Promise<{
|
|
3455
|
+
code: RCRTCCode;
|
|
3456
|
+
}>;
|
|
3457
|
+
/**
|
|
3458
|
+
* 设置房间属性
|
|
3459
|
+
* @param key 属性名
|
|
3460
|
+
* @param value 属性值
|
|
3461
|
+
* @param message 是否在设置属性的时候携带消息内容,传空则不往房间中发送消息
|
|
3462
|
+
* @param isInner RTC 业务内部使用参数,用户忽略
|
|
3463
|
+
*/
|
|
3464
|
+
setRoomAttribute(key: string, value: string, message?: {
|
|
3465
|
+
name: string;
|
|
3466
|
+
content: string;
|
|
3467
|
+
}, isInner?: boolean): Promise<{
|
|
3468
|
+
code: RCRTCCode;
|
|
3469
|
+
}>;
|
|
3470
|
+
/**
|
|
3471
|
+
* 删除房间属性
|
|
3472
|
+
* @param keys 待删除的属性名数组
|
|
3473
|
+
* @param message 是否在删除属性的时候携带消息内容,传空则不往房间中发送消息
|
|
3474
|
+
* @param isInner RTC 业务内部使用参数,用户忽略
|
|
3475
|
+
*/
|
|
3476
|
+
deleteRoomAttributes(keys: string[], message?: {
|
|
3477
|
+
name: string;
|
|
3478
|
+
content: string;
|
|
3479
|
+
}, isInner?: boolean): Promise<{
|
|
3480
|
+
code: RCRTCCode;
|
|
3481
|
+
}>;
|
|
3482
|
+
/**
|
|
3483
|
+
* 获取房间属性
|
|
3484
|
+
* @param keys 要查询的属性名数组,当数组长度为空时,取所有已设置的 kv 值
|
|
3485
|
+
* @param isInner RTC 业务内部使用参数,用户忽略
|
|
3486
|
+
*/
|
|
3487
|
+
getRoomAttributes(keys?: string[], isInner?: boolean): Promise<{
|
|
3488
|
+
code: RCRTCCode;
|
|
3489
|
+
data?: KVString;
|
|
3490
|
+
}>;
|
|
3491
|
+
/**
|
|
3492
|
+
* 设置当前用户属性(暂不开放)
|
|
3493
|
+
* @param key 属性名
|
|
3494
|
+
* @param value 属性值
|
|
3495
|
+
* @param message 是否在设置属性的时候携带消息内容,传空则不往房间中发送消息
|
|
3496
|
+
*/
|
|
3497
|
+
private _setUserAttributeValue;
|
|
3498
|
+
/**
|
|
3499
|
+
* 删除当前用户属性(暂不开放)
|
|
3500
|
+
* @param keys 待删除的属性名数组
|
|
3501
|
+
* @param message 是否在删除属性的时候携带消息内容,传空则不往房间中发送消息
|
|
3502
|
+
*/
|
|
3503
|
+
private _deleteUserAttributes;
|
|
3504
|
+
/**
|
|
3505
|
+
* 获取当前用户属性(暂不开放)
|
|
3506
|
+
* @param keys 要查询的属性名数组
|
|
3507
|
+
*/
|
|
3508
|
+
private _getUserAttributes;
|
|
3509
|
+
/**
|
|
3510
|
+
* 查询房间是否已销毁
|
|
3511
|
+
*/
|
|
3512
|
+
isDestroyed(): boolean;
|
|
3513
|
+
/**
|
|
3514
|
+
* 退出并销毁当前房间实例,退出后该房间的所有方法将不可用
|
|
3515
|
+
* @private
|
|
3516
|
+
*/
|
|
3517
|
+
__destroy(quitRoom: boolean): Promise<void>;
|
|
3518
|
+
/**
|
|
3519
|
+
* 退出房间之前禁用所有远端资源,避免退出动作耗时过长,
|
|
3520
|
+
* 导致在未完全退出的过程中仍能听到房间内的声音问题
|
|
3521
|
+
*/
|
|
3522
|
+
private _muteRemoteTracksBeforeQuit;
|
|
3523
|
+
private _leaveHandle;
|
|
3524
|
+
/**
|
|
3525
|
+
* 释放 PCManager 上的资源
|
|
3526
|
+
*/
|
|
3527
|
+
private _releasePCManager;
|
|
3528
|
+
private _onLocalTrackDestroied;
|
|
3529
|
+
/**
|
|
3530
|
+
* 本端流状态修改,需通知房间内其他成员
|
|
3531
|
+
* @param localTrack
|
|
3532
|
+
*/
|
|
3533
|
+
private _onLocalTrackMuted;
|
|
3534
|
+
/**
|
|
3535
|
+
* 增量发布资源,若发布的资源 tag 及媒体类型重复,后者将覆盖前者进行发布。
|
|
3536
|
+
* @param tracks 待发布的 RCLocalTrack 实例
|
|
3291
3537
|
* @returns
|
|
3292
3538
|
*/
|
|
3293
|
-
|
|
3539
|
+
publish(tracks: (RCLocalTrack | IPublishAttrs)[]): Promise<IPubSuccessRes>;
|
|
3294
3540
|
/**
|
|
3295
|
-
*
|
|
3541
|
+
* 获取跨房间连麦需携带参数 pushOtherRooms 的值
|
|
3296
3542
|
*/
|
|
3297
|
-
|
|
3543
|
+
protected _getPushOtherRoomsParams(): IPushOtherRooms[];
|
|
3298
3544
|
/**
|
|
3299
|
-
*
|
|
3545
|
+
* ice 断线后,尝试重新走 exchange
|
|
3300
3546
|
*/
|
|
3301
|
-
|
|
3547
|
+
protected _reTryExchange(): Promise<ICommandResult<void>>;
|
|
3302
3548
|
/**
|
|
3303
|
-
*
|
|
3549
|
+
* 增量取消资源发布,若相应资源中存在小流资源,则同时取消发布
|
|
3550
|
+
* @param tracks 取消发布的 RCLocalTrack 列表
|
|
3304
3551
|
*/
|
|
3305
|
-
|
|
3306
|
-
resolution: RCResolution;
|
|
3307
|
-
fps: RCFrameRate;
|
|
3308
|
-
CDNEnable: boolean | undefined;
|
|
3309
|
-
} | {
|
|
3310
|
-
CDNEnable: boolean;
|
|
3311
|
-
resolution?: undefined;
|
|
3312
|
-
fps?: undefined;
|
|
3313
|
-
};
|
|
3314
|
-
getClientSessionId(): string;
|
|
3315
|
-
}
|
|
3316
|
-
|
|
3317
|
-
/**
|
|
3318
|
-
* 北极星上报角色
|
|
3319
|
-
*/
|
|
3320
|
-
declare enum PolarisRole {
|
|
3552
|
+
unpublish(tracks: RCLocalTrack[]): Promise<IPubSuccessRes>;
|
|
3321
3553
|
/**
|
|
3322
|
-
*
|
|
3554
|
+
* resourceId 有效性验证
|
|
3555
|
+
* @param resourceId
|
|
3323
3556
|
*/
|
|
3324
|
-
|
|
3557
|
+
protected _isValidResourceId(resourceId: string): boolean;
|
|
3325
3558
|
/**
|
|
3326
|
-
*
|
|
3559
|
+
* 订阅资源
|
|
3560
|
+
* @param tracks
|
|
3327
3561
|
*/
|
|
3328
|
-
|
|
3329
|
-
|
|
3330
|
-
|
|
3331
|
-
|
|
3332
|
-
private readonly _context;
|
|
3333
|
-
private readonly _runtime;
|
|
3334
|
-
private readonly _roomId;
|
|
3335
|
-
private readonly _crtRTCRoom;
|
|
3336
|
-
private readonly _userRole;
|
|
3337
|
-
constructor(_context: RTCContext, _runtime: IRuntime, _roomId: string, _crtRTCRoom: RCAbstractRoom | RCAudienceLivingRoom, _userRole?: PolarisRole);
|
|
3338
|
-
private _send;
|
|
3339
|
-
private _getClientID;
|
|
3562
|
+
subscribe(tracks: (RCRemoteTrack | ISubscribeAttr)[]): Promise<{
|
|
3563
|
+
code: RCRTCCode;
|
|
3564
|
+
failedList?: ISubscribeAttr[];
|
|
3565
|
+
}>;
|
|
3340
3566
|
/**
|
|
3341
|
-
*
|
|
3567
|
+
* 取消订阅资源
|
|
3568
|
+
* @param tracks 预取消远端资源
|
|
3342
3569
|
*/
|
|
3343
|
-
|
|
3570
|
+
unsubscribe(tracks: RCRemoteTrack[]): Promise<{
|
|
3571
|
+
code: RCRTCCode;
|
|
3572
|
+
failedList?: ISubscribeAttr[];
|
|
3573
|
+
}>;
|
|
3344
3574
|
/**
|
|
3345
|
-
*
|
|
3346
|
-
*
|
|
3575
|
+
* 强制修改订阅列表,仅订阅数组中的资源,取消订阅其他已订阅资源。
|
|
3576
|
+
* 当参数为 `[]` 时,意味着不再订阅任何资源
|
|
3577
|
+
* @param tracks 变更的资源列表
|
|
3347
3578
|
*/
|
|
3348
|
-
|
|
3579
|
+
updateSubList(tracks: (RCRemoteTrack | ISubscribeAttr)[]): Promise<{
|
|
3580
|
+
code: RCRTCCode;
|
|
3581
|
+
failedList?: ISubscribeAttr[];
|
|
3582
|
+
}>;
|
|
3349
3583
|
/**
|
|
3350
|
-
*
|
|
3584
|
+
* 获取已发布的本地资源
|
|
3585
|
+
* @param trackId
|
|
3586
|
+
* @returns
|
|
3351
3587
|
*/
|
|
3352
|
-
|
|
3353
|
-
private _getAudioLevel;
|
|
3354
|
-
private _getBitrate;
|
|
3355
|
-
private _getPacketsLostRate;
|
|
3356
|
-
private _getFrameRate;
|
|
3357
|
-
private _getResolution;
|
|
3358
|
-
private _getJitter;
|
|
3359
|
-
private _getNackCount;
|
|
3360
|
-
private _getPliCount;
|
|
3361
|
-
private _getRTT;
|
|
3362
|
-
private _getTrackState;
|
|
3588
|
+
getLocalTrack(trackId: string): RCLocalTrack | null;
|
|
3363
3589
|
/**
|
|
3364
|
-
*
|
|
3365
|
-
|
|
3590
|
+
* 获取所有已发布的资源
|
|
3591
|
+
*/
|
|
3592
|
+
getLocalTracks(): RCLocalTrack[];
|
|
3593
|
+
/**
|
|
3594
|
+
* 根据 trackId 获取房间内的远端资源
|
|
3595
|
+
* @param trackId
|
|
3596
|
+
* @returns
|
|
3597
|
+
*/
|
|
3598
|
+
getRemoteTrack(trackId: string): RCRemoteAudioTrack | RCRemoteVideoTrack | null;
|
|
3599
|
+
/**
|
|
3600
|
+
* 获取当前已经订阅的全量资源
|
|
3601
|
+
* returns subscribedTracks ISubscribeAttr[]
|
|
3602
|
+
*/
|
|
3603
|
+
get subscribedTracks(): ISubscribeAttr[];
|
|
3604
|
+
private _appListener;
|
|
3605
|
+
/**
|
|
3606
|
+
* 注册事件监听器,多次注册会导致后者覆盖前者,可以通过使用 `registerRoomEventListener(null)` 取消注册
|
|
3607
|
+
* @param listener
|
|
3608
|
+
*/
|
|
3609
|
+
registerRoomEventListener(listener: IRoomEventListener | null): void;
|
|
3610
|
+
/**
|
|
3611
|
+
* 注册房间数据监控
|
|
3612
|
+
* @param listener
|
|
3613
|
+
* @description 该方法暂仅支持 Chrome 浏览器
|
|
3614
|
+
*/
|
|
3615
|
+
registerReportListener(listener: IRCRTCReportListener | null): void;
|
|
3616
|
+
/**
|
|
3617
|
+
* 音量上报
|
|
3618
|
+
* @param handler 音量事件监听函数
|
|
3619
|
+
* @param _ - 参数已废弃,SDK 默认以每秒一次进行回调~~上报时间间隔~~
|
|
3620
|
+
*/
|
|
3621
|
+
onAudioLevelChange(handler: IAudioLevelChangeHandler | null, _?: number): void;
|
|
3622
|
+
/**
|
|
3623
|
+
* 断线重连后尝试补发断线过程中的通知信息
|
|
3366
3624
|
*/
|
|
3367
|
-
sendR3Data(data: IInnerRCRTCStateReport): Promise<RCSendCode>;
|
|
3368
3625
|
/**
|
|
3369
|
-
*
|
|
3370
|
-
* @param
|
|
3626
|
+
* @private
|
|
3627
|
+
* @param livingType
|
|
3371
3628
|
*/
|
|
3372
|
-
|
|
3629
|
+
__onReconnected(livingType?: RCLivingType): void;
|
|
3630
|
+
private _onAudioMuteChange;
|
|
3631
|
+
private _onVideoMuteChange;
|
|
3373
3632
|
/**
|
|
3374
|
-
*
|
|
3633
|
+
* 存储连麦监听事件
|
|
3375
3634
|
*/
|
|
3376
|
-
|
|
3635
|
+
private _onRecvPKMsg;
|
|
3377
3636
|
/**
|
|
3378
|
-
*
|
|
3379
|
-
* RTC 订阅、取消订阅
|
|
3637
|
+
* 注册 PK 业务监听方法
|
|
3380
3638
|
*/
|
|
3381
|
-
|
|
3382
|
-
}
|
|
3383
|
-
|
|
3384
|
-
/**
|
|
3385
|
-
* PC 实例管理类
|
|
3386
|
-
*/
|
|
3387
|
-
declare class RCRTCPeerConnection extends EventEmitter {
|
|
3388
|
-
private _logger;
|
|
3639
|
+
protected _registerPKMsgListener(listener: IOnRecvPKMsg | null): void;
|
|
3389
3640
|
/**
|
|
3390
|
-
*
|
|
3641
|
+
* 退出 PK 房间
|
|
3391
3642
|
*/
|
|
3392
|
-
|
|
3643
|
+
protected _quitAllPKRoom(): Promise<void>;
|
|
3644
|
+
getClientSessionId(): string;
|
|
3393
3645
|
/**
|
|
3394
|
-
*
|
|
3646
|
+
* 切换已发布视频或音频的媒体设备
|
|
3647
|
+
* @param oldTrack 已经发布的视频轨道或音频轨道
|
|
3648
|
+
* @param newTrack 从新设备获取的视频轨道或音频轨道
|
|
3649
|
+
* @returns code 切换结果,RCRTCCode.SUCCESS 表示切换成功
|
|
3395
3650
|
*/
|
|
3396
|
-
|
|
3651
|
+
changeMediaDevice(oldTrack: RCCameraVideoTrack | RCMicphoneAudioTrack, newTrack: RCCameraVideoTrack | RCMicphoneAudioTrack): Promise<{
|
|
3652
|
+
code: RCRTCCode;
|
|
3653
|
+
}>;
|
|
3397
3654
|
/**
|
|
3398
|
-
*
|
|
3655
|
+
* 设置输入语言代码,用于语音识别精准识别
|
|
3656
|
+
* @param srcLanguage 语言代码
|
|
3657
|
+
* @description 需要在 `setEnableASR` 开启语音识别接口之前调用
|
|
3658
|
+
* @return
|
|
3399
3659
|
*/
|
|
3400
|
-
|
|
3660
|
+
setSrcLanguageCode(srcLanguage: string): Promise<ICommandResult<unknown>>;
|
|
3401
3661
|
/**
|
|
3402
|
-
*
|
|
3662
|
+
* 开启房间内的语音识别服务
|
|
3663
|
+
* @description 语音识别功能依赖房间内的音频流,开启后且房间内有音频流,会通过 `onReceiveStartASR` 通知业务层,代表真正开启成功
|
|
3664
|
+
* @returns
|
|
3403
3665
|
*/
|
|
3404
|
-
|
|
3666
|
+
startASR(): Promise<{
|
|
3667
|
+
code: RCRTCCode;
|
|
3668
|
+
}>;
|
|
3405
3669
|
/**
|
|
3406
|
-
*
|
|
3670
|
+
* 关闭房间内的语音识别服务
|
|
3671
|
+
* @returns
|
|
3407
3672
|
*/
|
|
3408
|
-
|
|
3409
|
-
|
|
3410
|
-
|
|
3411
|
-
static __INNER_ICE_STATE_CHANGE__: string;
|
|
3412
|
-
static __INNER_ICE_CONNECTED__: string;
|
|
3413
|
-
private readonly _rtcPeerConn;
|
|
3414
|
-
private readonly _sdpStrategy;
|
|
3415
|
-
reportParser: IStatParser | null;
|
|
3416
|
-
private pubLocalTracks;
|
|
3417
|
-
private _reTryExchangeTimer;
|
|
3418
|
-
private _reportStatsTimer;
|
|
3419
|
-
private _reportR3R4ToPolarisTimer;
|
|
3420
|
-
private _isDestroyed;
|
|
3421
|
-
private _formatStatsData?;
|
|
3422
|
-
constructor(_logger: BasicLogger,
|
|
3673
|
+
stopASR(): Promise<{
|
|
3674
|
+
code: RCRTCCode;
|
|
3675
|
+
}>;
|
|
3423
3676
|
/**
|
|
3424
|
-
*
|
|
3677
|
+
* 是否有语音识别资源
|
|
3678
|
+
* @returns
|
|
3425
3679
|
*/
|
|
3426
|
-
|
|
3680
|
+
asrIsAvailable(): boolean;
|
|
3427
3681
|
/**
|
|
3428
|
-
*
|
|
3682
|
+
* 设置房间内的语音识别资源是否可用
|
|
3683
|
+
* @param enable 为 ture 时,sdk 会获取语音识别资源并解析,通过房间监听事件 `onReceiveASRContent` 事件,抛出语音识别内容
|
|
3684
|
+
* @description
|
|
3685
|
+
* @returns
|
|
3429
3686
|
*/
|
|
3430
|
-
|
|
3687
|
+
setEnableASR(enable: boolean): Promise<{
|
|
3688
|
+
code: RCRTCCode;
|
|
3689
|
+
}>;
|
|
3431
3690
|
/**
|
|
3432
|
-
*
|
|
3691
|
+
* 开启语音实时翻译
|
|
3692
|
+
* @param destLangCode 翻译的目标语言
|
|
3693
|
+
* @description 执行时机:需在房间监听事件 `onReceiveStartASR` 中执行。
|
|
3694
|
+
* @description 执行条件:房间内语音识别资源被设置为可用
|
|
3695
|
+
* @returns
|
|
3433
3696
|
*/
|
|
3434
|
-
|
|
3697
|
+
startRealtimeTranslation(destLangCode: string): Promise<{
|
|
3698
|
+
code: RCRTCCode;
|
|
3699
|
+
}>;
|
|
3435
3700
|
/**
|
|
3436
|
-
*
|
|
3701
|
+
* 关闭语音实时翻译
|
|
3702
|
+
* @returns
|
|
3437
3703
|
*/
|
|
3438
|
-
|
|
3704
|
+
stopRealtimeTranslation(): Promise<{
|
|
3705
|
+
code: RCRTCCode;
|
|
3706
|
+
}>;
|
|
3439
3707
|
/**
|
|
3440
|
-
*
|
|
3708
|
+
* 开始智能总结
|
|
3709
|
+
*
|
|
3710
|
+
* @description 执行时机:需在房间监听事件 `onReceiveStartASR` 中执行。
|
|
3711
|
+
*
|
|
3712
|
+
* @discussion
|
|
3713
|
+
1. 智能总结任务依赖语音识别服务
|
|
3714
|
+
2. 开始智能总结任务为房间级别接口,房间内开始智能总结任务,房间内其他人通过 IRoomEventListener 的 onReceiveStartSummarization 收到通知,并携带任务 Id
|
|
3715
|
+
3. 智能总结任务开始后,房间内的语音识别内容会被用于智能总结生成文本内容
|
|
3716
|
+
4. 智能总结任务开始后,可通过 stopSummarization 接口关闭
|
|
3717
|
+
*
|
|
3718
|
+
* @returns taskId 智能总结任务 Id
|
|
3719
|
+
*/
|
|
3720
|
+
startSummarization(): Promise<{
|
|
3721
|
+
code: RCRTCCode;
|
|
3722
|
+
taskId?: string;
|
|
3723
|
+
}>;
|
|
3724
|
+
/**
|
|
3725
|
+
* 关闭智能总结
|
|
3726
|
+
*
|
|
3727
|
+
* @discussion
|
|
3728
|
+
1. 关闭智能总结任务为房间级别接口,房间内关闭智能总结任务,房间内其他人通过 IRoomEventListener 的 onReceiveStopSummarization 收到通知
|
|
3729
|
+
* @returns
|
|
3441
3730
|
*/
|
|
3442
|
-
|
|
3731
|
+
stopSummarization(): Promise<{
|
|
3732
|
+
code: RCRTCCode;
|
|
3733
|
+
}>;
|
|
3443
3734
|
/**
|
|
3444
|
-
*
|
|
3735
|
+
* 获取智能总结状态数据
|
|
3736
|
+
* @returns ISummarizationStatusData.status 智能总结开关状态
|
|
3737
|
+
* @returns ISummarizationStatusData.taskId 智能总结任务 Id
|
|
3445
3738
|
*/
|
|
3446
|
-
|
|
3447
|
-
|
|
3448
|
-
|
|
3449
|
-
|
|
3450
|
-
|
|
3451
|
-
|
|
3452
|
-
|
|
3453
|
-
|
|
3454
|
-
|
|
3739
|
+
getSummarizationStatusData(): ISummarizationStatusData | null;
|
|
3740
|
+
}
|
|
3741
|
+
|
|
3742
|
+
declare class RCLocalMediaStream {
|
|
3743
|
+
readonly msid: string;
|
|
3744
|
+
readonly mediaStream: MediaStream;
|
|
3745
|
+
readonly tinyStream: MediaStream;
|
|
3746
|
+
readonly tag: string;
|
|
3747
|
+
constructor(msid: string);
|
|
3748
|
+
}
|
|
3749
|
+
|
|
3750
|
+
interface IAudienceRoomEventListener extends IRCRTCTrackEventListener {
|
|
3455
3751
|
/**
|
|
3456
|
-
*
|
|
3752
|
+
* 主播加入
|
|
3753
|
+
* @param userIds 加入主播的 id 列表
|
|
3457
3754
|
*/
|
|
3458
|
-
|
|
3755
|
+
onAnchorJoin?(userId: string[]): void;
|
|
3459
3756
|
/**
|
|
3460
|
-
*
|
|
3461
|
-
* @param
|
|
3462
|
-
* @returns 具有两个属性的对象:
|
|
3463
|
-
* - sdp:SDP 字符串
|
|
3464
|
-
* - 语义:SDP 语义
|
|
3757
|
+
* 主播退出
|
|
3758
|
+
* @param userIds 退出主播的 id 列表
|
|
3465
3759
|
*/
|
|
3466
|
-
|
|
3467
|
-
private _firstConnectFromPub;
|
|
3760
|
+
onAnchorLeave?(userId: string[]): void;
|
|
3468
3761
|
/**
|
|
3469
|
-
*
|
|
3470
|
-
* @param
|
|
3762
|
+
* 房间内合流发布资源
|
|
3763
|
+
* @param tracks 新发布的合流音轨与视轨数据列表,包含新发布的 RCRemoteAudioTrack 与 RCRemoteVideoTrack 实例
|
|
3764
|
+
* @description
|
|
3765
|
+
* 当房间内某个主播第一次发布资源时触发
|
|
3471
3766
|
*/
|
|
3472
|
-
|
|
3473
|
-
getLocalTrack(trackId: string): RCLocalTrack | null;
|
|
3767
|
+
onTrackPublish?(tracks: RCRemoteTrack[]): void;
|
|
3474
3768
|
/**
|
|
3475
|
-
*
|
|
3476
|
-
* @param
|
|
3769
|
+
* 房间内取消合流发布资源
|
|
3770
|
+
* @param tracks 被取消发布的合流音轨与视轨数据列表
|
|
3771
|
+
* @description
|
|
3772
|
+
* 当房间内全部主播退出房间时,SDK 内部会取消对资源的订阅,业务层仅需处理 UI 业务
|
|
3477
3773
|
*/
|
|
3478
|
-
|
|
3774
|
+
onTrackUnpublish?(tracks: RCRemoteTrack[]): void;
|
|
3479
3775
|
/**
|
|
3480
|
-
*
|
|
3481
|
-
* @param
|
|
3482
|
-
* @returns 正在删除的轨道。
|
|
3776
|
+
* 房间内主播发布资源
|
|
3777
|
+
* @param tracks 主播新发布的音轨与视轨数据列表,包含新发布的 RCRemoteAudioTrack 与 RCRemoteVideoTrack 实例
|
|
3483
3778
|
*/
|
|
3484
|
-
|
|
3779
|
+
onAnchorTrackPublish?(tracks: RCRemoteTrack[]): void;
|
|
3485
3780
|
/**
|
|
3486
|
-
*
|
|
3781
|
+
* 房间内主播取消发布资源
|
|
3782
|
+
* @param tracks 被主播取消发布的音轨与视轨数据列表
|
|
3783
|
+
* @description 当资源被取消发布时,SDK 内部会取消对相关资源的订阅,业务层仅需处理 UI 业务
|
|
3487
3784
|
*/
|
|
3488
|
-
|
|
3785
|
+
onAnchorTrackUnpublish?(tracks: RCRemoteTrack[]): void;
|
|
3489
3786
|
/**
|
|
3490
|
-
*
|
|
3491
|
-
* @param
|
|
3787
|
+
* 房间主播禁用/启用音频
|
|
3788
|
+
* @param audioTrack RCRemoteAudioTrack 类实例
|
|
3492
3789
|
*/
|
|
3493
|
-
|
|
3494
|
-
private _updateRecvTransceiverMap;
|
|
3495
|
-
updateSubRemoteTracks(remoteTracks: RCRemoteTrack[]): void;
|
|
3790
|
+
onAudioMuteChange?(audioTrack: RCRemoteAudioTrack): void;
|
|
3496
3791
|
/**
|
|
3497
|
-
|
|
3792
|
+
* 房间主播禁用/启用视频
|
|
3793
|
+
* @param videoTrack RCRemoteVideoTrack 类实例对象
|
|
3794
|
+
*/
|
|
3795
|
+
onVideoMuteChange?(videoTrack: RCRemoteVideoTrack): void;
|
|
3796
|
+
/**
|
|
3797
|
+
* 房间内主播把发布的资源推至 CDN
|
|
3498
3798
|
*/
|
|
3499
|
-
|
|
3500
|
-
|
|
3501
|
-
|
|
3502
|
-
|
|
3799
|
+
onCDNInfoEnable?(CDNInfo: {
|
|
3800
|
+
resolution: RCResolution;
|
|
3801
|
+
fps: RCFrameRate;
|
|
3802
|
+
}): void;
|
|
3503
3803
|
/**
|
|
3504
|
-
*
|
|
3505
|
-
* @param listener
|
|
3804
|
+
* 主播停止推 CDN
|
|
3506
3805
|
*/
|
|
3507
|
-
|
|
3806
|
+
onCDNInfoDisable?(): void;
|
|
3508
3807
|
/**
|
|
3509
|
-
*
|
|
3808
|
+
* 主播改变推 CDN 的分辨率或帧率
|
|
3510
3809
|
*/
|
|
3511
|
-
|
|
3810
|
+
onCDNInfoChange?(CDNInfo: {
|
|
3811
|
+
resolution: RCResolution;
|
|
3812
|
+
fps: RCFrameRate;
|
|
3813
|
+
}): void;
|
|
3814
|
+
}
|
|
3815
|
+
/**
|
|
3816
|
+
* 观众直播房间类
|
|
3817
|
+
* 处理:
|
|
3818
|
+
* 1、通知观众房间内 人员变更、资源变更
|
|
3819
|
+
* 2、观众订阅、取消订阅资源
|
|
3820
|
+
*/
|
|
3821
|
+
declare class RCAudienceLivingRoom {
|
|
3822
|
+
private readonly _context;
|
|
3823
|
+
private readonly _runtime;
|
|
3824
|
+
private readonly _initOptions;
|
|
3825
|
+
private readonly _roomId;
|
|
3826
|
+
private readonly _joinResData;
|
|
3827
|
+
readonly livingType: RCLivingType;
|
|
3828
|
+
protected readonly _clientSessionId: string;
|
|
3829
|
+
private readonly _service;
|
|
3512
3830
|
/**
|
|
3513
|
-
*
|
|
3831
|
+
* 主播列表
|
|
3514
3832
|
*/
|
|
3515
|
-
private
|
|
3516
|
-
private _createRCRTCStateReport;
|
|
3833
|
+
private _roomAnchorList;
|
|
3517
3834
|
/**
|
|
3518
|
-
*
|
|
3519
|
-
* @returns 返回格式化后的数据
|
|
3835
|
+
* 合流、分流资源
|
|
3520
3836
|
*/
|
|
3521
|
-
private
|
|
3837
|
+
private _roomRes;
|
|
3522
3838
|
/**
|
|
3523
|
-
*
|
|
3839
|
+
* 主播分流资源
|
|
3524
3840
|
*/
|
|
3525
|
-
private
|
|
3841
|
+
private _roomAnchorRes;
|
|
3526
3842
|
/**
|
|
3527
|
-
*
|
|
3843
|
+
* 合流、分流 remoteTracks
|
|
3528
3844
|
*/
|
|
3529
|
-
private
|
|
3845
|
+
private _remoteTracks;
|
|
3846
|
+
private _appListener;
|
|
3847
|
+
private readonly _pc;
|
|
3848
|
+
private _subscribedList;
|
|
3849
|
+
private _sessionId;
|
|
3850
|
+
private _destroyed;
|
|
3530
3851
|
/**
|
|
3531
|
-
*
|
|
3852
|
+
* 北极星上报实例
|
|
3532
3853
|
*/
|
|
3533
|
-
|
|
3854
|
+
protected readonly _polarisReport: PolarisReporter;
|
|
3534
3855
|
/**
|
|
3535
|
-
*
|
|
3856
|
+
* 音量上报实例
|
|
3536
3857
|
*/
|
|
3537
|
-
|
|
3538
|
-
getRTCPeerConn(): RTCPeerConnection;
|
|
3858
|
+
private readonly _audioLevelReport;
|
|
3539
3859
|
/**
|
|
3540
|
-
*
|
|
3541
|
-
* 1. 连接生命周期与房间实例一致(包含观众加房间),仅在退出房间时进行关闭。
|
|
3542
|
-
* 2. 观众客户端(观众不加房间)订阅时创建,取消订阅时销毁
|
|
3860
|
+
* cdn_uris 资源
|
|
3543
3861
|
*/
|
|
3544
|
-
|
|
3545
|
-
|
|
3546
|
-
|
|
3547
|
-
|
|
3548
|
-
|
|
3549
|
-
|
|
3550
|
-
* 命令执行上下文
|
|
3551
|
-
*/
|
|
3552
|
-
declare class CommandExecuteContext extends EventEmitter {
|
|
3862
|
+
private _CDNUris;
|
|
3863
|
+
private _isPulling;
|
|
3864
|
+
private _pullTime;
|
|
3865
|
+
private readonly _store;
|
|
3866
|
+
private _crtUserId;
|
|
3867
|
+
private readonly _reportMediaActionLogger;
|
|
3553
3868
|
/**
|
|
3554
|
-
*
|
|
3869
|
+
* track 对应的 mediaServer 信息
|
|
3555
3870
|
*/
|
|
3556
|
-
|
|
3871
|
+
private _trackMediaMap;
|
|
3872
|
+
private readonly _logger;
|
|
3873
|
+
constructor(_context: RTCContext, _runtime: IRuntime, _initOptions: IRCRTCInitOptions, _roomId: string, _joinResData: {
|
|
3874
|
+
token: string;
|
|
3875
|
+
kvEntries: IServerRTCRoomEntry[];
|
|
3876
|
+
}, livingType: RCLivingType, _clientSessionId?: string);
|
|
3877
|
+
private _startPull;
|
|
3557
3878
|
/**
|
|
3558
|
-
*
|
|
3879
|
+
* 解析服务端返回的 KV 数据,赋值 room 内数据
|
|
3559
3880
|
*/
|
|
3560
|
-
|
|
3881
|
+
private _setInitData;
|
|
3882
|
+
protected _assertRoomDestroyed(): RCRTCCode | undefined;
|
|
3561
3883
|
/**
|
|
3562
|
-
*
|
|
3884
|
+
* @description 信令数据处理
|
|
3885
|
+
* @param roomId 数据对应的房间 Id
|
|
3886
|
+
* @param singalData 拉取到的数据
|
|
3887
|
+
* * key RC_ANCHOR_LIST value: 为主播 ID 集合
|
|
3888
|
+
* * key RC_RES_`userId` value: 为主播发布的资源
|
|
3889
|
+
* * key RC_RTC_SESSIONID value: sessionId
|
|
3890
|
+
* * key RC_CDN value: CDN 资源数据
|
|
3563
3891
|
*/
|
|
3564
|
-
|
|
3892
|
+
private singalDataChange;
|
|
3565
3893
|
/**
|
|
3566
|
-
*
|
|
3894
|
+
* 计算加入离开的主播 ID 列表
|
|
3567
3895
|
*/
|
|
3568
|
-
|
|
3896
|
+
private _diffAnchorList;
|
|
3897
|
+
private _handleNewJoinedAnchor;
|
|
3898
|
+
private _handleLeftedAnchor;
|
|
3569
3899
|
/**
|
|
3570
|
-
*
|
|
3900
|
+
* 计算新发布和取消发布的合流资源
|
|
3571
3901
|
*/
|
|
3572
|
-
|
|
3902
|
+
private _diffRoomResource;
|
|
3573
3903
|
/**
|
|
3574
|
-
*
|
|
3904
|
+
* 处理主播资源的新增发布
|
|
3575
3905
|
*/
|
|
3576
|
-
|
|
3906
|
+
private _dealPublished;
|
|
3577
3907
|
/**
|
|
3578
|
-
*
|
|
3908
|
+
* 处理主播资源的取消发布
|
|
3579
3909
|
*/
|
|
3580
|
-
|
|
3910
|
+
private _dealUnpublished;
|
|
3581
3911
|
/**
|
|
3582
|
-
*
|
|
3912
|
+
* 处理主播资源的变更
|
|
3583
3913
|
*/
|
|
3584
|
-
|
|
3585
|
-
constructor(
|
|
3914
|
+
private _dealModified;
|
|
3586
3915
|
/**
|
|
3587
|
-
*
|
|
3588
|
-
|
|
3589
|
-
|
|
3916
|
+
* 计算主播发布和取消发布的资源,以及资源的状态变更
|
|
3917
|
+
*/
|
|
3918
|
+
private _diffAnchorResource;
|
|
3919
|
+
private _onUserUnpublish;
|
|
3920
|
+
private _callAppListener;
|
|
3590
3921
|
/**
|
|
3591
|
-
*
|
|
3922
|
+
* ice 断线后,尝试重新走 exchange
|
|
3923
|
+
*/
|
|
3924
|
+
private _reTryExchange;
|
|
3925
|
+
/**
|
|
3926
|
+
* 获取 subscribe 接口的请求体数据
|
|
3927
|
+
* @param subscribeList 订阅清单
|
|
3928
|
+
* @param publishedStreams 已发布流
|
|
3929
|
+
* @param iceRestart
|
|
3592
3930
|
*/
|
|
3593
|
-
|
|
3931
|
+
protected _createSubscribeParams(subscribeList: ISubscribeAttr[], publishedStreams: {
|
|
3932
|
+
[msid: string]: RCLocalMediaStream;
|
|
3933
|
+
}, iceRestart: boolean): Promise<{
|
|
3934
|
+
reqBody: IBroadcastSubReqBody;
|
|
3935
|
+
offer: RTCSessionDescriptionInit;
|
|
3936
|
+
dynamicBitrate: {
|
|
3937
|
+
min: number;
|
|
3938
|
+
max: number;
|
|
3939
|
+
};
|
|
3940
|
+
}>;
|
|
3941
|
+
private _subscribeHandle;
|
|
3594
3942
|
/**
|
|
3595
|
-
*
|
|
3943
|
+
* 添加 peerConnection 事件
|
|
3596
3944
|
*/
|
|
3597
|
-
|
|
3945
|
+
private _addPeerCEvent;
|
|
3946
|
+
private _getReqHeaders;
|
|
3947
|
+
private _exchangeHandle;
|
|
3948
|
+
private _dealSubscribeResult;
|
|
3598
3949
|
/**
|
|
3599
|
-
*
|
|
3950
|
+
* 去重、转化参数格式为 ISubscribeAttr
|
|
3600
3951
|
*/
|
|
3601
|
-
|
|
3952
|
+
private _getParams;
|
|
3953
|
+
private _reportPubOrSubQualityData;
|
|
3954
|
+
private _updateSubListHandle;
|
|
3602
3955
|
/**
|
|
3603
|
-
*
|
|
3956
|
+
* 对比 cdn_uris 资源
|
|
3957
|
+
* @param newCDNUris 新的 cdn_uris 数据
|
|
3604
3958
|
*/
|
|
3605
|
-
|
|
3959
|
+
private _diffCDNUris;
|
|
3606
3960
|
/**
|
|
3607
|
-
*
|
|
3961
|
+
* 获取 CDN 资源对应的拉流地址
|
|
3962
|
+
* _CDNUris 无 url 时,说明未开启 CDN 推送
|
|
3963
|
+
* @returns CDNPlayUrl
|
|
3608
3964
|
*/
|
|
3609
|
-
|
|
3965
|
+
private _getCDNPlayUrl;
|
|
3610
3966
|
/**
|
|
3611
|
-
*
|
|
3967
|
+
* 获取 CDN 资源对应的拉流地址
|
|
3968
|
+
* @returns CDNPlayUrl
|
|
3612
3969
|
*/
|
|
3613
|
-
|
|
3970
|
+
getCDNPlayUrl(resolution?: RCResolution, fps?: RCFrameRate): Promise<{
|
|
3971
|
+
code: RCRTCCode;
|
|
3972
|
+
CDNPlayUrl?: string;
|
|
3973
|
+
}>;
|
|
3614
3974
|
/**
|
|
3615
|
-
*
|
|
3975
|
+
* 订阅资源
|
|
3976
|
+
* @param tracks
|
|
3616
3977
|
*/
|
|
3617
|
-
|
|
3978
|
+
subscribe(tracks: (RCRemoteTrack | ISubscribeAttr)[]): Promise<{
|
|
3979
|
+
code: RCRTCCode;
|
|
3980
|
+
failedList?: ISubscribeAttr[];
|
|
3981
|
+
}>;
|
|
3982
|
+
private __unsubscribe;
|
|
3618
3983
|
/**
|
|
3619
|
-
*
|
|
3984
|
+
* 取消订阅资源
|
|
3985
|
+
* @param tracks
|
|
3620
3986
|
*/
|
|
3621
|
-
|
|
3622
|
-
|
|
3623
|
-
|
|
3624
|
-
|
|
3625
|
-
* @typeParams T - 事务执行上下文类型
|
|
3626
|
-
* @typeParams S - 内存读写模块类型
|
|
3627
|
-
*/
|
|
3628
|
-
declare class BaseInvoker<T, S> {
|
|
3629
|
-
protected readonly _logger: BasicLogger;
|
|
3987
|
+
unsubscribe(tracks: RCRemoteTrack[]): Promise<{
|
|
3988
|
+
code: RCRTCCode;
|
|
3989
|
+
failedList?: ISubscribeAttr[];
|
|
3990
|
+
}>;
|
|
3630
3991
|
/**
|
|
3631
|
-
*
|
|
3992
|
+
* 退出房间并销毁当前房间实例,退出后该房间的所有方法将不可用
|
|
3993
|
+
* @private
|
|
3632
3994
|
*/
|
|
3633
|
-
|
|
3995
|
+
__destroy(quitRoom: boolean): Promise<void>;
|
|
3634
3996
|
/**
|
|
3635
|
-
*
|
|
3997
|
+
* 根据 trackId 获取房间内的远端资源
|
|
3998
|
+
* @param trackId
|
|
3636
3999
|
*/
|
|
3637
|
-
|
|
4000
|
+
getRemoteTrack(trackId: string): RCRemoteTrack;
|
|
3638
4001
|
/**
|
|
3639
|
-
*
|
|
4002
|
+
* TODO 待优化
|
|
4003
|
+
* @param trackId
|
|
3640
4004
|
*/
|
|
3641
|
-
|
|
3642
|
-
constructor(_logger: BasicLogger,
|
|
4005
|
+
getLocalTrack(trackId: string): RCRemoteTrack;
|
|
3643
4006
|
/**
|
|
3644
|
-
*
|
|
4007
|
+
* 断线重连后处理逻辑, SDK 内部处理调用
|
|
4008
|
+
* @private
|
|
3645
4009
|
*/
|
|
3646
|
-
|
|
4010
|
+
__onReconnected(): Promise<void>;
|
|
3647
4011
|
/**
|
|
3648
|
-
*
|
|
4012
|
+
* 观众房间事件注册
|
|
4013
|
+
* @param tag 参数描述
|
|
3649
4014
|
*/
|
|
3650
|
-
|
|
4015
|
+
registerRoomEventListener(listener: IAudienceRoomEventListener | null): void;
|
|
3651
4016
|
/**
|
|
3652
|
-
*
|
|
4017
|
+
* 音量上报
|
|
4018
|
+
* @param handler 业务端传入的音量上报事件
|
|
4019
|
+
* @param _ - 参数已废弃
|
|
3653
4020
|
*/
|
|
3654
|
-
|
|
3655
|
-
private
|
|
3656
|
-
private _busy;
|
|
3657
|
-
private _next;
|
|
3658
|
-
private _execute;
|
|
3659
|
-
push<R>(command: BaseCommand<R, T, S>): Promise<ICommandResult<R>>;
|
|
3660
|
-
private _isDestroyed;
|
|
3661
|
-
isDestroyed(): boolean;
|
|
3662
|
-
destroy(): void;
|
|
3663
|
-
}
|
|
3664
|
-
/**
|
|
3665
|
-
* 房间任务队列管理
|
|
3666
|
-
*/
|
|
3667
|
-
declare class Invoker extends BaseInvoker<CommandExecuteContext, Store> {
|
|
3668
|
-
constructor(context: CommandExecuteContext, store: Store);
|
|
4021
|
+
onAudioLevelChange(handler: IAudioLevelChangeHandler | null, _?: number): void;
|
|
4022
|
+
private _reportListener;
|
|
3669
4023
|
/**
|
|
3670
|
-
*
|
|
4024
|
+
* 注册房间数据监控
|
|
4025
|
+
* @param listener
|
|
3671
4026
|
*/
|
|
3672
|
-
|
|
3673
|
-
destroy(): void;
|
|
3674
|
-
}
|
|
3675
|
-
|
|
3676
|
-
declare enum CommandPriority {
|
|
3677
|
-
LOW = 0,
|
|
3678
|
-
NORMAL = 1,
|
|
3679
|
-
HIGH = 2
|
|
3680
|
-
}
|
|
3681
|
-
declare type ICommandResult<R = void> = {
|
|
3682
|
-
code: number;
|
|
3683
|
-
data?: R;
|
|
3684
|
-
};
|
|
3685
|
-
/**
|
|
3686
|
-
* 命令基类
|
|
3687
|
-
* @typeParams R - 返回值类型声明
|
|
3688
|
-
* @typeParams T - 命令执行上下文类型
|
|
3689
|
-
* @typeParams S - 内存数据缓存模块
|
|
3690
|
-
*/
|
|
3691
|
-
declare abstract class BaseCommand<R = void, T = CommandExecuteContext, S = Store> {
|
|
4027
|
+
registerReportListener(listener: IRCRTCReportListener | null): void;
|
|
3692
4028
|
/**
|
|
3693
|
-
*
|
|
3694
|
-
* @param context - 事务执行上下文
|
|
3695
|
-
* @param store - 内存读写模块
|
|
3696
|
-
* @param invoker - 任务队列
|
|
4029
|
+
* 获取房间 Id
|
|
3697
4030
|
*/
|
|
3698
|
-
|
|
4031
|
+
getRoomId(): string;
|
|
3699
4032
|
/**
|
|
3700
|
-
*
|
|
4033
|
+
* 获取当前 userId
|
|
3701
4034
|
*/
|
|
3702
|
-
|
|
4035
|
+
getCrtUserId(): string;
|
|
3703
4036
|
/**
|
|
3704
|
-
*
|
|
3705
|
-
* @returns 命令的种类。
|
|
4037
|
+
* 获取房间当前会话 Id,当房间内已无成员时房间会回收,重新加入时 sessionId 将更新
|
|
3706
4038
|
*/
|
|
3707
|
-
|
|
3708
|
-
}
|
|
3709
|
-
|
|
3710
|
-
/**
|
|
3711
|
-
* RTC 消息类型常量
|
|
3712
|
-
* @private
|
|
3713
|
-
*/
|
|
3714
|
-
declare enum RCRTCMessageType {
|
|
4039
|
+
getSessionId(): string;
|
|
3715
4040
|
/**
|
|
3716
|
-
*
|
|
3717
|
-
* @deprecated
|
|
4041
|
+
* 获取远程主播用户列表
|
|
3718
4042
|
*/
|
|
3719
|
-
|
|
4043
|
+
getRemoteUserIds(): string[];
|
|
3720
4044
|
/**
|
|
3721
|
-
*
|
|
3722
|
-
* @
|
|
4045
|
+
* 获取远端用户的资源列表
|
|
4046
|
+
* @param userId
|
|
4047
|
+
* @returns
|
|
3723
4048
|
*/
|
|
3724
|
-
|
|
4049
|
+
getRemoteTracksByUserId(userId: string): RCRemoteTrack[];
|
|
3725
4050
|
/**
|
|
3726
|
-
*
|
|
3727
|
-
* @
|
|
4051
|
+
* 获取房间内所有已发布的远端资源列表, 包含合流资源
|
|
4052
|
+
* @returns
|
|
3728
4053
|
*/
|
|
3729
|
-
|
|
4054
|
+
getRemoteTracks(): RCRemoteTrack[];
|
|
3730
4055
|
/**
|
|
3731
|
-
*
|
|
4056
|
+
* 获取远端 RTC tracks
|
|
3732
4057
|
*/
|
|
3733
|
-
|
|
4058
|
+
getRemoteRTCTracks(): RCRemoteTrack[];
|
|
3734
4059
|
/**
|
|
3735
|
-
*
|
|
4060
|
+
* 获取远端 MCU tracks
|
|
3736
4061
|
*/
|
|
3737
|
-
|
|
4062
|
+
getRemoteMCUTracks(): RCRemoteTrack[];
|
|
3738
4063
|
/**
|
|
3739
|
-
*
|
|
4064
|
+
* 获取房间内 CDN 信息
|
|
3740
4065
|
*/
|
|
3741
|
-
|
|
4066
|
+
getCDNInfo(): {
|
|
4067
|
+
resolution: RCResolution;
|
|
4068
|
+
fps: RCFrameRate;
|
|
4069
|
+
CDNEnable: boolean | undefined;
|
|
4070
|
+
} | {
|
|
4071
|
+
CDNEnable: boolean;
|
|
4072
|
+
resolution?: undefined;
|
|
4073
|
+
fps?: undefined;
|
|
4074
|
+
};
|
|
4075
|
+
getClientSessionId(): string;
|
|
4076
|
+
}
|
|
4077
|
+
|
|
4078
|
+
/**
|
|
4079
|
+
* 北极星上报角色
|
|
4080
|
+
*/
|
|
4081
|
+
declare enum PolarisRole {
|
|
3742
4082
|
/**
|
|
3743
|
-
*
|
|
4083
|
+
* 会议参会者、主播
|
|
3744
4084
|
*/
|
|
3745
|
-
|
|
4085
|
+
MeetingOrAnchor = 1,
|
|
3746
4086
|
/**
|
|
3747
|
-
*
|
|
4087
|
+
* 观众
|
|
3748
4088
|
*/
|
|
3749
|
-
|
|
4089
|
+
Audience = 2
|
|
4090
|
+
}
|
|
4091
|
+
|
|
4092
|
+
declare class PolarisReporter {
|
|
4093
|
+
private readonly _context;
|
|
4094
|
+
private readonly _runtime;
|
|
4095
|
+
private readonly _roomId;
|
|
4096
|
+
private readonly _crtRTCRoom;
|
|
4097
|
+
private readonly _userRole;
|
|
4098
|
+
constructor(_context: RTCContext, _runtime: IRuntime, _roomId: string, _crtRTCRoom: RCAbstractRoom | RCAudienceLivingRoom, _userRole?: PolarisRole);
|
|
4099
|
+
private _send;
|
|
4100
|
+
private _getClientID;
|
|
3750
4101
|
/**
|
|
3751
|
-
*
|
|
4102
|
+
* 小流需去掉 _tiny,小流 resourceId 为 userId_tag_mediaType_tiny
|
|
3752
4103
|
*/
|
|
3753
|
-
|
|
4104
|
+
private _getRealResourceId;
|
|
3754
4105
|
/**
|
|
3755
|
-
*
|
|
4106
|
+
* 生成北极星上报的 trackId
|
|
4107
|
+
* @param resourceId userId_11_1_tiny 改为 userId_11_tiny_video
|
|
3756
4108
|
*/
|
|
3757
|
-
|
|
4109
|
+
private _getPolarisTrackId;
|
|
3758
4110
|
/**
|
|
3759
|
-
*
|
|
4111
|
+
* 上下行 track 包含的公共字段
|
|
3760
4112
|
*/
|
|
3761
|
-
|
|
4113
|
+
private _getBaseData;
|
|
4114
|
+
private _getAudioLevel;
|
|
4115
|
+
private _getBitrate;
|
|
4116
|
+
private _getPacketsLostRate;
|
|
4117
|
+
private _getFrameRate;
|
|
4118
|
+
private _getResolution;
|
|
4119
|
+
private _getJitter;
|
|
4120
|
+
private _getNackCount;
|
|
4121
|
+
private _getPliCount;
|
|
4122
|
+
private _getRTT;
|
|
4123
|
+
private _getTrackState;
|
|
3762
4124
|
/**
|
|
3763
|
-
*
|
|
4125
|
+
* 发送上行音视频资源数据
|
|
4126
|
+
* @param data peerConnection stats 解析出来业务所需的所有字段
|
|
3764
4127
|
*/
|
|
3765
|
-
|
|
4128
|
+
sendR3Data(data: IInnerRCRTCStateReport): Promise<RCSendCode>;
|
|
3766
4129
|
/**
|
|
3767
|
-
*
|
|
4130
|
+
* 发送下行音视频资源数据
|
|
4131
|
+
* @param data peerConnection stats 解析出来业务所需的所有字段
|
|
3768
4132
|
*/
|
|
3769
|
-
|
|
4133
|
+
sendR4Data(data: IInnerRCRTCStateReport): Promise<RCSendCode>;
|
|
3770
4134
|
/**
|
|
3771
|
-
*
|
|
4135
|
+
* 加入房间
|
|
3772
4136
|
*/
|
|
3773
|
-
|
|
4137
|
+
sendR1(): void;
|
|
3774
4138
|
/**
|
|
3775
|
-
*
|
|
4139
|
+
* RTC 和 LIVE 发布、取消发布
|
|
4140
|
+
* RTC 订阅、取消订阅
|
|
3776
4141
|
*/
|
|
3777
|
-
|
|
4142
|
+
sendR2(action: string, status: string, trackIds: string[]): void;
|
|
3778
4143
|
}
|
|
3779
4144
|
|
|
3780
|
-
|
|
3781
|
-
|
|
3782
|
-
|
|
3783
|
-
|
|
3784
|
-
|
|
3785
|
-
|
|
4145
|
+
/**
|
|
4146
|
+
* PC 实例管理类
|
|
4147
|
+
*/
|
|
4148
|
+
declare class RCRTCPeerConnection extends EventEmitter {
|
|
4149
|
+
readonly _context: RTCContext;
|
|
4150
|
+
private _logger;
|
|
3786
4151
|
/**
|
|
3787
|
-
*
|
|
4152
|
+
* _reTryExchange 方法
|
|
3788
4153
|
*/
|
|
3789
|
-
|
|
4154
|
+
private readonly _reTryExchange;
|
|
3790
4155
|
/**
|
|
3791
|
-
*
|
|
4156
|
+
* 当前用户 id
|
|
3792
4157
|
*/
|
|
3793
|
-
|
|
4158
|
+
private readonly _currentUserId;
|
|
3794
4159
|
/**
|
|
3795
|
-
*
|
|
4160
|
+
* store 实例
|
|
3796
4161
|
*/
|
|
3797
|
-
|
|
3798
|
-
}
|
|
3799
|
-
declare class RCLivingPKHandler {
|
|
3800
|
-
private _invoker;
|
|
3801
|
-
private _PKInfo;
|
|
3802
|
-
private readonly _context;
|
|
3803
|
-
private readonly _runtime;
|
|
3804
|
-
private readonly _service;
|
|
3805
|
-
private readonly _initOptions;
|
|
4162
|
+
private readonly _store;
|
|
3806
4163
|
/**
|
|
3807
|
-
*
|
|
4164
|
+
* 北极星上传实例
|
|
3808
4165
|
*/
|
|
3809
|
-
private readonly
|
|
3810
|
-
private readonly _registerPKMsgListener;
|
|
4166
|
+
private readonly _polarisReport?;
|
|
3811
4167
|
/**
|
|
3812
|
-
*
|
|
4168
|
+
* 是否是房间内观众
|
|
3813
4169
|
*/
|
|
3814
|
-
private readonly
|
|
3815
|
-
|
|
4170
|
+
private readonly _isRoomAudience;
|
|
4171
|
+
static __INNER_EVENT_TRACK_READY__: string;
|
|
4172
|
+
static __INNER_AUDIOLEVEL_CHANGE__: string;
|
|
4173
|
+
static __INNER_ICE_STATE_CHANGE__: string;
|
|
4174
|
+
static __INNER_ICE_CONNECTED__: string;
|
|
4175
|
+
static __INNER_SEI_CONTENT__: string;
|
|
4176
|
+
private readonly _rtcPeerConn;
|
|
4177
|
+
private readonly _sdpStrategy;
|
|
4178
|
+
reportParser: IStatParser | null;
|
|
4179
|
+
private pubLocalTracks;
|
|
4180
|
+
private _reTryExchangeTimer;
|
|
4181
|
+
private _reportStatsTimer;
|
|
4182
|
+
private _reportR3R4ToPolarisTimer;
|
|
4183
|
+
private _isDestroyed;
|
|
4184
|
+
private _formatStatsData?;
|
|
4185
|
+
constructor(_context: RTCContext, _logger: BasicLogger,
|
|
3816
4186
|
/**
|
|
3817
|
-
*
|
|
4187
|
+
* _reTryExchange 方法
|
|
3818
4188
|
*/
|
|
3819
|
-
|
|
3820
|
-
private _appListener;
|
|
3821
|
-
private _mainRoomId;
|
|
4189
|
+
_reTryExchange: () => Promise<ICommandResult<void>>,
|
|
3822
4190
|
/**
|
|
3823
|
-
*
|
|
4191
|
+
* 当前用户 id
|
|
3824
4192
|
*/
|
|
3825
|
-
|
|
3826
|
-
private readonly _logger;
|
|
3827
|
-
constructor(_invoker: Invoker, _PKInfo: IPKInfo, _context: RTCContext, _runtime: IRuntime, _service: RCMediaService, _initOptions: IRCRTCInitOptions,
|
|
4193
|
+
_currentUserId: string,
|
|
3828
4194
|
/**
|
|
3829
|
-
*
|
|
4195
|
+
* store 实例
|
|
3830
4196
|
*/
|
|
3831
|
-
|
|
4197
|
+
_store: ReadableStore,
|
|
3832
4198
|
/**
|
|
3833
|
-
*
|
|
4199
|
+
* 北极星上传实例
|
|
3834
4200
|
*/
|
|
3835
|
-
|
|
3836
|
-
private _callAppListener;
|
|
4201
|
+
_polarisReport?: PolarisReporter | undefined,
|
|
3837
4202
|
/**
|
|
3838
|
-
*
|
|
4203
|
+
* 是否是房间内观众
|
|
3839
4204
|
*/
|
|
3840
|
-
|
|
4205
|
+
_isRoomAudience?: boolean,
|
|
3841
4206
|
/**
|
|
3842
|
-
*
|
|
4207
|
+
* 是否启用自定义加密
|
|
3843
4208
|
*/
|
|
3844
|
-
|
|
3845
|
-
|
|
4209
|
+
encrypt?: boolean);
|
|
4210
|
+
getLocalTracks(): RCLocalTrack[];
|
|
4211
|
+
private _decodeSeiData;
|
|
4212
|
+
private _onConnectionStateChange;
|
|
4213
|
+
private startAutoExecute;
|
|
4214
|
+
private stopAutoExecute;
|
|
4215
|
+
private _onICEConnectionStateChange;
|
|
4216
|
+
private _inRetry;
|
|
4217
|
+
private _handleRetry;
|
|
4218
|
+
private _onTrackReady;
|
|
3846
4219
|
/**
|
|
3847
|
-
*
|
|
4220
|
+
* @deprecated use RCLocalTrack.setBitrate instead of setBitrate
|
|
3848
4221
|
*/
|
|
3849
|
-
|
|
3850
|
-
private createLeaveOtherRoomCommand;
|
|
4222
|
+
setBitrate(max: number, min: number, start?: number): Promise<void>;
|
|
3851
4223
|
/**
|
|
3852
|
-
*
|
|
4224
|
+
* `createOffer` 是一个创建报价并记录报价 SDP 和 SDP 语义的函数
|
|
4225
|
+
* @param {boolean} iceRestart - 布尔值
|
|
4226
|
+
* @returns 具有两个属性的对象:
|
|
4227
|
+
* - sdp:SDP 字符串
|
|
4228
|
+
* - 语义:SDP 语义
|
|
3853
4229
|
*/
|
|
3854
|
-
|
|
4230
|
+
createOffer(iceRestart: boolean): Promise<IOfferInfo>;
|
|
4231
|
+
private _firstConnectFromPub;
|
|
3855
4232
|
/**
|
|
3856
|
-
*
|
|
4233
|
+
* @param answer
|
|
4234
|
+
* @param fromPub 是否来自于发布动作,用来对外通知连接成功后统计
|
|
3857
4235
|
*/
|
|
3858
|
-
|
|
4236
|
+
setRemoteAnswer(answer: string, fromPub?: boolean): Promise<RCRTCCode>;
|
|
4237
|
+
getLocalTrack(trackId: string): RCLocalTrack | null;
|
|
3859
4238
|
/**
|
|
3860
|
-
*
|
|
4239
|
+
* 它将本地轨道添加到对等连接。
|
|
4240
|
+
* @param {RCLocalTrack} track - 要添加的本地轨道。
|
|
3861
4241
|
*/
|
|
3862
|
-
|
|
4242
|
+
addLocalTrack(track: RCLocalTrack): void;
|
|
3863
4243
|
/**
|
|
3864
|
-
*
|
|
3865
|
-
* @param
|
|
3866
|
-
* @
|
|
3867
|
-
* @param options.autoMix 是否将本房间资源合并到被邀请者所处房间的 MCU 合流中
|
|
3868
|
-
* @param options.extra 拓展字段,可随邀请连麦消息透传给被邀请者
|
|
4244
|
+
* 按 ID 删除本地轨道
|
|
4245
|
+
* @param {string} trackId - 要移除的轨道的 ID。
|
|
4246
|
+
* @returns 正在删除的轨道。
|
|
3869
4247
|
*/
|
|
3870
|
-
|
|
3871
|
-
code: RCRTCCode | ErrorCode;
|
|
3872
|
-
}>;
|
|
4248
|
+
removeLocalTrackById(trackId: string): void;
|
|
3873
4249
|
/**
|
|
3874
|
-
*
|
|
3875
|
-
* @param inviteeRoomId 被邀请者所处的房间 roomId
|
|
3876
|
-
* @param inviteeUserId 被邀请者 userId
|
|
3877
|
-
* @param extra 附加信息,可随取消邀请连麦消息透传给被邀请者
|
|
4250
|
+
* 它会删除所有本地Track。
|
|
3878
4251
|
*/
|
|
3879
|
-
|
|
3880
|
-
code: RCRTCCode | ErrorCode;
|
|
3881
|
-
}>;
|
|
4252
|
+
removeAllLocalTrack(): void;
|
|
3882
4253
|
/**
|
|
3883
|
-
*
|
|
3884
|
-
* @param
|
|
3885
|
-
* @param inviterUserId 邀请者 userId
|
|
3886
|
-
* @param agree 是否同意连麦
|
|
3887
|
-
* @param options.autoMix 是否将本房间资源合并到邀请者所处房间的 MCU 合流中
|
|
3888
|
-
* @param options.extra 附加信息,可随响应连麦消息透传给邀请者
|
|
4254
|
+
* 从对等连接中删除本地轨道。
|
|
4255
|
+
* @param {RCLocalTrack} track - 要删除的本地轨道。
|
|
3889
4256
|
*/
|
|
3890
|
-
|
|
3891
|
-
|
|
3892
|
-
|
|
4257
|
+
removeLocalTrack(track: RCLocalTrack, isRemoveTiny?: boolean): void;
|
|
4258
|
+
private _updateRecvTransceiverMap;
|
|
4259
|
+
updateSubRemoteTracks(remoteTracks: RCRemoteTrack[]): void;
|
|
3893
4260
|
/**
|
|
3894
|
-
*
|
|
3895
|
-
* @roomId 副房间的 roomId
|
|
4261
|
+
* 获取当前已发布视频流信息
|
|
3896
4262
|
*/
|
|
3897
|
-
|
|
3898
|
-
|
|
3899
|
-
|
|
3900
|
-
|
|
3901
|
-
tracks?: RCRemoteTrack[];
|
|
3902
|
-
CDNEnable?: boolean;
|
|
3903
|
-
}>;
|
|
4263
|
+
getOutboundVideoInfo(): OutboundVideoInfo[];
|
|
4264
|
+
private _onLocalTrackMuted;
|
|
4265
|
+
private _onLocalTrackDestroied;
|
|
4266
|
+
private _reportListener;
|
|
3904
4267
|
/**
|
|
3905
|
-
*
|
|
3906
|
-
* @param
|
|
3907
|
-
|
|
3908
|
-
|
|
3909
|
-
leaveOtherRoom(room: RCLivingRoom, isQuitPK?: boolean): Promise<{
|
|
3910
|
-
code: RCRTCCode;
|
|
3911
|
-
}>;
|
|
4268
|
+
* 注册连接数据监控,开启质量数据上报定时器
|
|
4269
|
+
* @param listener
|
|
4270
|
+
*/
|
|
4271
|
+
registerReportListener(listener: IRCRTCReportListener | null): void;
|
|
3912
4272
|
/**
|
|
3913
|
-
*
|
|
3914
|
-
* @param roomId 连麦房间的 roomId
|
|
4273
|
+
* 组装上行质量报告数据
|
|
3915
4274
|
*/
|
|
3916
|
-
|
|
3917
|
-
inviteSessionId: string;
|
|
3918
|
-
inviterRoomId: string;
|
|
3919
|
-
inviterUserId: string;
|
|
3920
|
-
inviterUserAutoMix?: boolean | undefined;
|
|
3921
|
-
inviteeRoomId: string;
|
|
3922
|
-
inviteeUserAutoMix?: boolean | undefined;
|
|
3923
|
-
};
|
|
4275
|
+
private _createSenderReport;
|
|
3924
4276
|
/**
|
|
3925
|
-
*
|
|
4277
|
+
* 组装下行质量报告数据
|
|
3926
4278
|
*/
|
|
3927
|
-
|
|
4279
|
+
private _createReceiverReport;
|
|
4280
|
+
private _createRCRTCStateReport;
|
|
3928
4281
|
/**
|
|
3929
|
-
*
|
|
4282
|
+
* 获取 peerConnection stats 数据并格式化
|
|
4283
|
+
* @returns 返回格式化后的数据
|
|
3930
4284
|
*/
|
|
3931
|
-
|
|
3932
|
-
[roomId: string]: RCLivingRoom;
|
|
3933
|
-
};
|
|
3934
|
-
}
|
|
3935
|
-
|
|
3936
|
-
declare type ResourceMsgContent = {
|
|
4285
|
+
private _getStatsData;
|
|
3937
4286
|
/**
|
|
3938
|
-
*
|
|
3939
|
-
* * ignore 值为 `true` 表示该消息由 signal server 向旧版本 RTCLib 提供的兼容消息,无需处理
|
|
3940
|
-
* * 否则认为该消息是由旧版本 RTCLib 主动发出的增量变更消息,需要处理
|
|
4287
|
+
* 通知用户质量数据、peerConnection 北极星数据上报
|
|
3941
4288
|
*/
|
|
3942
|
-
|
|
4289
|
+
private _reportHandle;
|
|
3943
4290
|
/**
|
|
3944
|
-
*
|
|
4291
|
+
* 获取合流音源信息
|
|
3945
4292
|
*/
|
|
3946
|
-
|
|
3947
|
-
cdn_uris?: ICDNUris[];
|
|
3948
|
-
};
|
|
3949
|
-
|
|
3950
|
-
/**
|
|
3951
|
-
* 房间抽象基类
|
|
3952
|
-
*/
|
|
3953
|
-
declare abstract class RCAbstractRoom extends EventEmitter {
|
|
3954
|
-
protected readonly _context: RTCContext;
|
|
3955
|
-
protected readonly _runtime: IRuntime;
|
|
3956
|
-
readonly _roomId: string;
|
|
3957
|
-
protected readonly _service: RCMediaService;
|
|
3958
|
-
protected readonly _initOptions: IRCRTCInitOptions;
|
|
3959
|
-
protected readonly _clientSessionId: string;
|
|
4293
|
+
private _getLiveAudioState;
|
|
3960
4294
|
/**
|
|
3961
|
-
*
|
|
4295
|
+
* 北极星上报 R3、R4 数据
|
|
3962
4296
|
*/
|
|
3963
|
-
private
|
|
4297
|
+
private _sendR3R4Data;
|
|
3964
4298
|
/**
|
|
3965
|
-
*
|
|
4299
|
+
* 2s 给北极星上报一次 R3、R4
|
|
3966
4300
|
*/
|
|
3967
|
-
|
|
4301
|
+
__reportR3R4ToPolaris(): Promise<void>;
|
|
4302
|
+
getRTCPeerConn(): RTCPeerConnection;
|
|
3968
4303
|
/**
|
|
3969
|
-
*
|
|
4304
|
+
* 关闭 RTCPeerConnection 连接。其生命周期:
|
|
4305
|
+
* 1. 连接生命周期与房间实例一致(包含观众加房间),仅在退出房间时进行关闭。
|
|
4306
|
+
* 2. 观众客户端(观众不加房间)订阅时创建,取消订阅时销毁
|
|
3970
4307
|
*/
|
|
3971
|
-
|
|
3972
|
-
|
|
3973
|
-
|
|
3974
|
-
|
|
3975
|
-
|
|
3976
|
-
|
|
3977
|
-
|
|
4308
|
+
destroy(): void;
|
|
4309
|
+
clearReTryExchangeTimer(): void;
|
|
4310
|
+
isDestroyed(): boolean;
|
|
4311
|
+
}
|
|
4312
|
+
|
|
4313
|
+
/**
|
|
4314
|
+
* 命令执行上下文
|
|
4315
|
+
*/
|
|
4316
|
+
declare class CommandExecuteContext extends EventEmitter {
|
|
3978
4317
|
/**
|
|
3979
|
-
*
|
|
3980
|
-
* @param {RTCContext} _context - RTC上下文,
|
|
3981
|
-
* @param {IRuntime} _runtime - 运行时
|
|
3982
|
-
* @param {string} _roomId - 房间号
|
|
3983
|
-
* @param {RTCMode} _roomMode - RTC模式,
|
|
3984
|
-
* @param {RCMediaService} _service - RCMediaService
|
|
3985
|
-
* @param {IRCRTCInitOptions} _initOptions - IRCRTCInitOptions
|
|
3986
|
-
* @param {boolean} [isUpgrade] - 是否是升级,如果是升级则不会创建新的peerConnection
|
|
3987
|
-
* @param {boolean} [isMainRoom] - 无论是主房间,主房间都是用户创建的房间,子房间是用户创建的房间。
|
|
3988
|
-
* @param {string} _clientSessionId - 客户端会话 ID,用于标识客户端。
|
|
4318
|
+
* 日志工具
|
|
3989
4319
|
*/
|
|
3990
|
-
|
|
4320
|
+
readonly logger: BasicLogger;
|
|
3991
4321
|
/**
|
|
3992
|
-
*
|
|
4322
|
+
* MediaServer 请求实例
|
|
3993
4323
|
*/
|
|
3994
|
-
|
|
3995
|
-
/** 注册命令执行中的事件监听器 */
|
|
3996
|
-
private setCommandEventListener;
|
|
4324
|
+
readonly service: RCMediaService;
|
|
3997
4325
|
/**
|
|
3998
|
-
*
|
|
3999
|
-
* @param roomId 房间 id
|
|
4326
|
+
* IM 信令上下文
|
|
4000
4327
|
*/
|
|
4001
|
-
|
|
4328
|
+
readonly context: RTCContext;
|
|
4002
4329
|
/**
|
|
4003
|
-
*
|
|
4330
|
+
* 运行时
|
|
4004
4331
|
*/
|
|
4005
|
-
|
|
4006
|
-
code: RCRTCCode | ErrorCode;
|
|
4007
|
-
data?: IJoinRTCRoomData;
|
|
4008
|
-
}>;
|
|
4009
|
-
protected _initWithRoomData(offlineKickTime: number): void;
|
|
4010
|
-
private _handlePingResult;
|
|
4332
|
+
readonly runtime: IRuntime;
|
|
4011
4333
|
/**
|
|
4012
|
-
*
|
|
4013
|
-
* @deprecated use RCLocalTrack.setBitrate instead of setBitrate
|
|
4014
|
-
* @description
|
|
4015
|
-
* * 自 v5.1.0 版本开始,推荐使用 `RCLocalTrack.setBitrate` 对不同流分别指定码率。
|
|
4016
|
-
* * 该方法仅在 SDP `plan-b` 协议下(Chrome 92 与 Safari 11 之前的版本)有效。
|
|
4017
|
-
* @param max 音视频发送码率上限,不可小于 200 且不可小于 `min`
|
|
4018
|
-
* @param min 音视频发送码率下限,默认值为 1,且不可小于 1,不可大于 `max`
|
|
4019
|
-
* @param start 起始码率,默认为码率上限的 70%
|
|
4334
|
+
* PeerConenction 连接实例
|
|
4020
4335
|
*/
|
|
4021
|
-
|
|
4022
|
-
private _onTrackReady;
|
|
4023
|
-
protected _callAppListener(eventType: keyof IRoomEventListener, ...attrs: any[]): void;
|
|
4024
|
-
private _onTrackUnpublish;
|
|
4336
|
+
readonly peer: RCRTCPeerConnection;
|
|
4025
4337
|
/**
|
|
4026
|
-
*
|
|
4338
|
+
* 内存只读模块
|
|
4027
4339
|
*/
|
|
4028
|
-
|
|
4340
|
+
readonly store: ReadableStore;
|
|
4029
4341
|
/**
|
|
4030
|
-
*
|
|
4031
|
-
* @param byServer
|
|
4032
|
-
* * 当值为 false 时,说明本端 rtcPing 超时
|
|
4033
|
-
* * 当值为 true 时,说明本端收到被踢出房间通知
|
|
4034
|
-
* @private
|
|
4342
|
+
* 北极星统计工具
|
|
4035
4343
|
*/
|
|
4036
|
-
|
|
4037
|
-
private _rtcpeerClosed;
|
|
4344
|
+
readonly polarisReport: PolarisReporter;
|
|
4038
4345
|
/**
|
|
4039
|
-
*
|
|
4040
|
-
* @param content
|
|
4041
|
-
* @param messageType 消息类型
|
|
4042
|
-
* @param userId 消息发送者
|
|
4346
|
+
* 行为数据采集工具
|
|
4043
4347
|
*/
|
|
4044
|
-
|
|
4045
|
-
|
|
4348
|
+
readonly reportMediaActionLogger: ReportMediaActionLogger;
|
|
4349
|
+
constructor(
|
|
4046
4350
|
/**
|
|
4047
|
-
*
|
|
4048
|
-
* @param content
|
|
4351
|
+
* 日志工具
|
|
4049
4352
|
*/
|
|
4050
|
-
|
|
4353
|
+
logger: BasicLogger,
|
|
4051
4354
|
/**
|
|
4052
|
-
*
|
|
4355
|
+
* MediaServer 请求实例
|
|
4053
4356
|
*/
|
|
4054
|
-
|
|
4357
|
+
service: RCMediaService,
|
|
4055
4358
|
/**
|
|
4056
|
-
*
|
|
4359
|
+
* IM 信令上下文
|
|
4057
4360
|
*/
|
|
4058
|
-
|
|
4361
|
+
context: RTCContext,
|
|
4059
4362
|
/**
|
|
4060
|
-
*
|
|
4363
|
+
* 运行时
|
|
4061
4364
|
*/
|
|
4062
|
-
|
|
4365
|
+
runtime: IRuntime,
|
|
4063
4366
|
/**
|
|
4064
|
-
*
|
|
4367
|
+
* PeerConenction 连接实例
|
|
4065
4368
|
*/
|
|
4066
|
-
|
|
4369
|
+
peer: RCRTCPeerConnection,
|
|
4067
4370
|
/**
|
|
4068
|
-
*
|
|
4069
|
-
* @returns
|
|
4371
|
+
* 内存只读模块
|
|
4070
4372
|
*/
|
|
4071
|
-
|
|
4373
|
+
store: ReadableStore,
|
|
4072
4374
|
/**
|
|
4073
|
-
*
|
|
4074
|
-
* @param userId
|
|
4075
|
-
* @returns
|
|
4375
|
+
* 北极星统计工具
|
|
4076
4376
|
*/
|
|
4077
|
-
|
|
4377
|
+
polarisReport: PolarisReporter,
|
|
4078
4378
|
/**
|
|
4079
|
-
*
|
|
4379
|
+
* 行为数据采集工具
|
|
4080
4380
|
*/
|
|
4081
|
-
|
|
4381
|
+
reportMediaActionLogger: ReportMediaActionLogger);
|
|
4082
4382
|
/**
|
|
4083
|
-
*
|
|
4084
|
-
* @param name 消息名称
|
|
4085
|
-
* @param content 消息内容
|
|
4383
|
+
* 代理房间实例以获取跨房间连麦时的推送配置
|
|
4086
4384
|
*/
|
|
4087
|
-
|
|
4088
|
-
|
|
4089
|
-
|
|
4385
|
+
getPushOtherRooms: () => IPushOtherRooms[];
|
|
4386
|
+
}
|
|
4387
|
+
|
|
4388
|
+
declare enum CommandPriority {
|
|
4389
|
+
LOW = 0,
|
|
4390
|
+
NORMAL = 1,
|
|
4391
|
+
HIGH = 2
|
|
4392
|
+
}
|
|
4393
|
+
declare type ICommandResult<R = void> = {
|
|
4394
|
+
code: number;
|
|
4395
|
+
data?: R;
|
|
4396
|
+
};
|
|
4397
|
+
/**
|
|
4398
|
+
* 命令基类
|
|
4399
|
+
* @typeParams R - 返回值类型声明
|
|
4400
|
+
* @typeParams T - 命令执行上下文类型
|
|
4401
|
+
* @typeParams S - 内存数据缓存模块
|
|
4402
|
+
*/
|
|
4403
|
+
declare abstract class BaseCommand<R = void, T = CommandExecuteContext, S = Store> {
|
|
4090
4404
|
/**
|
|
4091
|
-
*
|
|
4092
|
-
* @param
|
|
4093
|
-
* @param
|
|
4094
|
-
* @param
|
|
4095
|
-
* @param isInner RTC 业务内部使用参数,用户忽略
|
|
4405
|
+
* 事务执行函数
|
|
4406
|
+
* @param context - 事务执行上下文
|
|
4407
|
+
* @param store - 内存读写模块
|
|
4408
|
+
* @param invoker - 任务队列
|
|
4096
4409
|
*/
|
|
4097
|
-
|
|
4098
|
-
name: string;
|
|
4099
|
-
content: string;
|
|
4100
|
-
}, isInner?: boolean): Promise<{
|
|
4101
|
-
code: RCRTCCode;
|
|
4102
|
-
}>;
|
|
4410
|
+
abstract execute(context: T, store: S, invoker: BaseInvoker<T, S>): Promise<ICommandResult<R>>;
|
|
4103
4411
|
/**
|
|
4104
|
-
*
|
|
4105
|
-
* @param keys 待删除的属性名数组
|
|
4106
|
-
* @param message 是否在删除属性的时候携带消息内容,传空则不往房间中发送消息
|
|
4107
|
-
* @param isInner RTC 业务内部使用参数,用户忽略
|
|
4412
|
+
* 获取指令优先级,必要时可 override 此函数
|
|
4108
4413
|
*/
|
|
4109
|
-
|
|
4110
|
-
name: string;
|
|
4111
|
-
content: string;
|
|
4112
|
-
}, isInner?: boolean): Promise<{
|
|
4113
|
-
code: RCRTCCode;
|
|
4114
|
-
}>;
|
|
4414
|
+
get priority(): CommandPriority;
|
|
4115
4415
|
/**
|
|
4116
|
-
*
|
|
4117
|
-
* @
|
|
4118
|
-
* @param isInner RTC 业务内部使用参数,用户忽略
|
|
4416
|
+
* 它返回命令的种类。
|
|
4417
|
+
* @returns 命令的种类。
|
|
4119
4418
|
*/
|
|
4120
|
-
|
|
4121
|
-
|
|
4122
|
-
|
|
4123
|
-
|
|
4419
|
+
get kind(): RCCommandKind;
|
|
4420
|
+
}
|
|
4421
|
+
|
|
4422
|
+
/**
|
|
4423
|
+
* @typeParams T - 事务执行上下文类型
|
|
4424
|
+
* @typeParams S - 内存读写模块类型
|
|
4425
|
+
*/
|
|
4426
|
+
declare class BaseInvoker<T, S> {
|
|
4427
|
+
protected readonly _logger: BasicLogger;
|
|
4124
4428
|
/**
|
|
4125
|
-
*
|
|
4126
|
-
* @param key 属性名
|
|
4127
|
-
* @param value 属性值
|
|
4128
|
-
* @param message 是否在设置属性的时候携带消息内容,传空则不往房间中发送消息
|
|
4429
|
+
* 内存数据管理实例
|
|
4129
4430
|
*/
|
|
4130
|
-
|
|
4431
|
+
protected readonly _context: T;
|
|
4131
4432
|
/**
|
|
4132
|
-
*
|
|
4133
|
-
* @param keys 待删除的属性名数组
|
|
4134
|
-
* @param message 是否在删除属性的时候携带消息内容,传空则不往房间中发送消息
|
|
4433
|
+
* 内存读写模块
|
|
4135
4434
|
*/
|
|
4136
|
-
|
|
4435
|
+
protected readonly _store: S;
|
|
4137
4436
|
/**
|
|
4138
|
-
*
|
|
4139
|
-
* @param keys 要查询的属性名数组
|
|
4437
|
+
* 命令终止时返回的错误码定义
|
|
4140
4438
|
*/
|
|
4141
|
-
private
|
|
4439
|
+
private abortCode;
|
|
4440
|
+
constructor(_logger: BasicLogger,
|
|
4142
4441
|
/**
|
|
4143
|
-
*
|
|
4442
|
+
* 内存数据管理实例
|
|
4144
4443
|
*/
|
|
4145
|
-
|
|
4444
|
+
_context: T,
|
|
4146
4445
|
/**
|
|
4147
|
-
*
|
|
4148
|
-
* @private
|
|
4446
|
+
* 内存读写模块
|
|
4149
4447
|
*/
|
|
4150
|
-
|
|
4448
|
+
_store: S,
|
|
4151
4449
|
/**
|
|
4152
|
-
*
|
|
4153
|
-
* 导致在未完全退出的过程中仍能听到房间内的声音问题
|
|
4450
|
+
* 命令终止时返回的错误码定义
|
|
4154
4451
|
*/
|
|
4155
|
-
|
|
4156
|
-
private
|
|
4452
|
+
abortCode: RCRTCCode);
|
|
4453
|
+
private _queue;
|
|
4454
|
+
private _busy;
|
|
4455
|
+
private _next;
|
|
4456
|
+
private _execute;
|
|
4457
|
+
push<R>(command: BaseCommand<R, T, S>): Promise<ICommandResult<R>>;
|
|
4458
|
+
private _isDestroyed;
|
|
4459
|
+
isDestroyed(): boolean;
|
|
4460
|
+
destroy(): void;
|
|
4461
|
+
}
|
|
4462
|
+
/**
|
|
4463
|
+
* 房间任务队列管理
|
|
4464
|
+
*/
|
|
4465
|
+
declare class Invoker extends BaseInvoker<CommandExecuteContext, Store> {
|
|
4466
|
+
constructor(context: CommandExecuteContext, store: Store);
|
|
4157
4467
|
/**
|
|
4158
|
-
*
|
|
4468
|
+
* 获取 store 存储实例,返回值类型 `ReadableStore`,避免非 command 定义中修改内存
|
|
4159
4469
|
*/
|
|
4160
|
-
|
|
4161
|
-
|
|
4470
|
+
get store(): ReadableStore;
|
|
4471
|
+
destroy(): void;
|
|
4472
|
+
}
|
|
4473
|
+
|
|
4474
|
+
declare enum RCRTCRealtimeTranslationType {
|
|
4475
|
+
OPEN = 1,
|
|
4476
|
+
CLOSE = 0
|
|
4477
|
+
}
|
|
4478
|
+
|
|
4479
|
+
declare class RCMediaService {
|
|
4480
|
+
private readonly _runtime;
|
|
4481
|
+
private readonly _context;
|
|
4162
4482
|
/**
|
|
4163
|
-
*
|
|
4164
|
-
* @param localTrack
|
|
4483
|
+
* 自定义 MediaServer 地址,当有值时,不再使用导航内的地址
|
|
4165
4484
|
*/
|
|
4166
|
-
private
|
|
4485
|
+
private readonly _msUrl?;
|
|
4167
4486
|
/**
|
|
4168
|
-
*
|
|
4169
|
-
* @param tracks 待发布的 RCLocalTrack 实例
|
|
4170
|
-
* @returns
|
|
4487
|
+
* 请求超时时长
|
|
4171
4488
|
*/
|
|
4172
|
-
|
|
4489
|
+
private readonly _timeout;
|
|
4173
4490
|
/**
|
|
4174
|
-
*
|
|
4491
|
+
* 已失败的请求地址
|
|
4175
4492
|
*/
|
|
4176
|
-
|
|
4493
|
+
private readonly _failedMs;
|
|
4177
4494
|
/**
|
|
4178
|
-
*
|
|
4495
|
+
* 服务器指纹数据,客户端不得修改,直接透传
|
|
4179
4496
|
*/
|
|
4180
|
-
|
|
4497
|
+
private _rtcFinger;
|
|
4181
4498
|
/**
|
|
4182
|
-
*
|
|
4183
|
-
* @param tracks 取消发布的 RCLocalTrack 列表
|
|
4499
|
+
* 服务器接口返回的 clusterId 数据,当此数据有值时,后续所有请求向此服务发送
|
|
4184
4500
|
*/
|
|
4185
|
-
|
|
4501
|
+
private _clusterId;
|
|
4186
4502
|
/**
|
|
4187
|
-
*
|
|
4188
|
-
* @param resourceId
|
|
4503
|
+
* MCU 服务地址
|
|
4189
4504
|
*/
|
|
4190
|
-
|
|
4505
|
+
private _configUrl;
|
|
4191
4506
|
/**
|
|
4192
|
-
*
|
|
4193
|
-
* @param tracks
|
|
4507
|
+
* 排好序的探测地址
|
|
4194
4508
|
*/
|
|
4195
|
-
|
|
4196
|
-
|
|
4197
|
-
|
|
4198
|
-
|
|
4509
|
+
private static msInDetector;
|
|
4510
|
+
private static detectorTime;
|
|
4511
|
+
private static detectValidMinute;
|
|
4512
|
+
private _msList;
|
|
4513
|
+
private _qualityMsList;
|
|
4514
|
+
private readonly _logger;
|
|
4515
|
+
constructor(_runtime: IRuntime, _context: RTCContext,
|
|
4199
4516
|
/**
|
|
4200
|
-
*
|
|
4201
|
-
* @param tracks 预取消远端资源
|
|
4517
|
+
* 自定义 MediaServer 地址,当有值时,不再使用导航内的地址
|
|
4202
4518
|
*/
|
|
4203
|
-
|
|
4204
|
-
code: RCRTCCode;
|
|
4205
|
-
failedList?: ISubscribeAttr[];
|
|
4206
|
-
}>;
|
|
4519
|
+
_msUrl?: string | undefined,
|
|
4207
4520
|
/**
|
|
4208
|
-
*
|
|
4209
|
-
* 当参数为 `[]` 时,意味着不再订阅任何资源
|
|
4210
|
-
* @param tracks 变更的资源列表
|
|
4521
|
+
* 请求超时时长
|
|
4211
4522
|
*/
|
|
4212
|
-
|
|
4213
|
-
code: RCRTCCode;
|
|
4214
|
-
failedList?: ISubscribeAttr[];
|
|
4215
|
-
}>;
|
|
4523
|
+
_timeout?: number);
|
|
4216
4524
|
/**
|
|
4217
|
-
*
|
|
4218
|
-
*
|
|
4219
|
-
*
|
|
4525
|
+
* 是否需要嗅探
|
|
4526
|
+
* im 未连接,无 navi 数据时,不需要嗅探
|
|
4527
|
+
* 客户端手动配置 mediaServer 时,不需要嗅探
|
|
4528
|
+
* navi 数据中 detectionServer 为空时,不需要嗅探
|
|
4529
|
+
* navi 数据中 jwt 为空时,不需要嗅探
|
|
4530
|
+
* 在探测有效期内不需要嗅探
|
|
4531
|
+
* RCMediaService.detectorTime 为 0 时,代表未探测过,需要嗅探
|
|
4220
4532
|
*/
|
|
4221
|
-
|
|
4533
|
+
isNededDetector(): boolean;
|
|
4534
|
+
detectorMediaSever(): void;
|
|
4222
4535
|
/**
|
|
4223
|
-
*
|
|
4536
|
+
* 地址探测
|
|
4537
|
+
* RTC 初始化时检测是否可以拿到 navi,可以拿到开始嗅探
|
|
4538
|
+
* 拿不到等 IM 链接成功后,再回调中调用开始嗅探
|
|
4224
4539
|
*/
|
|
4225
|
-
|
|
4540
|
+
private _startDetector;
|
|
4226
4541
|
/**
|
|
4227
|
-
*
|
|
4228
|
-
* @param trackId
|
|
4229
|
-
* @returns
|
|
4542
|
+
* 清空 msList 列表,重新请求导航后需清空 msList 列表
|
|
4230
4543
|
*/
|
|
4231
|
-
|
|
4544
|
+
clearMSList(): void;
|
|
4545
|
+
getMsList(): string[];
|
|
4232
4546
|
/**
|
|
4233
|
-
*
|
|
4234
|
-
*
|
|
4547
|
+
* _mslist 列表排序:[_clusterId, ping1DetectorUrl, 主域名, ping2DetectorUrl, ..., pingNDetectorUrl, 备用域名list ]
|
|
4548
|
+
* ping1 :ping 结果返回最快值
|
|
4235
4549
|
*/
|
|
4236
|
-
|
|
4237
|
-
private _appListener;
|
|
4550
|
+
private _sortMediaServiceList;
|
|
4238
4551
|
/**
|
|
4239
|
-
*
|
|
4240
|
-
* @param listener
|
|
4552
|
+
* 配置 gzip 请求头和请求体
|
|
4241
4553
|
*/
|
|
4242
|
-
|
|
4554
|
+
private _openGzip;
|
|
4243
4555
|
/**
|
|
4244
|
-
*
|
|
4245
|
-
* @param listener
|
|
4246
|
-
* @description 该方法暂仅支持 Chrome 浏览器
|
|
4556
|
+
* 处理 request 成功的结果
|
|
4247
4557
|
*/
|
|
4248
|
-
|
|
4558
|
+
private _dealRequestSuccessResult;
|
|
4249
4559
|
/**
|
|
4250
|
-
*
|
|
4251
|
-
* @param
|
|
4252
|
-
* @param
|
|
4560
|
+
* 发送请求,请求发送若失败,会继续尝试使用后续可用地址直到无地址可用,此时认为请求失败
|
|
4561
|
+
* @param path
|
|
4562
|
+
* @param header
|
|
4563
|
+
* @param body
|
|
4253
4564
|
*/
|
|
4254
|
-
|
|
4565
|
+
private _request;
|
|
4255
4566
|
/**
|
|
4256
|
-
*
|
|
4567
|
+
* 资源协商接口,订阅、发布、变更资源均可以使用此接口。该接口通过 sdp 字段交换 SDP 信息,
|
|
4568
|
+
* 并通过 subscribeList 和 publishList 表明最终发布和订阅的资源。本端产出 offer,服务器产出 answer
|
|
4569
|
+
* 每次接口调用,都会全量覆盖发布和订阅的资源。
|
|
4570
|
+
* @param header
|
|
4571
|
+
* @param body
|
|
4257
4572
|
*/
|
|
4573
|
+
exchange(headers: IRTCReqHeader, body: IExchangeReqBody, traceId: string, isNeedUpdateMsas?: boolean): Promise<{
|
|
4574
|
+
code: RCRTCCode;
|
|
4575
|
+
data?: IExchangeResponse | undefined;
|
|
4576
|
+
qualityMsList?: IMediaServerQualityData[] | undefined;
|
|
4577
|
+
}>;
|
|
4258
4578
|
/**
|
|
4259
|
-
*
|
|
4260
|
-
* @param livingType
|
|
4579
|
+
* 退出房间
|
|
4261
4580
|
*/
|
|
4262
|
-
|
|
4263
|
-
private _onAudioMuteChange;
|
|
4264
|
-
private _onVideoMuteChange;
|
|
4581
|
+
exit(headers: IRTCReqHeader): Promise<RCRTCCode>;
|
|
4265
4582
|
/**
|
|
4266
|
-
*
|
|
4583
|
+
* 观众端订阅主播资源
|
|
4267
4584
|
*/
|
|
4268
|
-
|
|
4585
|
+
broadcastSubscribe(headers: IRTCReqHeader, body: IBroadcastSubReqBody): Promise<{
|
|
4586
|
+
code: RCRTCCode;
|
|
4587
|
+
data?: IBroadcastSubRespBody | undefined;
|
|
4588
|
+
qualityMsList?: IMediaServerQualityData[] | undefined;
|
|
4589
|
+
}>;
|
|
4269
4590
|
/**
|
|
4270
|
-
*
|
|
4591
|
+
* 观众端退出订阅
|
|
4271
4592
|
*/
|
|
4272
|
-
|
|
4593
|
+
broadcastExit(headers: IRTCReqHeader): Promise<{
|
|
4594
|
+
code: RCRTCCode;
|
|
4595
|
+
}>;
|
|
4273
4596
|
/**
|
|
4274
|
-
*
|
|
4597
|
+
* 直播推流、自定义布局配置
|
|
4275
4598
|
*/
|
|
4276
|
-
|
|
4277
|
-
|
|
4599
|
+
setMcuConfig(headers: IMCUReqHeaders, body: IMCUConfig | ISetEnableCDN): Promise<{
|
|
4600
|
+
code: RCRTCCode;
|
|
4601
|
+
res?: any;
|
|
4602
|
+
}>;
|
|
4278
4603
|
/**
|
|
4279
|
-
*
|
|
4280
|
-
* @param oldTrack 已经发布的视频轨道或音频轨道
|
|
4281
|
-
* @param newTrack 从新设备获取的视频轨道或音频轨道
|
|
4282
|
-
* @returns code 切换结果,RCRTCCode.SUCCESS 表示切换成功
|
|
4604
|
+
* 房间内观众获取 CDN 资源信息、拉流地址
|
|
4283
4605
|
*/
|
|
4284
|
-
|
|
4606
|
+
getCDNResourceInfo(headers: ICDNPlayUrlReqHeaders, url: string, traceId: string): Promise<{
|
|
4607
|
+
code: RCRTCCode;
|
|
4608
|
+
res?: ICDNPlayUrlResponse;
|
|
4609
|
+
}>;
|
|
4610
|
+
updateASRStatus(headers: IRTCReqHeader, body: {
|
|
4611
|
+
'asr_status': RCRTCASRStatus;
|
|
4612
|
+
}, traceId: string): Promise<{
|
|
4613
|
+
code: RCRTCCode;
|
|
4614
|
+
data?: {
|
|
4615
|
+
resultCode: number;
|
|
4616
|
+
} | undefined;
|
|
4617
|
+
qualityMsList?: IMediaServerQualityData[] | undefined;
|
|
4618
|
+
}>;
|
|
4619
|
+
operateRealtimeTranslation(headers: IRTCReqHeader, body: {
|
|
4620
|
+
status: RCRTCRealtimeTranslationType;
|
|
4621
|
+
destLanguage?: string;
|
|
4622
|
+
}, traceId: string): Promise<{
|
|
4623
|
+
code: RCRTCCode;
|
|
4624
|
+
data?: {
|
|
4625
|
+
resultCode: number;
|
|
4626
|
+
} | undefined;
|
|
4627
|
+
qualityMsList?: IMediaServerQualityData[] | undefined;
|
|
4628
|
+
}>;
|
|
4629
|
+
operateSummarization(headers: IRTCReqHeader, body: {
|
|
4630
|
+
status: RCRTCOperateSummarizationType;
|
|
4631
|
+
}, traceId: string): Promise<{
|
|
4632
|
+
code: RCRTCCode;
|
|
4633
|
+
data?: {
|
|
4634
|
+
resultCode: number;
|
|
4635
|
+
taskId?: string | undefined;
|
|
4636
|
+
} | undefined;
|
|
4637
|
+
qualityMsList?: IMediaServerQualityData[] | undefined;
|
|
4638
|
+
}>;
|
|
4639
|
+
generateSummarization(roomId: string, taskId: string, startTime: number, endTime: number, config: IRCRTCGenerateSummarizationConfig, contentBlock: (data: string) => void, traceId: string): Promise<{
|
|
4640
|
+
code: RCRTCCode;
|
|
4641
|
+
}>;
|
|
4642
|
+
getASRContent(roomId: string, taskId: string, startTime: number, endTime: number, contentBlock: (data: string) => void, traceId: string, destLang?: string): Promise<{
|
|
4285
4643
|
code: RCRTCCode;
|
|
4286
4644
|
}>;
|
|
4287
4645
|
}
|
|
@@ -4851,6 +5209,10 @@ interface IJoinRTCRoomOptions {
|
|
|
4851
5209
|
* 设置用户属性
|
|
4852
5210
|
*/
|
|
4853
5211
|
userData?: IRTCUserData;
|
|
5212
|
+
/**
|
|
5213
|
+
* 昵称,用于智能总结
|
|
5214
|
+
*/
|
|
5215
|
+
nickName?: string;
|
|
4854
5216
|
}
|
|
4855
5217
|
/**
|
|
4856
5218
|
* RTC 业务客户端
|
|
@@ -5003,6 +5365,32 @@ declare class RCRTCClient extends RCMediaStreamCapture {
|
|
|
5003
5365
|
code: RCRTCCode | ErrorCode;
|
|
5004
5366
|
data?: IRTCJoinedInfo[];
|
|
5005
5367
|
}>;
|
|
5368
|
+
/**
|
|
5369
|
+
* 生成智能总结
|
|
5370
|
+
* @param roomId 生成智能总结的房间 Id
|
|
5371
|
+
* @param taskId 智能总结任务 Id,通过 onReceiveStartSummarization 回调获取到
|
|
5372
|
+
* @param startTime 本次需要总结的开始时间,UTC 时间戳,单位秒,传入 0,表示总结开始的时间
|
|
5373
|
+
* @param endTime 本次需要总结的结束时间,UTC 时间戳,单位秒,传入 0,表示当前时间,如果总结已经停止,则表示总结结束的时间
|
|
5374
|
+
* @param config 生成智能总结配置,其中 enableSummarization、enableSummarizationDetails、enableChapterSummary、enableTodoList、enableHashtag 必须有一个为 true,否则不会产生任何总结内容
|
|
5375
|
+
* @param contentBlock 内容回调
|
|
5376
|
+
* @returns
|
|
5377
|
+
*/
|
|
5378
|
+
generateSummarization(roomId: string, taskId: string, startTime: number | undefined, endTime: number | undefined, config: IRCRTCGenerateSummarizationConfig, contentBlock: (data: string) => void): Promise<{
|
|
5379
|
+
code: RCRTCCode;
|
|
5380
|
+
}>;
|
|
5381
|
+
/**
|
|
5382
|
+
* 获取语音转文字内容
|
|
5383
|
+
* @param roomId 获取语音转文字的房间 Id
|
|
5384
|
+
* @param taskId 智能总结任务 Id,通过 onReceiveStartSummarization 回调获取
|
|
5385
|
+
* @param startTime 本次需要获取语音转文字的开始时间,UTC 时间戳,单位秒,传入 0,表示总结开始的时间
|
|
5386
|
+
* @param endTime 本次需要获取语音转文字的结束时间,UTC 时间戳,单位秒,传入 0,表示当前时间,如果总结已经停止,则表示总结结束的时间
|
|
5387
|
+
* @param destLang 目标语言代码,如果传入 nil,则使用默认语言
|
|
5388
|
+
* @param contentBlock 内容回调,如果内容比较多,contentBlock 会回调多次
|
|
5389
|
+
* @returns
|
|
5390
|
+
*/
|
|
5391
|
+
getASRContent(roomId: string, taskId: string, startTime: number | undefined, endTime: number | undefined, contentBlock: (data: string) => void, destLang?: string): Promise<{
|
|
5392
|
+
code: RCRTCCode;
|
|
5393
|
+
}>;
|
|
5006
5394
|
}
|
|
5007
5395
|
|
|
5008
5396
|
/**
|
|
@@ -5052,4 +5440,4 @@ declare const helper: {
|
|
|
5052
5440
|
ifSupportScreenShare: typeof ifSupportScreenShare;
|
|
5053
5441
|
};
|
|
5054
5442
|
|
|
5055
|
-
export { BackgroundPictureFillMode, IAudienceRoomEventListener, IAudioLevelChangeHandler, ICameraVideoProfile, ICreateLocalTrackOptions, IJoinRTCRoomOptions, IJoinResCDNInfo, ILiveAudioState, IMCUOutputConfig, IMCUOutputVideoConfig, IMicphoneAudioProfile, IPKEndInfo, IPKInviteAnswerInfo, IPKInviteInfo, IPubSuccessRes, IPublishAttrs, IPublishedResource, IRCCandidatePairStat, IRCEncryptorHooks, IRCRTCInitOptions, IRCRTCReportListener, IRCRTCStateReport, IRCTrackStat, IRTCUserData, IReqResPKOptions, IRoomEventListener, IRoomPKEventListener, IScreenVideoProfile, ISubscribeAttr, IVideoProfile, MixLayoutMode, MixVideoRenderMode, RCAbstractRoom, RCAudienceClient, RCAudienceLivingRoom, RCAudioBitrate, RCCameraVideoTrack, RCEncryptFunction, RCFrameRate, RCInnerCDNPullIsHttps, RCInnerCDNPullKind, RCKickReason, RCLivingRoom, RCLivingType, RCLocalAudioTrack, RCLocalFileAudioTrack, RCLocalFileTrack, RCLocalFileVideoTrack, RCLocalTrack, RCLocalVideoTrack, RCMCUConfigBuilder, RCMediaStreamCapture, RCMediaType, RCMicphoneAudioTrack, RCRTCClient, RCRTCCode, RCRTCLiveRole, RCRTCPingResult, RCRTCRoom, RCRemoteAudioTrack, RCRemoteTrack, RCRemoteVideoTrack, RCResolution, RCScreenAudioTrack, RCScreenVideoTrack, RCTag, RCTrack, RCVideoBitrate, RTCJoinType, RTCMode, device, helper, installer };
|
|
5443
|
+
export { BackgroundPictureFillMode, IAudienceRoomEventListener, IAudioLevelChangeHandler, ICameraVideoProfile, ICreateLocalTrackOptions, IJoinRTCRoomOptions, IJoinResCDNInfo, ILiveAudioState, IMCUOutputConfig, IMCUOutputVideoConfig, IMicphoneAudioProfile, IPKEndInfo, IPKInviteAnswerInfo, IPKInviteInfo, IPubSuccessRes, IPublishAttrs, IPublishedResource, IRCCandidatePairStat, IRCEncryptorHooks, IRCRTCGenerateSummarizationConfig, IRCRTCInitOptions, IRCRTCReportListener, IRCRTCStateReport, IRCTrackStat, IRTCUserData, IReqResPKOptions, IRoomEventListener, IRoomPKEventListener, IScreenVideoProfile, ISubscribeAttr, ISummarizationStatusData, IVideoProfile, MixLayoutMode, MixVideoRenderMode, RCAbstractRoom, RCAudienceClient, RCAudienceLivingRoom, RCAudioBitrate, RCCameraVideoTrack, RCEncryptFunction, RCFrameRate, RCInnerCDNPullIsHttps, RCInnerCDNPullKind, RCKickReason, RCLivingRoom, RCLivingType, RCLocalAudioTrack, RCLocalFileAudioTrack, RCLocalFileTrack, RCLocalFileVideoTrack, RCLocalTrack, RCLocalVideoTrack, RCMCUConfigBuilder, RCMediaStreamCapture, RCMediaType, RCMicphoneAudioTrack, RCRTCASRContent, RCRTCClient, RCRTCCode, RCRTCGenerateSummarizationFormat, RCRTCLiveRole, RCRTCOperateSummarizationType, RCRTCPingResult, RCRTCRealtimeTranslationContent, RCRTCRoom, RCRemoteAudioTrack, RCRemoteTrack, RCRemoteVideoTrack, RCResolution, RCScreenAudioTrack, RCScreenVideoTrack, RCTag, RCTrack, RCVideoBitrate, RTCJoinType, RTCMode, device, helper, installer };
|