From 0d2e4e6b8954d77dd34664f861135ae41f7eb828 Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期五, 13 五月 2022 10:31:34 +0800
Subject: [PATCH] 单灯数据直接下载

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/WaterQualityEquipmentService.java |   92 ++++++++++++++++++++++++++++++++++++----------
 1 files changed, 72 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..fcb937d 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,14 +1,17 @@
 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.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;
@@ -18,28 +21,34 @@
 @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 +62,9 @@
         if (waterQualityEquipment == null) {
             throw new BusinessException("鎵句笉鍒版按璐ㄨ澶�");
         }
+        //鍒犻櫎鎽勬按璐ㄨ澶囧墠闇�瑕佸厛瑙g粦
+        poleBindingService.unBindPole(null, waterQualityEquipment.getWaterQualityEquipmentCode());
+
         return removeById(Id);
     }
 
@@ -70,10 +82,50 @@
         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());
+            return save(result);
         } 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