nasDownloadFileManager.m 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818
  1. //
  2. // nasDownloadFileManager.m
  3. //
  4. //
  5. // Created by David on 2024/8/5.
  6. //
  7. #import "nasDownloadFileManager.h"
  8. @interface nasDownloadFileManager ()
  9. @end
  10. @implementation nasDownloadFileManager
  11. static nasDownloadFileManager * cur_nasDownloadFileManager = nil;
  12. +(nasDownloadFileManager *)shareInstance;
  13. {
  14. static dispatch_once_t onceToken;
  15. dispatch_once(&onceToken, ^{
  16. cur_nasDownloadFileManager = [[nasDownloadFileManager alloc] init];
  17. });
  18. return cur_nasDownloadFileManager;
  19. }
  20. - (id)init
  21. {
  22. self = [super init];
  23. if (self) {
  24. //[self initManager];
  25. [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(downloadTaskFinishedNoti:) name:nasDownloadTaskExeEnd object:nil];
  26. [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(downloadTaskFinishedNoti:) name:nasDownloadTaskExeError object:nil];
  27. [self initDownloadManagerFun];
  28. }
  29. return self;
  30. }
  31. - (void)initDownloadManagerFun
  32. {
  33. [nasDownloadManager shareManager].uid = ksharedAppDelegate.DeviceThirdIdMod.data.sn;
  34. [nasDownloadManager shareManager].maxDownLoadCount = 3;
  35. [self delItemInDoneTaskFun];
  36. }
  37. - (NSMutableArray*)downLoadFileModelDataArr
  38. {
  39. if(_databaseArr && _databaseArr.count >=3){
  40. return _databaseArr[0];
  41. }
  42. return [NSMutableArray new];
  43. }
  44. #pragma mark 删除已经完成和删除文件的任务
  45. - (void)delItemInDoneTaskFun
  46. {
  47. // NSArray *allDownItemArr = [YCDownloadManager downloadList];
  48. //
  49. // for (YCDownloadItem *item in allDownItemArr) {
  50. // if (item.downloadStatus == YCDownloadStatusFinished) {
  51. // NSString *savePath = item.savePath;
  52. //
  53. // if (![[NSFileManager defaultManager] fileExistsAtPath:savePath]){
  54. // [YCDownloadManager stopDownloadWithItem:item];
  55. // }
  56. // }
  57. // }
  58. }
  59. #pragma mark 删除多余的任务 比如数据删除了 但是任务还在
  60. - (void)checkDownloadTaskFun{
  61. }
  62. //添加保存记录
  63. - (void)addNasDownloadRecordFunBy:(NSArray*)arr complete:(custom_complete_Arr)complete{
  64. KWeakSelf
  65. if(arr && arr.count >0 ){
  66. //1.排重处理
  67. [self getDataInDatabaseFun:NO complete:^(NSMutableArray * _Nonnull Arr) {
  68. dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0), ^{
  69. [weakSelf filterDownloadingTaskFunWithNewTaskArr:arr complete:complete];
  70. });
  71. }];
  72. }
  73. }
  74. - (void)filterDownloadingTaskFunWithNewTaskArr:(NSArray*)taskArr complete:(custom_complete_Arr)complete
  75. {
  76. NSMutableArray *addTaskArr = [NSMutableArray new];
  77. NSMutableArray * downloadingArr = [NSMutableArray new];
  78. if(_databaseArr && _databaseArr.count == 3){
  79. //downloadingArr = _databaseArr[0];
  80. downloadingArr = [NSMutableArray arrayWithArray:_databaseArr[0]];
  81. }
  82. for (couldPhoneFileModel*model in taskArr) {
  83. BOOL canAdd = YES;
  84. HLog(@"正在遍历下载数组 看是否有任务重复")
  85. if(downloadingArr.count > 0){
  86. for (couldPhoneFileModel*downloadingModel in downloadingArr) {
  87. if([downloadingModel.fileUrl isEqualToString:model.fileUrl]){
  88. canAdd = NO;
  89. break;
  90. }
  91. }
  92. }
  93. if(canAdd){
  94. model.bg_tableName = nas_box_download_tableName;
  95. [addTaskArr addObject:model];
  96. }
  97. }
  98. HLog(@"遍历下载数组 看是否有任务重复结束")
  99. downloadingArr = nil;
  100. if(addTaskArr.count >0){
  101. KWeakSelf
  102. //[couldPhoneFileModel bg_saveOrUpdateArray:arr];
  103. [couldPhoneFileModel bg_saveOrUpdateArrayAsync:addTaskArr complete:^(BOOL isSuccess) {
  104. //保存完成重新读取数据库 这样下载中的任务才会完整
  105. [weakSelf getDataInDatabaseFun:YES complete:^(NSMutableArray * _Nonnull Arr) {
  106. [weakSelf beginDownloadFilesByUrls:addTaskArr];
  107. complete(weakSelf.databaseArr);
  108. }];
  109. }];
  110. }
  111. else{//任务下载中
  112. complete(_databaseArr);
  113. }
  114. }
  115. #pragma mark 读取数据库数据
  116. - (void)getDataInDatabaseFun:(BOOL)isReGet complete:(custom_complete_Arr)complete
  117. {
  118. if(_databaseArr && _databaseArr.count == 3 && !isReGet){
  119. complete(_databaseArr);
  120. return;
  121. }
  122. if(!_databaseArr)
  123. {
  124. _databaseArr = [NSMutableArray new];
  125. }
  126. //KWeakSelf
  127. dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0), ^{
  128. [couldPhoneFileModel bg_findAsync:nas_box_download_tableName limit:0 orderBy:nil desc:YES complete:^(NSArray * _Nullable array) {
  129. NSMutableArray *failArr = [NSMutableArray new];
  130. NSMutableArray *doneArr = [NSMutableArray new];
  131. NSMutableArray *otherArr = [NSMutableArray new];
  132. if(array && array.count >0){
  133. for (couldPhoneFileModel * curModel in array) {
  134. if(curModel.curDownloadStateType == downloadStateFail){
  135. [failArr addObject:curModel];
  136. }
  137. else if(curModel.curDownloadStateType == downloadStateDone){
  138. [doneArr addObject:curModel];
  139. }
  140. else{
  141. [otherArr addObject:curModel];
  142. }
  143. }
  144. }
  145. @synchronized (self) {
  146. NSMutableArray *newArr = [NSMutableArray new];
  147. [newArr addObject:otherArr];
  148. [newArr addObject:doneArr];
  149. [newArr addObject:failArr];
  150. self->_databaseArr = newArr;
  151. if(isReGet){
  152. [self checkDownloadTaskFun];
  153. }
  154. complete(self->_databaseArr);
  155. }
  156. }];
  157. });
  158. }
  159. - (void)handleDatabaseArrByDelete:(couldPhoneFileModel*)delModel
  160. {
  161. if(_databaseArr && _databaseArr.count == 3 ){
  162. if(delModel.curDownloadStateType == downloadStateDone)
  163. {
  164. NSMutableArray *arr = _databaseArr[1];
  165. [self deteleModel:delModel inArr:arr];
  166. }
  167. else if(delModel.curDownloadStateType == downloadStateFail){
  168. NSMutableArray *arr = _databaseArr[2];
  169. [self deteleModel:delModel inArr:arr];
  170. }
  171. else{
  172. NSMutableArray *arr = _databaseArr[0];
  173. [self deteleModel:delModel inArr:arr];
  174. }
  175. }
  176. }
  177. #pragma mark 处理删除内存数据
  178. - (void)deteleModel:(couldPhoneFileModel*)delModel inArr:(NSMutableArray*)delArr{
  179. HLog(@"%ld -删除某个指定的下载对象 %@",delArr.count, delModel.name)
  180. if (delArr.count > 0) {
  181. [delArr removeObject:delModel];
  182. }
  183. // for (couldPhoneFileModel *dataModel in delArr) {
  184. // if(delModel.bg_id.integerValue == dataModel.bg_id.integerValue){
  185. // HLog(@"正在遍历下载的 数组 并且删除某个数据")
  186. // [delArr removeObject:dataModel];
  187. // break;
  188. // }
  189. // }
  190. }
  191. #pragma mark 删除本地数据库记录
  192. - (void)deleteBoxSaveFileRecordBy:(NSMutableArray *)delArr{
  193. NSMutableArray *curDelArr = [NSMutableArray arrayWithArray:delArr];
  194. for (couldPhoneFileModel *dataModel in curDelArr) {
  195. //1.内存数据删除
  196. [self handleDatabaseArrByDelete:dataModel];
  197. //2.删除数据量
  198. NSMutableString* where = [[NSMutableString alloc] initWithString:@"where "];
  199. NSString *curStr = [NSString stringWithFormat:@"%@=%@ ",bg_sqlKey(@"bg_id"),bg_sqlValue(dataModel.bg_id)];
  200. [where appendString:curStr];
  201. [couldPhoneFileModel bg_deleteAsync:nas_box_download_tableName where:where complete:^(BOOL isSuccess) {
  202. if(isSuccess){
  203. }
  204. }];
  205. if(dataModel.curDownloadStateType == downloadStateWait
  206. || dataModel.curDownloadStateType == downloadStateUploading){
  207. //3.取消下载
  208. NSString *urlString = dataModel.fileUrl;
  209. NSString *requestURLEncodedString = [urlString stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
  210. [[nasDownloadManager shareManager] deleteDownloadWithUrl:requestURLEncodedString];
  211. }
  212. }
  213. }
  214. - (void)deleteDownloadFileRecordBy:(NSMutableArray *)delArr withDelCache:(BOOL)isDelCache
  215. {
  216. [self deleteBoxSaveFileRecordBy:delArr];
  217. [[NSNotificationCenter defaultCenter] postNotificationName:downloadFileRefreshNotification object:nil];
  218. }
  219. #pragma mark 删除本地数据库记录
  220. - (void)deleteDownloadFileRecordBy:(NSMutableArray *)delArr withDelCache:(BOOL)isDelCache withAll:(BOOL)isAllType
  221. {
  222. if(isAllType){
  223. [[nasDownloadManager shareManager] suspendAllDownloadTask];
  224. }
  225. [self deleteDownloadFileRecordBy:delArr withDelCache:isAllType];
  226. }
  227. #pragma mark 更新本地数据库记录
  228. - (void)updataBoxSaveDataInFailBy:(couldPhoneFileModel*)dataModel
  229. {
  230. //1.修改数据库
  231. if(_databaseArr.count == 3){
  232. NSMutableArray *failArr = _databaseArr[2];
  233. NSMutableArray *ingArr = _databaseArr[0];
  234. for (couldPhoneFileModel* model in failArr) {
  235. if (dataModel.bg_id.integerValue == model.bg_id.integerValue) {
  236. HLog(@"正在遍历下载失败数组 并且删除某个数据")
  237. [failArr removeObject:model];
  238. [ingArr addObject:dataModel];
  239. break;
  240. }
  241. }
  242. }
  243. [dataModel bg_saveOrUpdateAsync:^(BOOL isSuccess) {
  244. }];
  245. }
  246. #pragma mark 开始下载文件
  247. - (void)beginDownloadFilesByUrls:(NSArray *)urlArr{
  248. // NSMutableArray*arr = [[SGDownloadManager shareManager] getAllOperation];
  249. // if(arr && arr.count > 0){
  250. // HLog(@"有任务正在下载");
  251. // [[SGDownloadManager shareManager] startAllDownloadTask];
  252. // return;
  253. // }
  254. if(urlArr && urlArr.count > 0){
  255. NSMutableArray *URLEncodedStringArr = [NSMutableArray new];
  256. for (NSInteger i= urlArr.count-1; i>=0; i--) {
  257. couldPhoneFileModel *fileModel = urlArr[i];
  258. NSString *urlString = fileModel.fileUrl;
  259. NSString *requestURLEncodedString = [urlString stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
  260. // [[mixDownloadManager shareManager] downloadWithURL:[NSURL URLWithString:requestURLEncodedString] complete:^(NSDictionary * _Nonnull respose, NSError * _Nonnull error) {
  261. // HLog(@"download:%@",respose);
  262. // }];
  263. [URLEncodedStringArr addObject:requestURLEncodedString];
  264. }
  265. BOOL isCanUseCellular = [HWDataManager getBoolWithKey:stringKeyAddSn(Const_file_Transfe_canUse_Cellular_all)];
  266. if(!isCanUseCellular){//不允许流量上传
  267. //
  268. if([AFNetworkReachabilityManager sharedManager].networkReachabilityStatus == AFNetworkReachabilityStatusReachableViaWWAN){
  269. mainBlock(^{
  270. [[iToast makeText:NSLocalizedString(@"File_Transfer_By_Cellular_tip",nil)] show];
  271. });
  272. [self saveDownloadloadingTaskByNetWorkErrorFun];
  273. return;
  274. }
  275. }
  276. [[nasDownloadManager shareManager] addDownloadWithURLs:URLEncodedStringArr];
  277. }
  278. }
  279. #pragma mark 下载完成
  280. - (void)downloadTaskFinishedNoti:(NSNotification *)notification
  281. {
  282. HLog(@"downloadTaskFinishedNoti")
  283. customDownloadOperation *model = notification.userInfo.allValues.firstObject;
  284. if(!model)return;
  285. //globalBlock(^{
  286. if (model.downloadState == customDownloadStateCompleted) {
  287. //1.先做数据保存
  288. NSDictionary *dataDict = [model downLoadInfoWithFinished:YES];
  289. [self saveFileInfoWithDict:dataDict with:model.url];
  290. [self handldDownloadDoneDataBy:model];
  291. HLog(@"handldDownloadDoneDataBy done")
  292. }
  293. else if (model.downloadState == customDownloadStateFailed){
  294. [self handldDownloadFailDataBy:model];
  295. }
  296. mainBlock(^{
  297. [[NSNotificationCenter defaultCenter] postNotificationName:nasDownloadTaskFinishedNotification object:model];
  298. [[webRtcManager shareManager] NasDownloadTaskFinishedNoti:model];
  299. });
  300. // });
  301. }
  302. #pragma mark 下载完成数据回调处理
  303. - (void)handldDownloadDoneDataBy:(customDownloadOperation*)model
  304. {
  305. //解码
  306. NSString * urlString = [model.url stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
  307. if(_databaseArr && _databaseArr.count == 3 ){
  308. HLog(@"正在遍历下载完成数组 开始 %@",model.fileName)
  309. NSMutableArray *ingArr0 = _databaseArr[0];
  310. NSMutableArray *ingArr = [NSMutableArray arrayWithArray:_databaseArr[0]];
  311. couldPhoneFileModel*curDataModel = nil;
  312. for (couldPhoneFileModel*dataModel in ingArr) {
  313. //HLog(@"22222222 %@\n%@",urlString,dataModel.fileUrl);
  314. if([urlString isEqualToString:dataModel.fileUrl]){
  315. // dataModel.curDownloadStateType = downloadStateDone;
  316. // HLog(@"正在遍历下载完成数组 并且添加 %@",dataModel.name)
  317. // NSMutableArray *doneArr = _databaseArr[1];
  318. // [doneArr insertObject:dataModel atIndex:0];
  319. //
  320. // //更新数据库
  321. // [dataModel bg_saveOrUpdateAsync:^(BOOL isSuccess) {
  322. //
  323. // }];
  324. curDataModel = dataModel;
  325. //[self deteleModel:dataModel inArr:ingArr];
  326. break;
  327. }
  328. }
  329. HLog(@"正在遍历下载完成数组 结束")
  330. if(curDataModel){
  331. curDataModel.curDownloadStateType = downloadStateDone;
  332. HLog(@"正在遍历下载完成数组 并且添加 %@",curDataModel.name)
  333. NSMutableArray *doneArr = _databaseArr[1];
  334. [doneArr insertObject:curDataModel atIndex:0];
  335. HLog(@"开始删除某个指定的下载对象 %@",curDataModel.name)
  336. [ingArr0 removeObject:curDataModel];
  337. HLog(@"完成删除某个指定的下载对象 %@",curDataModel.name)
  338. //更新数据库
  339. // [curDataModel bg_saveOrUpdateAsync:^(BOOL isSuccess) {
  340. // HLog(@"33333")
  341. // }];
  342. [curDataModel bg_saveOrUpdate];
  343. HLog(@"44444")
  344. }
  345. }
  346. }
  347. #pragma mark 下载失败数据回调处理
  348. - (void)handldDownloadFailDataBy:(customDownloadOperation*)model
  349. {
  350. //解码
  351. NSString * urlString = [model.url stringByReplacingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
  352. if(_databaseArr && _databaseArr.count == 3 ){
  353. NSMutableArray *ingArr0 = _databaseArr[0];
  354. NSMutableArray *ingArr = [NSMutableArray arrayWithArray:_databaseArr[0]];
  355. HLog(@"ingArr --%ld",ingArr.count)
  356. for (couldPhoneFileModel*dataModel in ingArr) {
  357. HLog(@"22222222 %@\n%@",urlString,dataModel.fileUrl);
  358. if([urlString isEqualToString:dataModel.fileUrl]){
  359. dataModel.curDownloadStateType = downloadStateFail;
  360. dataModel.failMsg = NSLocalizedString(@"File_download_error_404",nil);
  361. HLog(@"正在遍历下载失败数组 并且删除某个数据")
  362. //失败里面添加
  363. NSMutableArray *failArr = _databaseArr[2];
  364. [failArr insertObject:dataModel atIndex:0];
  365. //更新数据库
  366. [dataModel bg_saveOrUpdateAsync:^(BOOL isSuccess) {
  367. }];
  368. [self deteleModel:dataModel inArr:ingArr0];
  369. break;
  370. }
  371. }
  372. }
  373. }
  374. #pragma mark 全部暂停 或者暂停某一个
  375. - (void)suspendDownloadFileFun:(BOOL)isSuspendAll withModel:(couldPhoneFileModel*)dataModel
  376. {
  377. if(isSuspendAll){//全部暂停
  378. if (_databaseArr && _databaseArr.count == 3) {
  379. NSMutableArray *downloadingArr = _databaseArr[0];
  380. for (couldPhoneFileModel*model in downloadingArr) {
  381. model.curDownloadStateType = downloadStateSuspend;
  382. }
  383. if(downloadingArr.count > 0){
  384. [couldPhoneFileModel bg_saveOrUpdateArrayAsync:downloadingArr complete:^(BOOL isSuccess) {
  385. }];
  386. }
  387. }
  388. [[nasDownloadManager shareManager] suspendAllDownloadTask];
  389. //刷新UI
  390. mainBlock(^{
  391. [[NSNotificationCenter defaultCenter] postNotificationName:nasDownloadTaskFinishedNotification object:nil];
  392. });
  393. }
  394. else if(dataModel){//暂停指定任务
  395. NSString *urlString = dataModel.fileUrl;
  396. NSString *requestURLEncodedString = [urlString stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
  397. HLog(@"%@",urlString);
  398. [[nasDownloadManager shareManager] supendDownloadWithUrl:requestURLEncodedString];
  399. //2.修改状态
  400. if (_databaseArr && _databaseArr.count == 3) {
  401. NSMutableArray *downloadingArr = _databaseArr[0];
  402. for (couldPhoneFileModel*model in downloadingArr) {
  403. if(model.bg_id.integerValue == dataModel.bg_id.integerValue){
  404. model.curDownloadStateType = downloadStateSuspend;
  405. break;
  406. }
  407. }
  408. if(downloadingArr.count > 0){
  409. [couldPhoneFileModel bg_saveOrUpdateArrayAsync:downloadingArr complete:^(BOOL isSuccess) {
  410. }];
  411. }
  412. }
  413. }
  414. }
  415. #pragma mark 重新开始下载
  416. - (void)reDownloadFileFunBy:(NSMutableArray*)arr withAll:(BOOL)isAllType
  417. {
  418. HLog(@"reDownloadFileFunBy --- %ld",arr.count)
  419. KWeakSelf
  420. if(isAllType){
  421. if (_databaseArr && _databaseArr.count == 3) {
  422. NSMutableArray *downloadingArr = _databaseArr[0];
  423. NSMutableArray *ReverseOrderArr = [NSMutableArray new];
  424. for (NSInteger i = downloadingArr.count -1; i>=0; i--) {
  425. couldPhoneFileModel*model = downloadingArr[i];
  426. model.curDownloadStateType = downloadStateUploading;
  427. [ReverseOrderArr addObject:model];
  428. }
  429. //这里处理重新下载
  430. [weakSelf beginDownloadFilesByUrls:ReverseOrderArr];
  431. if(downloadingArr.count > 0){
  432. [couldPhoneFileModel bg_saveOrUpdateArrayAsync:downloadingArr complete:^(BOOL isSuccess) {
  433. }];
  434. }
  435. //刷新UI
  436. mainBlock(^{
  437. [[NSNotificationCenter defaultCenter] postNotificationName:nasDownloadTaskFinishedNotification object:nil];
  438. });
  439. }
  440. }
  441. else
  442. {
  443. NSMutableArray *downloadingArr = arr;
  444. NSMutableArray *ReverseOrderArr = [NSMutableArray new];
  445. for (NSInteger i = downloadingArr.count -1; i>=0; i--) {
  446. couldPhoneFileModel*model = downloadingArr[i];
  447. model.curDownloadStateType = downloadStateUploading;
  448. [ReverseOrderArr addObject:model];
  449. }
  450. //这里处理重新下载
  451. [self beginDownloadFilesByUrls:ReverseOrderArr];
  452. if(downloadingArr.count > 0){
  453. [couldPhoneFileModel bg_saveOrUpdateArrayAsync:downloadingArr complete:^(BOOL isSuccess) {
  454. }];
  455. }
  456. }
  457. // {
  458. //
  459. // couldPhoneFileModel* dataModel = nil;
  460. // if(arr && arr.count > 0){
  461. // dataModel = arr.firstObject;
  462. //
  463. // //修改数据库状态
  464. // dataModel.curDownloadStateType = downloadStateUploading;
  465. // [couldPhoneFileModel bg_saveOrUpdateArrayAsync:@[dataModel] complete:^(BOOL isSuccess) {
  466. //
  467. // }];
  468. // }else{
  469. // return;
  470. // }
  471. // NSString *urlString = dataModel.fileUrl;
  472. // NSString *requestURLEncodedString = [urlString stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
  473. // HLog(@"%@",urlString);
  474. //
  475. // [[nasDownloadManager shareManager] startDownLoadWithUrl:requestURLEncodedString];
  476. //
  477. // }
  478. }
  479. #pragma mark 重新开始下载 第一次进去传输列表是用
  480. - (void)firstReDownloadAllFileFun
  481. {
  482. if (_databaseArr && _databaseArr.count == 3) {
  483. NSMutableArray *downloadingArr = _databaseArr[0];
  484. NSMutableArray *URLEncodedStringArr = [NSMutableArray new];
  485. for (couldPhoneFileModel*model in downloadingArr) {
  486. if(model.curDownloadStateType == downloadStateUploading)
  487. {
  488. NSString *urlString = model.fileUrl;
  489. NSString *requestURLEncodedString = [urlString stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];
  490. [URLEncodedStringArr addObject:requestURLEncodedString];
  491. }
  492. }
  493. if(URLEncodedStringArr.count > 0){
  494. [[nasDownloadManager shareManager] addDownloadWithURLs:URLEncodedStringArr];
  495. }
  496. }
  497. }
  498. #pragma mark 检测是否有任务下载中或者暂停
  499. - (void)checkHadDownloadTaskWithComplete:(custom_complete_B)complete
  500. {
  501. [self getDataInDatabaseFun:NO complete:^(NSMutableArray * _Nonnull Arr) {
  502. mainBlock(^{
  503. if(!Arr || Arr.count != 3){
  504. complete(NO);
  505. }
  506. else{
  507. NSArray *firstArr = Arr[0];
  508. if(firstArr.count >0){
  509. complete(YES);
  510. }
  511. else{
  512. complete(NO);
  513. }
  514. }
  515. });
  516. }];
  517. }
  518. #pragma mark- download done plist Path
  519. - (NSString *)getDownloadDonePlistPath {
  520. NSString *fileFolder = [customDownloadCacheManager getFullDirector];
  521. return [fileFolder stringByAppendingPathComponent:@"nasDownloadDoneInfo.plist"];;
  522. }
  523. #pragma mark- download done plist
  524. - (NSMutableDictionary *)getDownloadDownList {
  525. if (!_downloadDoneList) { // 内存没有
  526. _downloadDoneList = [[NSDictionary dictionaryWithContentsOfFile:[self getDownloadDonePlistPath]] mutableCopy]; // 本地加载
  527. if (!_downloadDoneList) { // 本地没有,分配内存
  528. _downloadDoneList = [NSMutableDictionary dictionary];
  529. }
  530. }
  531. return _downloadDoneList;
  532. }
  533. /** 增加配置信息 */
  534. - (BOOL)saveFileInfoWithDict:(NSDictionary *)dict with:(NSString*)url {
  535. HLog(@"saveFileInfoWithDict")
  536. if(!dict || !url){
  537. return NO;
  538. }
  539. BOOL flag = NO;
  540. @synchronized (self) {
  541. NSString *key = url;
  542. NSMutableDictionary *dictM = [self getDownloadDownList];
  543. [dictM setObject:dict forKey:key];
  544. flag = [dictM writeToFile:[self getDownloadDonePlistPath] atomically:YES];
  545. return flag;
  546. }
  547. }
  548. /** 删除配置信息 */
  549. - (BOOL)deleteFileInfoWithUrl:(NSString *)url {
  550. if(!url){
  551. return NO;
  552. }
  553. BOOL flag = NO;
  554. @synchronized (self) {
  555. NSMutableDictionary *dictM = [self getDownloadDownList];
  556. [dictM removeObjectForKey:url];
  557. flag = [dictM writeToFile:[self getDownloadDonePlistPath] atomically:YES];
  558. }
  559. return flag;
  560. }
  561. #pragma mark-保存完成后 删除此次信息 download done plist
  562. - (void)deleteDownloadDonePlistInfoBy:(NSString*)fullPath
  563. {
  564. HLog(@"deleteDownloadDonePlistInfoBy:%@",fullPath)
  565. NSMutableDictionary *dictM = [self getDownloadDownList];
  566. NSDictionary * forDict = [NSDictionary dictionaryWithDictionary:dictM];
  567. for (NSString*key in forDict) {
  568. NSDictionary*dict = forDict[key];
  569. if ([[dict allKeys] containsObject:@"fullPath"]) {
  570. NSString * infofullPath = dict[@"fullPath"];
  571. if([fullPath isEqualToString:infofullPath]){
  572. [self deleteFileInfoWithUrl:key];
  573. break;
  574. }
  575. }
  576. }
  577. }
  578. #pragma mark-查询还有没有没处理的任务
  579. - (void)checkDownloadDonePlistInfoFun
  580. {
  581. HLog(@"checkDownloadDonePlistInfoFun")
  582. dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0), ^{
  583. NSMutableDictionary *dictM = [[self getDownloadDownList] mutableCopy];
  584. NSMutableArray *needDeletekeyArr = [NSMutableArray array];
  585. if(dictM.count > 0){
  586. for (NSString*key in dictM) {
  587. NSDictionary*dict = dictM[key];
  588. customDownloadOperation *model = [customDownloadOperation mj_objectWithKeyValues:dict];
  589. NSString*curFullPath = [customDownloadCacheManager getFullPathByOldFullPath:model.fullPath];
  590. //判断文件是否还存在
  591. if (![[NSFileManager defaultManager] fileExistsAtPath:curFullPath]) {
  592. //不存在 删除信息
  593. //[self deleteFileInfoWithUrl:key];
  594. [needDeletekeyArr addObject:key];
  595. }
  596. else{//存在 通知保存流程
  597. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.5 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  598. [[webRtcManager shareManager] NasDownloadTaskFinishedNoti:model];
  599. });
  600. break;
  601. }
  602. }
  603. }
  604. if(needDeletekeyArr.count > 0){
  605. for(NSString*key in needDeletekeyArr){
  606. //[self deleteFileInfoWithUrl:key];
  607. [dictM removeObjectForKey:key];
  608. }
  609. //保存更新本地数据
  610. [dictM writeToFile:[self getDownloadDonePlistPath] atomically:YES];
  611. [needDeletekeyArr removeAllObjects];
  612. }
  613. });
  614. }
  615. //网络失败后任务暂时保存
  616. - (void)saveDownloadloadingTaskByNetWorkErrorFun
  617. {
  618. HLog(@"hxd saveDownloadloadingTaskByNetWorkErrorFun")
  619. _netWorkFailSaveArr = [NSMutableArray arrayWithArray:self.downLoadFileModelDataArr];
  620. [[nasDownloadManager shareManager] suspendAllDownloadTask];
  621. if(_netWorkFailSaveArr.count > 0){
  622. _needToReDownloadTaskType = YES;
  623. }
  624. }
  625. //重新上传网络失败的任务
  626. - (void)reDownloadloadFileFunByNetWork
  627. {
  628. _needToReDownloadTaskType = NO;
  629. if(_netWorkFailSaveArr && _netWorkFailSaveArr.count >0){
  630. //重新获取url
  631. for (couldPhoneFileModel *fileModel in _netWorkFailSaveArr) {
  632. fileModel.fileUrl = @"";
  633. }
  634. //判断是否可以下载
  635. BOOL isCanUseCellular = [HWDataManager getBoolWithKey:stringKeyAddSn(Const_file_Transfe_canUse_Cellular_all)];
  636. if(!isCanUseCellular){//不允许流量下载
  637. //
  638. if([AFNetworkReachabilityManager sharedManager].networkReachabilityStatus == AFNetworkReachabilityStatusReachableViaWWAN){
  639. return;
  640. }
  641. }
  642. [self beginDownloadFilesByUrls:_netWorkFailSaveArr];
  643. [_netWorkFailSaveArr removeAllObjects];
  644. }
  645. }
  646. @end