nasBackupsManager.m 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629
  1. //
  2. // nasBackupsManager.m
  3. // Private-X
  4. //
  5. // Created by xd h on 2024/8/29.
  6. //
  7. #import "nasBackupsManager.h"
  8. #import "nasMixBackupsManager.h"
  9. @interface nasBackupsManager ()
  10. /**检测任务10s后 无反馈重新开始 */
  11. @property (nonatomic, assign) NSInteger taskRenewTime; //
  12. @property (nonatomic,strong)photosBackupsTaskModel *lastModel;//最后一次备份的数据
  13. @property (nonatomic, assign) BOOL isGetFileDataFailType;//获取图片失败
  14. @property (nonatomic, assign) NSUInteger getFileDataFailCount;//获取图片失败数量
  15. @end
  16. @implementation nasBackupsManager
  17. + (instancetype)shareInstance {
  18. static nasBackupsManager *_instance;
  19. static dispatch_once_t onceToken;
  20. dispatch_once(&onceToken, ^{
  21. _instance = [[self alloc] init];
  22. });
  23. return _instance;
  24. }
  25. - (void)AutohandlePhotosBackupsFun
  26. {
  27. NSString *curSdnId = ksharedAppDelegate.DeviceThirdIdMod.data.sdnId;
  28. if(!_sdnId || ![curSdnId isEqualToString:_sdnId])
  29. {//没有备份过 或者更换设备了
  30. [self handlePhotosBackupsFun];
  31. }
  32. else{
  33. [self checkReBackupsFileFun];
  34. }
  35. }
  36. - (void)handlePhotosBackupsFun
  37. {
  38. _getFileDataFailCount = 0;
  39. BOOL haveOpenBackups = [HWDataManager getBoolWithKey:stringKeyAddSn(Const_photo_backups_state)];
  40. if(!haveOpenBackups){
  41. return;
  42. }
  43. if(ksharedAppDelegate.DisabledFileTransferType){
  44. return;
  45. }
  46. //相册权限
  47. if (![[TZImageManager manager] authorizationStatusAuthorized]){
  48. [HWDataManager setBoolWithKey:Const_photo_backups_state value:NO];
  49. return;
  50. }
  51. NSString *curSdnId = ksharedAppDelegate.DeviceThirdIdMod.data.sdnId;
  52. _sdnId = curSdnId;
  53. [photosBackupsTaskModel bg_findAsync:backups_photos_tableName limit:0 orderBy:nil desc:YES complete:^(NSArray * _Nullable array) {
  54. if(!array || array.count == 0){
  55. [self getAllAlbumsFun];
  56. return;
  57. }
  58. if(array.count >1){
  59. [self keepDatabaseOneDataFun];
  60. }
  61. self->_lastModel = array.firstObject;
  62. HLog(@"1 bg_id:%@",self->_lastModel.bg_id);
  63. if(self->_lastModel.isBackupsSuspendType == backupsSuspendByUser){
  64. return;
  65. }
  66. if(self->_lastModel.curBackupsState == backupsStateFail
  67. ||self->_lastModel.curBackupsState == backupsStateDone){//上次备份完成
  68. [self getAllAlbumsFun];
  69. }
  70. else{//继续上次的备份任务
  71. [self handelBackupsModelFun:self->_lastModel];
  72. }
  73. }];
  74. }
  75. - (void)keepDatabaseOneDataFun
  76. {
  77. [photosBackupsTaskModel bg_deleteFirstObject:backups_photos_tableName];
  78. }
  79. //备份开始查询相册
  80. - (void)getAllAlbumsFun
  81. {
  82. //
  83. KWeakSelf
  84. [[TZImageManager manager] getAllAlbums:YES allowPickingImage:YES needFetchAssets:NO completion:^(NSArray<TZAlbumModel *> *models) {
  85. if(models.count >= 1){
  86. TZAlbumModel *curAlbumModel= models.firstObject;
  87. photosBackupsTaskModel * taskModel = [photosBackupsTaskModel new];
  88. //taskModel.count = curAlbumModel.count;
  89. //taskModel.result = curAlbumModel.result;
  90. taskModel.failCount = 0;
  91. taskModel.didBackupsCount = 0;
  92. taskModel.bg_tableName = backups_photos_tableName;
  93. //备份路径
  94. NSString * backupsDefaultPath = [HWDataManager getStringWithKey:stringKeyAddSn(Const_photo_backups_default_path)];
  95. if(!backupsDefaultPath || backupsDefaultPath.length == 0){
  96. backupsDefaultPath = Const_default_backups_path;
  97. [HWDataManager setStringWithKey:stringKeyAddSn(Const_photo_backups_default_path) value:backupsDefaultPath];
  98. }
  99. NSString *lastStr= [backupsDefaultPath substringFromIndex:backupsDefaultPath.length-1];
  100. if(![lastStr isEqualToString:@"/"]){
  101. backupsDefaultPath = [[NSString alloc] initWithFormat:@"%@/",backupsDefaultPath];
  102. }
  103. taskModel.backupsPath = backupsDefaultPath;
  104. NSMutableString *allLocalIdentifier= [NSMutableString new];
  105. for (PHAsset *asset in curAlbumModel.result) {
  106. if (asset.localIdentifier) {
  107. if(allLocalIdentifier.length >0){
  108. [allLocalIdentifier appendString:@"&"];
  109. }
  110. [allLocalIdentifier appendString:asset.localIdentifier];
  111. }
  112. }
  113. taskModel.totalLocalIdentifier = allLocalIdentifier;
  114. if(self->_lastModel
  115. && self->_lastModel.totalLocalIdentifier
  116. && (self->_lastModel.backupsPath && [self->_lastModel.backupsPath isEqualToString:taskModel.backupsPath])){//相册备份排重
  117. taskModel.PreDidBackupsCount = self->_lastModel.PreDidBackupsCount + self->_lastModel.didBackupsCount;
  118. taskModel.curTaskLocalIdentifier = [weakSelf AlbumBackupsHandleNew:taskModel];
  119. }
  120. else{
  121. taskModel.curTaskLocalIdentifier = allLocalIdentifier;
  122. }
  123. if(taskModel.curTaskLocalIdentifier.length == 0){
  124. taskModel.count = 0;
  125. }
  126. else{
  127. taskModel.count = [taskModel.curTaskLocalIdentifier componentsSeparatedByString:@"&"].count;
  128. }
  129. HLog(@"2 bg_id:%@",taskModel.bg_id);
  130. [taskModel bg_saveAsync:^(BOOL isSuccess) {
  131. if(!isSuccess){
  132. HLog(@"\n\nError!!!\n\n");
  133. }
  134. else{
  135. //[self handelBackupsModelFun:taskModel];
  136. [self handlePhotosBackupsFun];
  137. }
  138. }];
  139. }
  140. }];
  141. }
  142. - (NSString*)AlbumBackupsHandleNew:(photosBackupsTaskModel * )taskModel
  143. {
  144. NSArray* curLocalIdentifierArr = [taskModel.totalLocalIdentifier componentsSeparatedByString:@"&"];
  145. NSArray* preLocalIdentifierArr = [_lastModel.totalLocalIdentifier componentsSeparatedByString:@"&"];
  146. //处理异常 (上次没有备份完成)
  147. NSInteger totalBackupNum = _lastModel.PreDidBackupsCount + _lastModel.didBackupsCount + _lastModel.failCount;
  148. if(totalBackupNum < preLocalIdentifierArr.count){//preLocalIdentifierArr 改为已经备份过的
  149. preLocalIdentifierArr = [preLocalIdentifierArr subarrayWithRange:NSMakeRange(0,totalBackupNum)];
  150. }
  151. NSMutableArray *allArr = [NSMutableArray arrayWithArray:curLocalIdentifierArr];
  152. for (NSString*localIdentifier in preLocalIdentifierArr) {
  153. for (NSString* newlocalIdentifier in allArr) {
  154. if([localIdentifier isEqualToString:newlocalIdentifier]){
  155. [allArr removeObject:newlocalIdentifier];
  156. break;
  157. }
  158. }
  159. }
  160. NSMutableString *allLocalIdentifier= [NSMutableString new];
  161. for (NSString* newlocalIdentifier in allArr) {
  162. if(allLocalIdentifier.length >0){
  163. [allLocalIdentifier appendString:@"&"];
  164. }
  165. [allLocalIdentifier appendString:newlocalIdentifier];
  166. }
  167. //把上传失败的再次加上处理
  168. if (_lastModel.failTaskLocalIdentifier) {
  169. [allLocalIdentifier appendString:@"&"];
  170. [allLocalIdentifier appendString:_lastModel.failTaskLocalIdentifier];
  171. //清空
  172. _lastModel.failTaskLocalIdentifier = @"";
  173. }
  174. return allLocalIdentifier;
  175. }
  176. - (void)handelBackupsModelFun:(photosBackupsTaskModel*)backupsTaskModel
  177. {
  178. _curPhotosBackupsTaskMod = backupsTaskModel;
  179. _curPhotosBackupsTaskMod.isBackupsSuspendType = backupsSuspendNone;
  180. _curPhotosBackupsTaskMod.curBackupsState = backupsStateUploading;
  181. _curPhotosBackupsTaskMod.LocalIdentifierArr = [backupsTaskModel.curTaskLocalIdentifier componentsSeparatedByString:@"&"];
  182. if(_curPhotosBackupsTaskMod.LocalIdentifierArr.count == 0 ||_curPhotosBackupsTaskMod.curTaskLocalIdentifier.length == 0){
  183. _curPhotosBackupsTaskMod.didBackupsCount = 0;
  184. _curPhotosBackupsTaskMod.curBackupsState = backupsStateDone;
  185. [self RefreshDatabaseFun];
  186. [self changeBackupsFileStateFun];
  187. return;
  188. }
  189. if(_curPhotosBackupsTaskMod.LocalIdentifierArr.count
  190. <= (_curPhotosBackupsTaskMod.didBackupsCount + _curPhotosBackupsTaskMod.failCount))
  191. {
  192. _curPhotosBackupsTaskMod.curBackupsState = backupsStateDone;
  193. [self RefreshDatabaseFun];
  194. [self changeBackupsFileStateFun];
  195. return;
  196. }
  197. [self beginBackupsFileFun];
  198. }
  199. - (void)beginBackupsFileFun
  200. {
  201. BOOL isCanUseCellular = [HWDataManager getBoolWithKey:stringKeyAddSn(Const_file_Transfe_canUse_Cellular_all)];
  202. if(!isCanUseCellular){//不允许流量上传
  203. //
  204. if([AFNetworkReachabilityManager sharedManager].networkReachabilityStatus == AFNetworkReachabilityStatusReachableViaWWAN){
  205. _isWifiNeedReBackupsType = YES;
  206. return;
  207. }
  208. }
  209. _isWifiNeedReBackupsType = NO;
  210. _isWWANNeedReBackupsType = NO;
  211. self.taskRenewTime = [iTools getNowTimeStamp];
  212. NSInteger index = _curPhotosBackupsTaskMod.didBackupsCount + _curPhotosBackupsTaskMod.failCount;
  213. if(!_curPhotosBackupsTaskMod.LocalIdentifierArr){
  214. _curPhotosBackupsTaskMod.LocalIdentifierArr = [_curPhotosBackupsTaskMod.curTaskLocalIdentifier componentsSeparatedByString:@"&"];
  215. }
  216. if(index >= _curPhotosBackupsTaskMod.LocalIdentifierArr.count){
  217. _curPhotosBackupsTaskMod.curBackupsState = backupsStateDone;
  218. [self RefreshDatabaseFun];
  219. [self changeBackupsFileStateFun];
  220. _curPhotosBackupsTaskMod = nil;
  221. return;
  222. }
  223. NSString *curLocalIdentifier = _curPhotosBackupsTaskMod.LocalIdentifierArr[index];
  224. _curPhotosBackupsTaskMod.curFileLocalIdentifier = curLocalIdentifier;
  225. if(!curLocalIdentifier || curLocalIdentifier.length == 0)
  226. {
  227. [self getDataWrongToChangeFailFun];
  228. return;
  229. }
  230. _curPhotosBackupsTaskMod.didUploadBytes = 0;
  231. _curPhotosBackupsTaskMod.preDidUploadBytes = 0;
  232. _curPhotosBackupsTaskMod.totalBytes = 0;
  233. HLog(@"curLocalIdentifier:%@---%ld",curLocalIdentifier,_curPhotosBackupsTaskMod.failCount)
  234. //单次备份文件图片失败过多
  235. if(_getFileDataFailCount >500){
  236. _curPhotosBackupsTaskMod.failTaskLocalIdentifier = @"";
  237. NSString *tipStr = NSLocalizedString(@"backups_get_file_error_too_many",nil);
  238. [self changeBackupsFileStateToFailWith:tipStr];
  239. return;
  240. }
  241. PHFetchResult *fetchResult = [PHAsset fetchAssetsWithLocalIdentifiers:@[curLocalIdentifier] options:nil];
  242. PHAsset *curAsset = fetchResult.firstObject;
  243. NSString *fileName = [curAsset valueForKey:@"filename"];;
  244. if(!fileName || !curAsset){
  245. _isGetFileDataFailType = YES;
  246. [self getDataWrongToChangeFailFun];
  247. return;
  248. }
  249. _curPhotosBackupsTaskMod.filename = fileName;
  250. KWeakSelf
  251. if(curAsset.mediaType == PHAssetMediaTypeImage){
  252. _curPhotosBackupsTaskMod.curUploadFileType = uploadFileTypeImage;
  253. PHImageRequestOptions *options = [[PHImageRequestOptions alloc] init];
  254. options.networkAccessAllowed = YES; // Allow downloading from iCloud
  255. options.version = PHImageRequestOptionsVersionCurrent;
  256. options.deliveryMode = PHImageRequestOptionsDeliveryModeHighQualityFormat;
  257. [[PHImageManager defaultManager] requestImageDataForAsset:curAsset options:options resultHandler:^(NSData * _Nullable imageData, NSString * _Nullable dataUTI, UIImageOrientation orientation, NSDictionary * _Nullable info) {
  258. // 直接得到最终的 NSData 数据
  259. if (imageData) {
  260. weakSelf.isGetFileDataFailType = NO;
  261. [weakSelf afterGetImageDataFun:imageData];
  262. }
  263. else{
  264. weakSelf.isGetFileDataFailType = YES;
  265. [weakSelf getDataWrongToChangeFailFun];
  266. }
  267. }];
  268. }
  269. else{
  270. _curPhotosBackupsTaskMod.curUploadFileType = uploadFileTypeVideo;
  271. //判断文件是否在app内
  272. BOOL didSaveFile = [cachesFileManager checkFileIsSaveState:_curPhotosBackupsTaskMod.filename withType:uploadFileTypeVideo];
  273. if(didSaveFile){
  274. [self afterGetVideoDataFun];
  275. return;
  276. }
  277. //真正的视频数据
  278. PHVideoRequestOptions *options = [[PHVideoRequestOptions alloc] init];
  279. options.version = PHVideoRequestOptionsVersionOriginal;
  280. options.networkAccessAllowed = YES; // Allow downloading from iCloud
  281. [[PHImageManager defaultManager] requestAVAssetForVideo:curAsset options:options resultHandler:^(AVAsset *asset, AVAudioMix *audioMix, NSDictionary *info) {
  282. if ([asset isKindOfClass:[AVURLAsset class]]) {
  283. AVURLAsset* urlAsset = (AVURLAsset*)asset;
  284. BOOL isSuc = [cachesFileManager copyVideoItemAtPath:[urlAsset.URL path] fileName:self->_curPhotosBackupsTaskMod.filename error:nil];
  285. if (isSuc) {
  286. weakSelf.isGetFileDataFailType = NO;
  287. [weakSelf afterGetVideoDataFun];
  288. }
  289. else{
  290. weakSelf.isGetFileDataFailType = YES;
  291. [weakSelf getDataWrongToChangeFailFun];
  292. }
  293. }
  294. else{
  295. weakSelf.isGetFileDataFailType = YES;
  296. [weakSelf getDataWrongToChangeFailFun];
  297. }
  298. }];
  299. }
  300. }
  301. - (void)getDataWrongToChangeFailFun
  302. {
  303. [self deleteVideoFun];
  304. _curPhotosBackupsTaskMod.failCount += 1;
  305. if(_isGetFileDataFailType){
  306. _getFileDataFailCount += 1;
  307. }
  308. [self RefreshDatabaseFun];
  309. if(_curPhotosBackupsTaskMod.curBackupsState == backupsStateSuspend){
  310. return;
  311. }
  312. [self beginBackupsFileFun];
  313. }
  314. #pragma mark 备份失败 待添加重试逻辑
  315. - (void)changeBackupsFileStateToFailWith:(NSString*)errorStr
  316. {
  317. [self deleteVideoFun];
  318. _curPhotosBackupsTaskMod.curBackupsState = backupsStateFail;
  319. _curPhotosBackupsTaskMod.backupsTipMsg = errorStr;
  320. [self RefreshDatabaseFun];
  321. [self changeBackupsFileStateFun];
  322. }
  323. #pragma mark 1.4.2的失败处理
  324. - (void)changeBackupsFileStateToFailWithAfter142:(NSString*)errorStr
  325. {
  326. if(_curPhotosBackupsTaskMod.oneFileFailCount <= 3){
  327. _curPhotosBackupsTaskMod.oneFileFailCount ++;
  328. [[nasMixBackupsManager shareManager] cancelUploadAllTaskFun];
  329. //重新开始
  330. [self beginBackupsFileFun];
  331. }
  332. else{
  333. NSString * failTaskLocalIdentifier = nil;
  334. if(_curPhotosBackupsTaskMod.failTaskLocalIdentifier && _curPhotosBackupsTaskMod.failTaskLocalIdentifier.length > 0){
  335. failTaskLocalIdentifier = [[NSString alloc] initWithFormat:@"%@&%@",_curPhotosBackupsTaskMod.failTaskLocalIdentifier,_curPhotosBackupsTaskMod.curFileLocalIdentifier];
  336. }
  337. else{
  338. failTaskLocalIdentifier = [[NSString alloc] initWithFormat:@"%@",_curPhotosBackupsTaskMod.curFileLocalIdentifier];
  339. }
  340. _curPhotosBackupsTaskMod.oneFileFailCount = 0;
  341. [self getDataWrongToChangeFailFun];
  342. }
  343. }
  344. - (void)RefreshDatabaseFun
  345. {
  346. HLog(@"3 bg_id:%@",_curPhotosBackupsTaskMod.bg_id);
  347. [_curPhotosBackupsTaskMod bg_saveOrUpdateAsync:^(BOOL isSuccess) {
  348. if(isSuccess){
  349. }
  350. }];
  351. }
  352. - (void)afterGetImageDataFun:(NSData*)imageData
  353. {
  354. _curPhotosBackupsTaskMod.imageData = imageData;
  355. _curPhotosBackupsTaskMod.didUploadBytes = 0;
  356. _curPhotosBackupsTaskMod.totalBytes = [imageData length];
  357. //[[webSocketManager shareInstance] beginGotoBackupsFileFunBy:_curPhotosBackupsTaskMod];
  358. [self RefreshDatabaseFun];
  359. [self changeBackupsFileStateFun];
  360. [self realbBeginUploadwithFrpFun];
  361. }
  362. - (void)deleteVideoFun
  363. {
  364. if(_curPhotosBackupsTaskMod.curUploadFileType == uploadFileTypeVideo){
  365. [cachesFileManager removeItemAtPath:_curPhotosBackupsTaskMod.filename type:uploadFileTypeVideo error:nil];
  366. }
  367. }
  368. - (void)afterGetVideoDataFun
  369. {
  370. NSString *filePath = [cachesFileManager getFilePathWithName:_curPhotosBackupsTaskMod.filename type:uploadFileTypeVideo]; // 文件路径
  371. NSFileManager *manager0 = [NSFileManager defaultManager];
  372. if([manager0 fileExistsAtPath:filePath]) {
  373. NSFileHandle *fileHandle = [NSFileHandle fileHandleForReadingAtPath:filePath]; // 创建文件句柄
  374. if (fileHandle) {
  375. long long endOfFile = [fileHandle seekToEndOfFile];
  376. _curPhotosBackupsTaskMod.didUploadBytes = 0;
  377. _curPhotosBackupsTaskMod.totalBytes = endOfFile;
  378. [fileHandle closeFile];
  379. }
  380. }
  381. //[[webSocketManager shareInstance] beginGotoBackupsFileFunBy:_curPhotosBackupsTaskMod];
  382. [self RefreshDatabaseFun];
  383. [self changeBackupsFileStateFun];
  384. [self realbBeginUploadwithFrpFun];
  385. }
  386. #pragma mark 转frp上传
  387. - (void)realbBeginUploadwithFrpFun{
  388. uploadFileDataModel *fileModel = [uploadFileDataModel new];
  389. fileModel.curUploadFileType = _curPhotosBackupsTaskMod.curUploadFileType;
  390. fileModel.filename = _curPhotosBackupsTaskMod.filename;
  391. fileModel.totalBytes = _curPhotosBackupsTaskMod.totalBytes;
  392. fileModel.didUploadBytes = 0;
  393. fileModel.preDidUploadBytes = 0;
  394. fileModel.localIdentifier = _curPhotosBackupsTaskMod.curTaskLocalIdentifier;
  395. fileModel.curUploadStateType = uploadStateUploading;
  396. fileModel.savePath = _curPhotosBackupsTaskMod.backupsPath;
  397. //fileModel.taskId
  398. //@property (nonatomic, retain) NSData *_Nullable imageData;//image or video
  399. if(_curPhotosBackupsTaskMod.curUploadFileType == uploadFileTypeImage){
  400. fileModel.imageData = _curPhotosBackupsTaskMod.imageData;
  401. }
  402. [[nasMixBackupsManager shareManager] addBackupsWithModels:@[fileModel]];
  403. }
  404. - (void)backupsFileDoneFun
  405. {
  406. [self deleteVideoFun];
  407. _curPhotosBackupsTaskMod.didBackupsCount += 1;
  408. _curPhotosBackupsTaskMod.oneFileFailCount = 0;
  409. // if(!_curPhotosBackupsTaskMod.didBackupsOneFileType)
  410. // {
  411. // _curPhotosBackupsTaskMod.curTaskBackupsCount += 1;
  412. // }
  413. [self RefreshDatabaseFun];
  414. [self changeBackupsFileStateFun];
  415. if(_curPhotosBackupsTaskMod.curBackupsState == backupsStateSuspend){
  416. return;
  417. }
  418. //延时 进度条视觉效果
  419. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  420. [self beginBackupsFileFun];
  421. });
  422. }
  423. //修改文件上传的状态
  424. - (void)changeBackupsFileStateFun
  425. {
  426. self.taskRenewTime = [iTools getNowTimeStamp];
  427. [[NSNotificationCenter defaultCenter] postNotificationName:backupsFileRefreshNotification object:_curPhotosBackupsTaskMod];
  428. }
  429. - (void)suspendBackupsFileFun
  430. {
  431. if(!_curPhotosBackupsTaskMod){
  432. return;
  433. }
  434. _curPhotosBackupsTaskMod.curBackupsState = backupsStateSuspend;
  435. _curPhotosBackupsTaskMod.backupsTipMsg = NSLocalizedString(@"File_backups_Record_tip_Suspend",nil);
  436. [[nasMixBackupsManager shareManager] cancelUploadAllTaskFun];
  437. [_curPhotosBackupsTaskMod bg_saveOrUpdateAsync:^(BOOL isSuccess) {
  438. if(isSuccess){
  439. [self changeBackupsFileStateFun];
  440. }
  441. }];
  442. }
  443. //文件重新备份
  444. - (void)reBackupsFileFunBy:(photosBackupsTaskModel*)model
  445. {
  446. model.isBackupsSuspendType = backupsSuspendNone;
  447. model.curBackupsState = backupsStateUploading;
  448. _curPhotosBackupsTaskMod = model;
  449. [self RefreshDatabaseFun];
  450. [self changeBackupsFileStateFun];
  451. [self beginBackupsFileFun];
  452. // [_curPhotosBackupsTaskMod bg_saveOrUpdateAsync:^(BOOL isSuccess) {
  453. // if(isSuccess){
  454. // [self beginBackupsFileFun];
  455. // }
  456. // }];
  457. }
  458. //文件重新备份
  459. - (void)reBackupsFileFun
  460. {
  461. [self handlePhotosBackupsFun];
  462. //if(_curPhotosBackupsTaskMod.curBackupsState != backupsStateUploading)
  463. if(self->_lastModel.curBackupsState != backupsStateUploading){
  464. if(self->_lastModel.curBackupsState == backupsStateFail
  465. ||self->_lastModel.curBackupsState == backupsStateDone){//上次备份完成
  466. [self getAllAlbumsFun];
  467. }
  468. else{//继续上次的备份任务
  469. [self handelBackupsModelFun:self->_lastModel];
  470. }
  471. }
  472. }
  473. //检查是否需要重新备份
  474. - (void)checkReBackupsFileFun
  475. {
  476. if(!_curPhotosBackupsTaskMod){
  477. return;
  478. }
  479. if(_curPhotosBackupsTaskMod.curBackupsState != backupsStateUploading){
  480. return;
  481. }
  482. NSInteger curTime = [iTools getNowTimeStamp];
  483. if(self.taskRenewTime == 0){
  484. return;
  485. }
  486. if(curTime - self.taskRenewTime < 10){
  487. return;
  488. }
  489. [self beginBackupsFileFun];
  490. }
  491. //检查是否在备份中
  492. - (BOOL)checkBackupsingFun{
  493. if(!_curPhotosBackupsTaskMod){
  494. return NO;
  495. }
  496. if(_curPhotosBackupsTaskMod.curBackupsState == backupsStateSuspend){
  497. return NO;
  498. }
  499. return YES;
  500. }
  501. @end