From 41622b7aa1d948040b0f8ea024aece42d5a518a2 Mon Sep 17 00:00:00 2001
From: kaiyu <404897439@qq.com>
Date: Wed, 25 Aug 2021 09:29:05 +0800
Subject: [PATCH] screen-api                 SQL优化 screen-manage                日志模块更新,SQL优化

---
 screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java |   23 +++++++++++++++++++----
 1 files changed, 19 insertions(+), 4 deletions(-)

diff --git a/screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java b/screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java
index 748efc3..fa6fd33 100644
--- a/screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java
+++ b/screen-api/src/main/java/com/moral/api/websocket/SingleDeviceServer.java
@@ -1,12 +1,14 @@
 package com.moral.api.websocket;
 
 import com.moral.api.entity.Device;
+import com.moral.api.entity.MonitorPoint;
 import com.moral.api.entity.Sensor;
 import com.moral.api.entity.UnitConversion;
 import com.moral.constant.RedisConstants;
 import lombok.Data;
 import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.stereotype.Component;
+import org.springframework.util.ObjectUtils;
 import org.springframework.web.bind.annotation.PathVariable;
 
 import javax.websocket.*;
@@ -37,19 +39,32 @@
 
     private String mac;
 
-    private Map<String, Device> devicesInfo;
+    private Device deviceAlarmInfo;
 
     private List<UnitConversion> unitConversions;
+
+    private Map<String, Object> regionAqi;
 
     @OnOpen
     public void onOpen(Session session, @PathParam("mac") String mac) throws Exception {
         this.session = session;
         this.mac = mac;
-        this.devicesInfo = redisTemplate.opsForHash().entries(RedisConstants.DEVICE_INFO);
+        this.deviceAlarmInfo = (Device) redisTemplate.opsForHash().get(RedisConstants.DEVICE_INFO, mac);
         this.unitConversions = redisTemplate.opsForList().range(RedisConstants.UNIT_CONVERSION, 0, -1);
+        //���������������������������AQI������������������
+        Map<String, Object> deviceInfo = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.DEVICE, mac);
+        Map<String, Object> monitorPointMap = (Map<String, Object>) deviceInfo.get("monitorPoint");
+        String areaCode = String.valueOf(monitorPointMap.get("areaCode"));
+        String cityCode = String.valueOf(monitorPointMap.get("cityCode"));
+        try {
+            this.regionAqi = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, areaCode);
+            if (ObjectUtils.isEmpty(this.regionAqi))
+                this.regionAqi = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, cityCode);
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
         sockets.add(this);
-        System.out.println(mac);
-}
+    }
 
     @OnClose
     public void onClose() {

--
Gitblit v1.8.0