From 3945388625b6577a2574a88f109e314fe58dbe67 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期二, 17 五月 2022 16:57:09 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/MonitorService.java |   87 +++++++++++++++++++++++++++++++++++++++----
 1 files changed, 78 insertions(+), 9 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/MonitorService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/MonitorService.java
index dbb3a1b..9202b91 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/MonitorService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/MonitorService.java
@@ -8,14 +8,18 @@
 import com.sandu.common.execption.BusinessException;
 import com.sandu.common.object.BaseConditionVO;
 import com.sandu.common.service.impl.BaseServiceImpl;
+import com.sandu.common.util.SpringContextHolder;
+import com.sandu.ximon.admin.dto.YSY_AccessTokenDto;
+import com.sandu.ximon.admin.dto.YSY_MonitorDto;
 import com.sandu.ximon.admin.param.MonitorParam;
 import com.sandu.ximon.admin.security.SecurityUtils;
 import com.sandu.ximon.admin.utils.ListPagingUtils;
+import com.sandu.ximon.admin.utils.StoreOperationRecordsUtils;
+import com.sandu.ximon.admin.vo.EquipmentInfomation;
 import com.sandu.ximon.dao.bo.MonitorBo;
 import com.sandu.ximon.dao.domain.Monitor;
-import com.sandu.ximon.admin.dto.YSY_AccessTokenDto;
-import com.sandu.ximon.admin.dto.YSY_MonitorDto;
 import com.sandu.ximon.dao.domain.PoleBinding;
+import com.sandu.ximon.dao.enums.PoleBindingEnums;
 import com.sandu.ximon.dao.mapper.MonitorMapper;
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
@@ -99,6 +103,11 @@
             }
         }
 
+        if (baseConditionVO == null) {
+            baseConditionVO = new BaseConditionVO();
+            baseConditionVO.setPageSize(null);
+            baseConditionVO.setPageNo(null);
+        }
         CommonPage commonPage = ListPagingUtils.pages(temp, baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
         return commonPage;
     }
@@ -154,6 +163,16 @@
             //鍒犻櫎鎽勫儚澶磋澶囧墠闇�瑕佸厛瑙g粦
             poleBindingService.unBindPole(null, monitor.getDeviceSerial());
         }
+        /**
+         * 鍒犻櫎鎽勫儚澶存棩蹇楄褰曞紑濮�
+         */
+        String content = "{鎽勫儚澶碈ode锛�" + monitor.getDeviceSerial() + "锛� 鎽勫儚澶村悕绉帮細" + monitor.getDeviceName() + " }";
+        List<String> listCode = new ArrayList<>();
+        listCode.add(monitor.getDeviceSerial());
+        StoreOperationRecordsUtils.storeOperationData(listCode, null, "鍒犻櫎鎽勫儚澶�", content);
+        /**
+         * 鍒犻櫎鎽勫儚澶存棩蹇楄褰曠粨鏉�
+         */
         return removeById(Id);
     }
 
@@ -206,20 +225,40 @@
      *
      * @return
      */
-    public YSY_MonitorDto.MonitorDto getMonitorInfo(String deviceSerial) {
+    public EquipmentInfomation getMonitorInfo(String deviceSerial) {
+        EquipmentInfomation equipmentInfo = new EquipmentInfomation();
+        equipmentInfo.setEquipmentType("鎽勫儚澶�");
+        if (deviceSerial == null || deviceSerial.trim().length() == 0) {
+            return equipmentInfo;
+        }
+
+        Monitor one = getOne(Wrappers.lambdaQuery(Monitor.class).eq(Monitor::getDeviceSerial, deviceSerial));
+        if (one != null) {
+            equipmentInfo.setEquipmentCreateTime(one.getAddTime());
+            equipmentInfo.setEquipmentMac(one.getDeviceSerial());
+            equipmentInfo.setEquipmentName(one.getDeviceName());
+        }
+
         String token = getAccessToken();
         Map<String, Object> paramMap = new HashMap<>();
         paramMap.put("accessToken", token);
         paramMap.put("deviceSerial", deviceSerial);
         String s = HttpUtil.post(YSY_URL + GET_DEVICE_URL, paramMap);
-        YSY_MonitorDto monitorDto = null;
+
         try {
-            monitorDto = JSON.parseObject(s, YSY_MonitorDto.class);
-            return monitorDto.getData();
+            YSY_MonitorDto monitorDto = JSON.parseObject(s, YSY_MonitorDto.class);
+            if (monitorDto != null) {
+                //鍦ㄧ嚎鐘舵�侊細0-涓嶅湪绾匡紝1-鍦ㄧ嚎
+                if (monitorDto.getData().getStatus() == 1) {
+                    equipmentInfo.setEquipmentState("鍦ㄧ嚎");
+                } else {
+                    equipmentInfo.setEquipmentState("绂荤嚎");
+                }
+            }
         } catch (Exception e) {
             e.printStackTrace();
         }
-        return null;
+        return equipmentInfo;
     }
 
     /**
@@ -238,6 +277,7 @@
         String s = HttpUtil.post(YSY_URL + ADD_DEVICE_URL, paramMap);
         YSY_MonitorDto monitorDto = JSON.parseObject(s, YSY_MonitorDto.class);
 
+        boolean result;
         if ("200".equals(monitorDto.getCode()) || "20017".equals(monitorDto.getCode())) {
             Monitor monitor = new Monitor();
             monitor.setDeviceSerial(monitorDto.getData().getDeviceSerial());
@@ -247,10 +287,23 @@
             monitor.setIsEncrypt(monitorDto.getData().getIsEncrypt());
             monitor.setDeviceType(monitorDto.getData().getModel());
             monitor.setNetAddress(monitorDto.getData().getNetAddress());
-            return addMonitorInfoToTable(monitor);
+            result = addMonitorInfoToTable(monitor);
+
+            /**
+             * 鏂板鎽勫儚澶村紑濮�
+             */
+            String content = "{鎽勫儚澶碈ode锛�" + monitor.getDeviceSerial() + "锛� 鎽勫儚澶村悕绉帮細" + monitor.getDeviceName() + " }";
+            List<String> listCode = new ArrayList<>();
+            listCode.add(monitor.getDeviceSerial());
+            StoreOperationRecordsUtils.storeOperationData(listCode, null, "鏂板鎽勫儚澶�", content);
+            /**
+             * 鏂板鎽勫儚澶寸粨鏉�
+             */
+
         } else {
-            return false;
+            result = false;
         }
+        return result;
     }
 
     /**
@@ -371,8 +424,24 @@
             throw new BusinessException("淇敼澶囨敞鍙傛暟鏈夎锛�");
         }
         Monitor one = getOne(Wrappers.lambdaQuery(Monitor.class).eq(Monitor::getDeviceSerial, deviceSerial));
+
+        boolean belong = SpringContextHolder.getBean(PoleBindingService.class).isBelong(one.getDeviceSerial(), PoleBindingEnums.MONITOR);
+        if (!belong) {
+            throw new BusinessException("璇ヨ澶囦笉灞炰簬鎮�,涓嶈兘淇敼璁惧淇℃伅");
+        }
         if (one != null) {
             one.setNote(notes);
+
+            /**
+             * 娣诲姞鎽勫儚澶村娉ㄦ棩蹇楄褰曞紑濮�
+             */
+            String content = "缂栬緫鎽勫儚澶达細" +deviceSerial+"缂栬緫鍐呭锛�"+notes;
+            List<String> list  = new ArrayList<>();
+            list.add(deviceSerial);
+            StoreOperationRecordsUtils.storeOperationData(list, null, "缂栬緫鎽勫儚澶�", content);
+            /**
+             * 娣诲姞鎽勫儚澶村娉ㄦ棩蹇楄褰曠粨鏉�
+             */
             return updateById(one);
         } else {
             throw new BusinessException("鎽勫儚澶磋澶囦笉瀛樺湪锛�");

--
Gitblit v1.9.3