From cda9d3a12240ad659efc11603862487d946715b2 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期三, 27 四月 2022 18:14:08 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightPoleHeelingService.java |   42 +++++++++++++++++++++++++++++++++++++-----
 1 files changed, 37 insertions(+), 5 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightPoleHeelingService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightPoleHeelingService.java
index f06649f..347691d 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightPoleHeelingService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightPoleHeelingService.java
@@ -11,10 +11,14 @@
 import com.sandu.ximon.admin.manager.iot.frame.inner.request.*;
 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.LightPoleHeelingEnum;
 import com.sandu.ximon.admin.manager.iot.rrpc.mainboard.MainBoardInvokeSyncService;
 import com.sandu.ximon.admin.param.LightPoleHeelingListParam;
+import com.sandu.ximon.admin.security.SecurityUtils;
+import com.sandu.ximon.admin.utils.RedisUtils;
 import com.sandu.ximon.dao.domain.Light;
 import com.sandu.ximon.dao.domain.LightPoleHeeling;
+import com.sandu.ximon.dao.domain.LightPoleHeelingEquipment;
 import com.sandu.ximon.dao.domain.PoleBinding;
 import com.sandu.ximon.dao.mapper.LightPoleHeelingMapper;
 import lombok.AllArgsConstructor;
@@ -26,12 +30,15 @@
 @AllArgsConstructor
 public class LightPoleHeelingService extends BaseServiceImpl<LightPoleHeelingMapper, LightPoleHeeling> {
     private LightPoleHeelingMapper lightPoleHeelingMapper;
+    private LightPoleHeelingEquipmentService lightPoleHeelingEquipmentService;
 
     /**
      * 妯$硦鏌ヨ
      */
     public List<LightPoleHeeling> listLightPoleHeelingByKeyword(BaseConditionVO baseConditionVO, LightPoleHeelingListParam lightPoleHeelingListParam) {
-        PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
+        if (baseConditionVO != null) {
+            PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
+        }
         if (lightPoleHeelingListParam == null) {
             lightPoleHeelingListParam = new LightPoleHeelingListParam();
         }
@@ -41,10 +48,23 @@
             lightPoleHeelingListParam.setKeyword(lightPoleHeelingListParam.getKeyword().trim());
         }
 
-        List<LightPoleHeeling> lightPoleHeelings
-                = lightPoleHeelingMapper.listLightPoleHeeling(lightPoleHeelingListParam.getKeyword(), lightPoleHeelingListParam.getProcessingState());
+        List<LightPoleHeeling> lightPoleHeelings;
+        if (SecurityUtils.getClientId() == null) {
+            lightPoleHeelings = lightPoleHeelingMapper.listLightPoleHeeling(lightPoleHeelingListParam.getKeyword()
+                    , lightPoleHeelingListParam.getProcessingState(), null);
+        } else {
+            lightPoleHeelings = lightPoleHeelingMapper.listLightPoleHeeling(lightPoleHeelingListParam.getKeyword()
+                    , lightPoleHeelingListParam.getProcessingState(), SecurityUtils.getUserId());
+        }
 
         return lightPoleHeelings;
+    }
+
+    /**
+     * 鏍规嵁Mac鑾峰彇鏈�鏂版暟鎹�
+     */
+    public LightPoleHeeling getLightPoleHeelingByMac(String mac) {
+        return getOne(Wrappers.lambdaQuery(LightPoleHeeling.class).eq(LightPoleHeeling::getMac, mac));
     }
 
     /**
@@ -139,7 +159,7 @@
         LightPoleHeelingSetHeartbeatPacketTimeReqInnerFrame setHeartbeatPacketTimeReqInnerFrame =
                 new LightPoleHeelingSetHeartbeatPacketTimeReqInnerFrame(setTime);
 
-        A5Frame a5Frame = new A5Frame(A5OrderEnum.REQUEST_C3_DATA.getCode(), setHeartbeatPacketTimeReqInnerFrame);
+        A5Frame a5Frame = new A5Frame(A5OrderEnum.REQUEST_POLE_MONITOR_DATA.getCode(), setHeartbeatPacketTimeReqInnerFrame);
         System.out.println(a5Frame + "            -----a5Frame");
 
         CommonFrame commonFrame = MainBoardInvokeSyncService.getInstance().sendRRPC(devicesName, a5Frame);
@@ -163,7 +183,7 @@
         LightPoleHeelingSetSensorStateReqInnerFrame setSensorStateReqInnerFrame =
                 new LightPoleHeelingSetSensorStateReqInnerFrame();
 
-        A5Frame a5Frame = new A5Frame(A5OrderEnum.REQUEST_C3_DATA.getCode(), setSensorStateReqInnerFrame);
+        A5Frame a5Frame = new A5Frame(A5OrderEnum.REQUEST_POLE_MONITOR_DATA.getCode(), setSensorStateReqInnerFrame);
         System.out.println(a5Frame + "            -----a5Frame");
 
         CommonFrame commonFrame = MainBoardInvokeSyncService.getInstance().sendRRPC(devicesName, a5Frame);
@@ -201,6 +221,18 @@
             lightPoleHeeling.setWarningLevel(0);//姝e父
         }
 
+        //瀛樺偍璁惧鐘舵�佸埌缂撳瓨
+        RedisUtils.getBean().set(LightPoleHeelingEnum.LIGHT_POLE_HEELING_STATE.getCode() + deviceName
+                , heartBeatDataPackage, 300L);
+        /**
+         * 灏嗙伅鏉嗗�炬枩纭欢娣诲姞鍒扮‖浠惰〃
+         */
+        LightPoleHeelingEquipment one = lightPoleHeelingEquipmentService.getOne(Wrappers.lambdaQuery(LightPoleHeelingEquipment.class).eq(LightPoleHeelingEquipment::getMac, deviceName));
+        if (one == null) {
+            LightPoleHeelingEquipment equipment = new LightPoleHeelingEquipment();
+            equipment.setMac(deviceName);
+        }
+
         return save(lightPoleHeeling);
     }
 }

--
Gitblit v1.9.3