webRtcManager.m 43 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235
  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:1];
  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:2];
  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. [[NSNotificationCenter defaultCenter] postNotificationName:webRtcLinkStateChangeNotification object:nil];/*发送通知*/
  873. //链接成功
  874. [self handlAllMsgAfterDidLinkFun];
  875. //客户端停止写日志
  876. [ksharedAppDelegate.WebRtcLogger stop];
  877. }
  878. break;
  879. case RTCDataChannelStateClosing:
  880. {
  881. }
  882. break;
  883. case RTCDataChannelStateClosed:
  884. {
  885. [[NSNotificationCenter defaultCenter] postNotificationName:webRtcLinkStateChangeNotification object:nil];/*发送通知*/
  886. //链接断开
  887. [self relinkWebRtcFun];
  888. }
  889. break;
  890. default:
  891. break;
  892. }
  893. }
  894. -(void)onChannelDataFromPeerName:(NSString*)peerName buffer:(RTC_OBJC_TYPE(RTCDataBuffer) *)buffer
  895. {
  896. //HLog(@"onIceConnectedFromPeerName:%@",buffer.data);
  897. if(buffer && buffer.data){
  898. KWeakSelf
  899. mainBlock(^{
  900. [weakSelf handleWebRtcMsgResponseBy:buffer.data];
  901. });
  902. }
  903. }
  904. -(void)didGetStats:(NSString*)peerName stats:(RTC_OBJC_TYPE(RTCStatisticsReport) *)stats
  905. {
  906. //HLog(@"didGetStats:%@",stats)
  907. if(!_didReportWebRtcOKType
  908. && (self.ConnectionState == RTCIceConnectionStateConnected ||self.ConnectionState == RTCIceConnectionStateCompleted)){
  909. [self reportWebRtcRePoportTypeIsChannel:YES withStats:stats withSessionId:_webRtcChannelSessionId withLogKey:@""];
  910. _didReportWebRtcOKType = YES;
  911. _didReportWebRtcFailType = NO;//链接成功后 失败要重新上报
  912. [_mediaStream setShouldGetStats:NO];
  913. }
  914. }
  915. -(void)onAuthResultFromPeerName:(NSString*)peerName code:(int)code descriptions:(NSString*)descriptions
  916. {
  917. //HLog(@"webRtc P2P onAuthResultFromPeerName")
  918. }
  919. - (void)connectionChange:(NSString*)peerName
  920. didChangeLocalCandidate:(RTC_OBJC_TYPE(RTCIceCandidate) *)local
  921. remoteCandidate:(RTC_OBJC_TYPE(RTCIceCandidate) *)remote
  922. lastReceivedMs:(int)lastDataReceivedMs
  923. changeReason:(NSString *)reason
  924. {
  925. //HLog(@"webRtc P2P didChangeLocalCandidate")
  926. [self reportWebRtcRePoportTypeIsChannel:YES withLocal:local remoteCandidate:remote withSessionId:self.webRtcChannelSessionId withLogKey:@""];
  927. }
  928. #pragma mark 检测盒子的心跳情况
  929. - (void)checkBoxHeartbeatFun
  930. {
  931. //2、点击系统升级弹框确定按钮后30分钟内不弹;
  932. NSNumber *preSecondNum = [HWDataManager getNumberWithKey:stringKeyAddSn(@"disenable_type1_BoxHeartbeat")];
  933. if(preSecondNum){
  934. long seconds = [iTools getNowTimeStamp];
  935. if(seconds - preSecondNum.longValue <= 60*30){
  936. return;
  937. }
  938. }
  939. //3、重启、恢复出厂设备、首次设置密码 3个情况下8分钟之内不弹
  940. NSNumber *preSecondNum2 = [HWDataManager getNumberWithKey:stringKeyAddSn(@"disenable_type2_BoxHeartbeat")];
  941. if(preSecondNum2){
  942. long seconds = [iTools getNowTimeStamp];
  943. if(seconds - preSecondNum2.longValue <= 60*8){
  944. return;
  945. }
  946. }
  947. if(ksharedAppDelegate.didShowBoxHeartbeatAlertType
  948. ||[webRtcManager shareManager].isResetingType
  949. ||[webRtcManager shareManager].isRebootIngType
  950. || [ksharedAppDelegate didShowImageRenewViewFun]){
  951. return;
  952. }
  953. //1.隐私模式密码界面 3秒检测一次是否输入完成密码了
  954. if(ksharedAppDelegate.isDidShowPwdType){
  955. KWeakSelf
  956. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  957. [weakSelf checkBoxHeartbeatFun];
  958. });
  959. return;
  960. }
  961. // [[BoxHeartbeatAlertTool shareInstance] showBoxHeartbeatAlertFun:1 didClickBut:^(NSInteger tag) {
  962. //
  963. // }];
  964. if(ksharedAppDelegate.isWebSockLinkOKAginType && ksharedAppDelegate.cloudPhoneExtraFileListMod){
  965. return;
  966. }
  967. NSMutableDictionary *paraDict = [NSMutableDictionary new];
  968. KWeakSelf
  969. [[netWorkManager shareInstance] CommonGetWithCallBackCode:queryHeartbeat Parameters:paraDict success:^(id _Nonnull responseObject){
  970. queryHeartbeatModel *heartbeatMod = [[queryHeartbeatModel alloc] initWithDictionary:responseObject error:nil];
  971. if(heartbeatMod && heartbeatMod.data){
  972. [weakSelf checkBoxHeartbeatToShowPopViewFunBy:heartbeatMod];
  973. }
  974. } failure:^(NSError * _Nonnull error) {
  975. }];
  976. }
  977. #pragma mark 根据盒子的心跳情况 显示异常谈了
  978. - (void)checkBoxHeartbeatToShowPopViewFunBy:(queryHeartbeatModel*)heartbeatMod
  979. {
  980. if(!heartbeatMod || !heartbeatMod.data){
  981. return;
  982. }
  983. if (//!heartbeatMod.data.frpStatus&&
  984. !heartbeatMod.data.hostAgentStatus
  985. &&!heartbeatMod.data.containerAgentStatus) {//全部异常
  986. [[BoxHeartbeatAlertTool shareInstance] showBoxHeartbeatAlertFun:1 didClickBut:^(NSInteger tag) {
  987. }];
  988. }
  989. else if (heartbeatMod.data.hostAgentStatus
  990. //&& !heartbeatMod.data.frpStatus
  991. && !heartbeatMod.data.containerAgentStatus) {//frp异常
  992. [[BoxHeartbeatAlertTool shareInstance] showBoxHeartbeatAlertFun:2 didClickBut:^(NSInteger tag) {
  993. }];
  994. }
  995. }
  996. #pragma mark 显示重启成功 type:1 云手机 2 盒子
  997. - (void)showReStartSucFun:(NSInteger)type
  998. {
  999. //1.隐私模式密码界面 3秒检测一次是否输入完成密码了
  1000. if(ksharedAppDelegate.isDidShowPwdType){
  1001. KWeakSelf
  1002. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  1003. [weakSelf showReStartSucFun:type];
  1004. });
  1005. return;
  1006. }
  1007. [self closeBoxHeartbeatReStartViewFun];
  1008. BoxHeartbeatReStartSucView *view = [[BoxHeartbeatReStartSucView alloc] initWithType:type];
  1009. [ksharedAppDelegate.window addSubview:view];
  1010. [view mas_makeConstraints:^(MASConstraintMaker *make) {
  1011. make.left.mas_equalTo(0.f);
  1012. make.bottom.mas_equalTo(0.f);
  1013. make.right.mas_equalTo(0.f);
  1014. make.top.mas_equalTo(0.f);
  1015. }];
  1016. }
  1017. #pragma mark 关闭心跳弹框
  1018. - (void)closeBoxHeartbeatReStartViewFun
  1019. {
  1020. NSArray * subViews = ksharedAppDelegate.window.subviews;
  1021. for (BoxHeartbeatReStartView*view in subViews) {
  1022. if([view isKindOfClass:[BoxHeartbeatReStartView class]]
  1023. || [view isKindOfClass:[customRestartingBoxView class]]){
  1024. [view colseFun];
  1025. break;
  1026. }
  1027. }
  1028. }
  1029. @end