From 781564409e34d9881e3f27ebc110161e4232f5ed Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期三, 11 五月 2022 17:32:15 +0800
Subject: [PATCH] 客户新增优化

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java |   34 +++++++++++++++-------------------
 1 files changed, 15 insertions(+), 19 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java
index 869765b..10e620e 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/AirDataController.java
@@ -1,6 +1,5 @@
 package com.sandu.ximon.admin.controller;
 
-import com.alibaba.fastjson.JSON;
 import com.sandu.common.domain.ResponseVO;
 import com.sandu.common.object.BaseConditionVO;
 import com.sandu.common.util.ResponseUtil;
@@ -9,9 +8,11 @@
 import com.sandu.ximon.admin.manager.iot.frame.inner.request.AirDataReqInnerFrame;
 import com.sandu.ximon.admin.manager.iot.rrpc.dto.CommonFrame;
 import com.sandu.ximon.admin.manager.iot.rrpc.enums.A5OrderEnum;
+import com.sandu.ximon.admin.manager.iot.rrpc.enums.AtmoFunctionCode;
 import com.sandu.ximon.admin.manager.iot.rrpc.mainboard.MainBoardInvokeSyncService;
 import com.sandu.ximon.admin.security.PermissionConfig;
 import com.sandu.ximon.admin.service.AirDataService;
+import com.sandu.ximon.admin.utils.RedisUtils;
 import com.sandu.ximon.dao.bo.AirDataBo;
 import com.sandu.ximon.dao.enums.MenuEnum;
 import lombok.AllArgsConstructor;
@@ -31,6 +32,7 @@
 public class AirDataController {
     private final AirDataService airDataService;
     private PermissionConfig permissionConfig;
+    private RedisUtils redisUtils;
 
     /**
      * 鏌ヨ澶ф皵鏁版嵁妯$硦鏌ヨ
@@ -47,23 +49,14 @@
         return ResponseUtil.successPage(list);
     }
 
-    /**
-     * 鏌ヨ澶ф皵璁惧MAC鍦板潃
-     *
-     * @return
-     */
-    @GetMapping("/listAirEquipmentMAC")
-    public ResponseVO<Object> listAirEquipmentMAC() {
-        List<String> list = airDataService.listAirEquipmentMAC();
-        return ResponseUtil.success(list);
-    }
-
     @PostMapping("/updateAirEquipmentInfo")
     public ResponseVO<Object> updataAirEquipmentInfo(@RequestBody List<String> listMac) {
+        if (!permissionConfig.check(MenuEnum.AIR_DATA_UPDATE.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         AirDataReqInnerFrame airDataReqInnerFrame = new AirDataReqInnerFrame();
         A5Frame a5Frame = new A5Frame(A5OrderEnum.REQUEST_ATMOSPHERE_DATA.getCode(), airDataReqInnerFrame);
-//        WrapResponseCommonFrame<A5AtmosphereHeartbeatReportInnerFrame> wrapResponseCommonFrame =
-//                MainBoardInvokeSyncService.getInstance().sendRRPC(listMac.get(0), a5Frame, A5AtmosphereHeartbeatReportInnerFrame.class);
+        System.out.println(a5Frame + "          --------a5Frame");
 
         List<String> success = new ArrayList<>();
         List<String> failed = new ArrayList<>();
@@ -71,12 +64,15 @@
         listMac.parallelStream().forEach(macStr -> {
             try {
                 CommonFrame commonFrame = MainBoardInvokeSyncService.getInstance().sendRRPC(macStr, a5Frame);
-//                //娴嬭瘯鐢ㄧ殑
-//                String s = "{\"connectType\":\"FE\",\"crc32\":\"8685DF1B\",\"functionCode\":\"A5\",\"orderType\":\"84\",\"payload\":\"F0010022FFFF0101016666640000000000000000419D000000360089000000000002019300008CA14C69\",\"payloadLength\":\"002A\",\"validate\":true}";
-//                CommonFrame commonFrame1 = JSON.parseObject(s, CommonFrame.class);
-//                AirDataProcessor.getInstance().process("a1JsfPG4iKW",macStr,commonFrame1);
-                AirDataProcessor.getInstance().process("a1JsfPG4iKW",macStr,commonFrame);
+                System.out.println(commonFrame + "         -----------commonFrame");
+                AirDataProcessor.getInstance().process("a1JsfPG4iKW", macStr, commonFrame);
                 if (commonFrame != null) {
+
+                    //瀛樼紦瀛樺績璺冲寘
+                    RedisUtils.getBean().set(AtmoFunctionCode.AIR_HEARTBEAT.getCode() + macStr, commonFrame);
+                    //瀛樼紦瀛樼姸鎬�
+                    RedisUtils.getBean().set(AtmoFunctionCode.AIR_HEARTBEAT_STATE.getCode() + macStr, commonFrame, 300L);
+
                     success.add(macStr);
                 } else {
                     failed.add(macStr);

--
Gitblit v1.9.3