瀏覽代碼

修改删除文件的代码

chenyu 2 年之前
父節點
當前提交
73389e35c2
共有 1 個文件被更改,包括 76 次插入49 次删除
  1. 76 49
      RMS/src/main/java/cn/cslg/report/service/business/LitigationHistoryService.java

+ 76 - 49
RMS/src/main/java/cn/cslg/report/service/business/LitigationHistoryService.java

@@ -2,10 +2,14 @@ package cn.cslg.report.service.business;
 
 
 import cn.cslg.report.common.utils.Response;
+import cn.cslg.report.common.utils.SystemFileToReportFile;
 import cn.cslg.report.entity.*;
 import cn.cslg.report.entity.asso.AssoLitigationHisFile;
 
 import cn.cslg.report.mapper.LitigationHistoryMapper;
+import cn.cslg.report.service.file.FileManagerService;
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson2.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -17,6 +21,7 @@ import org.springframework.stereotype.Service;
 import org.springframework.web.multipart.MultipartFile;
 
 
+import java.io.IOException;
 import java.util.ArrayList;
 import java.util.List;
 import java.util.stream.Collectors;
@@ -27,75 +32,88 @@ import java.util.stream.Collectors;
 @SuppressWarnings({"all"})
 public class LitigationHistoryService extends ServiceImpl<LitigationHistoryMapper, LitigationHistory> {
     private final ReportFileService reportFileService;
-    private final AssoLitigationHisFileService  assoLitigationHisFileService;
+    private final AssoLitigationHisFileService assoLitigationHisFileService;
+    private final FileManagerService fileManagerService;
 
     /**
-     * @function: 删除诉讼历史 (对比方案与对比记录表的内容也要删除,报告也要删除)
      * @param id 诉讼历史id
      * @return
+     * @function: 删除诉讼历史 (对比方案与对比记录表的内容也要删除,报告也要删除)
      */
-    public String deleteLitigationHistory(int id){
-        LitigationHistory litigationHistory =this.getById(id);
+    public String deleteLitigationHistory(int id) throws IOException {
+        LitigationHistory litigationHistory = this.getById(id);
         this.removeById(id);
-        LambdaQueryWrapper<AssoLitigationHisFile> wrapper =new LambdaQueryWrapper<>();
-        wrapper.eq(AssoLitigationHisFile::getLitiHisId,litigationHistory.getId());
-        List<AssoLitigationHisFile> assoes= assoLitigationHisFileService.list(wrapper);
-        List<Integer> fileIds =assoes.stream().map(AssoLitigationHisFile::getFileId).collect(Collectors.toList());
-        //根据对比文件id删除报告
-        reportFileService.removeByIds(fileIds);
-        // 根据对比文件id对比方案与对比记录
-        assoLitigationHisFileService.remove(wrapper);
-       return Response.success();
+        LambdaQueryWrapper<AssoLitigationHisFile> wrapper = new LambdaQueryWrapper<>();
+        wrapper.eq(AssoLitigationHisFile::getLitiHisId, litigationHistory.getId());
+        List<AssoLitigationHisFile> assoes = assoLitigationHisFileService.list(wrapper);
+        if (assoes != null && assoes.size() > 0) {
+            List<Integer> fileIds = assoes.stream().map(AssoLitigationHisFile::getFileId).collect(Collectors.toList());
+            //根据对比文件id删除报告
+            //reportFileService.removeByIds(fileIds);
+            fileManagerService.deleteFileFromFMS(fileIds);
+            // 根据对比文件id对比方案与对比记录
+            assoLitigationHisFileService.remove(wrapper);
+        }
+        return Response.success();
     }
 
     /**
-     * @function: 增加诉讼历史
      * @param litigationHistory
-     * @param files 诉讼文件
+     * @param files             诉讼文件
      * @return
+     * @function: 增加诉讼历史
      */
-    public String addLitigationHistory(LitigationHistory litigationHistory,List<MultipartFile> files){
+    public String addLitigationHistory(LitigationHistory litigationHistory, List<MultipartFile> files) throws IOException {
         // 插入诉讼历史
         litigationHistory.insert();
-        if (files!=null&&files.size() != 0) {
+        if (files != null && files.size() != 0) {
             //将文档上传并返回文件入库的Id
-            List<Integer> fileIds = reportFileService.uploadFiles(files);
+            //List<Integer> fileIds = reportFileService.uploadFiles(files);
+            String res = fileManagerService.uploadFile(files);
+            JSONObject jsonObject = JSONObject.parseObject(res);
+            List<Integer> fileIds = JSONArray.parseArray(jsonObject.get("data").toString(), Integer.class);
             // 对比方案与对比记录 插入
-            assoLitigationHisFileService.addAsso(litigationHistory.getId(),fileIds);
+            assoLitigationHisFileService.addAsso(litigationHistory.getId(), fileIds);
         }
         return Response.success();
     }
+
     /**
-     * @function: 修改诉讼历史
      * @param litigationHistory
-     * @param files 诉讼文件
+     * @param files             诉讼文件
      * @return
+     * @function: 修改诉讼历史
      */
-    public Boolean updateLitigationHistory(LitigationHistory litigationHistory,List<MultipartFile> files){
+    public Boolean updateLitigationHistory(LitigationHistory litigationHistory, List<MultipartFile> files) throws IOException {
 
         // 根据无效Id查询对应的附件Id
-        LambdaQueryWrapper<AssoLitigationHisFile> wrapper =new LambdaQueryWrapper<>();
-        wrapper.eq(AssoLitigationHisFile::getLitiHisId,litigationHistory.getId());
-        List<AssoLitigationHisFile> assoes= assoLitigationHisFileService.list(wrapper);
-        List<Integer> fileIds =assoes.stream().map(AssoLitigationHisFile::getFileId).collect(Collectors.toList());
+        LambdaQueryWrapper<AssoLitigationHisFile> wrapper = new LambdaQueryWrapper<>();
+        wrapper.eq(AssoLitigationHisFile::getLitiHisId, litigationHistory.getId());
+        List<AssoLitigationHisFile> assoes = assoLitigationHisFileService.list(wrapper);
+        List<Integer> fileIds = assoes.stream().map(AssoLitigationHisFile::getFileId).collect(Collectors.toList());
         // 获得更新后的附件Id
-         List<Integer> updateFileId =new ArrayList<>();
-        if(litigationHistory.getReportFiles()!=null){
+        List<Integer> updateFileId = new ArrayList<>();
+        if (litigationHistory.getReportFiles() != null) {
             updateFileId = litigationHistory.getReportFiles().stream().map(ReportFiles::getId).collect(Collectors.toList());
-            fileIds.removeAll(updateFileId);}
+            fileIds.removeAll(updateFileId);
+        }
         //做差获得被删除的文件Id
-        if(fileIds.size()!=0){
+        if (fileIds.size() != 0) {
             //根据文件Id删除报告文件关联表记录
             LambdaQueryWrapper<AssoLitigationHisFile> deleteWrapper = new LambdaQueryWrapper<>();
-            deleteWrapper.in(AssoLitigationHisFile::getFileId,fileIds);
+            deleteWrapper.in(AssoLitigationHisFile::getFileId, fileIds);
             assoLitigationHisFileService.remove(deleteWrapper);
             //根据文件Id删除文件表记录
-            reportFileService.removeByIds(fileIds);
+            //reportFileService.removeByIds(fileIds);'
+            fileManagerService.deleteFileFromFMS(fileIds);
         }
-          //添加附件
-        if (files!=null&&files.size() != 0) {
+        //添加附件
+        if (files != null && files.size() != 0) {
             //将文档上传并返回文件入库的Id
-            List<Integer> fileIdList = reportFileService.uploadFiles(files);
+            //List<Integer> fileIdList = reportFileService.uploadFiles(files);
+            String res = fileManagerService.uploadFile(files);
+            JSONObject jsonObject = JSONObject.parseObject(res);
+            List<Integer> fileIdList = JSONArray.parseArray(jsonObject.get("data").toString(), Integer.class);
             assoLitigationHisFileService.addAsso(litigationHistory.getId(), fileIdList);
 
         }
@@ -104,32 +122,32 @@ public class LitigationHistoryService extends ServiceImpl<LitigationHistoryMappe
     }
 
     /**
-     * @function: 根据专利号查询诉讼历史
      * @param litigationHistory
      * @return
+     * @function: 根据专利号查询诉讼历史
      */
 
-    public String queryLitigationHistory(LitigationHistory litigationHistory){
-        LambdaQueryWrapper<LitigationHistory> wrapper =new LambdaQueryWrapper<>();
-               wrapper.eq(LitigationHistory::getPatentNo,litigationHistory.getPatentNo());
-               //分页
+    public String queryLitigationHistory(LitigationHistory litigationHistory) throws IOException {
+        LambdaQueryWrapper<LitigationHistory> wrapper = new LambdaQueryWrapper<>();
+        wrapper.eq(LitigationHistory::getPatentNo, litigationHistory.getPatentNo());
+        //分页
         if (litigationHistory.getSize() != null && litigationHistory.getCurrent() != null) {
             IPage<LitigationHistory> pages = this.page(new Page<>(litigationHistory.getCurrent(), litigationHistory.getSize()), wrapper);
             pages.setRecords(this.LitigationHistory(pages.getRecords()));
             return Response.success(pages);
         } else {
-            List<LitigationHistory>  histories= this.list(wrapper);
-            histories =this.LitigationHistory(histories);
+            List<LitigationHistory> histories = this.list(wrapper);
+            histories = this.LitigationHistory(histories);
             return Response.success(histories);
         }
     }
 
     /**
-     * @function:  装载诉讼历史
      * @param litigationHistories
      * @return
+     * @function: 装载诉讼历史
      */
-    public List<LitigationHistory> LitigationHistory(List<LitigationHistory> litigationHistories) {
+    public List<LitigationHistory> LitigationHistory(List<LitigationHistory> litigationHistories) throws IOException {
         //获得诉讼历史的Id
         List<Integer> ids = litigationHistories.stream().map(LitigationHistory::getId).collect(Collectors.toList());
         if (ids.size() != 0) {
@@ -140,17 +158,26 @@ public class LitigationHistoryService extends ServiceImpl<LitigationHistoryMappe
             //根据关联信息查询附件信息
             if (assoLitigationHisFiles.size() != 0) {
                 List<Integer> fileIds = assoLitigationHisFiles.stream().map(AssoLitigationHisFile::getFileId).collect(Collectors.toList());
-                LambdaQueryWrapper<ReportFiles> wrapper = new LambdaQueryWrapper<>();
-                wrapper.in(ReportFiles::getId, fileIds);
-                List<ReportFiles> reportFiles = reportFileService.list(wrapper);
+//                LambdaQueryWrapper<ReportFiles> wrapper = new LambdaQueryWrapper<>();
+//                wrapper.in(ReportFiles::getId, fileIds);
+//                List<ReportFiles> reportFiles = reportFileService.list(wrapper);
+                String res = fileManagerService.getSystemFileFromFMS(fileIds);
+                List<SystemFile> systemFiles = JSONArray.parseArray(res, SystemFile.class);
+
                 //遍历装载文件信息
                 litigationHistories.forEach(item -> {
                     List<AssoLitigationHisFile> partAsso = assoLitigationHisFiles.stream().filter(tem -> tem.getLitiHisId().equals(item.getId())).collect(Collectors.toList());
                     List<ReportFiles> reportFilesList = new ArrayList<>();
                     if (partAsso.size() != 0) {
                         List<Integer> partFileIds = partAsso.stream().map(AssoLitigationHisFile::getFileId).collect(Collectors.toList());
-                        List<ReportFiles> reportFiles1 = reportFiles.stream().filter(tem -> partFileIds.contains(tem.getId())).collect(Collectors.toList());
-                        reportFilesList = reportFiles1;
+//                        List<ReportFiles> reportFiles1 = reportFiles.stream().filter(tem -> partFileIds.contains(tem.getId())).collect(Collectors.toList());
+//                        reportFilesList = reportFiles1;
+                        List<SystemFile> systemFiles1 = systemFiles.stream().filter(tem -> partFileIds.contains(tem.getId())).collect(Collectors.toList());
+                        systemFiles1.forEach(systemFile -> {
+                            ReportFiles reportFile = new ReportFiles();
+                            SystemFileToReportFile.systemFileToReportFile(reportFile, systemFile);
+                            reportFilesList.add(reportFile);
+                        });
                     }
                     item.setReportFiles(reportFilesList);
                 });