webRtcManager.m 43 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231
  1. //
  2. // webRtcManager.m
  3. // 双子星云手机
  4. //
  5. // Created by xd h on 2024/9/5.
  6. //
  7. #import "webRtcManager.h"
  8. #import "webRtcManager+StatisticsReport.h"
  9. #import "RcGameWQKeyChain.h"
  10. #import "errorAlertTool.h"
  11. #import "webRtcManager+downloadNasFile.h"
  12. #import "nasMixUploadManager.h"
  13. #import "nasUploadFileManager.h"
  14. #import "nasDownloadFileManager.h"
  15. @interface webRtcManager ()<MediaStreamClientEventsDelegate>
  16. {
  17. NSMutableArray *commandSendCheckArr;//需要检测任务是否发出的的指令
  18. NSTimer *linkCheckSecondTimer; // 检测链接状态
  19. NSInteger tryRelinkNum;//重连次数
  20. }
  21. //第一次链接设备 要发送指令信息 实现单点登录
  22. @property (nonatomic, assign)BOOL didSendfristMsg;
  23. @end
  24. @implementation webRtcManager
  25. + (instancetype)shareManager {
  26. static webRtcManager *_instance;
  27. static dispatch_once_t onceToken;
  28. dispatch_once(&onceToken, ^{
  29. _instance = [[self alloc] init];
  30. });
  31. return _instance;
  32. }
  33. - (instancetype)init {
  34. if (self = [super init]) {
  35. //[self registeNotification];
  36. tryRelinkNum = 0;
  37. //2.客户端开始写日志
  38. [ksharedAppDelegate.WebRtcLogger start];
  39. HLog(@"webrtc :%@",ksharedAppDelegate.WebRtcLogger)
  40. _webRtcChannelSessionId = [iTools getNowTimeStampString];
  41. _mediaStream = [[RTC_OBJC_TYPE(AMediaStream) alloc] initWithFrame:CGRectZero];
  42. [_mediaStream setEventDelegate:self];
  43. linkCheckSecondTimer = [NSTimer scheduledTimerWithTimeInterval:10.0 target:self selector:@selector(timerChange) userInfo:nil repeats:YES];
  44. [[NSRunLoop currentRunLoop] addTimer:linkCheckSecondTimer forMode:NSRunLoopCommonModes];
  45. }
  46. return self;
  47. }
  48. #pragma mark 十秒一次的timer检测
  49. - (void)timerChange{
  50. [self checkChannelLinkStateFun];
  51. [self checkAllTaskFun];
  52. }
  53. #pragma mark 检测链接是否OK
  54. - (void)checkChannelLinkStateFun
  55. {
  56. if(_channelState != RTCDataChannelStateOpen
  57. ||(_ConnectionState != RTCIceConnectionStateConnected
  58. && _ConnectionState != RTCIceConnectionStateCompleted)
  59. ){
  60. if(!_didReportWebRtcFailType){//还没上报过通道链接情况
  61. tryRelinkNum ++;
  62. if(tryRelinkNum == 2){
  63. _didReportWebRtcFailType = YES;
  64. KWeakSelf
  65. globalBlock(^{
  66. [[addLogObject shareInstance] gotoAddLogFunBySuccess:^(NSString * _Nonnull key) {
  67. [weakSelf reportWebRtcRePoportTypeIsChannel:YES withStats:nil withSessionId:self->_webRtcChannelSessionId withLogKey:key];
  68. }];
  69. });
  70. //检测盒子心跳
  71. [self checkBoxHeartbeatFun];
  72. }
  73. }
  74. [self relinkWebRtcFun];
  75. }
  76. }
  77. #pragma mark 关闭链接
  78. - (void)closeLinkWebRtcFun
  79. {
  80. if((_ConnectionState == RTCIceConnectionStateConnected
  81. && _ConnectionState == RTCIceConnectionStateCompleted)
  82. || _channelState == RTCDataChannelStateOpen)
  83. {
  84. KWeakSelf
  85. mainBlock(^{
  86. [weakSelf.mediaStream disconnect];
  87. });
  88. }
  89. }
  90. #pragma mark 开始链接
  91. - (void)beginToLinkWebRtcFun
  92. {
  93. KWeakSelf
  94. mainBlock(^{
  95. [weakSelf secondBeginToLinkWebRtcFun];
  96. });
  97. }
  98. - (void)secondBeginToLinkWebRtcFun
  99. {
  100. if(ksharedAppDelegate.isWebSockLinkOKAginType
  101. || !ksharedAppDelegate.DeviceWebRtcMsgMod){
  102. return;
  103. }
  104. webRtcMsgModel * _webRtcMsgMod = ksharedAppDelegate.DeviceWebRtcMsgMod;
  105. webrtcServerModel * webrtcServerMod = ksharedAppDelegate.bestWebrtcServerModel;
  106. //链接用
  107. NSString *signallingUrl = [[NSString alloc] initWithFormat:@"%@:%@",webrtcServerMod.signallingIp,webrtcServerMod.signallingPort];
  108. NSURL *url = [NSURL URLWithString:signallingUrl];
  109. //ice用
  110. NSString *iceUrl = [[NSString alloc] initWithFormat:@"%@:%@",webrtcServerMod.turnIp,webrtcServerMod.turnPort];
  111. NSMutableDictionary *ice = [NSMutableDictionary new];
  112. if(iceUrl){
  113. [ice setValue:iceUrl forKey:@"CHINANET"];
  114. [ice setValue:iceUrl forKey:@"CMNET"];
  115. [ice setValue:iceUrl forKey:@"UNICOM"];
  116. }
  117. NSString *roomName = _webRtcMsgMod.data.uniqueIdentifier;
  118. [cachesFileManager writeLogsWithMsg:[[NSString alloc] initWithFormat:@"webrtc channel startUploadChannel--%@",signallingUrl]];
  119. //1.盒子开始写20秒日志
  120. [_mediaStream setCardLogToFile:@"/sdcard/webrtc_box.log" captureTime:@"20"];
  121. //2.客户端开始写日志
  122. [ksharedAppDelegate.WebRtcLogger start];
  123. HLog(@"webrtc :%@ --- channl start:%@",ksharedAppDelegate.WebRtcLogger,url)
  124. //vclusters 信令不鉴权 写不写都OK
  125. NSInteger result = [_mediaStream startUploadChannel:url ice:ice sn:roomName token:@"vclusters"];
  126. HLog(@"webrtc 发起连接 result:%ld",result)
  127. [_mediaStream setShouldGetStats:YES];
  128. }
  129. - (void)relinkWebRtcFun{
  130. ksharedAppDelegate.isWebSockLinkOKAginType = NO;
  131. if(!_isChangeBoxType){
  132. //客户端停止写日志
  133. [ksharedAppDelegate.WebRtcLogger stop];
  134. [cachesFileManager writeLogsWithMsg:@"webrtc channel relinkWebRtcFun"];
  135. [self beginToLinkWebRtcFun];
  136. }
  137. }
  138. #pragma mark webrtc P2P通道发送消息
  139. - (void)send_data:(NSString *)dataStr
  140. {
  141. [_mediaStream sendData:dataStr];
  142. HLog(@"客户端发出命令:%@",dataStr);
  143. }
  144. #pragma mark 盒子链接成功后需要处理的各种各样事情
  145. - (void)handlAllMsgAfterDidLinkFun
  146. {
  147. _isRebootIngType = NO;
  148. _isResetingType = NO;
  149. _isChangeBoxType = NO;
  150. tryRelinkNum = 0;
  151. ksharedAppDelegate.isWebSockLinkOKAginType = YES;
  152. //获取云机尺寸 兼容 720*1080 &1080*1920 不同分辨率的展示和触控
  153. NSString *getPhoneSizeStr = [RCCommandHelp getPhoneSizecommand];
  154. [self send_data:getPhoneSizeStr];
  155. //判断是否为需要改机
  156. BOOL isNeedRandomChangeParams = [HWDataManager getBoolWithKey:Const_need_random_Change_Params];
  157. if(isNeedRandomChangeParams)
  158. {
  159. NSString *commondStr = @"{\"type\":\"randomChangeParams\"}";
  160. [self send_data:commondStr];
  161. [HWDataManager setBoolWithKey:Const_need_random_Change_Params value:NO];
  162. }
  163. [self fristConnectNeedGiveAMsgFun];
  164. [self updateCopydata];
  165. // 报链接失败 后面又连接上了
  166. [[errorAlertTool shareInstance] dismissErrorAlertFun];
  167. //处理相册备份
  168. [[nasBackupsManager shareInstance] AutohandlePhotosBackupsFun];
  169. //获取磁盘外挂
  170. [self getExtraFilesListFun];
  171. [self getBaseInfoFun];
  172. [self getTvStatusFun];
  173. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  174. [self closeBoxHeartbeatReStartViewFun];
  175. });
  176. if(ksharedAppDelegate.needToShowReStratSucType){
  177. ksharedAppDelegate.needToShowReStratSucType = NO;
  178. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  179. [self showReStartSucFun];
  180. });
  181. }
  182. if(self.isReRestartIngBoxType){
  183. self.isReRestartIngBoxType = NO;
  184. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  185. [self showReStartSucFun];
  186. });
  187. }
  188. }
  189. #pragma mark 盒子第一次连接成功 给ws发送信息 单点登录 把其他账号挤下去
  190. - (void)fristConnectNeedGiveAMsgFun{
  191. if(!_didSendfristMsg )
  192. {
  193. [self getSysInfoFun];
  194. // NSString *curOaidStr = [RcGameWQKeyChain getOaidStringFun];
  195. // if(!curOaidStr){
  196. // curOaidStr = @"";
  197. // }
  198. // //未调通挤下线
  199. // NSString *commondStr = [[NSString alloc] initWithFormat:@"{\"type\":\"login\",\"value\":\"%@\"}",curOaidStr];
  200. // [self send_data:commondStr];
  201. // [self addCommandSendTaskFunWithType:@"offline_notification" WithCommandStr:commondStr];
  202. _didSendfristMsg = YES;
  203. [self getPreferredLanguage];
  204. NSString *commondStr2 = @"{\"type\":\"TvStatus\"}";
  205. [self send_data:commondStr2];
  206. }
  207. }
  208. #pragma mark 语言和市区 同步云机
  209. -(void)getPreferredLanguage
  210. {//{"data":{"language":"zh-CN","timeZone":"Etc/GMT+8"},"type":"setLanguages"}
  211. // iOS 获取设备当前语言的代码
  212. NSString *preferredLanguage = [[[NSBundle mainBundle] preferredLocalizations] firstObject];
  213. HLog(@"当前语言:%@", preferredLanguage);
  214. //en-US 英文 ja-JP 日文
  215. NSArray *arLanguages = [[NSUserDefaults standardUserDefaults] objectForKey:@"AppleLanguages"];
  216. NSLog(@"arLanguages:%@",arLanguages);
  217. ///获取设备当前地区的代码和APP语言环境
  218. NSString *languageCode = [NSLocale preferredLanguages][0];
  219. //目前支持 中文(简体 繁体) 英文 日语
  220. if([languageCode rangeOfString:@"zh-Hans"].location != NSNotFound)
  221. {
  222. preferredLanguage = @"zh-CN";
  223. }
  224. else if([languageCode rangeOfString:@"zh-Hant"].location != NSNotFound)
  225. {
  226. preferredLanguage = @"zh-HK";
  227. }
  228. else if([languageCode rangeOfString:@"ja-"].location != NSNotFound)
  229. {
  230. preferredLanguage = @"ja-JP";
  231. }
  232. else{
  233. preferredLanguage = @"en-US";
  234. }
  235. // if([languageCode rangeOfString:preferredLanguage].location != NSNotFound){
  236. // preferredLanguage = languageCode;
  237. // }
  238. // else{
  239. // preferredLanguage = @"en-US";
  240. // }
  241. NSString*gmtStr = [self UTCOffset];
  242. HLog(@"%@",gmtStr);
  243. // //获取名字,如“GMT+08:00
  244. NSString *commondStr = [NSString stringWithFormat:@"{\"type\":\"setLanguages\",\"data\":{\"language\":\"%@\",\"timeZone\":\"%@\"}}",preferredLanguage,gmtStr];
  245. [self send_data:commondStr];
  246. }
  247. #pragma mark 获取云机系统镜像等信息
  248. - (void)getSysInfoFun
  249. {
  250. NSString *commondStr = @"{\"type\":\"getSysInfo\"}";
  251. [self send_data:commondStr];
  252. }
  253. -(NSString *)UTCOffset {
  254. NSTimeZone *localTZ = [NSTimeZone localTimeZone];
  255. float offset = localTZ.secondsFromGMT/3600.0;
  256. if(offset > 0){
  257. return [NSString stringWithFormat:@"Etc/GMT+%g",offset];
  258. }
  259. return [NSString stringWithFormat:@"Etc/GMT%g",offset];
  260. }
  261. #pragma mark 收到系统信息消息回调处理
  262. - (void)getCouldPhoneSysInfoResponseFun:(NSDictionary *)dataDict{
  263. couldphoneSysInfoModel *model = [[couldphoneSysInfoModel alloc] initWithDictionary:dataDict error:nil];
  264. //[[NSNotificationCenter defaultCenter] postNotificationName:getCouldPhoneSysInfoNotification object:model];
  265. // NSString *hostImgVer = model.data.data.hostImgVer;
  266. // NSString *MyNewVersion = model.data.data.MyNewVersion;
  267. NSString *hostImgVer = model.data.hostImgVer;
  268. NSString *MyNewVersion = model.data.MyNewVersion;
  269. //test code
  270. // hostImgVer = @"1.2.3";
  271. // MyNewVersion = @"1.2.0";
  272. //判断当前版本号 待更新版本
  273. if (!hostImgVer || hostImgVer.length < 3
  274. ||!MyNewVersion || MyNewVersion.length < 3) {
  275. return;
  276. }
  277. NSArray *versionArr = [hostImgVer componentsSeparatedByString:@"."];
  278. NSArray *MyNewVersionArr = [MyNewVersion componentsSeparatedByString:@"."];
  279. NSInteger versionArrCount = versionArr.count;
  280. NSInteger MyNewVersionArrCount = MyNewVersionArr.count;
  281. NSInteger maxCount = versionArrCount < MyNewVersionArrCount ? versionArrCount:MyNewVersionArrCount;
  282. BOOL isNeedShowType = NO;
  283. //判断是否要更新镜像框
  284. if(maxCount > 0){
  285. for (int i=0; i<maxCount; i++) {
  286. NSString * numberStr1 = versionArr[i];
  287. NSString * numberStr2 = MyNewVersionArr[i];
  288. if(numberStr2.intValue > numberStr1.intValue){
  289. isNeedShowType =YES;
  290. break;
  291. }
  292. }
  293. }
  294. if(isNeedShowType){
  295. ksharedAppDelegate.isNeedShowImageNewType = YES;
  296. }
  297. //是否禁用文件传输 (1.3以及以上的镜像可以使用文件传输)
  298. if(versionArr.count >= 3)
  299. {
  300. NSString * oneStr = versionArr[0];
  301. NSString * twoStr = versionArr[1];
  302. NSString * threeStr = versionArr[2];
  303. if(oneStr.integerValue <=1 && twoStr.integerValue <=3 && threeStr.integerValue <=0){//禁用
  304. ksharedAppDelegate.DisabledFileTransferType = YES;
  305. if(MyNewVersionArr.count >= 3)
  306. {
  307. NSString * newOneStr = MyNewVersionArr[0];
  308. NSString * newTwoStr = MyNewVersionArr[1];
  309. NSString * newThreeStr = MyNewVersionArr[2];
  310. if(newOneStr.integerValue >=1 && newTwoStr.integerValue >=3 && newThreeStr.integerValue >= 1){
  311. ksharedAppDelegate.isImageNewFor130 = YES;
  312. }
  313. else{
  314. ksharedAppDelegate.isImageNewFor130 = NO;
  315. }
  316. }
  317. }
  318. else{
  319. ksharedAppDelegate.DisabledFileTransferType = NO;
  320. }
  321. //判断镜像是否为1.4.4以后
  322. if(oneStr.integerValue >=2){
  323. ksharedAppDelegate.isImageFor144Orlater = YES;
  324. [HWDataManager setBoolWithKey:stringKeyAddSn(Const_image_version_for_new_token) value:YES];
  325. }
  326. else if(twoStr.integerValue > 4){
  327. ksharedAppDelegate.isImageFor144Orlater = YES;
  328. [HWDataManager setBoolWithKey:stringKeyAddSn(Const_image_version_for_new_token) value:YES];
  329. }
  330. else if(threeStr.integerValue >= 4){
  331. ksharedAppDelegate.isImageFor144Orlater = YES;
  332. [HWDataManager setBoolWithKey:stringKeyAddSn(Const_image_version_for_new_token) value:YES];
  333. }
  334. else{
  335. ksharedAppDelegate.isImageFor144Orlater = NO;
  336. }
  337. }
  338. [[NSNotificationCenter defaultCenter] postNotificationName:getCouldPhoneSysInfoNotification object:model];
  339. }
  340. #pragma mark 添加消息重复机制
  341. -(void)addCommandSendTaskFunWithType:(NSString*)type WithCommandStr:(NSString*)commandStr
  342. {
  343. if(!commandSendCheckArr){
  344. commandSendCheckArr = [NSMutableArray new];
  345. }
  346. BOOL didAddType = NO;
  347. for (commandSendCheckModel *model in commandSendCheckArr) {
  348. if([model.type isEqualToString:type]){
  349. didAddType = YES;
  350. model.reSendNum = 0;
  351. model.sendTimerStamp = [iTools getNowTimeStamp];
  352. break;
  353. }
  354. }
  355. if(!didAddType){
  356. commandSendCheckModel *model = [commandSendCheckModel new];
  357. model.commandStr = commandStr;
  358. model.type = type;
  359. model.reSendNum = 0;
  360. model.sendTimerStamp = [iTools getNowTimeStamp];
  361. [commandSendCheckArr addObject:model];
  362. }
  363. }
  364. #pragma mark 删除代理确认收到的消息
  365. -(void)deleteCommandSendTaskFunWith:(NSString*)type
  366. {
  367. if(commandSendCheckArr && commandSendCheckArr.count >0){
  368. NSArray *taskArr = [NSArray arrayWithArray:commandSendCheckArr];
  369. for (commandSendCheckModel *model in taskArr) {
  370. if([type isEqualToString:model.type]){
  371. [commandSendCheckArr removeObject:model];
  372. }
  373. }
  374. }
  375. }
  376. #pragma mark 复制手机消息到云机
  377. - (void)updateCopydata{
  378. UIPasteboard* pasteboard = [UIPasteboard generalPasteboard];
  379. NSString *str = [pasteboard string];
  380. HLog(@"__________%s______%@____",__func__,str);
  381. if ([str rangeOfString:@"CVLUSTERS_NOUSE_"].location != NSNotFound)
  382. {
  383. str = nil;
  384. }
  385. if (str && str.length >0)
  386. {
  387. //HLog(@"hxd111 cutting %@",str);
  388. /*发送数据*/
  389. NSString *dataStr = [RCCommandHelp commandCuttingWithContent:str];
  390. [self send_data:dataStr];
  391. //pasteboard.string = @"";
  392. }
  393. }
  394. #pragma mark 获取云机以及外挂磁盘
  395. - (void)getExtraFilesListFun
  396. {
  397. // NSString *ExtraCommondStr = [RCCommandHelp getExtraFilesList];
  398. // [self send_data:ExtraCommondStr];
  399. //改走http方案
  400. [[NSNotificationCenter defaultCenter] postNotificationName:getExtraFilesDoneNotification object:nil];/*发送通知*/
  401. }
  402. #pragma mark 获取到云机以及外挂磁盘信息
  403. - (void)getExtraFilesResponseFun:(NSDictionary *)dataDict
  404. {
  405. cloudPhoneExtraFileListModel *model = [[cloudPhoneExtraFileListModel alloc] initWithDictionary:dataDict error:nil];
  406. ksharedAppDelegate.cloudPhoneExtraFileListMod = model;
  407. [[NSNotificationCenter defaultCenter] postNotificationName:getExtraFilesDoneNotification object:dataDict];/*发送通知*/
  408. }
  409. #pragma mark 获取云机基本信息
  410. - (void)getBaseInfoFun
  411. {
  412. NSString *commondStr = @"{\"type\":\"getBaseInfo\"}";
  413. [self send_data:commondStr];
  414. }
  415. #pragma mark 获取到云机基本信息
  416. - (void)getCouldPhoneBaseInfoResponseFun:(NSDictionary *)dataDict
  417. {
  418. couldPhoneBaseInfoModel *model = [[couldPhoneBaseInfoModel alloc] initWithDictionary:dataDict error:nil];
  419. [[NSNotificationCenter defaultCenter] postNotificationName:getCouldPhoneBaseInfoNotification object:model];
  420. }
  421. #pragma mark 获取到TV投屏状态
  422. - (void)getCouldPhoneTvStatusResponseFun:(NSDictionary *)dataDict
  423. {
  424. TvStatusModel *model = [[TvStatusModel alloc] initWithDictionary:dataDict error:nil];
  425. ksharedAppDelegate.TvStatusMod = model;
  426. [[NSNotificationCenter defaultCenter] postNotificationName:getCouldPhoneTvStatusNotification object:model];
  427. // if(![model.msg containsString:@"PushStreamBActivity"])
  428. // {
  429. // return;
  430. // }
  431. //
  432. // UIViewController*topVc = self.navigationController.viewControllers.lastObject;
  433. // if([topVc isKindOfClass:[PlayerViewController class]]){
  434. // [[iToast makeText:NSLocalizedString(@"tv_p2p_ing",nil)] show];
  435. // }
  436. }
  437. #pragma mark 重启云机
  438. - (void)needToRebootFun
  439. {
  440. NSString *commondStr = @"{\"type\":\"reboot\"}";
  441. [self send_data:commondStr];
  442. //添加到任务监听
  443. [self addCommandSendTaskFunWithType:@"reboot" WithCommandStr:commondStr];
  444. //数据埋点
  445. [[netWorkManager shareInstance] DataEmbeddingPointBy:3 withEventValue:@"Cloud_restart"];
  446. _isRebootIngType = YES;
  447. //1、重启、恢复出厂设备、首次设置密码 3个情况下8分钟之内不弹
  448. long seconds = [iTools getNowTimeStamp];
  449. NSNumber *secondsNum = [NSNumber numberWithLong:seconds];
  450. if(secondsNum){
  451. [HWDataManager setNumberWithKey:stringKeyAddSn(@"disenable_type2_BoxHeartbeat") value:secondsNum];
  452. }
  453. }
  454. #pragma mark 恢复出厂设置
  455. - (void)needToResetFun
  456. {
  457. NSString *commondStr = @"{\"type\":\"reset\"}";
  458. [self send_data:commondStr];
  459. //添加到任务监听
  460. [self addCommandSendTaskFunWithType:@"reset" WithCommandStr:commondStr];
  461. //数据埋点
  462. [[netWorkManager shareInstance] DataEmbeddingPointBy:3 withEventValue:@"Cloud_restore_factory"];
  463. _isResetingType = YES;
  464. //1、重启、恢复出厂设备、首次设置密码 3个情况下8分钟之内不弹
  465. long seconds = [iTools getNowTimeStamp];
  466. NSNumber *secondsNum = [NSNumber numberWithLong:seconds];
  467. if(secondsNum){
  468. [HWDataManager setNumberWithKey:stringKeyAddSn(@"disenable_type2_BoxHeartbeat") value:secondsNum];
  469. }
  470. }
  471. #pragma mark 云机截图保存到云机图库
  472. - (void)screenshotInCloudPhoneFun{
  473. NSString*taskUid = [iTools getTaskUidStr];
  474. NSString *commondStr = [RCCommandHelp commandCloudPhoneScreenshotWithTaskUid:taskUid];
  475. [self send_data:commondStr];
  476. }
  477. #pragma mark 获取TV投屏状态
  478. - (void)getTvStatusFun
  479. {
  480. NSString *commondStr = @"{\"type\":\"TvStatus\"}";
  481. [self send_data:commondStr];
  482. }
  483. #pragma mark 关闭TV投屏状态
  484. - (void)offTvFun
  485. {
  486. NSString *commondStr = @"{\"type\":\"TvOff\"}";
  487. [self send_data:commondStr];
  488. }
  489. #pragma mark 开启TV投屏状态
  490. - (void)onTvFun
  491. {
  492. NSString *commondStr = @"{\"type\":\"wakeupTV\"}";
  493. [self send_data:commondStr];
  494. }
  495. #pragma mark 创建备份文件夹
  496. - (void)createBackupsFolderBy:(NSString*)backupsDefaultPath
  497. {
  498. NSString *folderName = backupsDefaultPath;
  499. if(folderName && folderName.length >0){
  500. NSString * commandStr = [RCCommandHelp applyForCreateFolderwithFolderName:folderName];
  501. [self send_data:commandStr];
  502. }
  503. }
  504. #pragma mark 获取备份文件夹列表
  505. - (void)getBackupFolderListFun
  506. {
  507. NSString * commandStr = [RCCommandHelp getCreateFolderList];
  508. [self send_data:commandStr];
  509. }
  510. #pragma mark 创建文件夹回调
  511. - (void)createFolderResponseFun:(NSDictionary *)dataDict
  512. {
  513. couldPhoneCommonModel *model = [[couldPhoneCommonModel alloc] initWithDictionary:dataDict error:nil];
  514. if(model){
  515. NSNumber *curNum = [NSNumber numberWithInteger:model.status];
  516. [[NSNotificationCenter defaultCenter] postNotificationName:createFolderDoneNotification object:curNum];/*发送通知*/
  517. }
  518. }
  519. - (void)getFolderListResponseFun:(NSDictionary *)dataDict
  520. {
  521. [[NSNotificationCenter defaultCenter] postNotificationName:getFolderListDoneNotification object:dataDict];/*发送通知*/
  522. }
  523. - (void)searchFileListResponseFun:(NSDictionary *)dataDict
  524. {
  525. [[NSNotificationCenter defaultCenter] postNotificationName:searchFileListDoneNotification object:dataDict];/*发送通知*/
  526. }
  527. #pragma mark U盘插入相关
  528. - (void)getExtraMediaEventResponseFun:(NSDictionary *)dataDict
  529. {
  530. mainBlock((^{
  531. extraMediaEventModel *model = [[extraMediaEventModel alloc] initWithDictionary:dataDict error:nil];
  532. NSString *tip = nil;
  533. if(model.data.event == 0){
  534. tip = NSLocalizedString(@"disk_insertion_tip",nil);
  535. [self showInsertPopViewFun:model.data.name];
  536. }
  537. else if(model.data.event == 1){
  538. tip = NSLocalizedString(@"disk_extract_tip",nil);
  539. }
  540. else if(model.data.event == 2){
  541. tip = NSLocalizedString(@"disk_save_extract_tip",nil);
  542. }
  543. NSString *totalTips = [[NSString alloc] initWithFormat:@"%@%@",model.data.name,tip];
  544. [[iToast makeText:totalTips] show];
  545. }));
  546. }
  547. #pragma mark 显示插入UI弹框
  548. - (void)showInsertPopViewFun:(NSString*)name
  549. {
  550. if(self->curUSBInsertPopV){
  551. [self->curUSBInsertPopV removeFromSuperview];
  552. self->curUSBInsertPopV = nil;
  553. }
  554. self->curUSBInsertPopV = [[USBInsertPopView alloc] initWithFrame:CGRectMake(0, 0, SCREEN_W, SCREEN_H) withName:name];
  555. [[iTools getKeyWindow] addSubview:self->curUSBInsertPopV];
  556. }
  557. #pragma mark 检测nas任务情况
  558. - (void)checkAllTaskFun
  559. {
  560. HLog(@"checkAllTaskFun");
  561. //处理相册备份
  562. [[nasBackupsManager shareInstance] checkReBackupsFileFun];
  563. //处理上传失败的重新上传
  564. //[[nasUploadFileManager shareInstance] reUploadFileFunByNetWork];
  565. //[[nasDownloadFileManager shareInstance] reDownloadloadFileFunByNetWork];
  566. //if([AudioSessionObject shareManager].isBackgroundType)
  567. {
  568. [self checkFileTransfeTaskFun];
  569. }
  570. if([AFNetworkReachabilityManager sharedManager].networkReachabilityStatus == AFNetworkReachabilityStatusUnknown){
  571. [ksharedAppDelegate MonitorNetworkChangesFun];
  572. }
  573. }
  574. #pragma mark 检测是否正在进行的文件传输任务 设置后台状态
  575. - (void)checkFileTransfeTaskFun
  576. {
  577. BOOL isBackupsingType = [[nasBackupsManager shareInstance] checkBackupsingFun];
  578. BOOL isUploadingType = [[nasMixUploadManager shareManager] checkUploadTaskDoingFun];
  579. BOOL isDownloadingType = [[nasDownloadManager shareManager] isDownLoadIngType];
  580. BOOL isNasDownloadingType = [customDownloadManager shareManager].isDownLoadIngType;
  581. BOOL isBackground = [HWDataManager getBoolWithKey:stringKeyAddSn(Const_file_Transfe_working_background)];
  582. if ((isBackupsingType || isUploadingType || isDownloadingType ||isNasDownloadingType) && isBackground) {
  583. HLog(@"后台保活中");
  584. //[cachesFileManager writeLogsWithMsg:@"Background working"];
  585. }
  586. else{
  587. HLog(@"停止后台保活");
  588. //[cachesFileManager writeLogsWithMsg:@"stop Background working"];
  589. //[[AudioSessionObject shareManager] stopBackgroundActiveFun];
  590. }
  591. }
  592. #pragma mark 收到的webrtc消息处理
  593. - (void)handleWebRtcMsgResponseBy:(NSData*)message
  594. {
  595. if([message isKindOfClass:[NSMutableString class]] || [message isKindOfClass:[NSString class]])
  596. {
  597. message = [(NSString *)message dataUsingEncoding:(NSUTF8StringEncoding)];
  598. }
  599. NSError *error = nil;
  600. NSDictionary *dataDict = [NSJSONSerialization JSONObjectWithData:message options:NSJSONReadingMutableContainers error:&error];
  601. HLog(@"webRtc P2P 通道接收消息:------------------%@",dataDict);
  602. // if([message isKindOfClass:[NSData class]] && [message length] == 0){
  603. // if(type == RCSocketCloudPhoneReceiveTypeForPong)
  604. // {
  605. // [weakSelf keepWebSocketOKFun];
  606. // }
  607. // return;
  608. // }
  609. //
  610. // HLog(@"webSocket指令通道接收消息:------------------\n%@",message);
  611. //
  612. // if([message isKindOfClass:[NSMutableString class]] || [message isKindOfClass:[NSString class]])
  613. // {
  614. // message = [(NSString *)message dataUsingEncoding:(NSUTF8StringEncoding)];
  615. // }
  616. //
  617. // NSError *error = nil;
  618. // NSDictionary *dataDict = [NSJSONSerialization JSONObjectWithData:message options:NSJSONReadingMutableContainers error:&error];
  619. if(!dataDict){
  620. //[weakSelf handleDownloadResponseFunBy:message];
  621. return;
  622. }
  623. if(![dataDict isKindOfClass:[NSDictionary class]]){
  624. //[__NSCFString allKeys] unrecognized selector sent to ins
  625. return;
  626. }
  627. if(![[dataDict allKeys] containsObject:@"type"]){
  628. return;
  629. }
  630. NSString *messageType = dataDict[@"type"];
  631. if ([messageType isEqualToString:@"cutting"]) {
  632. //[[iToast makeText:@"复制成功"] show];
  633. }
  634. // else if ([messageType isEqualToString:@"forwardMsgRep"]){/*转发的回复*/
  635. //
  636. // cloudPhoneCommonModel *model = [[cloudPhoneCommonModel alloc] initWithDictionary:dataDict error:nil];
  637. // if(!model){
  638. // return;
  639. // }
  640. //
  641. // if([model.data.msg isEqualToString:@"only one socket"]||
  642. // [model.data.msg isEqualToString:@"only one socket2"]){
  643. // [weakSelf deleteCommandSendTaskFunWith:@"offline_notification"];
  644. // }
  645. // }
  646. // else if ([messageType isEqualToString:@"forwardMsg"]){/*转发*/
  647. // /*获取指令类型*/
  648. // NSString *code = nil;
  649. // if ([[dataDict allKeys] containsObject:@"data"]) {
  650. // NSDictionary *data = dataDict[@"data"];
  651. //
  652. // if([data isKindOfClass:[NSString class]]){
  653. // NSString * dataStr = (NSString*)data;
  654. // if([dataStr isEqualToString:@"offline_notification"]){
  655. // HLog(@"被别人挤下线了");
  656. // [weakSelf LogoutByOtherFun];
  657. // }
  658. //
  659. // return;
  660. // }
  661. // else if ([data isKindOfClass:[NSDictionary class]] && [[data allKeys] containsObject:@"code"]) {
  662. // code = [data objectForKey:@"code"];
  663. //
  664. // if (![code isKindOfClass:[NSString class]]) {
  665. // code = [NSString stringWithFormat:@"%ld",[code integerValue]];
  666. // }
  667. // }
  668. // }
  669. //
  670. // /*获取用户名*/
  671. // NSString *useName = nil;
  672. // if ([[dataDict allKeys] containsObject:@"data"]) {
  673. // NSDictionary *data = dataDict[@"data"];
  674. // if ([[data allKeys] containsObject:@"userName"]) {
  675. // //useName = [data objectForKey:@"userName"];
  676. // }
  677. // }
  678. //
  679. //
  680. // if ([code isEqualToString:@"phoneSizeChange"]){/*分辨率改变*/
  681. // if ([[dataDict allKeys] containsObject:@"data"]) {
  682. // NSDictionary *data = dataDict[@"data"];
  683. // if ([[data allKeys] containsObject:@"width"]) {
  684. // ksharedAppDelegate.couldPhone_W_PHONE = [[data objectForKey:@"width"] integerValue];
  685. // }
  686. // if ([[data allKeys] containsObject:@"height"]) {
  687. // ksharedAppDelegate.couldPhone_H_PHONE = [[data objectForKey:@"height"] integerValue];
  688. // }
  689. //
  690. // if (ksharedAppDelegate.couldPhone_W_PHONE > ksharedAppDelegate.couldPhone_H_PHONE) {
  691. // CGFloat temp = ksharedAppDelegate.couldPhone_W_PHONE;
  692. // ksharedAppDelegate.couldPhone_W_PHONE = ksharedAppDelegate.couldPhone_H_PHONE;
  693. // ksharedAppDelegate.couldPhone_H_PHONE = temp;
  694. // }
  695. // }
  696. // }
  697. // }
  698. else if ([messageType isEqualToString:@"getPhoneSize"] || [messageType isEqualToString:@"setPhoneSize"]){
  699. //NSString *sn = nil;
  700. if([messageType isEqualToString:@"setPhoneSize"]){
  701. self.isDiDChangePhoneSizeType = YES;
  702. }
  703. if ([[dataDict allKeys] containsObject:@"data"]) {
  704. NSDictionary *data = dataDict[@"data"];
  705. if ([[data allKeys] containsObject:@"status"]) {
  706. NSInteger status = [[data objectForKey:@"status"] integerValue];
  707. if (status == 0) {/*不是当前设备直接返回*/
  708. if ([[data allKeys] containsObject:@"width"]) {
  709. ksharedAppDelegate.couldPhone_W_PHONE = [[data objectForKey:@"width"] integerValue];
  710. }
  711. if ([[data allKeys] containsObject:@"height"]) {
  712. ksharedAppDelegate.couldPhone_H_PHONE = [[data objectForKey:@"height"] integerValue];
  713. }
  714. if (ksharedAppDelegate.couldPhone_W_PHONE > ksharedAppDelegate.couldPhone_H_PHONE) {
  715. CGFloat temp = ksharedAppDelegate.couldPhone_W_PHONE;
  716. ksharedAppDelegate.couldPhone_W_PHONE = ksharedAppDelegate.couldPhone_H_PHONE;
  717. ksharedAppDelegate.couldPhone_H_PHONE = temp;
  718. }
  719. }
  720. }
  721. }
  722. }
  723. // else if ([messageType isEqualToString:@"sync_wifi"]){
  724. // [weakSelf sync_wifiBackHandleFun];
  725. // }
  726. // else if ([messageType isEqualToString:@"reProduceText"]){
  727. // if ([[dataDict allKeys] containsObject:@"data"]) {
  728. // NSDictionary *data = dataDict[@"data"];
  729. //
  730. // if ([[data allKeys] containsObject:@"text"]) {
  731. // NSString *pasteboardStr = [data objectForKey:@"text"];
  732. // UIPasteboard* pasteboard = [UIPasteboard generalPasteboard];
  733. // pasteboard.string = pasteboardStr;
  734. // }
  735. // }
  736. // }
  737. // else if ([messageType isEqualToString:@"downAdnInstallRep"]){
  738. // if ([[dataDict allKeys] containsObject:@"data"]) {
  739. // NSDictionary *data = dataDict[@"data"];
  740. //
  741. // if ([[data allKeys] containsObject:@"status"]) {
  742. // NSString *status = [data objectForKey:@"status"];
  743. // if ([status isEqualToString:@"1"]) {
  744. // mainBlock(^{
  745. // // [[iToast makeText:@"App下载完成"] show];
  746. // });
  747. // }else if ([status isEqualToString:@"0"]){
  748. // mainBlock(^{
  749. // //[[iToast makeText:@"App下载中"] show];
  750. // });
  751. // }
  752. // }
  753. // }
  754. // }
  755. // else if ([messageType isEqualToString:@"shakeit"]){
  756. // HLog(@"\n-----摇一摇成功------");
  757. // }else if ([messageType isEqualToString:@"keyboardFeedbackBean"]){/*调起键盘*/
  758. // HLog(@"\n-----待处理 调起键盘------");
  759. // // [weakSelf keyboardFeedbackBeanFun];
  760. // }else if ([messageType isEqualToString:@"FileRandomReady"]
  761. // ||[messageType isEqualToString:@"FilePartReady"]
  762. // ){/*申请文件上传得到答复*/
  763. // [weakSelf applyUploadFileServiceResponseFun:dataDict];
  764. // }
  765. // else if ([messageType isEqualToString:@"uploadFileRandomRet"]
  766. // ||[messageType isEqualToString:@"uploadFilePartRet"]
  767. // ){/*文件上传得到答复*/
  768. // [weakSelf upLoadFileFunServiceResponseFun:dataDict];
  769. // }
  770. // else if ([messageType isEqualToString:@"backUpFileRandomReady"]
  771. // ||[messageType isEqualToString:@"backUpPartReady"]
  772. // ){/*文件备份得到答复*/
  773. // [weakSelf applyBackupsFileServiceResponseFun:dataDict];
  774. // }
  775. // else if ([messageType isEqualToString:@"backUpFileRandomRet"]
  776. // ||[messageType isEqualToString:@"backUpFilePartRet"]){/*文件备份得到答复*/
  777. // [weakSelf backupsFileFunServiceResponseFun:dataDict];
  778. // }
  779. else if ([messageType isEqualToString:@"getBaseInfo"]){/*获取云机的基本信息*/
  780. [self getCouldPhoneBaseInfoResponseFun:dataDict];
  781. }
  782. else if ([messageType isEqualToString:@"getSysInfo"]){/*获取云机的系统信息*/
  783. [self getCouldPhoneSysInfoResponseFun:dataDict];
  784. }
  785. else if ([messageType isEqualToString:@"TvStatus"]){/*获取TV投屏信息*/
  786. [self getCouldPhoneTvStatusResponseFun:dataDict];
  787. }
  788. else if ([messageType isEqualToString:@"TvOff"]){/*关闭TV投屏*/
  789. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  790. [self getTvStatusFun];
  791. });
  792. }
  793. else if ([messageType isEqualToString:@"wakeupTV"]){/*开启TV投屏*/
  794. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  795. [self getTvStatusFun];
  796. });
  797. }
  798. else if ([messageType isEqualToString:@"reboot"]){/*重启*/
  799. //[weakSelf stopForceStartTimerFun];
  800. }
  801. else if ([messageType isEqualToString:@"mkdir"]){/*创建文件夹*/
  802. [self createFolderResponseFun:dataDict];
  803. }
  804. else if ([messageType isEqualToString:@"getBackupPath"]){/*创建文件夹*/
  805. [self getFolderListResponseFun:dataDict];
  806. }
  807. else if ([messageType isEqualToString:@"search"]){/*创建文件夹*/
  808. [self searchFileListResponseFun:dataDict];
  809. }
  810. else if ([messageType isEqualToString:@"getExtraFiles"]){/*获取云机产品信息*/
  811. [self getExtraFilesResponseFun:dataDict];
  812. }
  813. else if ([messageType isEqualToString:@"extraMediaEvent"]){/*磁盘插拔*/
  814. [self getExtraMediaEventResponseFun:dataDict];
  815. [self getExtraFilesListFun];
  816. }
  817. else if ([messageType isEqualToString:@"reset"]){/**/
  818. [self deleteCommandSendTaskFunWith:@"reset"];
  819. }
  820. else if ([messageType isEqualToString:@"shortcatRep"]){/*截图*/
  821. [[iToast makeText:NSLocalizedString(@"shortcatRep_tip",nil)] show];
  822. }
  823. }
  824. #pragma mark WebRTC 回调 MediaStreamClientEventsDelegate
  825. #pragma mark 不能再这里函数判断 这个是推拉流的
  826. -(void)onChangeConnectionStateFromPeerName:(NSString*)peerName didChangeIceConnectionState:(RTCIceConnectionState)state
  827. {
  828. HLog(@"channel P2P onChangeConnectionStateFromPeerName: state:%ld",state)
  829. self.ConnectionState = state;
  830. [cachesFileManager writeLogsWithMsg:[[NSString alloc] initWithFormat:@"webrtc channel onChangeConnectionStateFromPeerName:%ld",state]];
  831. switch (state) {
  832. case RTCIceConnectionStateConnected:{
  833. //链接成功
  834. }
  835. break;
  836. case RTCIceConnectionStateCompleted:
  837. //链接完成
  838. break;
  839. case RTCIceConnectionStateFailed:
  840. case RTCIceConnectionStateDisconnected:
  841. case RTCIceConnectionStateClosed:{
  842. if(!_didReportWebRtcFailType && state == RTCIceConnectionStateFailed){//还没上报过通道链接情况
  843. _didReportWebRtcFailType = YES;
  844. KWeakSelf
  845. globalBlock(^{
  846. [[addLogObject shareInstance] gotoAddLogFunBySuccess:^(NSString * _Nonnull key) {
  847. [weakSelf reportWebRtcRePoportTypeIsChannel:YES withStats:nil withSessionId:self->_webRtcChannelSessionId withLogKey:key];
  848. }];
  849. });
  850. }
  851. //链接关闭
  852. [self relinkWebRtcFun];
  853. }
  854. break;
  855. default:
  856. break;
  857. }
  858. }
  859. #pragma mark 通道连接状态变化监听
  860. - (void)dataChannelDidChangeFromPeerName:(NSString*)peerName State:(RTCDataChannelState)state
  861. {
  862. HLog(@"webRtc P2P dataChannelDidChangeFromPeerName: state:%ld",state)
  863. [cachesFileManager writeLogsWithMsg:[[NSString alloc] initWithFormat:@"webrtc channel dataChannelDidChangeFromPeerName:%ld",state]];
  864. self.channelState = state;
  865. switch (state) {
  866. case RTCDataChannelStateConnecting:
  867. {
  868. }
  869. break;
  870. case RTCDataChannelStateOpen:
  871. {
  872. //链接成功
  873. [self handlAllMsgAfterDidLinkFun];
  874. //客户端停止写日志
  875. [ksharedAppDelegate.WebRtcLogger stop];
  876. }
  877. break;
  878. case RTCDataChannelStateClosing:
  879. {
  880. }
  881. break;
  882. case RTCDataChannelStateClosed:
  883. {
  884. //链接断开
  885. [self relinkWebRtcFun];
  886. }
  887. break;
  888. default:
  889. break;
  890. }
  891. }
  892. -(void)onChannelDataFromPeerName:(NSString*)peerName buffer:(RTC_OBJC_TYPE(RTCDataBuffer) *)buffer
  893. {
  894. //HLog(@"onIceConnectedFromPeerName:%@",buffer.data);
  895. if(buffer && buffer.data){
  896. KWeakSelf
  897. mainBlock(^{
  898. [weakSelf handleWebRtcMsgResponseBy:buffer.data];
  899. });
  900. }
  901. }
  902. -(void)didGetStats:(NSString*)peerName stats:(RTC_OBJC_TYPE(RTCStatisticsReport) *)stats
  903. {
  904. //HLog(@"didGetStats:%@",stats)
  905. if(!_didReportWebRtcOKType
  906. && (self.ConnectionState == RTCIceConnectionStateConnected ||self.ConnectionState == RTCIceConnectionStateCompleted)){
  907. [self reportWebRtcRePoportTypeIsChannel:YES withStats:stats withSessionId:_webRtcChannelSessionId withLogKey:@""];
  908. _didReportWebRtcOKType = YES;
  909. _didReportWebRtcFailType = NO;//链接成功后 失败要重新上报
  910. [_mediaStream setShouldGetStats:NO];
  911. }
  912. }
  913. -(void)onAuthResultFromPeerName:(NSString*)peerName code:(int)code descriptions:(NSString*)descriptions
  914. {
  915. //HLog(@"webRtc P2P onAuthResultFromPeerName")
  916. }
  917. - (void)connectionChange:(NSString*)peerName
  918. didChangeLocalCandidate:(RTC_OBJC_TYPE(RTCIceCandidate) *)local
  919. remoteCandidate:(RTC_OBJC_TYPE(RTCIceCandidate) *)remote
  920. lastReceivedMs:(int)lastDataReceivedMs
  921. changeReason:(NSString *)reason
  922. {
  923. //HLog(@"webRtc P2P didChangeLocalCandidate")
  924. [self reportWebRtcRePoportTypeIsChannel:YES withLocal:local remoteCandidate:remote withSessionId:self.webRtcChannelSessionId withLogKey:@""];
  925. }
  926. #pragma mark 检测盒子的心跳情况
  927. - (void)checkBoxHeartbeatFun
  928. {
  929. //2、点击系统升级弹框确定按钮后30分钟内不弹;
  930. NSNumber *preSecondNum = [HWDataManager getNumberWithKey:stringKeyAddSn(@"disenable_type1_BoxHeartbeat")];
  931. if(preSecondNum){
  932. long seconds = [iTools getNowTimeStamp];
  933. if(seconds - preSecondNum.longValue <= 60*30){
  934. return;
  935. }
  936. }
  937. //3、重启、恢复出厂设备、首次设置密码 3个情况下8分钟之内不弹
  938. NSNumber *preSecondNum2 = [HWDataManager getNumberWithKey:stringKeyAddSn(@"disenable_type2_BoxHeartbeat")];
  939. if(preSecondNum2){
  940. long seconds = [iTools getNowTimeStamp];
  941. if(seconds - preSecondNum2.longValue <= 60*8){
  942. return;
  943. }
  944. }
  945. if(ksharedAppDelegate.didShowBoxHeartbeatAlertType
  946. ||[webRtcManager shareManager].isResetingType
  947. ||[webRtcManager shareManager].isRebootIngType
  948. || [ksharedAppDelegate didShowImageRenewViewFun]){
  949. return;
  950. }
  951. //1.隐私模式密码界面 3秒检测一次是否输入完成密码了
  952. if(ksharedAppDelegate.isDidShowPwdType){
  953. KWeakSelf
  954. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  955. [weakSelf checkBoxHeartbeatFun];
  956. });
  957. return;
  958. }
  959. // [[BoxHeartbeatAlertTool shareInstance] showBoxHeartbeatAlertFun:1 didClickBut:^(NSInteger tag) {
  960. //
  961. // }];
  962. if(ksharedAppDelegate.isWebSockLinkOKAginType && ksharedAppDelegate.cloudPhoneExtraFileListMod){
  963. return;
  964. }
  965. NSMutableDictionary *paraDict = [NSMutableDictionary new];
  966. KWeakSelf
  967. [[netWorkManager shareInstance] CommonGetWithCallBackCode:queryHeartbeat Parameters:paraDict success:^(id _Nonnull responseObject){
  968. queryHeartbeatModel *heartbeatMod = [[queryHeartbeatModel alloc] initWithDictionary:responseObject error:nil];
  969. if(heartbeatMod && heartbeatMod.data){
  970. [weakSelf checkBoxHeartbeatToShowPopViewFunBy:heartbeatMod];
  971. }
  972. } failure:^(NSError * _Nonnull error) {
  973. }];
  974. }
  975. #pragma mark 根据盒子的心跳情况 显示异常谈了
  976. - (void)checkBoxHeartbeatToShowPopViewFunBy:(queryHeartbeatModel*)heartbeatMod
  977. {
  978. if(!heartbeatMod || !heartbeatMod.data){
  979. return;
  980. }
  981. if (//!heartbeatMod.data.frpStatus&&
  982. !heartbeatMod.data.hostAgentStatus
  983. &&!heartbeatMod.data.containerAgentStatus) {//全部异常
  984. [[BoxHeartbeatAlertTool shareInstance] showBoxHeartbeatAlertFun:1 didClickBut:^(NSInteger tag) {
  985. }];
  986. }
  987. else if (heartbeatMod.data.hostAgentStatus
  988. //&& !heartbeatMod.data.frpStatus
  989. && !heartbeatMod.data.containerAgentStatus) {//frp异常
  990. [[BoxHeartbeatAlertTool shareInstance] showBoxHeartbeatAlertFun:2 didClickBut:^(NSInteger tag) {
  991. }];
  992. }
  993. }
  994. #pragma mark 显示重启成功
  995. - (void)showReStartSucFun
  996. {
  997. //1.隐私模式密码界面 3秒检测一次是否输入完成密码了
  998. if(ksharedAppDelegate.isDidShowPwdType){
  999. KWeakSelf
  1000. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  1001. [weakSelf showReStartSucFun];
  1002. });
  1003. return;
  1004. }
  1005. [self closeBoxHeartbeatReStartViewFun];
  1006. BoxHeartbeatReStartSucView *view = [[BoxHeartbeatReStartSucView alloc] init];
  1007. [ksharedAppDelegate.window addSubview:view];
  1008. [view mas_makeConstraints:^(MASConstraintMaker *make) {
  1009. make.left.mas_equalTo(0.f);
  1010. make.bottom.mas_equalTo(0.f);
  1011. make.right.mas_equalTo(0.f);
  1012. make.top.mas_equalTo(0.f);
  1013. }];
  1014. }
  1015. #pragma mark 关闭心跳弹框
  1016. - (void)closeBoxHeartbeatReStartViewFun
  1017. {
  1018. NSArray * subViews = ksharedAppDelegate.window.subviews;
  1019. for (BoxHeartbeatReStartView*view in subViews) {
  1020. if([view isKindOfClass:[BoxHeartbeatReStartView class]]
  1021. || [view isKindOfClass:[customRestartingBoxView class]]){
  1022. [view colseFun];
  1023. break;
  1024. }
  1025. }
  1026. }
  1027. @end