NetworkServiceHandler.m 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. //
  2. // NetworkServiceHandler.m
  3. // OneCable
  4. //
  5. // Created by Jason Lee on 2/15/16.
  6. // Copyright © 2016 ntels. All rights reserved.
  7. //
  8. #import "JDObject.h"
  9. #import "NetworkServiceHandler.h"
  10. #import "Reachability.h"
  11. @interface NetworkServiceHandler () <NSNetServiceBrowserDelegate, NSNetServiceDelegate> {
  12. NSNetServiceBrowser *_netServiceBrowser;
  13. BOOL _isNotFirstLoading;
  14. Reachability *_reachability;
  15. }
  16. @property (strong, nonatomic) NSNetService *netService;
  17. @end
  18. @implementation NetworkServiceHandler
  19. - (BOOL)startSearchBonjourServices {
  20. NSLog(@"currentReachabilityStatus= %zd", _reachability.currentReachabilityStatus);
  21. // _isNotFirstLoading = NO;
  22. if (_reachability.currentReachabilityStatus != ReachableViaWiFi) {
  23. return NO;
  24. }
  25. //1.check if wifi
  26. // if (_netServiceBrowser) {
  27. // [_netServiceBrowser stop];
  28. // _netServiceBrowser = nil;
  29. // }
  30. NSString *browseType;
  31. if (!_netService) {
  32. _netServiceBrowser = [[NSNetServiceBrowser alloc] init];
  33. _netServiceBrowser.delegate = self;
  34. // browseType = @"_services._dns-sd._udp.";
  35. browseType = @"_ntelshub._tcp.";
  36. // browseType = @"_ntelshub._tcp.local.";
  37. NSLog(@"Serch BrowseType : %@", browseType);
  38. [_netServiceBrowser searchForServicesOfType:browseType inDomain:@""];
  39. } else {
  40. [self publishNetService];
  41. // NSString *fullDomainName = [NSString stringWithFormat:@"%@.%@", _netService.name, _netService.type];
  42. // NSArray *domainNameParts = [fullDomainName componentsSeparatedByString:@"."];
  43. // NSLog(@"%@, %@", [domainNameParts objectAtIndex:0], [domainNameParts objectAtIndex:1]);
  44. // browseType = [NSString stringWithFormat:@"%@.%@.", [domainNameParts objectAtIndex:0], [domainNameParts objectAtIndex:1]];
  45. // browseType = _netService.type;
  46. }
  47. return YES;
  48. }
  49. - (void)publishNetService {
  50. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, [JDFacade facade].deviceHostName);
  51. if (!_netService) {
  52. _netService = [[NSNetService alloc] initWithDomain:@"" type:@"_ntelshub._tcp" name:[JDFacade facade].deviceHostName port:7979];
  53. _netService.delegate = self;
  54. }
  55. if (_netService) {
  56. [_netService publish];
  57. } else {
  58. NSLog(@"An error occurred initializing the NSNetService object.");
  59. }
  60. }
  61. #pragma mark - NSNetServiceDelegate methods
  62. - (void)netServiceBrowser:(NSNetServiceBrowser *)browser didFindService:(NSNetService *)service moreComing:(BOOL)moreComing {
  63. NSMutableDictionary *info = [NSMutableDictionary dictionary];
  64. info[@"name"] = service.name;
  65. info[@"domain"] = service.domain;
  66. info[@"type"] = service.type;
  67. info[@"hostName"] = service.hostName;
  68. info[@"Data"] = service.type;
  69. info[@"Address"] = service.addresses;
  70. // info[@"port"] = service.port;
  71. NSLog(@"Finish : %@", info );
  72. NSLog(@"Port : %i", service.port );
  73. if (!_isNotFirstLoading) {
  74. [self publishNetService];
  75. _isNotFirstLoading = YES;
  76. }
  77. }
  78. - (void)netServiceDidPublish:(NSNetService *)sender {
  79. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, sender);
  80. if (self.delegate && [self.delegate respondsToSelector:@selector(didSucceedPublishService)]) {
  81. [self.delegate didSucceedPublishService];
  82. }
  83. }
  84. - (void)netServiceWillPublish:(NSNetService *)sender {
  85. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, sender);
  86. }
  87. - (void)netServiceDidStop:(NSNetService *)sender {
  88. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, sender);
  89. }
  90. - (void)netService:(NSNetService *)sender didAcceptConnectionWithInputStream:(NSInputStream *)inputStream outputStream:(NSOutputStream *)outputStream {
  91. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, sender);
  92. }
  93. - (void)netService:(NSNetService *)sender didNotPublish:(NSDictionary<NSString *,NSNumber *> *)errorDict {
  94. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, errorDict);
  95. if (self.delegate && [self.delegate respondsToSelector:@selector(didFailPublishService:)]) {
  96. [self.delegate didFailPublishService:errorDict];
  97. }
  98. }
  99. - (void)netService:(NSNetService *)sender didNotResolve:(NSDictionary *)errorDict {
  100. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, sender);
  101. NSNumber *errorCode = [errorDict valueForKey:NSNetServicesErrorCode];
  102. switch ([errorCode intValue]) {
  103. case NSNetServicesActivityInProgress:
  104. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, @"Service Resolution Currently in Progress. Please Wait.");
  105. break;
  106. case NSNetServicesTimeoutError:
  107. NSLog(@"%s\n %@", __PRETTY_FUNCTION__, @"Service Resolution Currently in Progress. Please Wait.");
  108. //service stop
  109. [sender stop];
  110. if (self.delegate && [self.delegate respondsToSelector:@selector(didFailPublishService:)]) {
  111. [self.delegate didFailPublishService:errorDict];
  112. }
  113. break;
  114. }
  115. }
  116. - (void)netServiceDidResolveAddress:(NSNetService *)service {
  117. // mDNSDetailViewController *sdvc = [self.storyboard instantiateViewControllerWithIdentifier:@"mDNSDetailViewController"];
  118. // sdvc.selectedService = service;
  119. //
  120. // [self.navigationController pushViewController:sdvc animated:YES];
  121. }
  122. #pragma mark - Reachability Notification
  123. - (void)netReachabilityChanged:(id)notification {
  124. if (_reachability.currentReachabilityStatus == ReachableViaWiFi) {
  125. NSLog(@"%s\n currentReachabilityStatus = %zd", __PRETTY_FUNCTION__, _reachability.currentReachabilityStatus);
  126. [self performSelectorInBackground:@selector(startSearchBonjourServices) withObject:nil];
  127. }
  128. }
  129. - (void)dealloc {
  130. NSLog(@"%s", __PRETTY_FUNCTION__);
  131. [[NSNotificationCenter defaultCenter] removeObserver:self forKeyPath:kReachabilityChangedNotification];
  132. [_reachability stopNotifier];
  133. [_netServiceBrowser stop];
  134. }
  135. #pragma mark - Singleton
  136. + (NetworkServiceHandler *)handler {
  137. static NetworkServiceHandler *sharedNetworkServiceHandler = nil;
  138. static dispatch_once_t onceToken;
  139. dispatch_once(&onceToken, ^{
  140. sharedNetworkServiceHandler = [[self alloc] init];
  141. });
  142. return sharedNetworkServiceHandler;
  143. }
  144. - (id)init {
  145. if (self = [super init]) {
  146. [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(netReachabilityChanged:) name:kReachabilityChangedNotification object:nil];
  147. _reachability = [Reachability reachabilityForLocalWiFi];
  148. [_reachability startNotifier];
  149. }
  150. return self;
  151. }
  152. @end