From 06c8e98ca993dec47203bb4cfb7209692d13baca Mon Sep 17 00:00:00 2001
From: WS <1143478319@qq.com>
Date: 星期四, 17 八月 2023 15:18:05 +0800
Subject: [PATCH] 提交通风作业信息同步

---
 src/main/java/com/fzzy/whjl/view/pr/WhjlApi1103PR.java |  102 +++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 98 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/fzzy/whjl/view/pr/WhjlApi1103PR.java b/src/main/java/com/fzzy/whjl/view/pr/WhjlApi1103PR.java
index b340457..6a02038 100644
--- a/src/main/java/com/fzzy/whjl/view/pr/WhjlApi1103PR.java
+++ b/src/main/java/com/fzzy/whjl/view/pr/WhjlApi1103PR.java
@@ -1,11 +1,27 @@
 package com.fzzy.whjl.view.pr;
 
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
 import com.bstek.dorado.annotation.DataProvider;
 import com.bstek.dorado.annotation.DataResolver;
 import com.bstek.dorado.annotation.Expose;
+import com.fzzy.api.Constant;
+import com.fzzy.api.data.ApiParam;
+import com.fzzy.api.dto.ResponseDto;
+import com.fzzy.api.entity.ApiConfs;
+import com.fzzy.api.entity.ApiInfoData;
+import com.fzzy.api.service.ApiCommonService;
+import com.fzzy.api.service.ApiPushManager;
+import com.fzzy.api.service.ApiRemoteService;
+import com.fzzy.api.view.repository.ApiInfoDataRep;
+import com.fzzy.whjl.WhjlConstant;
 import com.fzzy.whjl.dto.WhjlApi1103;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
 
+import java.util.ArrayList;
+import java.util.Date;
 import java.util.List;
 
 /**
@@ -15,6 +31,14 @@
  */
 @Component
 public class WhjlApi1103PR {
+
+    @Autowired
+    private ApiCommonService apiCommonService;
+    @Autowired
+    private ApiPushManager apiPushManager;
+    @Autowired
+    private ApiInfoDataRep apiInfoDataRep;
+
     /**
      * 鑾峰彇鍒楄〃淇℃伅
      * whjlApi1103PR#listData
@@ -23,7 +47,21 @@
      */
     @DataProvider
     public List<WhjlApi1103> listData() {
-        return null;
+        List<ApiInfoData> result = apiInfoDataRep.getDataByInteId(WhjlConstant.API_CODE_1103);
+        if (null == result || result.isEmpty()) {
+            return null;
+        }
+        List<WhjlApi1103> list = new ArrayList<>();
+        WhjlApi1103 whjlApi1103;
+        for (ApiInfoData infoData : result) {
+            whjlApi1103 = JSONObject.parseObject(infoData.getData(), WhjlApi1103.class);
+            whjlApi1103.setKqdm(infoData.getKqdm());
+            whjlApi1103.setCzbz(infoData.getCzbz());
+            whjlApi1103.setUpdateTime(infoData.getUpdateTime());
+            whjlApi1103.setBizId(infoData.getDataId());
+            list.add(whjlApi1103);
+        }
+        return list;
     }
 
     /**
@@ -34,8 +72,19 @@
      * @return
      */
     @DataResolver
-    public String saveData(WhjlApi1103 data) {
-        return null;
+    public void saveData(WhjlApi1103 data) {
+        ApiInfoData infoData = new ApiInfoData();
+        infoData.setId(data.getBizId());
+        infoData.setKqdm(data.getKqdm());
+        infoData.setInteType(WhjlConstant.API_CATEGORY_11);
+        infoData.setInteId(WhjlConstant.API_CODE_1103);
+        infoData.setUpdateTime(new Date());
+        infoData.setDataId(data.getBizId());
+        infoData.setData(JSON.toJSONString(data));
+        infoData.setCzbz(data.getCzbz());
+        infoData.setRemarks("澶囨敞淇℃伅");
+
+        apiInfoDataRep.save(infoData);
     }
 
     /**
@@ -47,6 +96,7 @@
      */
     @Expose
     public String delData(WhjlApi1103 data) {
+        apiInfoDataRep.deleteById(data.getBizId());
         return null;
     }
 
@@ -59,6 +109,50 @@
      */
     @Expose
     public String pushData(List<WhjlApi1103> items) {
-        return null;
+        ResponseDto responseDto;
+        String result = "";
+
+        String kqdm = items.get(0).getKqdm();
+        ApiConfs apiConf = apiCommonService.getConf(kqdm);
+
+        if (null == apiConf) {
+            return "绯荤粺娌℃湁鑾峰彇鍒板綋鍓嶅簱鍖洪厤缃俊鎭紝鎵ц澶辫触";
+        }
+
+        //灏佽鍙傛暟
+        ApiParam param = new ApiParam(apiConf, WhjlConstant.API_CATEGORY_11, WhjlConstant.API_CODE_1103);
+
+        //鑾峰彇瀹炵幇鎺ュ彛
+        ApiRemoteService apiService = apiPushManager.getApiRemoteService(param.getPushProtocol());
+        if (null == apiService) {
+            return "绯荤粺娌℃湁褰撳墠鎺ㄩ�佸崗璁厤缃紝鎵ц澶辫触";
+        }
+
+        //鎺ㄩ�侊紝鏁版嵁涓洪泦鍚堝舰寮�
+        responseDto = apiService.pushData(param, apiConf, items);
+        if (responseDto.getSuccess() == 0) {
+            //鎺ㄩ�佹垚鍔燂紝鏇存柊鏁版嵁涓婁紶鐘舵��
+            ApiInfoData infoData;
+            for (WhjlApi1103 data : items) {
+                if (Constant.CZBZ_I.equals(data.getCzbz())) {
+
+                    infoData = new ApiInfoData();
+                    infoData.setId(data.getBizId());
+                    infoData.setKqdm(data.getKqdm());
+                    infoData.setInteType(WhjlConstant.API_CATEGORY_11);
+                    infoData.setInteId(WhjlConstant.API_CODE_1103);
+                    infoData.setUpdateTime(new Date());
+                    infoData.setDataId(data.getBizId());
+
+                    data.setCzbz(Constant.CZBZ_U);
+                    infoData.setCzbz(Constant.CZBZ_U);
+                    infoData.setData(JSON.toJSONString(data));
+
+                    apiInfoDataRep.save(infoData);
+                }
+            }
+            result += responseDto.toString();
+        }
+        return result;
     }
 }

--
Gitblit v1.9.3