SocketServiceHandler.m 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291
  1. //
  2. // SocketServiceHandler.m
  3. // OneCable
  4. //
  5. // Created by KaRam Kim on 2017. 2. 17..
  6. // Copyright © 2017년 ntels. All rights reserved.
  7. //
  8. #import "SocketServiceHandler.h"
  9. #import "Definitions.h"
  10. #import "JDJSONModel.h"
  11. #import "JDObject.h"
  12. #define MAX_RETRY_CONNECT_COUNT 1
  13. @interface SocketServiceHandler() <SRWebSocketDelegate>
  14. {
  15. SRWebSocket *_socket;
  16. NSMutableArray<NSDictionary *> *_messages;
  17. NSMutableArray *_delegates;
  18. int _retryCount;
  19. }
  20. //@property NSMutableDictionary* controllers;
  21. //@property int controllerId;
  22. @end
  23. @implementation SocketServiceHandler
  24. + (id)sharedManager
  25. {
  26. static SocketServiceHandler *sharedSocketServiceHandler = nil;
  27. static dispatch_once_t onceToken;
  28. dispatch_once(&onceToken, ^{
  29. sharedSocketServiceHandler = [[self alloc] init];
  30. });
  31. return sharedSocketServiceHandler;
  32. }
  33. - (id) init
  34. {
  35. self = [super init];
  36. if (self) {
  37. _isConnected = NO;
  38. _messages = [[NSMutableArray alloc] init];
  39. _delegates = [[NSMutableArray alloc] init];
  40. // self.controllerId = 0;
  41. [self socketOpen];
  42. }
  43. return self;
  44. }
  45. //- (void) initDelegate:(id<SocketServiceDelegate>) delegate
  46. //{
  47. // [self setDelegate:delegate];
  48. //}
  49. - (SRReadyState) getSocketStatus
  50. {
  51. return _socket.readyState;
  52. }
  53. - (void) socketOpen
  54. {
  55. NSLog(@"socketOpen");
  56. _strSocketURL = [NSString stringWithFormat:@"%@%@", kSocketServer, API_ROOT_PATH];
  57. NSLog(@"socketURL : %@", _strSocketURL);
  58. if( _socket != nil )
  59. {
  60. [_socket open];
  61. }
  62. else
  63. {
  64. NSMutableURLRequest *request = [[NSMutableURLRequest alloc] initWithURL:[NSURL URLWithString:_strSocketURL]];
  65. if([[JDFacade facade].loginUser authorization]!=nil)
  66. {
  67. [request setValue:[[JDFacade facade].loginUser authorization] forHTTPHeaderField:API_AUTHORIZATION_KEY];
  68. }
  69. NSLog(@"All Header Info : %@", request.allHTTPHeaderFields);
  70. _socket = [[SRWebSocket alloc] initWithURLRequest:request];
  71. _socket.delegate = self;
  72. [_socket open];
  73. }
  74. }
  75. - (void) open
  76. {
  77. if( !_isConnected )
  78. {
  79. if( _socket.readyState == SR_OPEN )
  80. {
  81. _isConnected = YES;
  82. }
  83. else if ( _socket.readyState == SR_CLOSED || _socket.readyState == SR_CLOSING )
  84. {
  85. [self close];
  86. _socket = nil;
  87. [self socketOpen];
  88. }
  89. }
  90. }
  91. - (void) close
  92. {
  93. if( _isConnected )
  94. {
  95. [_socket close];
  96. _socket = nil;
  97. }
  98. else
  99. {
  100. if (_socket != nil)
  101. {
  102. _socket = nil;
  103. }
  104. }
  105. _isConnected = NO;
  106. }
  107. - (void) sendData:(NSDictionary *)data
  108. {
  109. NSLog(@"Send Data : %@", data);
  110. if(_socket.readyState == SR_OPEN)
  111. {
  112. NSLog(@"1");
  113. NSError *error;
  114. NSData *jsonData = [NSJSONSerialization dataWithJSONObject:data
  115. options:NSJSONWritingPrettyPrinted // Pass 0 if you don't care about the readability of the generated string
  116. error:&error];
  117. if (!jsonData)
  118. {
  119. NSLog(@"Got an error: %@", error);
  120. }
  121. else
  122. {
  123. NSString *jsonString = [[NSString alloc] initWithData:jsonData encoding:NSUTF8StringEncoding];
  124. NSLog(@"Socket Send Data : %@", jsonString);
  125. [_socket send:jsonString];
  126. }
  127. }
  128. else if ( _socket.readyState == SR_CLOSED || _socket.readyState == SR_CLOSING )
  129. {
  130. NSLog(@"2");
  131. [_messages addObject:data];
  132. [self reConnect];
  133. }
  134. else
  135. {
  136. NSLog(@"3");
  137. [_messages addObject:data];
  138. if(!_isConnected)
  139. {
  140. [self socketOpen];
  141. }
  142. }
  143. }
  144. - (void) sendDataWithDelegate:(NSDictionary *)data delegate:(id)delegate
  145. {
  146. [self addDelegate:delegate];
  147. [self sendData:data];
  148. }
  149. - (void)addDelegate:(id)delegate {
  150. // short controllerId = self.controllerId++;
  151. // if (self.controllerId >= INT16_MAX) {
  152. // self.controllerId = 0;
  153. // }
  154. [_delegates addObject:delegate];
  155. }
  156. - (void)removeDelegate:(id)delegate {
  157. [_delegates removeObject:delegate];
  158. }
  159. -(void) reConnect
  160. {
  161. if(_retryCount < MAX_RETRY_CONNECT_COUNT)
  162. {
  163. _retryCount++;
  164. [self close];
  165. _socket = nil;
  166. [self socketOpen];
  167. }
  168. else
  169. {
  170. [self close];
  171. }
  172. }
  173. #pragma mark - SRWebSocketDelegate
  174. - (void)webSocketDidOpen:(SRWebSocket *)webSocket
  175. {
  176. NSLog(@"SOCKET didOpen");
  177. _retryCount = 0;
  178. // Open이 되지 않은 상태에서 전송시도한 메세지들을 발송한다.
  179. for (NSDictionary *data in _messages)
  180. {
  181. [self sendData:data];
  182. [_messages removeObject:data];
  183. }
  184. for (id controller in _delegates) {
  185. if (controller && [controller respondsToSelector:@selector(socketConnectComplete)]) {
  186. [controller socketConnectComplete];
  187. }
  188. }
  189. }
  190. - (void)webSocket:(SRWebSocket *)webSocket didReceiveMessage:(id)message
  191. {
  192. NSLog(@"SOCKET didReceiveMessage : %@", message);
  193. NSString *errString = @"";
  194. if( message == nil || [message isEqualToString:@""] )
  195. errString = @"message empty";
  196. else
  197. {
  198. NSError* error = nil;
  199. NSDictionary *jsonObj = [NSJSONSerialization JSONObjectWithData:[message dataUsingEncoding:NSUTF8StringEncoding]
  200. options:NSJSONReadingAllowFragments
  201. error:&error];
  202. if (error != nil) {
  203. NSLog(@"NSJSONSerialization JSONObject error: %@", [error localizedDescription]);
  204. return;
  205. }
  206. id JSONModel = nil;
  207. JSONModel = [[SocketModel alloc] initWithDictionary:jsonObj error:&error];
  208. for (id controller in _delegates) {
  209. if (controller!=nil && [controller respondsToSelector:@selector(socketDidReceiveMessage:info:)]) {
  210. [controller socketDidReceiveMessage:JSONModel info:jsonObj];
  211. [self removeDelegate:controller];
  212. }
  213. }
  214. // TODO : 전달받은 데이터로 자동으로 처리할 내용이 있으면 이곳에서 처리할것
  215. }
  216. }
  217. - (void)webSocket:(SRWebSocket *)webSocket didFailWithError:(NSError *)error
  218. {
  219. NSLog(@"WebSocket error: %@", error);
  220. _isConnected = NO;
  221. [self reConnect];
  222. }
  223. - (void)webSocket:(SRWebSocket *)webSocket didReceivePong:(NSData *)pongPayload
  224. {
  225. NSLog(@"WebSocket Receive Pong: %@", pongPayload);
  226. }
  227. - (void)webSocket:(SRWebSocket *)webSocket didCloseWithCode:(NSInteger)code reason:(NSString *)reason wasClean:(BOOL)wasClean
  228. {
  229. NSLog(@"WebSocket closed with code: %ld reason:%@ wasClean:%d",
  230. (long)code, reason, wasClean);
  231. _isConnected = NO;
  232. [self reConnect];
  233. }
  234. @end