webRtcManager.m 36 KB

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