SocketServiceHandler.m 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354
  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. #define MAX_REQUEST_ID 255
  14. #define NONE_DELEGATE_REQUEST_ID -99
  15. @interface SocketServiceHandler() <SRWebSocketDelegate>
  16. {
  17. SRWebSocket *_socket;
  18. NSMutableArray<SocketRequestModel *> *_messages;
  19. // NSMutableArray *_delegates;
  20. int _retryCount;
  21. }
  22. @property NSMutableDictionary* controllers;
  23. @property NSMutableDictionary* responses;
  24. @property int controllerId;
  25. @end
  26. @implementation SocketServiceHandler
  27. + (id)sharedManager
  28. {
  29. static SocketServiceHandler *sharedSocketServiceHandler = nil;
  30. static dispatch_once_t onceToken;
  31. dispatch_once(&onceToken, ^{
  32. sharedSocketServiceHandler = [[self alloc] init];
  33. });
  34. return sharedSocketServiceHandler;
  35. }
  36. - (id) init
  37. {
  38. self = [super init];
  39. if (self) {
  40. _isConnected = NO;
  41. _messages = [[NSMutableArray alloc] init];
  42. // _delegates = [[NSMutableArray alloc] init];
  43. _controllers = [[NSMutableDictionary alloc] init];
  44. _responses = [[NSMutableDictionary alloc] init];
  45. self.controllerId = 0;
  46. [self socketOpen];
  47. }
  48. return self;
  49. }
  50. //- (void) initDelegate:(id<SocketServiceDelegate>) delegate
  51. //{
  52. // [self setDelegate:delegate];
  53. //}
  54. - (SRReadyState) getSocketStatus
  55. {
  56. return _socket.readyState;
  57. }
  58. - (void) socketOpen
  59. {
  60. NSLog(@"socketOpen");
  61. _strSocketURL = [NSString stringWithFormat:@"%@%@", kSocketServer, API_ROOT_PATH];
  62. NSLog(@"socketURL : %@", _strSocketURL);
  63. if( _socket != nil )
  64. {
  65. [_socket open];
  66. }
  67. else
  68. {
  69. NSMutableURLRequest *request = [[NSMutableURLRequest alloc] initWithURL:[NSURL URLWithString:_strSocketURL]];
  70. if([[JDFacade facade].loginUser authorization]!=nil)
  71. {
  72. [request setValue:[[JDFacade facade].loginUser authorization] forHTTPHeaderField:API_AUTHORIZATION_KEY];
  73. }
  74. NSString *language = [[NSLocale preferredLanguages] objectAtIndex:0];
  75. #ifdef DEBUG_MODE
  76. language = @"ko";
  77. #endif
  78. [request setValue:language forHTTPHeaderField:API_LANGUAGE_KEY];
  79. NSLog(@"All Header Info : %@", request.allHTTPHeaderFields);
  80. _socket = [[SRWebSocket alloc] initWithURLRequest:request];
  81. _socket.delegate = self;
  82. [_socket open];
  83. }
  84. }
  85. - (void) open
  86. {
  87. if( !_isConnected )
  88. {
  89. if( _socket.readyState == SR_OPEN )
  90. {
  91. _isConnected = YES;
  92. }
  93. else if ( _socket.readyState == SR_CLOSED || _socket.readyState == SR_CLOSING )
  94. {
  95. [self close];
  96. _socket = nil;
  97. [self socketOpen];
  98. }
  99. }
  100. }
  101. - (void) close
  102. {
  103. if( _isConnected )
  104. {
  105. [_socket close];
  106. _socket = nil;
  107. }
  108. else
  109. {
  110. if (_socket != nil)
  111. {
  112. _socket = nil;
  113. }
  114. }
  115. _isConnected = NO;
  116. }
  117. - (void) sendData:(SocketRequestModel *)data
  118. {
  119. if(_socket.readyState == SR_OPEN)
  120. {
  121. NSLog(@"Socket Ready Send Data");
  122. NSLog(@"Send Data : %@", data);
  123. NSLog(@"Send Param : %@", data.getSendMessage);
  124. [_socket send:data.getSendMessage];
  125. }
  126. else if ( _socket.readyState == SR_CLOSED || _socket.readyState == SR_CLOSING )
  127. {
  128. NSLog(@"Socket State is NOT Ready, Retry Process");
  129. [_messages addObject:data];
  130. [self reConnect];
  131. }
  132. else
  133. {
  134. NSLog(@"Socket NOT Ready, Retry Process");
  135. [_messages addObject:data];
  136. if(!_isConnected)
  137. {
  138. [self socketOpen];
  139. }
  140. }
  141. }
  142. - (void) sendDataWihOutDelegate:(SocketRequestModel *)data
  143. {
  144. [self sendDataWithDelegate:data modelClass:nil delegate:nil];
  145. }
  146. - (void) sendDataWithDelegate:(SocketRequestModel *)data delegate:(id)delegate
  147. {
  148. [self sendDataWithDelegate:data modelClass:nil delegate:delegate];
  149. }
  150. - (void) sendDataWithDelegate:(SocketRequestModel *)data modelClass:(Class)modelClass delegate:(id)delegate
  151. {
  152. short controllerId = NONE_DELEGATE_REQUEST_ID;
  153. if (delegate) {
  154. controllerId = self.controllerId++;
  155. if (self.controllerId >= INT16_MAX) {
  156. self.controllerId = 0;
  157. }
  158. }
  159. data.requestId = [NSString stringWithFormat:@"%d", controllerId];
  160. NSLog(@"Request ID : %@", data.requestId);
  161. if (delegate) {
  162. [_controllers setObject:delegate forKey:[NSNumber numberWithInt:controllerId]];
  163. }
  164. if (modelClass) {
  165. [_responses setObject:modelClass forKey:[NSNumber numberWithInt:controllerId]];
  166. }
  167. [self sendData:data];
  168. }
  169. - (void)removeDelegate:(id)delegate {
  170. // [_delegates removeObject:delegate];
  171. }
  172. -(void) reConnect
  173. {
  174. if(_retryCount < MAX_RETRY_CONNECT_COUNT)
  175. {
  176. _retryCount++;
  177. [self close];
  178. _socket = nil;
  179. [self socketOpen];
  180. }
  181. else
  182. {
  183. [self close];
  184. }
  185. }
  186. #pragma mark - SRWebSocketDelegate
  187. - (void)webSocketDidOpen:(SRWebSocket *)webSocket
  188. {
  189. NSLog(@"SOCKET didOpen");
  190. _retryCount = 0;
  191. // Open이 되지 않은 상태에서 전송시도한 메세지들을 발송한다.
  192. for (SocketRequestModel *data in _messages)
  193. {
  194. [self sendData:data];
  195. [_messages removeObject:data];
  196. }
  197. // for (id controller in _delegates) {
  198. // if (controller && [controller respondsToSelector:@selector(socketConnectComplete)]) {
  199. // [controller socketConnectComplete];
  200. // }
  201. // }
  202. }
  203. - (void)webSocket:(SRWebSocket *)webSocket didReceiveMessage:(id)message
  204. {
  205. NSLog(@"SOCKET didReceiveMessage : %@", message);
  206. NSString *errString = @"";
  207. if( message == nil || [message isEqualToString:@""] )
  208. errString = @"message empty";
  209. else
  210. {
  211. id JSONModel = nil;
  212. NSError *error = nil;
  213. NSString *JSONString = [NSString stringWithUTF8Data:[message dataUsingEncoding:NSUTF8StringEncoding]];
  214. // NSDictionary *jsonObj = [NSJSONSerialization JSONObjectWithData:[message dataUsingEncoding:NSUTF8StringEncoding]
  215. // options:NSJSONReadingAllowFragments
  216. // error:&error];
  217. //
  218. NSLog(@"Json String : %@", JSONString);
  219. if (error != nil) {
  220. NSLog(@"NSJSONSerialization JSONObject error: %@", [error localizedDescription]);
  221. return;
  222. }
  223. SocketModel *response = [[SocketModel alloc] initWithString:JSONString error:&error];
  224. NSNumber* controllerId = [NSNumber numberWithInteger:[response.requestId integerValue]];
  225. id controller = [self.controllers objectForKey:controllerId];
  226. Class modelClass = [self.responses objectForKey:controllerId];
  227. id rawJSON = [NSJSONSerialization JSONObjectWithData:[message dataUsingEncoding:NSUTF8StringEncoding]
  228. options:NSJSONReadingAllowFragments
  229. error:&error];
  230. if (modelClass) {
  231. if ([rawJSON isKindOfClass:[NSArray class]]) {
  232. NSDictionary *JSONDic = @{@"list": rawJSON};
  233. JSONModel = [[modelClass alloc] initWithDictionary:JSONDic error:&error];
  234. }
  235. else {
  236. JSONModel = [[modelClass alloc] initWithString:JSONString error:&error];
  237. }
  238. } else {
  239. JSONModel = rawJSON;
  240. }
  241. if (!controller) {
  242. if (self.controllers.count > 1) {
  243. NSArray* array = self.controllers.allKeys;
  244. NSArray* sortedArray = [array sortedArrayUsingSelector:@selector(compare:)];
  245. for (NSNumber *key in sortedArray) {
  246. id controller = [self.controllers objectForKey:key];
  247. if ([controller respondsToSelector:@selector(socketDidReceiveMessage:result:)]) {
  248. [controller socketDidReceiveMessage:JSONModel result:response];
  249. }
  250. }
  251. }
  252. }
  253. else {
  254. if ([controller respondsToSelector:@selector(socketDidReceiveMessage:result:)]) {
  255. [controller socketDidReceiveMessage:JSONModel result:response];
  256. }
  257. if (self.controllers.count > 1) {
  258. NSArray* array = self.controllers.allKeys;
  259. NSArray* sortedArray = [array sortedArrayUsingSelector:@selector(compare:)];
  260. [self.controllers removeObjectForKey:[sortedArray objectAtIndex:0]];
  261. }
  262. }
  263. // TODO : 전달받은 데이터로 자동으로 처리할 내용이 있으면 이곳에서 처리할것
  264. }
  265. }
  266. - (void)webSocket:(SRWebSocket *)webSocket didFailWithError:(NSError *)error
  267. {
  268. NSLog(@"WebSocket error: %@", error);
  269. _isConnected = NO;
  270. [self reConnect];
  271. }
  272. - (void)webSocket:(SRWebSocket *)webSocket didReceivePong:(NSData *)pongPayload
  273. {
  274. NSLog(@"WebSocket Receive Pong: %@", pongPayload);
  275. }
  276. - (void)webSocket:(SRWebSocket *)webSocket didCloseWithCode:(NSInteger)code reason:(NSString *)reason wasClean:(BOOL)wasClean
  277. {
  278. NSLog(@"WebSocket closed with code: %ld reason:%@ wasClean:%d",
  279. (long)code, reason, wasClean);
  280. _isConnected = NO;
  281. [self reConnect];
  282. }
  283. @end