ApiFileService.cs 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651
  1. using Aip.Service.Aip.Exceptions;
  2. using Aip.Service.Aip.Models;
  3. using Aip.Service.Aip.Serivces;
  4. using Aip.Service.Models.App;
  5. using Aip.Service.Models.Request;
  6. using Aip.Service.Models.Response;
  7. using Aip.Service.Services.Interfaces;
  8. using Aip.Service.Utils;
  9. using Microsoft.InformationProtection;
  10. using Newtonsoft.Json;
  11. using Serilog;
  12. using System.Diagnostics;
  13. using System.Text;
  14. using static System.Net.WebRequestMethods;
  15. namespace Aip.Service.Services;
  16. public class ApiFileService : BaseService, IApiFileService
  17. {
  18. private readonly ILogger<ApiFileService> _log;
  19. protected readonly AipFileService _aipFileService;
  20. private HttpClient _httpClient;
  21. public ApiFileService(ILogger<ApiFileService> log, IApiConfigService aipConfigService, AipFileService aipFileService)
  22. :base(aipConfigService)
  23. {
  24. _log = log;
  25. _aipFileService = aipFileService;
  26. _httpClient = new HttpClient(new HttpClientHandler
  27. {
  28. MaxConnectionsPerServer = int.MaxValue
  29. });
  30. _httpClient.BaseAddress = new Uri("http://localhost:5050");
  31. _httpClient.DefaultRequestHeaders.ConnectionClose = false;
  32. _httpClient.Timeout = TimeSpan.FromSeconds(20);
  33. }
  34. public async Task<ResponseInfo> GetInfo(RequestFileInfo req)
  35. {
  36. string reqFileName = _aipConfigService.GetRequestFileName(req.file.realFileName);
  37. if (!FileUtils.IsExists(reqFileName))
  38. {
  39. return new ResponseInfo
  40. {
  41. errorCode = 101,
  42. errorMessage = "파일이 존재하지 않습니다.",
  43. };
  44. }
  45. string? newFileExt = _aipConfigService.GetSupportedFileType(reqFileName);
  46. if (newFileExt == null)
  47. {
  48. return new ResponseInfo
  49. {
  50. errorCode = 102,
  51. errorMessage = "지원하지 않는 파일형식 입니다.",
  52. };
  53. }
  54. var task = Task.Run(() =>
  55. {
  56. return ResponseGetFileInfo(_aipFileService.GetFileInfo(reqFileName), req.file.dispFileName);
  57. });
  58. ResponseInfo result = await task;
  59. return result;
  60. }
  61. public async Task<ResponseFile> SetLabel(RequestFileSet req)
  62. {
  63. try
  64. {
  65. CheckAip check = CheckAipRequest(req.apiGuid, req.file.dispFileName, req.file.realFileName, false);
  66. if (check.errorCode != 0)
  67. {
  68. return new ResponseFile
  69. {
  70. errorCode = check.errorCode,
  71. errorMessage = check.errorMessage,
  72. dispFileName = check.dispFileName,
  73. realFileName = req.file.realFileName,
  74. actualFileName = check.actualFileName,
  75. };
  76. }
  77. var task = Task.Run(() =>
  78. {
  79. Stopwatch sw = new Stopwatch();
  80. sw.Start();
  81. _log.LogInformation("SetLabel: [{0}], AipFileService............Start: {1}", Task.CurrentId, req.file.dispFileName);
  82. SetFileInfo fileInfo = _aipFileService.SetLabel(check.reqFileName, check.actualFileName, req.email, req.aipGuid, "", req.comment);
  83. sw.Stop();
  84. _log.LogInformation("SetLabel: [{0}], AipFileService..............End: {1,6} ms. actualFileName: {2}", Task.CurrentId, sw.ElapsedMilliseconds.ToString("#,##0"), req.file.dispFileName);
  85. return ResponseSetFile(fileInfo, req.file.dispFileName, req.file.realFileName, Path.GetFileName(fileInfo.newFileName));
  86. });
  87. ResponseFile result = await task;
  88. result.endDateTime = DateTime.Now;
  89. return result;
  90. }
  91. catch (AipFileException ex)
  92. {
  93. return ResponseFileException(ex, req.file.dispFileName);
  94. }
  95. catch (Exception e)
  96. {
  97. return ResponseFileException(e, req.file.dispFileName);
  98. }
  99. }
  100. public async Task<List<SetFileInfo>> SetAipFileLabels(RequestMultiFileSet reqSet)
  101. {
  102. var startTotal = Stopwatch.GetTimestamp();
  103. Log.Error("SetAipFileLabels Tatal {0} EA. Start.", reqSet.files.Count);
  104. List<SetFileInfo> result = new List<SetFileInfo>();
  105. var tasks = new List<Task<SetFileInfo>>();
  106. foreach (RequestFile req in reqSet.files)
  107. {
  108. CheckAip check = CheckAipRequest(reqSet.apiGuid, req.dispFileName, req.realFileName, false);
  109. if (check.errorCode != 0)
  110. {
  111. continue;
  112. }
  113. tasks.Add(Task.Run(() =>
  114. {
  115. //Thread.Sleep(100);
  116. SetFileInfo fileInfo = _aipFileService.SetLabel(check.reqFileName, check.actualFileName, reqSet.email, reqSet.aipGuid, "", reqSet.comment);
  117. return fileInfo;
  118. }));
  119. }
  120. await Task.WhenAll(tasks);
  121. foreach (var task in tasks)
  122. {
  123. result.Add(task.Result);
  124. }
  125. Log.Error("====================== SetAipFileLabels Tatal {0} EA. ..Stop. {1} ms.", reqSet.files.Count, TimeUtils.GetElapsedMilliseconds(startTotal));
  126. return result;
  127. }
  128. public async Task<List<ResponseFile>> SetLabels(RequestMultiFileSet reqSet)
  129. {
  130. List<ResponseFile> result = new List<ResponseFile>();
  131. //var tasks = new List<Task<ResponseFile>>();
  132. try
  133. {
  134. var startTotal = Stopwatch.GetTimestamp();
  135. int taskBatchSize = 40;
  136. for (int ii = 0; ii < reqSet.files.Count; ii += taskBatchSize)
  137. {
  138. var start = Stopwatch.GetTimestamp();
  139. _log.LogInformation("{0} 작업 시작", ii);
  140. var batchFiles = reqSet.files.Skip(ii).Take(taskBatchSize).ToList();
  141. var batchTasks = batchFiles.Select(req => Task.Run(() =>
  142. {
  143. CheckAip check = CheckAipRequest(reqSet.apiGuid, req.dispFileName, req.realFileName, false);
  144. if (check.errorCode != 0)
  145. {
  146. return new ResponseFile
  147. {
  148. errorCode = check.errorCode,
  149. errorMessage = check.errorMessage,
  150. dispFileName = check.dispFileName,
  151. realFileName = req.realFileName,
  152. actualFileName = check.actualFileName,
  153. };
  154. }
  155. Thread.Sleep(100);
  156. SetFileInfo fileInfo = _aipFileService.SetLabel(check.reqFileName, check.actualFileName, reqSet.email, reqSet.aipGuid, "", reqSet.comment);
  157. return ResponseSetFile(fileInfo, req.dispFileName, req.realFileName, Path.GetFileName(fileInfo.newFileName));
  158. }));
  159. await Task.WhenAll(batchTasks);
  160. result.AddRange(await Task.WhenAll(batchTasks)); // 병렬로 결과를 가져오도록 수정
  161. _log.LogInformation("{0} 작업 완료. {1} ms.", ii, TimeUtils.GetElapsedMilliseconds(start));
  162. //result.AddRange(batchTasks.Select(t => t.Result));
  163. }
  164. _log.LogInformation("{0} EA. 작업 완료. {1} ms.", reqSet.files.Count, TimeUtils.GetElapsedMilliseconds(startTotal));
  165. }
  166. catch (AipFileException ex)
  167. {
  168. var exceptionResult = ResponseFileException(ex, reqSet.apiKey);
  169. result.Add(exceptionResult);
  170. }
  171. catch (Exception e)
  172. {
  173. var exceptionResult = ResponseFileException(e, reqSet.apiKey);
  174. result.Add(exceptionResult);
  175. }
  176. return result;
  177. }
  178. public async Task<List<ResponseFile>> SetLabels1(RequestMultiFileSet reqSet)
  179. {
  180. List<ResponseFile> result = new List<ResponseFile>();
  181. var tasks = new List<Task<ResponseFile>>();
  182. try
  183. {
  184. //Label label = _aipFileService.GetLabelById(reqSet.apiGuid);
  185. //if (label == null)
  186. //{
  187. // throw new AipFileException(101, "Label 정보를 찾을 수 없습니다.");
  188. //}
  189. foreach (RequestFile req in reqSet.files)
  190. {
  191. CheckAip check = CheckAipRequest(reqSet.apiGuid, req.dispFileName, req.realFileName, false);
  192. if (check.errorCode != 0)
  193. {
  194. result.Add(new ResponseFile
  195. {
  196. errorCode = check.errorCode,
  197. errorMessage = check.errorMessage,
  198. dispFileName = check.dispFileName,
  199. realFileName = req.realFileName,
  200. actualFileName = check.actualFileName,
  201. });
  202. continue;
  203. }
  204. tasks.Add(Task.Run(() =>
  205. {
  206. Thread.Sleep(100);
  207. SetFileInfo fileInfo = _aipFileService.SetLabel(check.reqFileName, check.actualFileName, reqSet.email, reqSet.aipGuid, "", reqSet.comment);
  208. return ResponseSetFile(fileInfo, req.dispFileName, req.realFileName, Path.GetFileName(fileInfo.newFileName));
  209. }));
  210. }
  211. await Task.WhenAll(tasks);
  212. foreach (var task in tasks)
  213. {
  214. result.Add(task.Result);
  215. }
  216. }
  217. catch (AipFileException ex)
  218. {
  219. var exceptionResult = ResponseFileException(ex, reqSet.apiKey);
  220. result.Add(exceptionResult);
  221. }
  222. catch (Exception e)
  223. {
  224. var exceptionResult = ResponseFileException(e, reqSet.apiKey);
  225. result.Add(exceptionResult);
  226. }
  227. return result;
  228. }
  229. public async Task<List<ResponseFile>> SetLabels2(RequestMultiFileSet reqSet)
  230. {
  231. List<ResponseFile> result = new List<ResponseFile>();
  232. var tasks = new List<Task<ResponseFile>>();
  233. try
  234. {
  235. //Label label = _aipFileService.GetLabelById(reqSet.apiGuid);
  236. //if (label == null)
  237. //{
  238. // throw new AipFileException(101, "Label 정보를 찾을 수 없습니다.");
  239. //}
  240. foreach (RequestFile req in reqSet.files)
  241. {
  242. CheckAip check = CheckAipRequest(reqSet.apiGuid, req.dispFileName, req.realFileName, false);
  243. if (check.errorCode != 0)
  244. {
  245. result.Add(new ResponseFile
  246. {
  247. errorCode = check.errorCode,
  248. errorMessage = check.errorMessage,
  249. dispFileName = check.dispFileName,
  250. realFileName = req.realFileName,
  251. actualFileName = check.actualFileName,
  252. });
  253. continue;
  254. }
  255. tasks.Add(Task.Run(() =>
  256. {
  257. Thread.Sleep(100);
  258. SetFileInfo fileInfo = _aipFileService.SetLabel(check.reqFileName, check.actualFileName, reqSet.email, reqSet.aipGuid, "", reqSet.comment);
  259. return ResponseSetFile(fileInfo, req.dispFileName, req.realFileName, Path.GetFileName(fileInfo.newFileName));
  260. }));
  261. }
  262. await Task.WhenAll(tasks);
  263. foreach (var task in tasks)
  264. {
  265. result.Add(task.Result);
  266. }
  267. }
  268. catch (AipFileException ex)
  269. {
  270. var exceptionResult = ResponseFileException(ex, reqSet.apiKey);
  271. result.Add(exceptionResult);
  272. }
  273. catch (Exception e)
  274. {
  275. var exceptionResult = ResponseFileException(e, reqSet.apiKey);
  276. result.Add(exceptionResult);
  277. }
  278. return result;
  279. }
  280. public async Task<List<ResponseFile>> SetLabels3(RequestMultiFileSet reqSet)
  281. {
  282. List<ResponseFile> result = new List<ResponseFile>();
  283. try
  284. {
  285. _log.LogInformation("{0} EA. 작업 시작.", reqSet.files.Count);
  286. var startTotal = Stopwatch.GetTimestamp();
  287. int ii = 0;
  288. foreach (RequestFile req in reqSet.files)
  289. {
  290. var start = Stopwatch.GetTimestamp();
  291. //_log.LogInformation("{0} 작업 시작, {1}", ii, req.dispFileName);
  292. CheckAip check = CheckAipRequest(reqSet.apiGuid, req.dispFileName, req.realFileName, false);
  293. if (check.errorCode != 0)
  294. {
  295. result.Add(new ResponseFile
  296. {
  297. errorCode = check.errorCode,
  298. errorMessage = check.errorMessage,
  299. dispFileName = check.dispFileName,
  300. realFileName = req.realFileName,
  301. actualFileName = check.actualFileName,
  302. });
  303. _log.LogError("{0} 작업 오류, {1}", ii, req.dispFileName);
  304. continue;
  305. }
  306. SetFileInfo fileInfo = _aipFileService.SetLabel(check.reqFileName, check.actualFileName, reqSet.email, reqSet.aipGuid, "", reqSet.comment);
  307. result.Add(ResponseSetFile(fileInfo, req.dispFileName, req.realFileName, Path.GetFileName(fileInfo.newFileName)));
  308. _log.LogInformation("{0} 작업 완료. {1},, {2} ms.", ii++, req.dispFileName, TimeUtils.GetElapsedMilliseconds(start));
  309. }
  310. _log.LogInformation("{0} EA. 작업 완료. {1} ms.", reqSet.files.Count, TimeUtils.GetElapsedMilliseconds(startTotal));
  311. }
  312. catch (AipFileException ex)
  313. {
  314. var exceptionResult = ResponseFileException(ex, reqSet.apiKey);
  315. result.Add(exceptionResult);
  316. }
  317. catch (Exception e)
  318. {
  319. var exceptionResult = ResponseFileException(e, reqSet.apiKey);
  320. result.Add(exceptionResult);
  321. }
  322. return result;
  323. }
  324. public async Task<List<ResponseFile>> SetLabels4(RequestMultiFileSet reqSet)
  325. {
  326. int Port = 7000;
  327. int seq = 0;
  328. List<ResponseFile> result = new List<ResponseFile>();
  329. try
  330. {
  331. _log.LogInformation("{0} EA. 작업 시작.", reqSet.files.Count);
  332. var startTotal = Stopwatch.GetTimestamp();
  333. var tasks = new List<Task<ResponseFile>>();
  334. foreach (RequestFile req in reqSet.files)
  335. {
  336. RequestFileSet reqFileSet = new RequestFileSet
  337. {
  338. apiKey = reqSet.apiKey,
  339. email = reqSet.email,
  340. aipGuid = reqSet.aipGuid,
  341. comment = reqSet.comment,
  342. file = new RequestFile
  343. {
  344. dispFileName = req.dispFileName,
  345. realFileName = req.realFileName,
  346. }
  347. };
  348. var json = JsonConvert.SerializeObject(reqFileSet);
  349. var content = new StringContent(json, Encoding.UTF8, "application/json");
  350. //string reqUri = $"http://localhost:{Port + seq++}/api/v1/file/set-label";
  351. string reqUri = $"/api/v1/file/set-label";
  352. if (seq >= 31) seq = 0;
  353. tasks.Add(Task.Run(() =>
  354. {
  355. ApiResponseModel<ResponseFile> fileInfo = SendRequestsAsync( reqUri, reqFileSet).Result;
  356. return fileInfo.result!;
  357. }));
  358. }
  359. await Task.WhenAll(tasks);
  360. foreach (var task in tasks)
  361. {
  362. result.Add(task.Result);
  363. }
  364. _log.LogInformation("{0} EA. 작업 완료. {1} ms.", reqSet.files.Count, TimeUtils.GetElapsedMilliseconds(startTotal));
  365. }
  366. catch (AipFileException ex)
  367. {
  368. var exceptionResult = ResponseFileException(ex, reqSet.apiKey);
  369. result.Add(exceptionResult);
  370. }
  371. catch (Exception e)
  372. {
  373. var exceptionResult = ResponseFileException(e, reqSet.apiKey);
  374. result.Add(exceptionResult);
  375. }
  376. return result;
  377. }
  378. private async Task<ApiResponseModel<ResponseFile>> SendRequestsAsync(string reqUri, RequestFileSet reqFileSet)
  379. {
  380. var content = new StringContent(JsonConvert.SerializeObject(reqFileSet), Encoding.UTF8, "application/json");
  381. try
  382. {
  383. var response = await _httpClient.PostAsync(reqUri, content);//.ConfigureAwait(false);
  384. if (response.IsSuccessStatusCode)
  385. {
  386. Log.Information($"Request successful for: {reqFileSet.file.dispFileName}");
  387. }
  388. else
  389. {
  390. Log.Error($"Request failed for: {reqFileSet.file.dispFileName}. Status code: {response.StatusCode}");
  391. }
  392. #pragma warning disable CS8603 // 가능한 null 참조 반환입니다.
  393. return JsonConvert.DeserializeObject<ApiResponseModel<ResponseFile>>(await response.Content.ReadAsStringAsync());
  394. #pragma warning restore CS8603 // 가능한 null 참조 반환입니다.
  395. }
  396. finally
  397. {
  398. content?.Dispose();
  399. }
  400. }
  401. public async Task<ResponseFile> DelLabel(RequestFileDel req)
  402. {
  403. try
  404. {
  405. CheckAip check = CheckAipRequest(req.apiGuid, req.file.dispFileName, req.file.realFileName, false);
  406. if (check.errorCode != 0)
  407. {
  408. return new ResponseFile
  409. {
  410. errorCode = check.errorCode,
  411. errorMessage = check.errorMessage,
  412. dispFileName = check.dispFileName,
  413. };
  414. }
  415. var task = Task.Run(() =>
  416. {
  417. SetFileInfo fileInfo = _aipFileService.DeleteLabel(check.reqFileName, check.actualFileName, req.email, req.comment, false);
  418. return ResponseSetFile(fileInfo, req.file.dispFileName, req.file.realFileName, Path.GetFileName(fileInfo.newFileName));
  419. });
  420. ResponseFile result = await task;
  421. return result;
  422. }
  423. catch (Exception e)
  424. {
  425. return ResponseFileException(e, req.file.dispFileName);
  426. }
  427. }
  428. public async Task<ResponseFile> SetProtection(RequestFileSet req)
  429. {
  430. try
  431. {
  432. CheckAip check = CheckAipRequest(req.apiGuid, req.file.dispFileName, req.file.realFileName, false);
  433. if (check.errorCode != 0)
  434. {
  435. return new ResponseFile
  436. {
  437. errorCode = check.errorCode,
  438. errorMessage = check.errorMessage,
  439. dispFileName = check.dispFileName,
  440. };
  441. }
  442. var task = Task.Run(() =>
  443. {
  444. SetFileInfo fileInfo = _aipFileService.SetProtection(check.reqFileName, check.actualFileName, req.email, req.aipGuid, req.comment);
  445. return ResponseSetFile(fileInfo, req.file.dispFileName, req.file.realFileName, Path.GetFileName(fileInfo.newFileName));
  446. });
  447. ResponseFile result = await task;
  448. return result;
  449. }
  450. catch (Exception e)
  451. {
  452. return ResponseFileException(e, req.file.dispFileName);
  453. }
  454. }
  455. public async Task<ResponseFile> RemoveProtection(RequestFileDel req)
  456. {
  457. try
  458. {
  459. CheckAip check = CheckAipRequest(req.apiGuid, req.file.dispFileName, req.file.realFileName, false);
  460. if (check.errorCode != 0)
  461. {
  462. return new ResponseFile
  463. {
  464. errorCode = check.errorCode,
  465. errorMessage = check.errorMessage,
  466. dispFileName = check.dispFileName,
  467. };
  468. }
  469. var task = Task.Run(() =>
  470. {
  471. SetFileInfo fileInfo = _aipFileService.RemoveProtection(check.reqFileName, check.actualFileName, req.email, req.comment);
  472. return ResponseSetFile(fileInfo, req.file.dispFileName, req.file.realFileName, Path.GetFileName(fileInfo.newFileName));
  473. });
  474. ResponseFile result = await task;
  475. return result;
  476. }
  477. catch (Exception e)
  478. {
  479. return ResponseFileException(e, req.file.dispFileName);
  480. }
  481. }
  482. public async Task<ResponseFile> SetLabelProtection(RequestFileAllSet req)
  483. {
  484. try
  485. {
  486. CheckAip check = CheckAipRequest(req.apiGuid, req.file.dispFileName, req.file.realFileName, false);
  487. if (check.errorCode != 0)
  488. {
  489. return new ResponseFile
  490. {
  491. errorCode = check.errorCode,
  492. errorMessage = check.errorMessage,
  493. dispFileName = check.dispFileName,
  494. };
  495. }
  496. var task = Task.Run(() =>
  497. {
  498. SetFileInfo fileInfo = _aipFileService.SetLabel(check.reqFileName, check.actualFileName, req.email, req.aipGuid, req.templateGuid, req.comment);
  499. return ResponseSetFile(fileInfo, req.file.dispFileName, req.file.realFileName, Path.GetFileName(fileInfo.newFileName));
  500. });
  501. ResponseFile result = await task;
  502. return result;
  503. }
  504. catch (Exception e)
  505. {
  506. return ResponseFileException(e, req.file.dispFileName);
  507. }
  508. }
  509. public async Task<ResponseFile> RemoveLabelProtection(RequestFileDel req)
  510. {
  511. try
  512. {
  513. CheckAip check = CheckAipRequest(req.apiGuid, req.file.dispFileName, req.file.realFileName, false);
  514. if (check.errorCode != 0)
  515. {
  516. return new ResponseFile
  517. {
  518. errorCode = check.errorCode,
  519. errorMessage = check.errorMessage,
  520. dispFileName = check.dispFileName,
  521. };
  522. }
  523. var task = Task.Run(() =>
  524. {
  525. SetFileInfo fileInfo = _aipFileService.DeleteLabel(check.reqFileName, check.actualFileName, req.email, req.comment, true);
  526. return ResponseSetFile(fileInfo, req.file.dispFileName, req.file.realFileName, Path.GetFileName(fileInfo.newFileName));
  527. });
  528. ResponseFile result = await task;
  529. return result;
  530. }
  531. catch (Exception e)
  532. {
  533. return ResponseFileException(e, req.file.dispFileName);
  534. }
  535. }
  536. public async Task<ResponseFile> EncryptFile(IFormFile file, RequestBase baseReq)
  537. {
  538. CheckMultipartFile check = ValidateMultipartFile(file, baseReq.apiGuid);
  539. try
  540. {
  541. if (check.errorCode != 0)
  542. {
  543. return new ResponseFile
  544. {
  545. errorCode = check.errorCode,
  546. errorMessage = check.errorMessage,
  547. dispFileName = check.dispFileName,
  548. };
  549. }
  550. RequestFileSet req = new RequestFileSet
  551. {
  552. apiKey = baseReq.apiKey,
  553. email = baseReq.email,
  554. apiGuid = baseReq.apiGuid,
  555. decryptKey = string.Empty,
  556. file = new RequestFile
  557. {
  558. dispFileName = check.dispFileName,
  559. realFileName = check.saveFileName,
  560. },
  561. aipGuid = _aipConfigService.aipSetting.SetLabelId,
  562. comment = "EncryptFile"
  563. };
  564. ResponseFile result = await SetLabel(req);
  565. return result;
  566. }
  567. catch (Exception e)
  568. {
  569. return ResponseFileException(e, file.FileName);
  570. }
  571. finally
  572. {
  573. FileUtils.DeleteFile(_aipConfigService.GetRequestFileName(check.saveFileName));
  574. }
  575. }
  576. public async Task<ResponseFile> DecryptFile(IFormFile file, RequestBase baseReq)
  577. {
  578. CheckMultipartFile check = ValidateMultipartFile(file, baseReq.apiGuid);
  579. try
  580. {
  581. if (check.errorCode != 0)
  582. {
  583. return new ResponseFile
  584. {
  585. errorCode = check.errorCode,
  586. errorMessage = check.errorMessage,
  587. dispFileName = check.dispFileName,
  588. };
  589. }
  590. RequestFileDel req = new RequestFileDel
  591. {
  592. apiKey = baseReq.apiKey,
  593. email = baseReq.email,
  594. apiGuid = baseReq.apiGuid,
  595. decryptKey = string.Empty,
  596. file = new RequestFile
  597. {
  598. dispFileName = check.dispFileName,
  599. realFileName = check.saveFileName,
  600. },
  601. comment = "DecryptFile"
  602. };
  603. ResponseFile result = await DelLabel(req);
  604. return result;
  605. }
  606. catch (Exception e)
  607. {
  608. return ResponseFileException(e, file.FileName);
  609. }
  610. finally
  611. {
  612. FileUtils.DeleteFile(_aipConfigService.GetRequestFileName(check.saveFileName));
  613. }
  614. }
  615. }