From fd3d8c8f17fb3517fce11ffa7790853f010e34c7 Mon Sep 17 00:00:00 2001
From: xusd <330628789@qq.com>
Date: Fri, 04 Jul 2025 14:17:00 +0800
Subject: [PATCH] Merge branch 'feature/login_test-wjz' into feature/login_test

---
 dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseFeedbackService.java      |   85 ++++++++++
 dyh-service/dyh-sys/src/main/resources/config/application.yml                                    |    2 
 dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/impl/SysClientImpl.java          |   24 +++
 dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/controller/web/GridEventWebController.java |   10 +
 dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/SysClient.java                   |   11 +
 dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/domain/vo/SaveEventFeedBackVo.java         |   79 +++++++++
 dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/service/GridEventService.java              |  175 +++++++++++++++++++++
 dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/domain/vo/SaveEventFeedBackVo.java    |   74 +++++++++
 8 files changed, 454 insertions(+), 6 deletions(-)

diff --git a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/domain/vo/SaveEventFeedBackVo.java b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/domain/vo/SaveEventFeedBackVo.java
new file mode 100644
index 0000000..cc2861b
--- /dev/null
+++ b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/domain/vo/SaveEventFeedBackVo.java
@@ -0,0 +1,74 @@
+package cn.huge.module.cases.domain.vo;
+
+import cn.huge.module.sys.dto.FileInfoBaseDTO;
+import lombok.Data;
+
+import java.util.List;
+
+/**
+ * @ClassName SaveEventFeedBackVo
+ * @Description 同步办理反馈接口入参
+ * @Author 文锦钊
+ * @Date 2025/7/3 10:48
+ **/
+
+@Data
+public class SaveEventFeedBackVo {
+
+    /**
+     * 反馈记录id,36位,建议用uuid (必填)
+     */
+    private String id;
+
+    /**
+     * 事件工单id (必填)
+     */
+    private String evtId;
+
+    /**
+     * 反馈用户部门名称 (必填)
+     */
+    private String appOrgName;
+
+    /**
+     * 反馈用户名称 (必填)
+     */
+    private String appUserName;
+
+    /**
+     * 反馈用户部门id (必填)
+     */
+    private String appOrgId;
+
+    /**
+     * 反馈用户id (必填)
+     */
+    private String appUserId;
+
+    /**
+     * 反馈时间,格式yyyy-MM-dd HH:mm:ss (必填)
+     * 示例:2022-05-20 15:11:21
+     */
+    private String appTime;
+
+    /**
+     * 反馈意见 (必填)
+     */
+    private String approveContent;
+
+    /**
+     * 环节处理期限,格式yyyy-MM-dd HH:mm:ss (必填)
+     * 示例:2022-05-20 15:11:21
+     */
+    private String processingTime;
+
+    /**
+     * 环节处理类型 (选填)
+     */
+    private String handleType;
+
+    /**
+     * 附件文件列表
+     */
+    private List<FileInfoBaseDTO> fileInfoList;
+}
diff --git a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseFeedbackService.java b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseFeedbackService.java
index 2d32d8e..e54301e 100644
--- a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseFeedbackService.java
+++ b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/service/CaseFeedbackService.java
@@ -1,12 +1,15 @@
 package cn.huge.module.cases.service;
+import java.util.ArrayList;
 
 import cn.huge.base.common.exception.ServiceException;
 import cn.huge.base.common.utils.DateUtils;
 import cn.huge.base.common.utils.IdUtils;
 import cn.huge.base.common.utils.ObjectUtils;
+import cn.huge.base.common.utils.ThreadPoolUtils;
 import cn.huge.module.cases.consts.CaseTaskConsts;
 import cn.huge.module.cases.domain.dto.MediatorDTO;
 import cn.huge.module.cases.domain.po.*;
+import cn.huge.module.cases.domain.vo.SaveEventFeedBackVo;
 import cn.huge.module.client.api.impl.CustClientImpl;
 import cn.huge.module.client.api.impl.SysClientImpl;
 import cn.huge.module.client.api.impl.UtilsClientImpl;
@@ -14,15 +17,18 @@
 import cn.huge.module.cust.dto.CtUnitDTO;
 import cn.huge.module.cust.dto.CtUserDTO;
 import cn.huge.module.mediate.constant.CaseBaseConsts;
+import cn.huge.module.mediate.constant.CaseBaseConstsEnum;
 import cn.huge.module.sys.dto.FileIdInfoBaseDTO;
 import cn.huge.module.sys.dto.FileInfoBaseDTO;
 import cn.huge.module.sys.dto.FileTypeInfoBaseDTO;
+import cn.huge.module.utils.TimeUtils;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.google.common.collect.Maps;
 import org.apache.commons.collections.CollectionUtils;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.scheduling.annotation.Async;
 import org.springframework.stereotype.Service;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.data.domain.Page;
@@ -32,6 +38,7 @@
 
 import javax.print.DocFlavor;
 import java.util.*;
+import java.util.concurrent.CompletableFuture;
 import java.util.stream.Collectors;
 
 /**
@@ -73,6 +80,9 @@
 
     @Autowired
     private CaseMediatorService caseMediatorService;
+
+    @Autowired
+    private CaseInfoService caseInfoService;
 
     /**
      * 更新对象
@@ -165,10 +175,83 @@
             }
             caseFeedback.setUpdateTime(nowDate);
             this.saveOrUpdate(caseFeedback);
+
+            //  异步同步纠纷办理反馈信息
+            asyncSaveEventFeedback(caseFeedback, userId);
+
         } catch (Exception e) {
             log.error("[caseFeedbackService.savecaseFeedback]调用失败,异常信息:" + e, e);
             throw new ServiceException("caseFeedbackService.savecaseFeedback", e);
         }
+    }
+
+    /**
+     * 异步保存办理反馈信息
+     *
+     * @param caseFeedback
+     * @param userId
+     */
+    private void asyncSaveEventFeedback(CaseFeedback caseFeedback, String userId) {
+        String caseId = caseFeedback.getCaseId();
+        CaseInfo caseInfo = caseInfoService.getById(caseId);
+        String canalSecond = caseInfo.getCanalSecond();
+
+        //  需要同步的渠道类型
+        List<String> needSyncTypeList = new ArrayList<>();
+        needSyncTypeList.add(CaseBaseConstsEnum.CASE_CANAL_SECOND_1.getIndex());
+        needSyncTypeList.add(CaseBaseConstsEnum.CASE_CANAL_SECOND_2.getIndex());
+        needSyncTypeList.add(CaseBaseConstsEnum.CASE_CANAL_SECOND_7.getIndex());
+
+        if (!needSyncTypeList.contains(canalSecond)) {
+            log.info("当前来源的事项不需要同步,来源为:" + CaseBaseConstsEnum.getDes(canalSecond));
+            return ;
+        }
+
+        //  使用单例设计的线程池来异步同步
+        ThreadPoolUtils.submit(()->{
+            log.info("异步保存办理反馈信息开始");
+            //  保存办理反馈信息后需要同步到大平台中
+            String evtId = caseInfo.getCaseRef();
+
+            //  反馈用户信息
+            CtUserDTO ctUserDTO = custClient.clientGetUser(userId);
+            CtUnitDTO ctUnitDTO = custClient.getUnitById(ctUserDTO.getUnitId());
+
+            //  反馈意见内容
+            String handleContent = caseFeedback.getHandleContent();
+
+            //  反馈时间
+            Date now = new Date();
+            String appTime = TimeUtils.format(now,TimeUtils.STANDARD_PATTERN);
+            String processingTime = TimeUtils.format(TimeUtils.after(now,14),TimeUtils.STANDARD_PATTERN);
+
+            //  构建参数
+            SaveEventFeedBackVo saveEventFeedBackVo = new SaveEventFeedBackVo();
+            saveEventFeedBackVo.setId(caseId);
+            saveEventFeedBackVo.setEvtId(evtId);
+
+            //  先传递当前子系统的用户id
+            saveEventFeedBackVo.setAppUserId(userId);
+            saveEventFeedBackVo.setAppUserName(ctUserDTO.getTrueName());
+            saveEventFeedBackVo.setAppOrgId(ctUnitDTO.getId());
+            saveEventFeedBackVo.setAppOrgName(ctUnitDTO.getUnitName());
+
+            saveEventFeedBackVo.setAppTime(appTime);
+            saveEventFeedBackVo.setApproveContent(handleContent);
+            saveEventFeedBackVo.setProcessingTime(processingTime);
+            saveEventFeedBackVo.setHandleType("");
+
+            //  附件信息
+            List<FileInfoBaseDTO> fileInfoList = caseFeedback.getFileInfoList();
+            saveEventFeedBackVo.setFileInfoList(fileInfoList);
+
+            //  发起同步
+            sysClient.saveEventFeedback(saveEventFeedBackVo);
+            log.info("异步保存办理反馈信息成功!!");
+            return null;
+        });
+
+
     }
 
     /**
@@ -333,6 +416,8 @@
                 caseFeedback.setHandleType(CaseTaskConsts.HANDLE_TYPE_2);
             }
             this.save(caseFeedback);
+            //  异步同步纠纷办理反馈信息
+            asyncSaveEventFeedback(caseFeedback, userId);
         } catch (Exception e) {
             log.error("[caseFeedbackService.savecaseFeedback]调用失败,异常信息:" + e, e);
             throw new ServiceException("caseFeedbackService.savecaseFeedback", e);
diff --git a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/SysClient.java b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/SysClient.java
index 7644dce..6903a68 100644
--- a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/SysClient.java
+++ b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/SysClient.java
@@ -4,6 +4,7 @@
 import cn.huge.base.common.bo.ReturnBO;
 import cn.huge.module.cases.domain.dto.GridApprovalRecordDTO;
 import cn.huge.module.cases.domain.vo.GenerateQrCodeRequestVo;
+import cn.huge.module.cases.domain.vo.SaveEventFeedBackVo;
 import cn.huge.module.sys.vo.*;
 import cn.huge.module.sys.dto.*;
 import cn.huge.module.cases.domain.dto.FileRelateDTO;
@@ -205,4 +206,14 @@
      */
     @GetMapping("/api/citizen/event/getCaseRefByGenerateQrCode")
     ReturnBO getCaseRefByGenerateQrCode(@RequestBody GenerateQrCodeRequestVo generateQrCodeRequestVo);
+
+    /**
+     * 获取大平台事项编号
+     *
+     * @param saveEventFeedBackVo
+     * @return Object
+     * @url {ctx}/api/web/gridEvent/saveEventFeedback
+     */
+    @PostMapping("/api/web/gridEvent/saveEventFeedback")
+    ReturnBO saveEventFeedback(@RequestBody SaveEventFeedBackVo saveEventFeedBackVo);
 }
diff --git a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/impl/SysClientImpl.java b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/impl/SysClientImpl.java
index c587b9d..7e5f89f 100644
--- a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/impl/SysClientImpl.java
+++ b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/client/api/impl/SysClientImpl.java
@@ -10,6 +10,7 @@
 import cn.huge.module.cases.domain.dto.GridApprovalRecordDTO;
 import cn.huge.module.cases.domain.dto.GridEventDTO;
 import cn.huge.module.cases.domain.vo.GenerateQrCodeRequestVo;
+import cn.huge.module.cases.domain.vo.SaveEventFeedBackVo;
 import cn.huge.module.sy.service.SyHolidayService;
 import cn.huge.module.syncbydyh.domain.po.SyCause;
 import cn.huge.module.sys.vo.*;
@@ -569,4 +570,27 @@
             throw new ServiceException("SysClientImpl.getCaseRefByGenerateQrCode", e);
         }
     }
+
+    /**
+     * 办理反馈信息
+     *
+     * @param vo           同步办理反馈信息的入参
+     * @return
+     * @url {ctx}/api/client/event/generateQrCode
+     */
+    public String saveEventFeedback(SaveEventFeedBackVo vo){
+        try{
+            ReturnBO returnBo = sysClient.saveEventFeedback(vo);
+            if (ReturnConsts.OK == returnBo.getCode()){
+                String id = (String) returnBo.getData();
+                return id;
+            }else{
+                log.error("Client外服务接口[SysClientImpl.saveEventFeedback]请求异常:" + returnBo.getMsg(), returnBo.getMsg());
+                throw new ClientException("SysClientImpl.saveEventFeedback", returnBo.getMsg());
+            }
+        }catch (Exception e){
+            log.error("service方法[SysClientImpl.saveEventFeedback]请求成功,处理异常:"+e, e);
+            throw new ServiceException("SysClientImpl.saveEventFeedback", e);
+        }
+    }
 }
diff --git a/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/controller/web/GridEventWebController.java b/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/controller/web/GridEventWebController.java
index 64e066e..e0449f7 100644
--- a/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/controller/web/GridEventWebController.java
+++ b/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/controller/web/GridEventWebController.java
@@ -508,4 +508,14 @@
         }
         return ReturnSucUtils.getRepInfo();
     }
+
+    /**
+     * 同步办理反馈接口信息
+     * @param saveEventFeedBackVo
+     * @return
+     */
+    @PostMapping("/saveEventFeedback")
+    public R<Object> saveEventFeedback(@RequestBody SaveEventFeedBackVo saveEventFeedBackVo) {
+        return service.saveEventFeedback(saveEventFeedBackVo);
+    }
 }
diff --git a/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/domain/vo/SaveEventFeedBackVo.java b/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/domain/vo/SaveEventFeedBackVo.java
new file mode 100644
index 0000000..838280f
--- /dev/null
+++ b/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/domain/vo/SaveEventFeedBackVo.java
@@ -0,0 +1,79 @@
+package cn.huge.module.grid.domain.vo;
+
+import cn.huge.module.sys.dto.FileInfoBaseDTO;
+import lombok.Data;
+
+import java.util.List;
+
+/**
+ * @ClassName SaveEventFeedBackVo
+ * @Description 同步办理反馈接口入参
+ * @Author 文锦钊
+ * @Date 2025/7/3 10:48
+ **/
+
+@Data
+public class SaveEventFeedBackVo {
+
+    /**
+     * 反馈记录id,36位,建议用uuid (必填)
+     */
+    private String id;
+
+    /**
+     * 事件工单id (必填)
+     */
+    private String evtId;
+
+    /**
+     * 反馈用户部门名称 (必填)
+     */
+    private String appOrgName;
+
+    /**
+     * 反馈用户名称 (必填)
+     */
+    private String appUserName;
+
+    /**
+     * 反馈用户部门id (必填)
+     */
+    private String appOrgId;
+
+    /**
+     * 反馈用户id (必填)
+     */
+    private String appUserId;
+
+    /**
+     * 反馈时间,格式yyyy-MM-dd HH:mm:ss (必填)
+     * 示例:2022-05-20 15:11:21
+     */
+    private String appTime;
+
+    /**
+     * 反馈意见 (必填)
+     */
+    private String approveContent;
+
+    /**
+     * 环节处理期限,格式yyyy-MM-dd HH:mm:ss (必填)
+     * 示例:2022-05-20 15:11:21
+     */
+    private String processingTime;
+
+    /**
+     * 环节处理类型 (选填)
+     */
+    private String handleType;
+
+    /**
+     * 反馈附件列表 (选填)
+     */
+    private List<GridFileRelatedVo> feedbackAttrInfos;
+
+    /**
+     * 原子系统的反馈附件列表 (选填)
+     */
+    private List<FileInfoBaseDTO> fileInfoList;
+}
diff --git a/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/service/GridEventService.java b/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/service/GridEventService.java
index 19c2c34..f84c75b 100644
--- a/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/service/GridEventService.java
+++ b/dyh-service/dyh-sys/src/main/java/cn/huge/module/grid/service/GridEventService.java
@@ -1,26 +1,36 @@
 package cn.huge.module.grid.service;
 
+import cn.huge.base.common.bo.R;
 import cn.huge.base.common.exception.ServiceException;
 import cn.huge.base.common.utils.DateUtils;
+import cn.huge.base.common.utils.HttpClientUtils;
 import cn.huge.base.common.utils.IdUtils;
+import cn.huge.base.common.utils.ObjectUtils;
+import cn.huge.module.client.api.impl.CustClientImpl;
 import cn.huge.module.client.api.impl.UtilsClientImpl;
+import cn.huge.module.cust.dto.CtUserDTO;
 import cn.huge.module.grid.dao.mapper.GridEventMapper;
+import cn.huge.module.grid.domain.dto.GridFileUploadDTO;
+import cn.huge.module.grid.domain.dto.GridOrgDTO;
 import cn.huge.module.grid.domain.po.GridEvent;
+import cn.huge.module.grid.domain.vo.*;
+import cn.huge.module.sys.dto.FileInfoBaseDTO;
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-import org.apache.ibatis.annotations.Param;
+import org.apache.commons.codec.digest.DigestUtils;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
 import lombok.extern.slf4j.Slf4j;
-import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.domain.Page;
 import org.springframework.data.domain.PageImpl;
 import org.springframework.data.domain.PageRequest;
 import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.CollectionUtils;
 
-import javax.annotation.PostConstruct;
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 /**
  * @author wangwh
@@ -40,6 +50,39 @@
 
     @Autowired
     private UtilsClientImpl utilsClient;
+
+    @Autowired
+    private GridCaseTaskService gridCaseTaskService;
+
+    @Autowired
+    private GridCaseDataService gridCaseDataService;
+
+    @Autowired
+    private GridUserService gridUserService;
+
+    @Autowired
+    private CustClientImpl custClient;
+
+    @Value("${grid.url:http://219.137.166.84:8061}")
+    private String gridUrl;
+    @Value("${grid.username:mtxt0011}")
+    private String userName;
+    @Value("${grid.password}")
+    private String passWord;
+    @Value("${grid.secret:BZb2hLCx05}")
+    private String secret;
+    @Value("${grid.passid:b08c0ec0-772d-caf8-5c9b-1f7d86295a95}")
+    private String passid;
+    public HashMap<String,String> initHeadVo() {
+        long timestamp = System.currentTimeMillis()/1000;
+        HashMap<String,String> headVo = new HashMap<>();
+        headVo.put("x-rio-paasid",passid);
+        headVo.put("x-rio-timestamp",timestamp+"");
+        headVo.put("x-rio-nonce","mt");
+        headVo.put("x-rio-signature", DigestUtils.sha256Hex(timestamp+secret+"mt"+timestamp));
+        return headVo;
+    }
+
 
     /**
      * 更新对象
@@ -141,4 +184,124 @@
     public GridEvent getEventByCaseId(String caseId) {
         return mapper.getEventByCaseId(caseId);
     }
+
+    /**
+     * 同步矛纠工单的办理反馈信息
+     *
+     * @param saveEventFeedBackVo
+     * @return
+     */
+    public R<Object> saveEventFeedback(SaveEventFeedBackVo saveEventFeedBackVo) {
+        HashMap<String,String> headVo=  initHeadVo();
+        try{
+            //  传递过来的是子平台的id,需要转换为大平台的id
+            String appOrgId = saveEventFeedBackVo.getAppOrgId();
+
+            String appGridUnitId = null;
+            if (StringUtils.isNotBlank(appOrgId)) {
+                appGridUnitId = gridCaseTaskService.getGridUnitIdByUnitId(saveEventFeedBackVo.getAppOrgId());
+                saveEventFeedBackVo.setAppOrgId(appGridUnitId);
+                if (StringUtils.isBlank(appGridUnitId)) {
+                    throw new Exception("矛纠工单的办理反馈信息的组织不存在");
+                }
+            }
+//        else {
+//            saveEventFeedBackVo.setAppOrgId(gridEvent.getSysOrgId());
+//            saveEventFeedBackVo.setAppOrgName(gridEvent.getSysOrgName());
+//        }
+            log.info("当前环节组织:" + saveEventFeedBackVo.getAppOrgId());
+
+            if (StringUtils.isNotBlank(saveEventFeedBackVo.getAppUserId())) {
+                CtUserDTO ctUserDTO = custClient.clientGetUserAll(saveEventFeedBackVo.getAppUserId());
+                if (ObjectUtils.isNotEmpty(ctUserDTO)) {
+                    if (StringUtils.isNotBlank(ctUserDTO.getIdcard())) {
+                        GridUserIdNumberVo gridUserIdNumberVo = new GridUserIdNumberVo();
+                        gridUserIdNumberVo.setIdNumber(ctUserDTO.getIdcard());
+                        R<GridUserVo> result = gridUserService.getUserByIdNumber(gridUserIdNumberVo);
+                        if (R.SUCCESS == result.getCode()) {
+                            saveEventFeedBackVo.setAppUserId(result.getData().getId());
+                            log.info("当前环节审批用户为: " + saveEventFeedBackVo.getAppUserId());
+                        } else {
+                            saveEventFeedBackVo.setAppUserId("a9406a88c8234cda82452799bf6bd6cd");
+                            log.info("当前环节审批用户为特殊用户,身份证找不到用户{},{}", ctUserDTO.getIdcard(), ctUserDTO.getTrueName());
+                        }
+                    } else {
+                        saveEventFeedBackVo.setAppUserId("a9406a88c8234cda82452799bf6bd6cd");
+                        log.info("当前环节审批用户为特殊用户,找不到用户{}", saveEventFeedBackVo.getAppUserId());
+                    }
+                } else {
+                    saveEventFeedBackVo.setAppUserId("a9406a88c8234cda82452799bf6bd6cd");
+                    log.info("当前环节审批用户为特殊用户,找不到用户{}", saveEventFeedBackVo.getAppUserId());
+                }
+            } else {
+                saveEventFeedBackVo.setAppUserId("a9406a88c8234cda82452799bf6bd6cd");
+                log.info("矛纠工单的办理反馈信息的用户为特殊用户");
+            }
+
+            //  判断附件不为空
+            List<FileInfoBaseDTO> fileInfoList = saveEventFeedBackVo.getFileInfoList();
+            if (!CollectionUtils.isEmpty(fileInfoList)){
+                List<GridFileRelatedVo> feedbackAttrInfos = new ArrayList<>();
+                log.info("获取到矛纠工单的办理反馈信息的附件上传:" + fileInfoList.size());
+                for (FileInfoBaseDTO fileInfoBaseDTO : fileInfoList) {
+                    try {
+                        GridFileUploadVo gridFileUploadVo = new GridFileUploadVo();
+                        gridFileUploadVo.setFileName(fileInfoBaseDTO.getFileName());
+                        gridFileUploadVo.setFilePath(fileInfoBaseDTO.getFullPath());
+                        gridFileUploadVo.setFileSize(fileInfoBaseDTO.getSize() != null ? fileInfoBaseDTO.getSize().longValue() : 0L);
+                        gridFileUploadVo.setType(fileInfoBaseDTO.getSuffix());
+                        R<GridFileUploadDTO> result = null;
+                        //上传附件信息
+                        result = gridCaseDataService.uploadFileInfo(gridFileUploadVo);
+                        if (R.SUCCESS == result.getCode()) {
+                            //获取上传结果,组成新的附件对象
+                            GridFileUploadDTO gridFileUploadDTO = result.getData();
+                            GridFileRelatedVo gridFileRelatedVo = new GridFileRelatedVo();
+                            gridFileRelatedVo.setFileName(gridFileUploadDTO.getFileName());
+                            gridFileRelatedVo.setFilePath(gridFileUploadDTO.getFilePath());
+                            gridFileRelatedVo.setOriginalFileName(gridFileUploadDTO.getOriginalFileName());
+                            gridFileRelatedVo.setFileSize(gridFileUploadDTO.getFileSize());
+                            gridFileRelatedVo.setType("add");
+                            gridFileRelatedVo.setFileType(gridFileUploadDTO.getFileType());
+                            feedbackAttrInfos.add(gridFileRelatedVo);
+                        }
+                    } catch (Exception e) {
+                        e.printStackTrace();
+                        log.info("附件上传失败:" + fileInfoBaseDTO.getId());
+                    }
+                }
+
+                //  上传完成后设置原附件列表为空
+                saveEventFeedBackVo.setFileInfoList(null);
+            }
+
+
+            //  发起请求
+            log.info("办理反馈信息-xsd:{}", JSON.toJSONString(saveEventFeedBackVo));
+            log.info("办理反馈信息-xsd:{}", gridUrl + "/standard/eventform/saveFeedback");
+            String s = null;
+            try {
+                s = HttpClientUtils.httpPostRaw(gridUrl + "/standard/eventform/saveFeedback", JSON.toJSONString(saveEventFeedBackVo), headVo, "utf-8");
+            } catch (Exception e) {
+                log.info("xsderror:{}", e);
+                throw new RuntimeException(e);
+            }
+            log.info("xsd:{}", s);
+
+            //
+            JSONObject object = JSONObject.parseObject(s);
+            if (object.getInteger("code") != null && object.getInteger("code") == 0) {
+                log.info("同步矛纠工单的办理反馈信息成功!");
+                Object data = object.get("data");
+                return R.ok(data);
+            } else {
+                log.info("同步矛纠工单的办理反馈信息失败,错误原因:" + object.getString("message"));
+                return R.fail("同步矛纠工单的办理反馈信息失败");
+            }
+        }catch (Exception e){
+            log.error("同步矛纠工单的办理反馈信息报错",e);
+        }
+        return R.fail("同步矛纠工单的办理反馈信息失败");
+
+    }
 }
diff --git a/dyh-service/dyh-sys/src/main/resources/config/application.yml b/dyh-service/dyh-sys/src/main/resources/config/application.yml
index f1b17fc..b39db80 100644
--- a/dyh-service/dyh-sys/src/main/resources/config/application.yml
+++ b/dyh-service/dyh-sys/src/main/resources/config/application.yml
@@ -16,6 +16,8 @@
   main:
     #可以重复命名配置
     allow-bean-definition-overriding: true
+    # 处理循环引用
+    allow-circular-references: true
 
 #server配置
 server:

--
Gitblit v1.8.0