RASingleton.m 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265
  1. //
  2. // RASingleton.m
  3. // Apex And Drivers
  4. //
  5. // Created by Jack on 2018/6/6.
  6. // Copyright © 2018年 USAI. All rights reserved.
  7. //
  8. #import "RASingleton.h"
  9. static RASingleton *singleton;
  10. @interface RASingleton ()
  11. @property (nonatomic,strong) NSMutableString *log;
  12. @end
  13. @implementation RASingleton {
  14. NSString *_secretKey;
  15. }
  16. @synthesize backgroundReportType = _backgroundReportType;
  17. + (instancetype)sharedInstance {
  18. static dispatch_once_t tocken;
  19. dispatch_once(&tocken, ^{
  20. singleton = [[RASingleton alloc] init];
  21. singleton->_secretKey = @"usai";
  22. singleton->_savePassword = [[[NSUserDefaults standardUserDefaults] objectForKey:@"savePassword"] boolValue];
  23. });
  24. return singleton;
  25. }
  26. - (void)setSavePassword:(BOOL)savePassword {
  27. _savePassword = savePassword;
  28. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  29. [defaults setObject:@(_savePassword) forKey:@"savePassword"];
  30. }
  31. #pragma mark - User
  32. - (NSString *)secretKey {
  33. return _secretKey;
  34. }
  35. - (NSString *)encryptUser {
  36. if (!self.user) {
  37. return nil;
  38. }
  39. return [self encryptString:self.user];
  40. }
  41. - (NSString *)encryptPassword {
  42. if (!self.password) {
  43. return nil;
  44. }
  45. return [self encryptString:self.password];
  46. }
  47. - (void)saveUserInfo {
  48. if (self.user && self.password) {
  49. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  50. [defaults removeObjectForKey:@"user"];
  51. [defaults removeObjectForKey:@"password"];
  52. [defaults removeObjectForKey:@"firstName"];
  53. [defaults setValue:self.encryptUser forKey:@"user"];
  54. [defaults setValue:self.encryptPassword forKey:@"password"];
  55. [defaults setObject:self.firstName forKey:@"firstName"];
  56. [defaults setBool:TRUE forKey:@"autologin"];
  57. [defaults synchronize];
  58. }
  59. }
  60. - (NSString *)savedUser {
  61. NSString * user = [self decryptString:[[NSUserDefaults standardUserDefaults] stringForKey:@"user"]];
  62. return user;
  63. }
  64. - (NSString *)savedPassword {
  65. NSString * password = [self decryptString:[[NSUserDefaults standardUserDefaults] stringForKey:@"password"]];
  66. return password;
  67. }
  68. - (NSString *)savedFirstName {
  69. return [[NSUserDefaults standardUserDefaults] stringForKey:@"firstName"];
  70. }
  71. - (void)loginUser:(NSString *)user password:(NSString *)password firstName:(NSString *)firstName {
  72. _user = user;
  73. _password = password;
  74. _firstName = firstName;
  75. [self saveUserInfo];
  76. [self bindUserWithNotificationToken];
  77. [self setShouldAutoLogin:YES];
  78. }
  79. - (BOOL)autoLogin {
  80. _user = [self savedUser];
  81. _password = [self savedPassword];
  82. _firstName = [self savedFirstName];
  83. if ([self shouldAutoLogin]) {
  84. return _user.length && _password.length;
  85. }
  86. return NO;
  87. }
  88. - (void)setNotificationToken:(NSString *)notificationToken {
  89. _notificationToken = notificationToken;
  90. [self bindUserWithNotificationToken];
  91. }
  92. - (void)bindUserWithNotificationToken {
  93. if (_user.length && _password.length && _notificationToken.length) {
  94. dispatch_async(dispatch_get_global_queue(0, 0), ^{
  95. [RADataProvider bindNitificationToken:self.notificationToken];
  96. });
  97. }
  98. }
  99. - (void)logout {
  100. _user = nil;
  101. _password = nil;
  102. _firstName = nil;
  103. if (!self.savePassword) {
  104. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  105. [defaults removeObjectForKey:@"user"];
  106. [defaults removeObjectForKey:@"password"];
  107. [defaults removeObjectForKey:@"firstName"];
  108. [defaults synchronize];
  109. }
  110. [self setShouldAutoLogin:NO];
  111. }
  112. - (void)changePassword:(NSString *)password {
  113. _password = password;
  114. [self saveUserInfo];
  115. }
  116. - (BOOL)shouldAutoLogin {
  117. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  118. return [defaults boolForKey:@"autoLogin"];
  119. }
  120. - (void)setShouldAutoLogin:(BOOL)login {
  121. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  122. [defaults setBool:login forKey:@"autoLogin"];
  123. [defaults synchronize];
  124. }
  125. #pragma mark - Location
  126. - (void)setRequiredLocation:(BOOL)requiredLocation {
  127. _requiredLocation = requiredLocation;
  128. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  129. [defaults setBool:_requiredLocation forKey:@"requiredLocation"];
  130. [defaults synchronize];
  131. [self sendRequiredLocationNotification];
  132. }
  133. - (void)loadSavedReuqiredLocation { // 启动的时候
  134. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  135. _requiredLocation = [[defaults objectForKey:@"requiredLocation"] boolValue];
  136. [self sendRequiredLocationNotification];
  137. }
  138. - (void)sendRequiredLocationNotification {
  139. if (_requiredLocation) {
  140. [[NSNotificationCenter defaultCenter] postNotificationName:RANotificationStartLocation object:nil];
  141. } else {
  142. [[NSNotificationCenter defaultCenter] postNotificationName:RANotificationStopLocation object:nil];
  143. }
  144. }
  145. #pragma mark - Utils
  146. - (NSString *)encryptString:(NSString *)str {
  147. if (str == nil) {
  148. return nil;
  149. }
  150. return [AESCrypt encrypt:str password:self.secretKey];
  151. }
  152. - (NSString *)decryptString:(NSString *)str {
  153. if (str == nil) {
  154. return nil;
  155. }
  156. return [AESCrypt decrypt:str password:self.secretKey];
  157. }
  158. #pragma mark - NetworkQueue
  159. - (NSOperationQueue *)networkQueue {
  160. if (!_networkQueue) {
  161. _networkQueue = [[NSOperationQueue alloc] init];
  162. _networkQueue.maxConcurrentOperationCount = 5;
  163. _networkQueue.qualityOfService = NSQualityOfServiceUtility;
  164. }
  165. return _networkQueue;
  166. }
  167. #pragma mark - Backgroud Report Location Permission
  168. - (void)setBackgroundReportType:(RABackgroundReportType)backgroundReportType {
  169. _backgroundReportType = backgroundReportType;
  170. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  171. [defaults setInteger:_backgroundReportType forKey:@"backgroundReportLocationPermissionType"];
  172. [defaults synchronize];
  173. }
  174. - (RABackgroundReportType)backgroundReportType {
  175. if (_backgroundReportType == 0) {
  176. NSUserDefaults *defaults =[NSUserDefaults standardUserDefaults];
  177. _backgroundReportType = (RABackgroundReportType)[defaults integerForKey:@"backgroundReportLocationPermissionType"];
  178. }
  179. return _backgroundReportType;
  180. }
  181. #pragma mark - Log
  182. - (NSMutableString *)log {
  183. if (!_log) {
  184. _log = [NSMutableString string];
  185. }
  186. return _log;
  187. }
  188. - (void)writeLog:(NSString *)log {
  189. if (log.length) {
  190. [self.log appendFormat:@"\n%@",log];
  191. }
  192. }
  193. - (void)saveLogs {
  194. if (self.log.length > 0) {
  195. NSString *cacheDir = [NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) lastObject];
  196. NSString *logPath = [cacheDir stringByAppendingPathComponent:@"log"];
  197. [self.log writeToFile:logPath atomically:NO encoding:NSUTF8StringEncoding error:nil];
  198. }
  199. }
  200. @end