connectDeviceManager.m 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646
  1. //
  2. // connectDeviceManager.m
  3. // 隐私保护
  4. //
  5. // Created by xd h on 2023/10/9.
  6. //
  7. //第三方 瑞云 的链接服务
  8. #import "connectDeviceManager.h"
  9. #import <RayProxy/RaylinkProxy.h>
  10. #import <CocoaAsyncSocket/GCDAsyncSocket.h>
  11. #import "WHPingTester.h"
  12. #import "RSATool.h"
  13. @interface connectDeviceManager ()<
  14. GCDAsyncSocketDelegate,
  15. RaylinkProxyDelegate,
  16. WHPingDelegate
  17. >
  18. {
  19. dispatch_queue_t initProxyQueue;
  20. WHPingTester *whPingTester;
  21. BOOL didRuiYunInitOkType;
  22. BOOL disconnected_cb_type;//瑞云回调链接断开了
  23. BOOL didPingType;//是否ping过
  24. BOOL didRuiyunLinkType;//是否瑞云链接通过
  25. }
  26. @property (nonatomic, strong) NSTimer *connectCheckTimer;
  27. //@property (nonatomic, strong) GCDAsyncSocket *socket;
  28. //
  29. //@property (nonatomic, strong) GCDAsyncSocket *serverSocket;
  30. @property (nonatomic, assign) BOOL sdnConnected;
  31. @property (nonatomic, assign) BOOL peerConnected;
  32. @property (nonatomic, assign) NSInteger tcpPort;
  33. @property (nonatomic, copy) NSString *Pre_sdnId;//上一个sdn好
  34. @property (nonatomic, assign) BOOL isGetThridMsgType;
  35. @end
  36. @implementation connectDeviceManager
  37. static connectDeviceManager *connectDeviceManagerInstance = nil;
  38. +(connectDeviceManager *)shareInstance;
  39. {
  40. static dispatch_once_t onceToken;
  41. dispatch_once(&onceToken, ^{
  42. connectDeviceManagerInstance = [[connectDeviceManager alloc] init];
  43. connectDeviceManagerInstance.curConnectDeviceState = DeviceConnectUnknown;
  44. });
  45. return connectDeviceManagerInstance;
  46. }
  47. #pragma mark 根据扫码的sn获取第三方信息
  48. -(void)getThridMsgBySN:(NSString*)snStr needReconnect:(BOOL)needReconnect didNetEnd:(netWork_DidEndByOK)didNetEndIsOK
  49. {
  50. if(_isGetThridMsgType){
  51. didNetEndIsOK(-1);
  52. return;
  53. }
  54. if(needReconnect){
  55. _curConnectDeviceState = DeviceConnectGetThridMsging;
  56. //更换设备
  57. // NSString *curSdnId = self.DeviceThirdIdMod.data.sdnId;
  58. // if(curSdnId){
  59. // _Pre_sdnId = curSdnId;
  60. // }
  61. }
  62. NSMutableDictionary *paraDict = [NSMutableDictionary new];
  63. [paraDict setValue:snStr forKey:@"sn"];
  64. _isGetThridMsgType = YES;
  65. KWeakSelf
  66. [[netWorkManager shareInstance] CommonGetWithCallBackCode:getThirdIdBySn Parameters:paraDict success:^(id _Nonnull responseObject) {
  67. if(!needReconnect){
  68. NSError *parseError;
  69. NSData *jsonData = [NSJSONSerialization dataWithJSONObject:responseObject options:NSJSONWritingPrettyPrinted error:&parseError];
  70. if (parseError) {
  71. //解析出错
  72. }
  73. NSString * str = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
  74. [cachesFileManager writeLogsWithMsg:str];
  75. }
  76. self->_isGetThridMsgType = NO;
  77. DeviceThirdIdModel *model = [[DeviceThirdIdModel alloc] initWithDictionary:responseObject error:nil];
  78. if(model.status == 0
  79. && model.data)
  80. {
  81. weakSelf.DeviceThirdIdMod = model;
  82. NSString*desPwdstr = [RSATool AES128Decrypt:weakSelf.DeviceThirdIdMod.data.password key:AESCODEKEEYY];
  83. didNetEndIsOK(YES);
  84. /*密码保持在本地*/
  85. NSDictionary *deviceDict = [HWDataManager getObjectWithKey:Const_Have_Add_Device];
  86. NSMutableDictionary *dict = [[NSMutableDictionary alloc] initWithDictionary:deviceDict];
  87. [dict setObject:desPwdstr forKey:Const_Have_Add_Device_PWD];
  88. NSString *sdnid = model.data.sdnId;
  89. if(sdnid){
  90. [dict setObject:sdnid forKey:Const_Have_Add_Device_sdnid];
  91. }
  92. [HWDataManager setObjectWithKey:Const_Have_Add_Device_Privacy_Mode value:[NSNumber numberWithBool:model.data.isPrivacyMode]];
  93. [HWDataManager setObjectWithKey:Const_Have_Add_Device value:dict];
  94. //
  95. bool connected = [RaylinkProxy.sharedManager isSdnConnected];
  96. if(!connected || needReconnect){
  97. self->didPingType = NO;
  98. self->didRuiyunLinkType = NO;
  99. self->_isPingOk = NO;
  100. weakSelf.curConnectDeviceState = DeviceConnectGetThridOK;
  101. NSString *ipStr = weakSelf.DeviceThirdIdMod.data.ip;
  102. [weakSelf startPingDeviceIp:ipStr];
  103. [weakSelf initRuiyunSDKFun];
  104. }
  105. }
  106. else{
  107. if(model.status == 201||model.status == 202){
  108. didNetEndIsOK(model.status);
  109. }
  110. else{
  111. didNetEndIsOK(2);
  112. }
  113. }
  114. } failure:^(NSError * _Nonnull error) {
  115. HLog("网络报错");
  116. self->_isGetThridMsgType = NO;
  117. didNetEndIsOK(NO);
  118. }];
  119. }
  120. #pragma mark 刷新扫码的sn获取第三方信息 是否需要重连
  121. -(void)RefreshThridMsg
  122. {
  123. /*先判断本地有无设备 无设备时需要先扫码添加设备*/
  124. NSDictionary *deviceDict = [HWDataManager getObjectWithKey:Const_Have_Add_Device];
  125. if (deviceDict && [[deviceDict allKeys] containsObject:Const_Have_Add_Device_SN]){
  126. //有设备了先去做链接准备 // 80bec9c5
  127. NSString *SNStr = deviceDict[@"Const_Have_Add_Device_SN"];
  128. if(SNStr){
  129. [[connectDeviceManager shareInstance] getThridMsgBySN:SNStr needReconnect:NO didNetEnd:^(NSInteger didSuc) {
  130. }];
  131. }
  132. }
  133. }
  134. #pragma mark 初始化瑞云的SDK等
  135. - (void)initRuiyunSDKFun{
  136. if(didRuiYunInitOkType){
  137. [self onConnectFun];
  138. return;
  139. }
  140. HLog(@"initRuiyunSDKFun");
  141. self.sdnConnected = NO;
  142. self.peerConnected = NO;
  143. //self.sendBtn.enabled = NO;
  144. //self.sdnConnectStateLab.text = @"SDN state: Connectting";
  145. //self.sdnIDLab.text = @"My SDN ID:";
  146. RaylinkProxy.sharedManager.delegate = self;
  147. initProxyQueue = dispatch_queue_create("init_proxy", 0);
  148. NSURL *logUrl = [[NSFileManager.defaultManager URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask].firstObject URLByAppendingPathComponent:@"logs"];
  149. if (![NSFileManager.defaultManager fileExistsAtPath:logUrl.path]) {
  150. [NSFileManager.defaultManager createDirectoryAtURL:logUrl withIntermediateDirectories:YES attributes:NULL error:NULL];
  151. }
  152. KWeakSelf
  153. dispatch_async(initProxyQueue, ^{
  154. NSData *sdnInfo = [NSData dataWithContentsOfURL:[[NSBundle.mainBundle bundleURL] URLByAppendingPathComponent:@"planet.1ali_3ry_peer"]];
  155. /// 1. 初始化代理库
  156. [RaylinkProxy.sharedManager initProxy:logUrl.path rootSdnInfo:sdnInfo];
  157. self->didRuiYunInitOkType = YES;
  158. /// 启动定时器监听 SND 连接状态
  159. self.connectCheckTimer = [NSTimer scheduledTimerWithTimeInterval:0.5 repeats:YES block:^(NSTimer * _Nonnull timer) {
  160. /// 2. 监听SDN 连接状态
  161. bool connected = [RaylinkProxy.sharedManager isSdnConnected];
  162. if (self.sdnConnected == connected) {
  163. return;
  164. }
  165. self.sdnConnected = connected;
  166. if (self.sdnConnected) {
  167. [weakSelf onConnectFun];
  168. [self->_connectCheckTimer invalidate];
  169. //self.sdnConnectStateLab.text = @"SDN state: Connected";
  170. //self.sdnIDLab.text = [@"My SDN ID: " stringByAppendingString:[RaylinkProxy.sharedManager getSdnId]];
  171. } else {
  172. //self.sdnConnectStateLab.text = @"SDN state: Connectting";
  173. }
  174. }];
  175. [[NSRunLoop currentRunLoop] addTimer:self.connectCheckTimer forMode:NSRunLoopCommonModes];
  176. [[NSRunLoop currentRunLoop] run];
  177. });
  178. /// 作为服务端时,启动端口监听
  179. // self.serverSocket = [[GCDAsyncSocket alloc] initWithDelegate:self delegateQueue:dispatch_get_main_queue()];
  180. //
  181. // if ([self.serverSocket acceptOnPort:0 error:NULL]) {
  182. // //self.serverPortLab.text = [NSString stringWithFormat: @"server port: %d", self.serverSocket.localPort];
  183. // NSLog(@"accept ok %d",self.serverSocket.localPort);
  184. // }
  185. }
  186. - (void)onConnectFun{
  187. if (self.peerConnected == YES
  188. && _Pre_sdnId
  189. && ![_Pre_sdnId isEqualToString:self.DeviceThirdIdMod.data.sdnId]) {
  190. //[self disconnect];
  191. //return;
  192. }
  193. _curConnectDeviceState = DeviceConnectDeciceing;
  194. NSString *curSdnId = self.DeviceThirdIdMod.data.sdnId; //@"3dfe7c1f";
  195. if(!curSdnId){
  196. NSDictionary *deviceDict = [HWDataManager getObjectWithKey:Const_Have_Add_Device];
  197. if(deviceDict && [[deviceDict allKeys] containsObject:Const_Have_Add_Device_sdnid])
  198. {
  199. curSdnId = deviceDict[Const_Have_Add_Device_sdnid];
  200. }
  201. }
  202. /// 3. 根据对端的 SDN ID 创建连接
  203. [RaylinkProxy.sharedManager createNewConnection:curSdnId];
  204. //self.socket = [[GCDAsyncSocket alloc] initWithDelegate:self delegateQueue:dispatch_get_main_queue()];
  205. //[self.connectBtn setEnabled:NO];
  206. //[self.connectBtn setTitle:@"连接中..." forState:UIControlStateDisabled];
  207. }
  208. - (void)disconnect {
  209. NSString *curSdnId = self.DeviceThirdIdMod.data.sdnId;
  210. if(_Pre_sdnId){
  211. curSdnId = _Pre_sdnId;
  212. }
  213. if(curSdnId){
  214. [RaylinkProxy.sharedManager closeConnection:curSdnId];
  215. [RaylinkProxy.sharedManager closeHttpService:curSdnId];
  216. //[self.connectBtn setTitle:@"连接" forState:UIControlStateNormal];
  217. self.peerConnected = NO;
  218. }
  219. }
  220. - (IBAction)onClickSend:(id)sender {
  221. // if (self.messageTF.text.length <= 0) {
  222. // return;
  223. // }
  224. //[self.socket writeData:[@"111" dataUsingEncoding:NSUTF8StringEncoding] withTimeout:-1 tag:0];
  225. }
  226. //- (void)socket:(GCDAsyncSocket *)sock didAcceptNewSocket:(GCDAsyncSocket *)newSocket {
  227. //
  228. // NSLog(@"didAcceptNewSocket");
  229. //
  230. //
  231. // [newSocket setDelegate:self delegateQueue:dispatch_get_main_queue()];
  232. //
  233. // NSThread *revcThread = [[NSThread alloc] initWithBlock:^{
  234. //
  235. // while (true) {
  236. // [newSocket readDataWithTimeout:-1 tag:0];
  237. // [NSThread sleepForTimeInterval:0.1];
  238. // }
  239. // }];
  240. //
  241. // [revcThread start];
  242. //
  243. //}
  244. - (void)onProxyConnected:(NSString *)sdnId status:(int)status {
  245. if (status == 0) {
  246. /// 4. 创建 HttpService
  247. self.tcpPort = [RaylinkProxy.sharedManager createHttpService:sdnId];
  248. self.tcpPortStr = [[NSString alloc] initWithFormat:@"%ld",self.tcpPort];
  249. [[netWorkManager shareInstance] setAFHTTPSessionManagerFunBy:self.tcpPort];
  250. /// 5. 添加端口防火墙
  251. [RaylinkProxy.sharedManager addSdnId:sdnId ip:ruiyunlinkIp allowPort:9300];
  252. [RaylinkProxy.sharedManager addSdnId:sdnId ip:ruiyunlinkIp allowPort:9100];
  253. [RaylinkProxy.sharedManager addSdnId:sdnId ip:ruiyunlinkIp allowPort:9888];
  254. [cachesFileManager writeLogsWithMsg:@"onProxyConnected connectToHost"];
  255. /// 6. 等待连接成功回调,创建 TCP socket 连接 HttpService 的端口
  256. // NSError *error;
  257. //
  258. // NSString*log1 = [[NSString alloc] initWithFormat:@"onProxyConnected connectToHost begin %ld", (long)self.tcpPort];
  259. // [cachesFileManager writeLogsWithMsg:log1];
  260. //
  261. // [self.socket connectToHost:@"127.0.0.1" onPort:self.tcpPort error:&error];
  262. //
  263. // NSString*log2 = [[NSString alloc] initWithFormat:@"onProxyConnected connectToHost end %ld, self.socket = %@ error = %@", (long)self.tcpPort, self.socket, error];
  264. // [cachesFileManager writeLogsWithMsg:log2];
  265. _curConnectDeviceState = DeviceConnectDeciceOk;
  266. _Pre_sdnId = self.DeviceThirdIdMod.data.sdnId;
  267. disconnected_cb_type = NO;
  268. didRuiyunLinkType = YES;
  269. [self beginLinkWebSocketFun];
  270. } else {
  271. HLog(@"瑞云链接断开");
  272. }
  273. }
  274. - (void)OnProxyDisconnected_cb:(NSString *)sdnId {
  275. //[RaylinkProxy.sharedManager closeHttpService:sdnId];
  276. [cachesFileManager writeLogsWithMsg:@"OnProxyDisconnected_cb"];
  277. disconnected_cb_type = YES;
  278. }
  279. //瑞云sock 断开了 需要重连
  280. - (void)tryReconnectFun{
  281. [cachesFileManager writeLogsWithMsg:@"tryReconnect"];
  282. [cachesFileManager writeLogsWithMsg:@"click again try Net Work"];
  283. [self getThridMsgBySN:self.DeviceThirdIdMod.data.changeSn needReconnect:NO didNetEnd:^(NSInteger didSuc) {
  284. NSString *tip = [[NSString alloc] initWithFormat:@"Net Work state:%ld",didSuc];
  285. [cachesFileManager writeLogsWithMsg:tip];
  286. }];
  287. if(!disconnected_cb_type){
  288. [cachesFileManager writeLogsWithMsg:@"tryReconnect return"];
  289. return;
  290. }
  291. NSURL *logUrl = [[NSFileManager.defaultManager URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask].firstObject URLByAppendingPathComponent:@"logs"];
  292. if (![NSFileManager.defaultManager fileExistsAtPath:logUrl.path]) {
  293. [NSFileManager.defaultManager createDirectoryAtURL:logUrl withIntermediateDirectories:YES attributes:NULL error:NULL];
  294. }
  295. // dispatch_queue_t reinitProxyQueue = dispatch_queue_create("reinit_proxy", 0);
  296. //
  297. //
  298. // [cachesFileManager writeLogsWithMsg:@"tryReconnect initProxy 0"];
  299. // dispatch_async(reinitProxyQueue, ^{
  300. // NSData *sdnInfo = [NSData dataWithContentsOfURL:[[NSBundle.mainBundle bundleURL] URLByAppendingPathComponent:@"planet.1ali_3ry_peer"]];
  301. //
  302. // /// 1. 初始化代理库
  303. // [cachesFileManager writeLogsWithMsg:@"tryReconnect initProxy 1"];
  304. // self->disconnected_cb_type = NO;
  305. // self->_isReInitType = YES;
  306. // [RaylinkProxy.sharedManager initProxy:logUrl.path rootSdnInfo:sdnInfo];
  307. // self->_isReInitType = NO;
  308. // [cachesFileManager writeLogsWithMsg:@"tryReconnect initProxy 2"];
  309. // });
  310. // //KWeakSelf
  311. // NSMutableDictionary *paraDict = [NSMutableDictionary new];
  312. // if(self.DeviceThirdIdMod.data.sn){
  313. // [paraDict setValue:self.DeviceThirdIdMod.data.sn forKey:@"sn"];
  314. // }
  315. //
  316. // [cachesFileManager writeLogsWithMsg:@"tryReconnect CommonGetWithCallBackCode"];
  317. // [[netWorkManager shareInstance] CommonGetWithCallBackCode:getThirdIdBySn Parameters:paraDict success:^(id _Nonnull responseObject) {
  318. //
  319. // dispatch_async(self->initProxyQueue, ^{
  320. // NSData *sdnInfo = [NSData dataWithContentsOfURL:[[NSBundle.mainBundle bundleURL] URLByAppendingPathComponent:@"planet.1ali_3ry_peer"]];
  321. //
  322. // /// 1. 初始化代理库
  323. // [RaylinkProxy.sharedManager initProxy:logUrl.path rootSdnInfo:sdnInfo];
  324. // [cachesFileManager writeLogsWithMsg:@"tryReconnect initProxy"];
  325. // });
  326. //
  327. //
  328. // } failure:^(NSError * _Nonnull error) {
  329. // HLog("网络报错");
  330. // }];
  331. }
  332. //音视频 链接返回-5的时候调用
  333. - (void)recreateHttpServiceFun{
  334. [cachesFileManager writeLogsWithMsg:@"recreateHttpServiceFun"];
  335. NSString *sdnId = self.DeviceThirdIdMod.data.sdnId;
  336. self.tcpPort = [RaylinkProxy.sharedManager createHttpService:sdnId];
  337. self.tcpPortStr = [[NSString alloc] initWithFormat:@"%ld",self.tcpPort];
  338. [[netWorkManager shareInstance] setAFHTTPSessionManagerFunBy:self.tcpPort];
  339. [RaylinkProxy.sharedManager addSdnId:sdnId ip:ruiyunlinkIp allowPort:9300];
  340. [RaylinkProxy.sharedManager addSdnId:sdnId ip:ruiyunlinkIp allowPort:9100];
  341. [RaylinkProxy.sharedManager addSdnId:sdnId ip:ruiyunlinkIp allowPort:9888];
  342. }
  343. //- (void)socket:(GCDAsyncSocket *)sock didConnectToHost:(NSString *)host port:(uint16_t)port {
  344. //
  345. // NSLog(@"didConnectToHost %d", port);
  346. //
  347. // NSThread *thread = [[NSThread alloc] initWithBlock:^{
  348. // while (true) {
  349. //
  350. // [self.socket readDataWithTimeout:-1 tag:0];
  351. // [NSThread sleepForTimeInterval:0.1];
  352. //
  353. // }
  354. // }];
  355. //
  356. // [thread start];
  357. //
  358. // /// 7. Socket 连接成功后,通过 socket 发送, self.peerPortTF 为对端服务端口
  359. // //[sock writeData:[[NSString stringWithFormat:@"CONNECT 127.0.0.1:%@ HTTP/1.0\r\n\r\n", @"9100"] dataUsingEncoding:NSUTF8StringEncoding] withTimeout:-1 tag:0];
  360. //
  361. // NSLog(@"readDataToData");
  362. //
  363. // [cachesFileManager writeLogsWithMsg:@"didConnectToHost writeData"];
  364. //}
  365. //
  366. //- (void)socket:(GCDAsyncSocket *)sock didWriteDataWithTag:(long)tag
  367. //{
  368. // NSLog(@"socket:%p didWriteDataWithTag:%ld", sock, tag);
  369. //}
  370. //
  371. //- (void)socket:(GCDAsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag {
  372. //
  373. //
  374. // if (tag == 0) {
  375. //
  376. // NSString *str = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
  377. //
  378. // /// 8. 收到包含 `HTTP/1.0 200`的字符串,则认为连接成功。可以正常给对端发消息了
  379. // if ([str containsString:@"HTTP/1.0 200"]) {
  380. // NSLog(@"Connected");
  381. // self.peerConnected = YES;
  382. //// self.connectBtn.enabled = YES;
  383. //// [self.connectBtn setTitle:@"断开连接" forState:UIControlStateNormal];
  384. // }
  385. //
  386. // }
  387. //
  388. // //self.revcLab.text = [NSString stringWithFormat:@"接收:%@", [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding]];
  389. //}
  390. #pragma mark 保持卡密码
  391. -(void)updateCardInfoBySN:(NSString*)snStr withPwdStr:(NSString*)pwd didNetEnd:(netWork_DidEndByOK)didNetEndIsOK
  392. {
  393. NSMutableDictionary *paraDict = [NSMutableDictionary new];
  394. [paraDict setValue:snStr forKey:@"sn"];
  395. NSString* enPwdStr = [RSATool AES128Encrypt:pwd key:AESCODEKEEYY];
  396. if(enPwdStr){
  397. [paraDict setValue:enPwdStr forKey:@"password"];
  398. }
  399. KWeakSelf
  400. [[netWorkManager shareInstance] CommonPostCallBackCode:updateCardInfo Parameters:paraDict success:^(id _Nonnull responseObject) {
  401. SuperModel*model = [[SuperModel alloc] initWithDictionary:responseObject error:nil];
  402. if(model && model.status == 0)
  403. {
  404. didNetEndIsOK(YES);
  405. [connectDeviceManager shareInstance].DeviceThirdIdMod.data.password = enPwdStr;
  406. /*密码保持在本地*/
  407. NSDictionary *deviceDict = [HWDataManager getObjectWithKey:Const_Have_Add_Device];
  408. NSMutableDictionary *dict = [[NSMutableDictionary alloc] initWithDictionary:deviceDict];
  409. [dict setObject:pwd forKey:Const_Have_Add_Device_PWD];
  410. [HWDataManager setObjectWithKey:Const_Have_Add_Device value:dict];
  411. }
  412. else{
  413. didNetEndIsOK(NO);
  414. }
  415. } failure:^(NSError * _Nonnull error) {
  416. HLog("网络报错");
  417. didNetEndIsOK(NO);
  418. }];
  419. }
  420. #pragma mark ---ping-----站点 判断是否是局域网
  421. - (void)startPingDeviceIp:(NSString *)roomInternetIp
  422. {
  423. //roomInternetIp = @"www.baidu.com";
  424. if(!roomInternetIp || roomInternetIp.length < 7){
  425. self.isPingOk = NO;
  426. return;
  427. }
  428. if (self->whPingTester)
  429. {
  430. [self->whPingTester stopPing];
  431. self->whPingTester = nil;
  432. }
  433. self->whPingTester = [[WHPingTester alloc] initWithHostName:roomInternetIp];
  434. self->whPingTester.delegate = self;
  435. //self->whPingTester.countdownTime = 1; //1秒ping一次
  436. [self->whPingTester startPing];
  437. /// 启动定时器监听 10秒后 whPingTester的状态
  438. [NSTimer scheduledTimerWithTimeInterval:5 repeats:NO block:^(NSTimer * _Nonnull timer) {
  439. if(self->whPingTester){
  440. [self didGetPingStateIsOK:NO];
  441. }
  442. }];
  443. }
  444. #pragma mark ---ping---- 代理回调
  445. - (void) didPingSucccessWithTime:(float)time withError:(NSError*) error
  446. {
  447. HLog(@"time:%f \n error: %@",time,error)
  448. //if(error.code == 111 || time > 1000) //超时或者延时超过100ms,就要记录数据
  449. if(error != nil)
  450. {
  451. [self didGetPingStateIsOK:NO];
  452. }
  453. else if(time > 0){
  454. [self didGetPingStateIsOK:YES];
  455. }
  456. }
  457. - (void) didPingfialewithError:(NSError*)error
  458. {
  459. HLog(@" error error: %@",error)
  460. [self didGetPingStateIsOK:NO];
  461. }
  462. -(void)didGetPingStateIsOK:(BOOL)isOk
  463. {
  464. self.isPingOk = isOk;
  465. [self->whPingTester stopPing];
  466. self->whPingTester = nil;
  467. didPingType = YES;
  468. [self beginLinkWebSocketFun];
  469. }
  470. - (void)beginLinkWebSocketFun
  471. {
  472. if(!didPingType){
  473. return;
  474. }
  475. //局域网不通 瑞云还没连接好
  476. if(!self.isPingOk && !didRuiyunLinkType){
  477. return;
  478. }
  479. //切换设备
  480. if([[webSocketManager shareInstance].commandChannelManager rc_socketStatus] == RCSocketCloudPhoneStatusConnected
  481. ||[[webSocketManager shareInstance].commandChannelManager rc_socketStatus] == RCSocketCloudPhoneStatusReceived){
  482. [[webSocketManager shareInstance].commandChannelManager rc_close];
  483. [webSocketManager shareInstance].commandChannelManager = nil;
  484. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  485. [[webSocketManager shareInstance] opencommandChannelManagerrc_openURL];
  486. });
  487. }
  488. else{//非第一次
  489. [[webSocketManager shareInstance] opencommandChannelManagerrc_openURL];
  490. }
  491. }
  492. @end