From c8ce26aac0004e249a0cef35fe15b2ddb280ad25 Mon Sep 17 00:00:00 2001
From: liuhaonan <konodioda2333@vip.qq.com>
Date: 星期三, 27 四月 2022 15:51:10 +0800
Subject: [PATCH] 大气数据推送到LED

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/AirDataService.java |   44 +++++++++++++++++++++++++++++++++++++-------
 1 files changed, 37 insertions(+), 7 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/AirDataService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/AirDataService.java
index 5cabbbc..18eab04 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/AirDataService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/AirDataService.java
@@ -5,9 +5,12 @@
 import com.github.pagehelper.PageHelper;
 import com.sandu.common.object.BaseConditionVO;
 import com.sandu.common.service.impl.BaseServiceImpl;
-import com.sandu.ximon.admin.security.SecurityUtils;
-import com.sandu.ximon.dao.bo.AirDataBo;
+import com.sandu.common.util.ResUtils;
 import com.sandu.ximon.admin.manager.iot.frame.inner.report.A5AtmosphereHeartbeatReportInnerFrame;
+import com.sandu.ximon.admin.manager.iot.rrpc.enums.AtmoFunctionCode;
+import com.sandu.ximon.admin.security.SecurityUtils;
+import com.sandu.ximon.admin.utils.RedisUtils;
+import com.sandu.ximon.dao.bo.AirDataBo;
 import com.sandu.ximon.dao.domain.AirData;
 import com.sandu.ximon.dao.domain.AirEquipment;
 import com.sandu.ximon.dao.mapper.AirDataMapper;
@@ -41,6 +44,9 @@
         airEquipment.setCreateTime(airData.getCreateTime());
         airEquipmentService.addAirEquipment(airEquipment);
 
+        //瀛樼紦瀛�
+        RedisUtils.getBean().set(AtmoFunctionCode.AIR_HEARTBEAT.getCode() + deviceName, heartBeatDataPackage, 300L);
+
         return save(airData);
     }
 
@@ -48,11 +54,15 @@
      * 鏌ヨ澶ф皵鏁版嵁(妯$硦鏌ヨ)
      */
     public List<AirDataBo> listAirDataByKeyword(BaseConditionVO baseConditionVO, String keyword) {
-        Long clientId = SecurityUtils.getClientId();
-        PageHelper.startPage(baseConditionVO.getPageNo(),baseConditionVO.getPageSize());
-        List<Long> listAirId = baseMapper.listAirId(keyword,clientId);
-        if(CollUtil.isEmpty(listAirId)){
-            return null;
+        PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
+        List<Long> listAirId;
+        if (SecurityUtils.getClientId() == null) {
+            listAirId = baseMapper.listAirId(keyword, null);
+        } else {
+            listAirId = baseMapper.listAirId(keyword, SecurityUtils.getUserId());
+        }
+        if (CollUtil.isEmpty(listAirId)) {
+            return CollUtil.newArrayList();
         }
         List<AirDataBo> airDataBos = baseMapper.listAirDataByIds(listAirId);
         return airDataBos;
@@ -66,4 +76,24 @@
         return airDataMapper.listAirEquipmentMAC();
     }
 
+    /**
+     * +
+     * 鏍规嵁鐏潌id鏌ヨ澶ф皵鏁版嵁
+     */
+    public A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage getDataByPoleid(Long poleId) {
+        String code;
+        if (SecurityUtils.getClientId() != null) {
+            code = baseMapper.getCodeByPoleId(poleId, SecurityUtils.getUserId());
+        } else {
+            code = baseMapper.getCodeByPoleId(poleId, null);
+        }
+        A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage heartBeatDataPackage
+                = RedisUtils.getBean().get(AtmoFunctionCode.AIR_HEARTBEAT.getCode() + code, A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage.class);
+        if (heartBeatDataPackage == null) {
+            return null;
+        }
+
+        return heartBeatDataPackage;
+    }
+
 }

--
Gitblit v1.9.3