connectDeviceManager.m 20 KB

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