From 4676c3c00f3e56ed65c149f4dd2c2697e0f1890c Mon Sep 17 00:00:00 2001
From: CZT <czt18638530771@163.com>
Date: 星期六, 07 十月 2023 09:58:23 +0800
Subject: [PATCH] 优化温湿度数据同步

---
 src/main/java/com/fzzy/api/view/pr/Api1108PR.java |   62 ++++++++++++++++++++++++++----
 1 files changed, 53 insertions(+), 9 deletions(-)

diff --git a/src/main/java/com/fzzy/api/view/pr/Api1108PR.java b/src/main/java/com/fzzy/api/view/pr/Api1108PR.java
index 23e2d4a..0fec5cc 100644
--- a/src/main/java/com/fzzy/api/view/pr/Api1108PR.java
+++ b/src/main/java/com/fzzy/api/view/pr/Api1108PR.java
@@ -4,6 +4,7 @@
 import com.bstek.dorado.annotation.DataResolver;
 import com.bstek.dorado.annotation.Expose;
 import com.fzzy.api.data.ApiParam;
+import com.fzzy.api.data.PushProtocol;
 import com.fzzy.api.entity.ApiConfs;
 import com.fzzy.api.service.ApiCommonService;
 import com.fzzy.api.service.ApiPushManager;
@@ -55,7 +56,7 @@
 		Api1108 data = new Api1108();
 		BeanUtils.copyProperties(entity, data);
 
-		data.setId(data.getId().trim());
+		data.setId(data.getBizId().trim());
 		api1108Rep.save(data);
 	}
 
@@ -97,22 +98,38 @@
 	 */
 	@Expose
 	public String pushData(List<Api1108> items) {
-		ResponseDto responseDto;
-		String result = "";
-		Api1108 d;
+
 		//鑾峰彇閰嶇疆
 		String kqdm = items.get(0).getKqdm();
 		ApiConfs apiConf = apiCommonService.getConf(kqdm);
 
 		if (null == apiConf) return "绯荤粺娌℃湁鑾峰彇鍒板綋鍓嶅簱鍖洪厤缃俊鎭紝鎵ц澶辫触";
 
-		//灏佽鍙傛暟
-		ApiParam param = new ApiParam(apiConf, Constant.API_CATEGORY_11, Constant.API_CODE_1108);
-
 		//鑾峰彇瀹炵幇鎺ュ彛
-		ApiRemoteService apiRemoteService = apiPushManager.getApiRemoteService(param.getPushProtocol());
+		ApiRemoteService apiRemoteService = apiPushManager.getApiRemoteService(apiConf.getPushProtocol());
 		if (null == apiRemoteService) return "绯荤粺娌℃湁褰撳墠鎺ㄩ�佸崗璁厤缃紝鎵ц澶辫触";
 
+		if (PushProtocol.SB_SH_2023.getCode().equals(apiConf.getPushProtocol())){
+			return pushDataList(items,apiRemoteService,apiConf);
+		}
+		return pushDataSingle(items,apiRemoteService,apiConf);
+	}
+
+	/**
+	 * 鍗曟潯鏁版嵁json鎺ㄩ��
+	 *
+	 * @param items
+	 * @param apiRemoteService
+	 * @param apiConf
+	 * @return
+	 */
+	private String pushDataSingle(List<Api1108> items, ApiRemoteService apiRemoteService, ApiConfs apiConf) {
+		ResponseDto responseDto;
+		String result = "";
+
+		//灏佽鍙傛暟
+		ApiParam param = new ApiParam(apiConf, Constant.API_CATEGORY_11, Constant.API_CODE_1108);
+		Api1108 d;
 		for (Api1108 data : items) {
 			d = new Api1108();
 			BeanUtils.copyProperties(data, d);
@@ -122,11 +139,38 @@
 			result += responseDto.toString();
 			if (responseDto.getSuccess() == 0) {
 				if (Constant.CZBZ_I.equals(d.getCzbz())) {
-					api1108Rep.updateStatus(data.getKqdm(), Constant.CZBZ_U);
+					api1108Rep.updateStatus(data.getId(), Constant.CZBZ_U);
 				}
 			}
 		}
 		return result;
 	}
 
+	/**
+	 * 澶氭潯鏁版嵁json鎺ㄩ��
+	 *
+	 * @param items
+	 * @param apiRemoteService
+	 * @param apiConf
+	 * @return
+	 */
+	private String pushDataList(List<Api1108> items, ApiRemoteService apiRemoteService, ApiConfs apiConf) {
+
+		//灏佽鍙傛暟
+		ApiParam param = new ApiParam(apiConf, Constant.API_CATEGORY_11, Constant.API_CODE_1108);
+
+		//鎺ㄩ�侊紝鏁版嵁涓洪泦鍚堝舰寮�
+		ResponseDto responseDto = apiRemoteService.pushData(param, apiConf, items);
+		if (responseDto.getSuccess() == 0) {
+			//鎺ㄩ�佹垚鍔燂紝鏇存柊鏁版嵁涓婁紶鐘舵��
+			for (Api1108 data : items) {
+				if (Constant.CZBZ_I.equals(data.getCzbz())) {
+					//鏇存柊鐘舵��
+					api1108Rep.updateStatus(data.getId(), Constant.CZBZ_U);
+				}
+			}
+		}
+		return responseDto.toString();
+	}
+
 }

--
Gitblit v1.9.3