From 72046386cf8a85ad7dae79d82485fa60c2c421e6 Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期二, 05 七月 2022 18:25:12 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/WaterQualityEquipmentService.java |  119 +++++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 99 insertions(+), 20 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/WaterQualityEquipmentService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/WaterQualityEquipmentService.java
index d238095..31bb0d9 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/WaterQualityEquipmentService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/WaterQualityEquipmentService.java
@@ -1,45 +1,56 @@
 package com.sandu.ximon.admin.service;
 
-import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import cn.hutool.http.HttpUtil;
+import com.alibaba.fastjson.JSON;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.github.pagehelper.PageHelper;
 import com.sandu.common.execption.BusinessException;
+import com.sandu.common.object.BaseConditionVO;
 import com.sandu.common.service.impl.BaseServiceImpl;
-import com.sandu.ximon.admin.param.WaterQualityEquipmentParam;
-import com.sandu.ximon.dao.domain.AirEquipment;
-import com.sandu.ximon.dao.domain.Monitor;
+import com.sandu.ximon.admin.dto.WaterQualityDataDto;
+import com.sandu.ximon.admin.security.SecurityUtils;
+import com.sandu.ximon.admin.utils.StoreOperationRecordsUtils;
+import com.sandu.ximon.admin.vo.EquipmentInfomation;
+import com.sandu.ximon.dao.bo.WaterQualityEquipmentBo;
 import com.sandu.ximon.dao.domain.WaterQualityEquipment;
-import com.sandu.ximon.dao.mapper.AirEquipmentMapper;
 import com.sandu.ximon.dao.mapper.WaterQualityEquipmentMapper;
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
 
+import java.util.ArrayList;
 import java.util.List;
 
 @Service
 @AllArgsConstructor
 public class WaterQualityEquipmentService extends BaseServiceImpl<WaterQualityEquipmentMapper, WaterQualityEquipment> {
+    //姘磋川鍙傛暟鑾峰彇缃戝潃锛屼緥濡傦細"http://iot.ainongye.cn/json/璁惧缂栧彿.json"
+    private final String WATER_QUALITY_DATA_URL = "http://iot.ainongye.cn/json/";
+    private WaterQualityEquipmentMapper waterQualityEquipmentMapper;
+    private final PoleBindingService poleBindingService;
 
     /**
      * 鏌ヨ鍏ㄩ儴姘磋川璁惧
      */
-    public List<WaterQualityEquipment> listWaterQualityEquipment() {
-        LambdaQueryWrapper<WaterQualityEquipment> wrapper = Wrappers.lambdaQuery(WaterQualityEquipment.class);
-        List<WaterQualityEquipment> list = list(wrapper);
-
-        return list;
+    public List<WaterQualityEquipmentBo> listWaterQualityEquipment() {
+        return waterQualityEquipmentMapper.listWaterQualityEquipment();
     }
 
     /**
      * 妯$硦鏌ヨ
      */
-    public List<WaterQualityEquipment> listWaterQualityEquipmentByKeyword(String keyword) {
-
-        LambdaQueryWrapper<WaterQualityEquipment> wrapper = Wrappers.lambdaQuery(WaterQualityEquipment.class);
-        if (keyword != null) {
-            wrapper.like(WaterQualityEquipment::getBelongTo, keyword);
+    public List<WaterQualityEquipmentBo> listWaterQualityEquipmentByKeyword(BaseConditionVO baseConditionVO, String keyword) {
+        Long userId = SecurityUtils.getUserId();
+        if (baseConditionVO != null) {
+            PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
         }
-        List<WaterQualityEquipment> airDataList = list(wrapper);
-        return airDataList;
+        List<WaterQualityEquipmentBo> waterQualityEquipmentBoList;
+        //涓虹┖鏄秴绠�
+        if (SecurityUtils.getClientId() == null) {
+            waterQualityEquipmentBoList = waterQualityEquipmentMapper.listWaterQualityEquipmentByIds(keyword, null);
+        } else {
+            waterQualityEquipmentBoList = waterQualityEquipmentMapper.listWaterQualityEquipmentByIds(keyword, userId);
+        }
+        return waterQualityEquipmentBoList;
     }
 
     /**
@@ -53,6 +64,21 @@
         if (waterQualityEquipment == null) {
             throw new BusinessException("鎵句笉鍒版按璐ㄨ澶�");
         }
+        //鍒犻櫎鎽勬按璐ㄨ澶囧墠闇�瑕佸厛瑙g粦
+        poleBindingService.unBindPole(null, waterQualityEquipment.getWaterQualityEquipmentCode());
+
+        /**
+         * 鍒犻櫎姘磋川璁惧 鏃ュ織璁板綍寮�濮�
+         */
+        List<String> listCode = new ArrayList<>(1);
+        listCode.add(waterQualityEquipment.getWaterQualityEquipmentCode());
+        String content = "{ 璁惧id:" + waterQualityEquipment.getId() + "璁惧code锛�" + waterQualityEquipment.getWaterQualityEquipmentCode() +
+                "}";
+
+        StoreOperationRecordsUtils.storeOperationData(listCode, null, "鍒犻櫎姘磋川璁惧", content);
+        /**
+         * 鍒犻櫎姘磋川璁惧 鏃ュ織璁板綍缁撴潫
+         */
         return removeById(Id);
     }
 
@@ -70,10 +96,63 @@
         WaterQualityEquipment one = getOne(Wrappers.lambdaQuery(WaterQualityEquipment.class).eq(WaterQualityEquipment::getWaterQualityEquipmentCode,
                 waterQualityEquipment.getWaterQualityEquipmentCode()));
         if (one == null) {
-            return save(waterQualityEquipment);
+            WaterQualityEquipment result = new WaterQualityEquipment();
+            result.setWaterQualityEquipmentCode(waterQualityEquipment.getWaterQualityEquipmentCode());
+            boolean save = save(result);
+            /**
+             * 娣诲姞姘磋川璁惧 鏃ュ織璁板綍寮�濮�
+             */
+            List<String> listCode = new ArrayList<>(1);
+            listCode.add(waterQualityEquipment.getWaterQualityEquipmentCode());
+            String content = "{ 璁惧id:" + waterQualityEquipment.getId() + "璁惧code锛�" + waterQualityEquipment.getWaterQualityEquipmentCode() +
+                    "}";
+
+            StoreOperationRecordsUtils.storeOperationData(listCode, null, "娣诲姞姘磋川璁惧", content);
+            /**
+             * 娣诲姞姘磋川璁惧 鏃ュ織璁板綍缁撴潫
+             */
+            return save;
         } else {
-            waterQualityEquipment.setId(one.getId());
-            return updateById(waterQualityEquipment);
+            throw new BusinessException("璇ユ按璐ㄨ澶囧凡瀛樺湪锛�");
         }
     }
+
+    /**
+     * 棣栭〉鐏潌缁戝畾淇℃伅
+     */
+    public EquipmentInfomation getWaterQualityDataInfo(String waterQualityEquipmentCode) {
+        EquipmentInfomation equipmentInfo = new EquipmentInfomation();
+        equipmentInfo.setEquipmentType("姘磋川璁惧");
+        if (waterQualityEquipmentCode == null || waterQualityEquipmentCode.trim().length() == 0) {
+            return equipmentInfo;
+        }
+
+        WaterQualityEquipment one = getOne(Wrappers.lambdaQuery(WaterQualityEquipment.class).eq(WaterQualityEquipment::getWaterQualityEquipmentCode,
+                waterQualityEquipmentCode));
+        if (one != null) {
+            equipmentInfo.setEquipmentCreateTime(one.getCreateTime());
+            equipmentInfo.setEquipmentMac(one.getWaterQualityEquipmentCode());
+        }
+
+        try {
+            String s = HttpUtil.get(WATER_QUALITY_DATA_URL + waterQualityEquipmentCode + ".json");
+            System.out.println(waterQualityEquipmentCode + "-------------------------------" + s);
+            if (!s.startsWith("{")) {
+                equipmentInfo.setEquipmentState("鏈煡");
+                return equipmentInfo;
+            }
+            WaterQualityDataDto waterQualityDataDto = JSON.parseObject(s, WaterQualityDataDto.class);
+            //璁剧疆姘磋川璁惧鐘舵��
+            if (waterQualityDataDto != null) {
+                equipmentInfo.setEquipmentState("鍦ㄧ嚎");
+            } else {
+                equipmentInfo.setEquipmentState("绂荤嚎");
+            }
+        } catch (Exception e) {
+            e.printStackTrace();
+            log.error("姘磋川璁惧鍙蜂笉姝g‘");
+            equipmentInfo.setEquipmentState("鏈煡");
+        }
+        return equipmentInfo;
+    }
 }

--
Gitblit v1.9.3