From 5688e9adb709a253e1ce69b510457b9c88a645a9 Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Thu, 16 Sep 2021 16:39:18 +0800
Subject: [PATCH] screnn_api特殊设备实体类修改,走航车实时websocket,manage设备补偿

---
 screen-api/src/main/java/com/moral/api/service/SpecialDeviceService.java            |    2 
 screen-api/src/main/java/com/moral/api/entity/GovMonitorPoint.java                  |   98 ++++++++++++++++
 screen-manage/src/main/java/com/moral/api/util/AdjustDataUtils.java                 |    2 
 screen-api/src/main/resources/mapper/SpecialDeviceMapper.xml                        |    1 
 screen-api/src/main/java/com/moral/api/entity/SpecialDevice.java                    |    4 
 screen-api/src/main/java/com/moral/api/pojo/redisBean/SpecialDeviceInfoDTO.java     |   46 +++++++
 screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java       |   38 +++---
 screen-api/src/main/resources/mapper/GovMonitorPointMapper.xml                      |   22 +++
 screen-api/src/main/java/com/moral/api/controller/CruiserController.java            |    2 
 screen-api/src/main/java/com/moral/api/service/impl/GovMonitorPointServiceImpl.java |   20 +++
 screen-api/src/main/java/com/moral/api/service/GovMonitorPointService.java          |   16 ++
 screen-api/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java             |    9 +
 screen-api/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml                 |    1 
 screen-api/src/main/java/com/moral/api/mapper/GovMonitorPointMapper.java            |   16 ++
 screen-api/src/main/java/com/moral/api/websocket/CruiserWebSocketServer.java        |   19 +-
 screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java   |   13 +-
 screen-common/src/main/java/com/moral/constant/Constants.java                       |    2 
 17 files changed, 267 insertions(+), 44 deletions(-)

diff --git a/screen-api/src/main/java/com/moral/api/controller/CruiserController.java b/screen-api/src/main/java/com/moral/api/controller/CruiserController.java
index 39012ba..ac6fdb9 100644
--- a/screen-api/src/main/java/com/moral/api/controller/CruiserController.java
+++ b/screen-api/src/main/java/com/moral/api/controller/CruiserController.java
@@ -38,7 +38,7 @@
     @GetMapping("selectCruisers")
     @ApiOperation(value = "������������������������������������������", notes = "���������������")
     public ResultMessage getCarsInfo() {
-        List<Map<String, Object>> response = specialDeviceService.getCarsInfo();
+        List<Map<String, Object>> response = specialDeviceService.selectCruisers();
         return ResultMessage.ok(response);
     }
 
diff --git a/screen-api/src/main/java/com/moral/api/entity/GovMonitorPoint.java b/screen-api/src/main/java/com/moral/api/entity/GovMonitorPoint.java
new file mode 100644
index 0000000..62024c1
--- /dev/null
+++ b/screen-api/src/main/java/com/moral/api/entity/GovMonitorPoint.java
@@ -0,0 +1,98 @@
+package com.moral.api.entity;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.extension.activerecord.Model;
+import com.baomidou.mybatisplus.annotation.TableId;
+import java.io.Serializable;
+import java.util.Date;
+
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+
+/**
+ * <p>
+ * 
+ * </p>
+ *
+ * @author moral
+ * @since 2021-09-16
+ */
+@Data
+@EqualsAndHashCode(callSuper = false)
+public class GovMonitorPoint extends Model<GovMonitorPoint> {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * id
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    private Integer id;
+
+    /**
+     * ������������code
+     */
+    private String guid;
+
+    /**
+     * ������
+     */
+    private String name;
+
+    /**
+     * ������
+     */
+    private Double longitude;
+
+    /**
+     * ������
+     */
+    private Double latitude;
+
+    /**
+     * ���������
+     */
+    private Integer provinceCode;
+
+    /**
+     * ���������
+     */
+    private Integer cityCode;
+
+    /**
+     * ���/���������
+     */
+    private Integer areaCode;
+
+    /**
+     * ���������������������������������������������
+     */
+    private String stationLevel;
+
+    /**
+     * ������������
+     */
+    private Date createTime;
+
+    /**
+     * ������������
+     */
+    private Date updateTime;
+
+    /**
+     * ������������
+     */
+    private String isDelete;
+
+    /**
+     * ������
+     */
+    private String desc;
+
+
+    @Override
+    protected Serializable pkVal() {
+        return this.id;
+    }
+
+}
diff --git a/screen-api/src/main/java/com/moral/api/entity/SpecialDevice.java b/screen-api/src/main/java/com/moral/api/entity/SpecialDevice.java
index 1e8fbde..34310b9 100644
--- a/screen-api/src/main/java/com/moral/api/entity/SpecialDevice.java
+++ b/screen-api/src/main/java/com/moral/api/entity/SpecialDevice.java
@@ -12,11 +12,11 @@
 
 /**
  * <p>
- * 
+ *
  * </p>
  *
  * @author moral
- * @since 2021-08-18
+ * @since 2021-08-11
  */
 @Data
 @EqualsAndHashCode(callSuper = false)
diff --git a/screen-api/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java b/screen-api/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java
index 3a80119..9efb6d0 100644
--- a/screen-api/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java
+++ b/screen-api/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java
@@ -11,11 +11,11 @@
 
 /**
  * <p>
- * 
+ *
  * </p>
  *
  * @author moral
- * @since 2021-08-26
+ * @since 2021-08-11
  */
 @Data
 @EqualsAndHashCode(callSuper = false)
@@ -40,6 +40,11 @@
     private String mac;
 
     /**
+     * ������������id
+     */
+    private String guid;
+
+    /**
      * ���������id���������������������������������manage_account
      */
     private String operateIds;
diff --git a/screen-api/src/main/java/com/moral/api/mapper/GovMonitorPointMapper.java b/screen-api/src/main/java/com/moral/api/mapper/GovMonitorPointMapper.java
new file mode 100644
index 0000000..0e471f2
--- /dev/null
+++ b/screen-api/src/main/java/com/moral/api/mapper/GovMonitorPointMapper.java
@@ -0,0 +1,16 @@
+package com.moral.api.mapper;
+
+import com.moral.api.entity.GovMonitorPoint;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+/**
+ * <p>
+ *  Mapper ������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-09-16
+ */
+public interface GovMonitorPointMapper extends BaseMapper<GovMonitorPoint> {
+
+}
diff --git a/screen-api/src/main/java/com/moral/api/pojo/redisBean/SpecialDeviceInfoDTO.java b/screen-api/src/main/java/com/moral/api/pojo/redisBean/SpecialDeviceInfoDTO.java
new file mode 100644
index 0000000..0f238f3
--- /dev/null
+++ b/screen-api/src/main/java/com/moral/api/pojo/redisBean/SpecialDeviceInfoDTO.java
@@ -0,0 +1,46 @@
+package com.moral.api.pojo.redisBean;
+
+import lombok.Data;
+
+import java.util.List;
+
+import com.moral.api.entity.GovMonitorPoint;
+import com.moral.api.entity.ManageAccount;
+import com.moral.api.entity.Organization;
+import com.moral.api.entity.SpecialDevice;
+import com.moral.api.entity.Version;
+
+/**
+ * @program: screen
+ * @description: ������������������redis���������
+ * @author: lizijie
+ * @create: 2021-09-14 16:41
+ **/
+@Data
+public class SpecialDeviceInfoDTO {
+
+    /**
+     * ������������
+     */
+    private SpecialDevice specialDevice;
+
+    /**
+     * ������������
+     */
+    private GovMonitorPoint govMonitorPoint;
+
+    /**
+     * ������
+     */
+    private Version version;
+
+    /**
+     * ���������
+     */
+    private List<ManageAccount> operates;
+
+    /**
+     * ������
+     */
+    private Organization organization;
+}
diff --git a/screen-api/src/main/java/com/moral/api/service/GovMonitorPointService.java b/screen-api/src/main/java/com/moral/api/service/GovMonitorPointService.java
new file mode 100644
index 0000000..0231239
--- /dev/null
+++ b/screen-api/src/main/java/com/moral/api/service/GovMonitorPointService.java
@@ -0,0 +1,16 @@
+package com.moral.api.service;
+
+import com.moral.api.entity.GovMonitorPoint;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+/**
+ * <p>
+ *  ���������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-09-16
+ */
+public interface GovMonitorPointService extends IService<GovMonitorPoint> {
+
+}
diff --git a/screen-api/src/main/java/com/moral/api/service/SpecialDeviceService.java b/screen-api/src/main/java/com/moral/api/service/SpecialDeviceService.java
index 4a2f53a..240760d 100644
--- a/screen-api/src/main/java/com/moral/api/service/SpecialDeviceService.java
+++ b/screen-api/src/main/java/com/moral/api/service/SpecialDeviceService.java
@@ -17,7 +17,7 @@
 public interface SpecialDeviceService extends IService<SpecialDevice> {
 
     //���������������������������������������������
-    List<Map<String, Object>> getCarsInfo();
+    List<Map<String, Object>> selectCruisers();
 
     //���������������
     List<Map<String, Object>> carTrajectory(Map<String, Object> params);
diff --git a/screen-api/src/main/java/com/moral/api/service/impl/GovMonitorPointServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/GovMonitorPointServiceImpl.java
new file mode 100644
index 0000000..7ad0cbe
--- /dev/null
+++ b/screen-api/src/main/java/com/moral/api/service/impl/GovMonitorPointServiceImpl.java
@@ -0,0 +1,20 @@
+package com.moral.api.service.impl;
+
+import com.moral.api.entity.GovMonitorPoint;
+import com.moral.api.mapper.GovMonitorPointMapper;
+import com.moral.api.service.GovMonitorPointService;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springframework.stereotype.Service;
+
+/**
+ * <p>
+ *  ���������������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-09-16
+ */
+@Service
+public class GovMonitorPointServiceImpl extends ServiceImpl<GovMonitorPointMapper, GovMonitorPoint> implements GovMonitorPointService {
+
+}
diff --git a/screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java
index 3de0dad..b0bb025 100644
--- a/screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java
+++ b/screen-api/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java
@@ -2,8 +2,7 @@
 
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.moral.api.entity.HistorySecondSpecial;
-import com.moral.api.entity.Organization;
+
 import com.moral.api.entity.SpecialDevice;
 import com.moral.api.entity.SpecialDeviceHistory;
 import com.moral.api.mapper.HistorySecondCruiserMapper;
@@ -14,7 +13,7 @@
 import com.moral.api.service.SpecialDeviceService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.moral.constant.Constants;
-import com.moral.constant.RedisConstants;
+
 import com.moral.util.DateUtils;
 import com.moral.util.GeodesyUtils;
 import com.moral.util.TokenUtils;
@@ -62,7 +61,7 @@
     private final static Double dis = 50d;
 
     @Override
-    public List<Map<String, Object>> getCarsInfo() {
+    public List<Map<String, Object>> selectCruisers() {
         //������������������������
         Map<String, Object> userInfo = (Map<String, Object>) TokenUtils.getUserInfo();
         Map<String, Object> orgInfo = (Map<String, Object>) userInfo.get("organization");
@@ -70,7 +69,7 @@
         QueryWrapper<SpecialDeviceHistory> queryWrapper = new QueryWrapper<>();
         queryWrapper.select("mac", "name")
                 .eq("organization_id", orgId)
-                .eq("special_type", Constants.SPECIAL_DEVICE_CAR)
+                .eq("special_type", Constants.SPECIAL_DEVICE_CRUISER)
                 .eq("is_delete", Constants.NOT_DELETE);
         return specialDeviceHistoryService.listMaps(queryWrapper);
     }
@@ -108,8 +107,8 @@
     @Override
     public SpecialDevice getSpecialDeviceMapByMac(String mac) {
         QueryWrapper<SpecialDevice> queryWrapper = new QueryWrapper();
-        queryWrapper.eq("mac",mac);
-        queryWrapper.eq("is_delete",Constants.NOT_DELETE);
+        queryWrapper.eq("mac", mac);
+        queryWrapper.eq("is_delete", Constants.NOT_DELETE);
         SpecialDevice specialDevice = specialDeviceMapper.selectOne(queryWrapper);
         return specialDevice;
     }
diff --git a/screen-api/src/main/java/com/moral/api/websocket/CruiserWebSocketServer.java b/screen-api/src/main/java/com/moral/api/websocket/CruiserWebSocketServer.java
index ebb0ed4..65f9a72 100644
--- a/screen-api/src/main/java/com/moral/api/websocket/CruiserWebSocketServer.java
+++ b/screen-api/src/main/java/com/moral/api/websocket/CruiserWebSocketServer.java
@@ -19,6 +19,7 @@
 
 import com.moral.api.entity.SpecialDevice;
 import com.moral.api.entity.UnitConversion;
+import com.moral.api.pojo.redisBean.SpecialDeviceInfoDTO;
 import com.moral.constant.RedisConstants;
 
 //���������������websocket
@@ -47,18 +48,18 @@
         this.session = session;
         this.mac = mac;
         this.specialDevice = (SpecialDevice) redisTemplate.opsForHash().get(RedisConstants.SPECIAL_DEVICE_INFO, mac);
-        //���������������������������AQI������������������
-        /*Map<String, Object> deviceInfo = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.DEVICE, mac);
-        Map<String, Object> orgInfo = (Map<String, Object>) deviceInfo.get("organization");
-        String areaCode = String.valueOf(orgInfo.get("areaCode"));
-        String cityCode = String.valueOf(orgInfo.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);
+            //������������������
+            SpecialDeviceInfoDTO deviceInfo = (SpecialDeviceInfoDTO) redisTemplate.opsForHash().get(RedisConstants.SPECIAL_DEVICE, mac);
+            //���������������������������������guid,
+            String guid = deviceInfo.getSpecialDevice().getGuid();
+            if (!ObjectUtils.isEmpty(guid)) {
+                //������������aqi���������������������
+                this.regionAqi = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, guid);
+            }
         } catch (Exception e) {
             e.printStackTrace();
-        }*/
+        }
         sockets.add(this);
     }
 
diff --git a/screen-api/src/main/resources/mapper/GovMonitorPointMapper.xml b/screen-api/src/main/resources/mapper/GovMonitorPointMapper.xml
new file mode 100644
index 0000000..90ee6cd
--- /dev/null
+++ b/screen-api/src/main/resources/mapper/GovMonitorPointMapper.xml
@@ -0,0 +1,22 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.moral.api.mapper.GovMonitorPointMapper">
+
+    <!-- ������������������������ -->
+    <resultMap id="BaseResultMap" type="com.moral.api.entity.GovMonitorPoint">
+        <id column="id" property="id"/>
+        <result column="guid" property="guid"/>
+        <result column="name" property="name"/>
+        <result column="longitude" property="longitude"/>
+        <result column="latitude" property="latitude"/>
+        <result column="province_code" property="provinceCode"/>
+        <result column="city_code" property="cityCode"/>
+        <result column="area_code" property="areaCode"/>
+        <result column="station_level" property="stationLevel"/>
+        <result column="create_time" property="createTime"/>
+        <result column="update_time" property="updateTime"/>
+        <result column="is_delete" property="isDelete"/>
+        <result column="desc" property="desc"/>
+    </resultMap>
+
+</mapper>
\ No newline at end of file
diff --git a/screen-api/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml b/screen-api/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml
index a2b05bb..987bbd5 100644
--- a/screen-api/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml
+++ b/screen-api/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml
@@ -7,6 +7,7 @@
         <id column="id" property="id"/>
         <result column="name" property="name"/>
         <result column="mac" property="mac"/>
+        <result column="guid" property="guid"/>
         <result column="operate_ids" property="operateIds"/>
         <result column="organization_id" property="organizationId"/>
         <result column="device_version_id" property="deviceVersionId"/>
diff --git a/screen-api/src/main/resources/mapper/SpecialDeviceMapper.xml b/screen-api/src/main/resources/mapper/SpecialDeviceMapper.xml
index 452b9f0..8c5e135 100644
--- a/screen-api/src/main/resources/mapper/SpecialDeviceMapper.xml
+++ b/screen-api/src/main/resources/mapper/SpecialDeviceMapper.xml
@@ -7,6 +7,7 @@
         <id column="id" property="id"/>
         <result column="name" property="name"/>
         <result column="mac" property="mac"/>
+        <result column="guid" property="guid"/>
         <result column="operate_ids" property="operateIds"/>
         <result column="organization_id" property="organizationId"/>
         <result column="device_version_id" property="deviceVersionId"/>
diff --git a/screen-common/src/main/java/com/moral/constant/Constants.java b/screen-common/src/main/java/com/moral/constant/Constants.java
index 4346d0d..1d6250d 100644
--- a/screen-common/src/main/java/com/moral/constant/Constants.java
+++ b/screen-common/src/main/java/com/moral/constant/Constants.java
@@ -212,7 +212,7 @@
     /*
      * ������������������������������
      * */
-    public static final String SPECIAL_DEVICE_CAR = "0";
+    public static final String SPECIAL_DEVICE_CRUISER = "0";
 
     /*
      * ������������������������������
diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java
index 66b431a..8d26374 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java
+++ b/screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java
@@ -441,13 +441,11 @@
         Map<String, Object> adjustFormula = redisTemplate.opsForHash().entries(RedisConstants.ADJUST + "_" + mac);
         if (!ObjectUtils.isEmpty(adjustFormula)) {
             Map<String, Object> deviceInfo = getDeviceByMac(mac);
-            Map<String, Object> monitorPoint = (Map<String, Object>) deviceInfo.get("monitorPoint");
-            String areaCode = monitorPoint.get("areaCode").toString();
-            String cityCode = monitorPoint.get("cityCode").toString();
-
-            Map<String, Object> aqiMap = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, areaCode);
-            if (ObjectUtils.isEmpty(aqiMap)) {
-                aqiMap = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, cityCode);
+            //������������������������������������
+            Map<String, Object> govMpInfo = (Map<String, Object>) deviceInfo.get("govMonitorPoint");
+            Map<String, Object> aqiMap = null;
+            if (govMpInfo.get("guid") != null) {
+               aqiMap = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, govMpInfo.get("guid").toString());
             }
             return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap);
         }
@@ -528,12 +526,12 @@
     }
 
     /**
-    * @Description: ���������������������������������������������������������������������������������������������
-            * @Param: [orgId, versionId]
-            * @return: void
-            * @Author: ���������
-            * @Date: 2021/9/6
-            */
+     * @Description: ���������������������������������������������������������������������������������������������
+     * @Param: [orgId, versionId]
+     * @return: void
+     * @Author: ���������
+     * @Date: 2021/9/6
+     */
     private void insertOrganizationUnitAlarm(Integer orgId, Integer versionId) {
         //���������������������������
         QueryWrapper<OrganizationUnitAlarm> queryOrganizationVersionWrapper = new QueryWrapper<>();
@@ -556,7 +554,7 @@
                     String sensorCode = versionSensorUnit.getSensorCode();
                     //���������������������
                     SysDictData alarm = sensorAlarms.get(sensorCode);
-                    if(alarm!=null)
+                    if (alarm != null)
                         organizationUnitAlarm.setAlarmLevel(alarm.getDataValue());
                     organizationUnitAlarm.setOrganizationId(orgId);
                     organizationUnitAlarm.setVersionId(versionId);
@@ -570,12 +568,12 @@
     }
 
     /**
-    * @Description: ������������������������������������������������������������������������������������������������������������������������������������
-            * @Param: [orgId, versionId]
-            * @return: void
-            * @Author: ���������
-            * @Date: 2021/9/6
-            */
+     * @Description: ������������������������������������������������������������������������������������������������������������������������������������
+     * @Param: [orgId, versionId]
+     * @return: void
+     * @Author: ���������
+     * @Date: 2021/9/6
+     */
     private void deleteOrganizationUnitAlarm(Integer orgId, Integer versionId) {
         QueryWrapper<Device> queryOrganizationVersionWrapper = new QueryWrapper<>();
         queryOrganizationVersionWrapper.eq("organization_id", orgId);
diff --git a/screen-manage/src/main/java/com/moral/api/util/AdjustDataUtils.java b/screen-manage/src/main/java/com/moral/api/util/AdjustDataUtils.java
index e8f0e91..4406532 100644
--- a/screen-manage/src/main/java/com/moral/api/util/AdjustDataUtils.java
+++ b/screen-manage/src/main/java/com/moral/api/util/AdjustDataUtils.java
@@ -24,7 +24,7 @@
     /**
      * @param deviceData    ������������
      * @param adjustFormula ������������
-     * @param aqiMap        ���������������������������������aqi������
+     * @param aqiMap        ������������������������������aqi������
      * @return Map<String, Object> ���������������
      */
     public Map<String, Object> adjust(Map<String, Object> deviceData, Map<String, Object> adjustFormula, Map<String, Object> aqiMap) {

--
Gitblit v1.8.0