From b353cecfa4181d281243df5a70d1de5cc373e35d Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期二, 06 九月 2022 15:51:44 +0800
Subject: [PATCH] changes

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/PoleService.java |  145 +++++++++++++++---------------------------------
 1 files changed, 46 insertions(+), 99 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/PoleService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/PoleService.java
index c41fbda..aa3193a 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/PoleService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/PoleService.java
@@ -14,7 +14,6 @@
 import com.sandu.common.service.impl.BaseServiceImpl;
 import com.sandu.common.util.SpringContextHolder;
 import com.sandu.ximon.admin.dto.DeviceStatus;
-import com.sandu.ximon.admin.dto.WaterQualityDataDto;
 import com.sandu.ximon.admin.manager.iot.frame.A1Frame;
 import com.sandu.ximon.admin.manager.iot.frame.FrameBuilder;
 import com.sandu.ximon.admin.manager.iot.frame.IRequestFrame;
@@ -25,14 +24,18 @@
 import com.sandu.ximon.admin.manager.iot.frame.inner.response.A1DeviceMacRespInnerFrame;
 import com.sandu.ximon.admin.manager.iot.frame.inner.response.A1TernaryCodeRespInnerFrame;
 import com.sandu.ximon.admin.manager.iot.rrpc.dto.CommonFrame;
-import com.sandu.ximon.admin.manager.iot.rrpc.enums.*;
+import com.sandu.ximon.admin.manager.iot.rrpc.enums.A1OrderEnum;
+import com.sandu.ximon.admin.manager.iot.rrpc.enums.A2OrderEnum;
+import com.sandu.ximon.admin.manager.iot.rrpc.enums.A5OrderEnum;
+import com.sandu.ximon.admin.manager.iot.rrpc.enums.DeviceStateEnum;
 import com.sandu.ximon.admin.manager.iot.rrpc.mainboard.MainBoardInvokeSyncService;
-import com.sandu.ximon.admin.param.*;
+import com.sandu.ximon.admin.param.PoleBindingParam;
+import com.sandu.ximon.admin.param.PoleParam;
+import com.sandu.ximon.admin.param.PoleStatesParam;
 import com.sandu.ximon.admin.redis.LightKey;
 import com.sandu.ximon.admin.security.SecurityUtils;
 import com.sandu.ximon.admin.utils.LightemitUtils;
 import com.sandu.ximon.admin.utils.ListPagingUtils;
-import com.sandu.ximon.admin.utils.RedisUtils;
 import com.sandu.ximon.admin.utils.StoreOperationRecordsUtils;
 import com.sandu.ximon.admin.utils.response.VnnoxResult;
 import com.sandu.ximon.admin.vo.PoleBindVO;
@@ -71,6 +74,7 @@
         BeanUtils.copyProperties(param, pole);
         pole.setPoleCode(generatePoleCode());
         pole.setDeviceType(-1);
+        pole.setCentre(1);
         boolean save = save(pole);
 
         /**
@@ -99,6 +103,9 @@
         Pole update = new Pole();
         BeanUtils.copyProperties(param, update);
         update.setId(poleId);
+        if (param.getIsCenter() != null) {
+            update.setCentre(param.getIsCenter());
+        }
         /**
          * 淇敼鐏潌鏃ュ織璁板綍寮�濮�
          */
@@ -160,7 +167,7 @@
      */
     public Map<String, Integer> poleCount() {
         Map<String, Integer> result = new HashMap<>();
-        LambdaQueryWrapper<Pole> wrapper = new LambdaQueryWrapper<>();
+        LambdaQueryWrapper<Pole> wrapper;
         if (SecurityUtils.getClientId() == null) {
             wrapper = Wrappers.lambdaQuery(Pole.class);
         } else {
@@ -168,120 +175,49 @@
                 w.eq(Pole::getUserId, SecurityUtils.getUserId());
             });
         }
+
         //鐏潌
         List<Pole> list = list(wrapper);
-        List<Pole> poles = isOnLine(list);
-        result.put("poleOnlineCount", poles.size());
         result.put("poleTotalCount", list.size());
 
         //璇虹摝
-        List<LedPlayerEntity> ledPlayerEntities = SpringContextHolder.getBean(LedPlayerEntityService.class).ledPlayerEntityList(null, null, null, null);
-        int number = 0;
-        for (LedPlayerEntity bean : ledPlayerEntities) {
-            if (bean.getOnlineStatus() == 1) {
-                number++;
-            }
-        }
-        result.put("novaOnlineCount", number);
+        List<LedPlayerEntity> ledPlayerEntities = SpringContextHolder.getBean(LedPlayerEntityService.class).ledPlayerEntityListOnHome();
         result.put("novaTotalCount", ledPlayerEntities.size());
 
         //ip闊虫煴
-        number = 0;
-        BroadcastTerminalV2Param broadcastTerminalV2Param = new BroadcastTerminalV2Param();
-        broadcastTerminalV2Param.setBindingState(2);
-        broadcastTerminalV2Param.setWorkState(2);
-        List<BroadcastTerminalV2EntityBo> broadcastTerminalList = SpringContextHolder.getBean(IpVolumeService.class).getBroadcastTerminalList(null, null, null, broadcastTerminalV2Param);
-        for (BroadcastTerminalV2EntityBo bean : broadcastTerminalList) {
-            if (bean.getStatus() != 0) {
-                number++;
-            }
-        }
-        result.put("broadcastOnlineCount", number);
+        List<BroadcastTerminalV2EntityBo> broadcastTerminalList = SpringContextHolder.getBean(IpVolumeService.class).getBroadcastTerminalListOnHome();
         result.put("broadcastTotalCount", broadcastTerminalList.size());
 
         //鎽勫儚澶�
-        number = 0;
-        MonitorParam monitorParam = new MonitorParam();
-        monitorParam.setEquipmentState(2);
-        monitorParam.setBindingState(2);
-        List<MonitorBo> monitorBos = SpringContextHolder.getBean(MonitorService.class).listMonitorByKeyword(null, null, null, monitorParam).getList();
-        monitorParam.setEquipmentState(1);
-        List<MonitorBo> online = SpringContextHolder.getBean(MonitorService.class).listMonitorByKeyword(null, null, null, monitorParam).getList();
-        result.put("monitorOnlineCount", online.size());
+
+        List<MonitorBo> monitorBos = SpringContextHolder.getBean(MonitorService.class).listMonitorOnHome();
         result.put("monitorTotalCount", monitorBos.size());
 
         //鍗曠伅
-        number = 0;
-        List<Light> lights = SpringContextHolder.getBean(LightService.class).listLight();
-        for (Light light : lights) {
-            if (light.getOnlineStatus() == 1) {
-                number++;
-            }
-        }
-        result.put("LightOnlineCount", number);
+        List<LightBo> lights = SpringContextHolder.getBean(LightService.class).listLightOnHome();
         result.put("LightTotalCount", lights.size());
 
         //鍏呯數妗�
-        number = 0;
-        List<C3ChargingBo> c3mChargings = SpringContextHolder.getBean(C3ChargingService.class).getC3ChargingListByKeyword(null, null);
-        for (C3ChargingBo c3ChargingBo : c3mChargings) {
-            if (c3ChargingBo.getStatusBit() != 0) {
-                number++;
-            }
-        }
-        result.put("C3ChargingOnlineCount", number);
+        List<C3ChargingBo> c3mChargings = SpringContextHolder.getBean(C3ChargingService.class).getC3ChargingList();
         result.put("C3ChargingTotalCount", c3mChargings.size());
 
-
         //澶ф皵
-        number = 0;
-        List<AirEquipmentBo> airEquipments = SpringContextHolder.getBean(AirEquipmentService.class).listAirEquipmentByKeyword(null, null);
-        for (AirEquipmentBo airEquipmentBo : airEquipments) {
-            if (RedisUtils.getBean().get(AtmoFunctionCode.AIR_HEARTBEAT_STATE.getCode() + airEquipmentBo.getMac()) != null) {
-                number++;
-            }
-        }
-        result.put("AirEquipmentOnlineCount", number);
+        List<AirEquipmentBo> airEquipments = SpringContextHolder.getBean(AirEquipmentService.class).listAirEquipmentOnHome();
         result.put("AirEquipmentTotalCount", airEquipments.size());
         //澶ф皵(鍐滆��)
-        number = 0;
-        List<AirEquipmentNongGengBo> airEquipmentNongGengBos = SpringContextHolder.getBean(AirEquipmentNongGengService.class).listAirEquipmentByKeyword(null, null);
-        for (AirEquipmentNongGengBo airEquipmentNongGengBo : airEquipmentNongGengBos) {
-            if (RedisUtils.getBean().get(AtmoFunctionCode.AIR_HEARTBEAT_NONG_GENG_STATE.getCode() + airEquipmentNongGengBo.getMac()) != null) {
-                number++;
-            }
-        }
-        result.put("AirEquipmentNongGengOnlineCount", number);
+        List<AirEquipmentNongGengBo> airEquipmentNongGengBos = SpringContextHolder.getBean(AirEquipmentNongGengService.class).listAirEquipmentOnHome();
         result.put("AirEquipmentNongGengTotalCount", airEquipmentNongGengBos.size());
+
         //姘磋川
-        number = 0;
         List<WaterQualityEquipmentBo> waterQualityEquipments = SpringContextHolder.getBean(WaterQualityEquipmentService.class).listWaterQualityEquipmentByKeyword(null, null);
-
-        for (WaterQualityEquipmentBo waterQualityEquipmentBo : waterQualityEquipments) {
-            WaterQualityDataDto waterQualityDataDto = SpringContextHolder.getBean(WaterQualityDataService.class).getWaterQualityDataInfo(waterQualityEquipmentBo.getWaterQualityEquipmentCode());
-            if (waterQualityDataDto != null) {
-                number++;
-            }
-        }
-        result.put("WaterQualityEquipmentOnlineCount", number);
         result.put("WaterQualityEquipmentTotalCount", waterQualityEquipments.size());
-        //鐏潌鍊炬枩
-        number = 0;
-        List<LightPoleHeeling> lightPoleHeelings = SpringContextHolder.getBean(LightPoleHeelingService.class).listLightPoleHeelingByKeyword(null, null);
 
-        for (LightPoleHeeling lightPoleHeeling : lightPoleHeelings) {
-            if (RedisUtils.getBean().get(LightPoleHeelingEnum.LIGHT_POLE_HEELING_STATE.getCode() + lightPoleHeeling.getMac()) != null) {
-                number++;
-            }
-        }
-        result.put("LightPoleHeelingOnlineCount", number);
-        result.put("LightPoleHeelingTotalCount", lightPoleHeelings.size());
+        //鐏潌鍊炬枩
+        List<LightPoleHeelingEquipmentBo> lightPoleHeelingEquipmentBos = SpringContextHolder.getBean(LightPoleHeelingEquipmentService.class).LightPoleHeelingEquipmentListOnHome();
+        result.put("LightPoleHeelingTotalCount", lightPoleHeelingEquipmentBos.size());
 
         //鐔欒
-        List<PoleLightemitEntity> poleLightemitEntities = SpringContextHolder.getBean(PoleLightemitService.class).listLed(null, null, null, false);
-        List<PoleLightemitEntity> poleLightemitEntityOnlineList = SpringContextHolder.getBean(PoleLightemitService.class).listLed(null, null, null, true);
-
-        result.put("XiXunOnlineCount", poleLightemitEntityOnlineList.size());
+        List<PoleLightemitEntity> poleLightemitEntities = SpringContextHolder.getBean(PoleLightemitService.class).listLedOnHome();
         result.put("XiXunTotalCount", poleLightemitEntities.size());
 
         return result;
@@ -326,14 +262,22 @@
         String orderBy = "t1." + orderByResult + " " + orderBySeq;
 
         List<Pole> poleList;
+        Integer center = param.getCenter();
         if (SecurityUtils.getClientId() == null) {
             poleList = poleMapper.queryPoleOnLineStatesList(null, param.getIsTrue(),
-                    param.getBingStates(), param.getGroupid(), param.getKeyword(), orderBy);
+                    param.getBingStates(), param.getGroupid(), param.getKeyword(), center, orderBy);
         } else {
             poleList = poleMapper.queryPoleOnLineStatesList(SecurityUtils.getUserId(),
-                    param.getIsTrue(), param.getBingStates(), param.getGroupid(), param.getKeyword(), orderBy);
+                    param.getIsTrue(), param.getBingStates(), param.getGroupid(), param.getKeyword(), center, orderBy);
         }
 
+        poleList.forEach(
+                centre -> {
+                    if (centre.getCentre() == 0) {
+                        centre.setCenter(true);
+                    }
+                }
+        );
         List<Pole> PoleResult = isOnLine(poleList, param);
         setCount(PoleResult);
 
@@ -569,10 +513,10 @@
      */
     public boolean poleReset(Long id) {
         Pole byId = getById(id);
-        String deviceName = byId.getDeviceCode();
         if (byId == null) {
             throw new BusinessException("鏈壘鍒拌鐏潌");
         }
+        String deviceName = byId.getDeviceCode();
         if (deviceName.isEmpty()) {
             throw new BusinessException("璇ョ伅鏉哅ca涓虹┖");
         }
@@ -699,17 +643,20 @@
         boolean result = saveOrUpdate(pole);
 
         if (result) {
-            Light light = new Light();
-            light.setDeviceCode(uniqueMac);
-            light.setLightCount(2);
-            SpringContextHolder.getBean(LightService.class).save(light);
+            Light light = SpringContextHolder.getBean(LightService.class).getOne(Wrappers.lambdaQuery(Light.class).eq(Light::getDeviceCode, pole.getDeviceCode()).last("limit 1"));
+            if (light == null) {
+                light = new Light();
+                light.setDeviceCode(uniqueMac);
+                light.setLightCount(2);
+                SpringContextHolder.getBean(LightService.class).save(light);
+            }
         }
 
         /**
          * 瀹炰綋鐏潌娉ㄥ唽鏃ュ織璁板綍寮�濮�
          */
-//        String content = "{鐏潌ID锛�" + pole.getId() + ",鐏潌缂栧彿锛�" + pole.getPoleCode() + ",鐏潌鍚嶇О锛�" + pole.getPoleName() + ",鐏潌绫诲瀷锛�" + pole.getDeviceType() + ",鐏潌MAC锛�" + pole.getDeviceCode() + " }";
-//        StoreOperationRecordsUtils.storeOperationData(null, null, "瀹炰綋鐏潌娉ㄥ唽", content);
+        String content = "{鐏潌ID锛�" + pole.getId() + ",鐏潌缂栧彿锛�" + pole.getPoleCode() + ",鐏潌鍚嶇О锛�" + pole.getPoleName() + ",鐏潌绫诲瀷锛�" + pole.getDeviceType() + ",鐏潌MAC锛�" + pole.getDeviceCode() + " }";
+        StoreOperationRecordsUtils.storeOperationData(null, null, "瀹炰綋鐏潌娉ㄥ唽", content);
         /**
          * 瀹炰綋鐏潌娉ㄥ唽鏃ュ織璁板綍缁撴潫
          */

--
Gitblit v1.9.3