From 6f12948893fcc846dfb32aa861c473a842edcd56 Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Wed, 23 Jun 2021 14:46:15 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev_

---
 screen-manage/src/main/java/com/moral/api/controller/TestController.java       |    5 -
 screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java |   72 ++++++++++++++++--
 screen-common/src/main/java/com/moral/constant/ResponseCodeEnum.java           |    3 
 screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java  |   79 ++++++++++---------
 screen-manage/src/main/java/com/moral/api/util/CacheUtils.java                 |    5 +
 screen-manage/src/main/java/com/moral/api/entity/VersionSensorUnit.java        |   17 ++++
 6 files changed, 128 insertions(+), 53 deletions(-)

diff --git a/screen-common/src/main/java/com/moral/constant/ResponseCodeEnum.java b/screen-common/src/main/java/com/moral/constant/ResponseCodeEnum.java
index 8f51aad..cf8b71c 100644
--- a/screen-common/src/main/java/com/moral/constant/ResponseCodeEnum.java
+++ b/screen-common/src/main/java/com/moral/constant/ResponseCodeEnum.java
@@ -59,7 +59,8 @@
     ORGANIZATION_EXIST_MONITORPOINT(-44,"���������������������������������"),
     CHILDREN_ORGANIZATION_EXIST_MONITORPOINT(-45,"������������������������������������"),
     DEVICE_IS_NULL(-46, "���������������"),
-    TARGET_IS_NULL(-47, "���������������������")
+    TARGET_IS_NULL(-47, "���������������������"),
+    VERSION_USED(-48,"������������������������������")
     ;
     private final Integer code;
     private final String  msg;
diff --git a/screen-manage/src/main/java/com/moral/api/controller/TestController.java b/screen-manage/src/main/java/com/moral/api/controller/TestController.java
index 81bb874..13865dc 100644
--- a/screen-manage/src/main/java/com/moral/api/controller/TestController.java
+++ b/screen-manage/src/main/java/com/moral/api/controller/TestController.java
@@ -182,9 +182,4 @@
         writer.close();
         fis.close();
     }
-
-    @GetMapping("testCacheUtils")
-    public void testCacheUtils(){
-        CacheUtils.flushDeviceAlarmUnit();
-    }
 }
diff --git a/screen-manage/src/main/java/com/moral/api/entity/VersionSensorUnit.java b/screen-manage/src/main/java/com/moral/api/entity/VersionSensorUnit.java
index 33c428e..0e2ee21 100644
--- a/screen-manage/src/main/java/com/moral/api/entity/VersionSensorUnit.java
+++ b/screen-manage/src/main/java/com/moral/api/entity/VersionSensorUnit.java
@@ -7,6 +7,7 @@
 import java.time.LocalDateTime;
 import java.io.Serializable;
 import java.util.Date;
+import java.util.Objects;
 
 import lombok.Data;
 import lombok.EqualsAndHashCode;
@@ -77,6 +78,22 @@
      */
     private String isDelete;
 
+    @Override
+    public boolean equals(Object o) {
+        if (this == o) return true;
+        if (o == null || getClass() != o.getClass()) return false;
+        VersionSensorUnit that = (VersionSensorUnit) o;
+        return Objects.equals(sensorCode, that.sensorCode) &&
+                Objects.equals(unitKey, that.unitKey) &&
+                Objects.equals(upper, that.upper) &&
+                Objects.equals(lower, that.lower);
+    }
+
+    @Override
+    public int hashCode() {
+
+        return Objects.hash(super.hashCode(), sensorCode, unitKey, upper, lower);
+    }
 
     @Override
     protected Serializable pkVal() {
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 c1b48df..4af7aef 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
@@ -12,6 +12,7 @@
 import com.moral.api.service.DeviceService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 
+import com.moral.api.util.CacheUtils;
 import com.moral.api.util.AdjustDataUtils;
 import com.moral.api.util.LogUtils;
 import com.moral.constant.Constants;
@@ -91,8 +92,7 @@
      * ���redis������������������
      * */
     private Map<String, Object> getDeviceInfoFromRedis(String mac) {
-        Map<String, Object> deviceInfo = (Map<String, Object>) redisTemplate.opsForValue().get(getDeviceKey(mac));
-        return deviceInfo;
+        return (Map<String, Object>) redisTemplate.opsForValue().get(getDeviceKey(mac));
     }
 
     /*
@@ -116,13 +116,6 @@
         return keysConnect(RedisConstants.DEVICE, mac);
     }
 
-    /*
-     * ���redis������������������
-     * */
-    private Map<String, Object> getOrgAlarmConfigFromRedis(String orId) {
-        return null;
-    }
-
     //redis key������
     private String keysConnect(String... keys) {
         StringBuilder key = new StringBuilder(keys[0]);
@@ -141,13 +134,15 @@
         deviceMapper.insert(device);
         Map<String, Object> deviceInfo = selectDeviceInfoById(device.getId());
         //���������������������������
-        insertOrganizationUnitAlarm(orgId, device.getDeviceVersionId());
+        insertOrganizationUnitAlarm(orgId,device.getDeviceVersionId());
         //������������������������redis
         String mac = device.getMac();
         //���redis���������������������
         delDeviceInfoFromRedis(mac);
         //������������������redis
         setDeviceInfoToRedis(mac, deviceInfo);
+        //������deviceInfo������
+        CacheUtils.flushDeviceAlarmInfo();
         //������������������
         HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest();
         StringBuilder content = new StringBuilder();
@@ -165,6 +160,12 @@
         String mac = device.getMac();
         //���redis���������������������
         delDeviceInfoFromRedis(mac);
+        //���������������������������
+        Integer versionId = device.getDeviceVersionId();
+        Integer orgId = device.getOrganizationId();
+        deleteOrganizationUnitAlarm(orgId,versionId);
+        //������deviceInfo������
+        CacheUtils.flushDeviceAlarmInfo();
         //������������������
         HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest();
         StringBuilder content = new StringBuilder();
@@ -178,7 +179,7 @@
         Integer deviceId = device.getId();
         Device oldDevice = deviceMapper.selectById(deviceId);
         //���������������������������������������������������������������������������������id������������
-        if (!ObjectUtils.isEmpty(device.getMonitorPointId())) {
+        if(!ObjectUtils.isEmpty(device.getMonitorPointId())){
             MonitorPoint monitorPoint = monitorPointMapper.selectById(device.getMonitorPointId());
             device.setOrganizationId(monitorPoint.getOrganizationId());
         }
@@ -186,19 +187,21 @@
         Device updateDevice = deviceMapper.selectById(deviceId);
         String mac = updateDevice.getMac();
         //���������������������������
-        Integer oldOrgId = oldDevice.getOrganizationId();
-        Integer newOrgId = updateDevice.getOrganizationId();
-        Integer oldVersionId = oldDevice.getDeviceVersionId();
-        Integer newVersionId = updateDevice.getDeviceVersionId();
-        if (!oldOrgId.equals(newOrgId) || !oldVersionId.equals(newVersionId)) {
-            deleteOrganizationUnitAlarm(oldOrgId, oldVersionId);
-            insertOrganizationUnitAlarm(newOrgId, newVersionId);
-        }
+       Integer oldOrgId = oldDevice.getOrganizationId();
+       Integer newOrgId = updateDevice.getOrganizationId();
+       Integer oldVersionId = oldDevice.getDeviceVersionId();
+       Integer newVersionId = updateDevice.getDeviceVersionId();
+       if(!oldOrgId.equals(newOrgId)||!oldVersionId.equals(newVersionId)){
+           deleteOrganizationUnitAlarm(oldOrgId,oldVersionId);
+           insertOrganizationUnitAlarm(newOrgId,newVersionId);
+       }
         //���redis���������������������
         delDeviceInfoFromRedis(mac);
         Map<String, Object> deviceInfo = selectDeviceInfoById(deviceId);
         //������������������redis
         setDeviceInfoToRedis(mac, deviceInfo);
+        //������deviceInfo������
+        CacheUtils.flushDeviceAlarmInfo();
         //������������������
         HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest();
         StringBuilder content = new StringBuilder();
@@ -490,18 +493,18 @@
         return state;
     }
 
-    private void insertOrganizationUnitAlarm(Integer orgId, Integer versionId) {
+    private void insertOrganizationUnitAlarm(Integer orgId,Integer versionId){
         QueryWrapper<OrganizationUnitAlarm> queryOrganizationVersionWrapper = new QueryWrapper<>();
-        queryOrganizationVersionWrapper.eq("organization_id", orgId);
-        queryOrganizationVersionWrapper.eq("version_id", versionId);
-        queryOrganizationVersionWrapper.eq("is_delete", Constants.NOT_DELETE);
+        queryOrganizationVersionWrapper.eq("organization_id",orgId);
+        queryOrganizationVersionWrapper.eq("version_id",versionId);
+        queryOrganizationVersionWrapper.eq("is_delete",Constants.NOT_DELETE);
         List<OrganizationUnitAlarm> organizationUnitAlarms = organizationUnitAlarmMapper.selectList(queryOrganizationVersionWrapper);
-        if (ObjectUtils.isEmpty(organizationUnitAlarms)) {
-            QueryWrapper<VersionSensorUnit> queryVersionSensorUnitWrapper = new QueryWrapper<>();
-            queryVersionSensorUnitWrapper.eq("version_id", versionId);
-            queryVersionSensorUnitWrapper.eq("is_delete", Constants.NOT_DELETE);
+        if(ObjectUtils.isEmpty(organizationUnitAlarms)){
+            QueryWrapper<VersionSensorUnit> queryVersionSensorUnitWrapper =new QueryWrapper<>();
+            queryVersionSensorUnitWrapper.eq("version_id",versionId);
+            queryVersionSensorUnitWrapper.eq("is_delete",Constants.NOT_DELETE);
             List<VersionSensorUnit> versionSensorUnits = versionSensorUnitMapper.selectList(queryVersionSensorUnitWrapper);
-            if (!ObjectUtils.isEmpty(versionSensorUnits)) {
+            if(!ObjectUtils.isEmpty(versionSensorUnits)){
                 for (VersionSensorUnit versionSensorUnit : versionSensorUnits) {
                     OrganizationUnitAlarm organizationUnitAlarm = new OrganizationUnitAlarm();
                     organizationUnitAlarm.setOrganizationId(orgId);
@@ -515,19 +518,19 @@
         }
     }
 
-    private void deleteOrganizationUnitAlarm(Integer orgId, Integer versionId) {
+    private void deleteOrganizationUnitAlarm(Integer orgId,Integer versionId){
         QueryWrapper<Device> queryOrganizationVersionWrapper = new QueryWrapper<>();
-        queryOrganizationVersionWrapper.eq("organization_id", orgId);
-        queryOrganizationVersionWrapper.eq("device_version_id", versionId);
-        queryOrganizationVersionWrapper.eq("is_delete", Constants.NOT_DELETE);
+        queryOrganizationVersionWrapper.eq("organization_id",orgId);
+        queryOrganizationVersionWrapper.eq("device_version_id",versionId);
+        queryOrganizationVersionWrapper.eq("is_delete",Constants.NOT_DELETE);
         List<Device> devices = deviceMapper.selectList(queryOrganizationVersionWrapper);
-        if (ObjectUtils.isEmpty(devices)) {//������������������������������������������������������
+        if(ObjectUtils.isEmpty(devices)){//������������������������������������������������������
             UpdateWrapper deleteWrapper = new UpdateWrapper();
-            deleteWrapper.eq("organization_id", orgId);
-            deleteWrapper.eq("version_id", versionId);
-            deleteWrapper.eq("is_delete", Constants.NOT_DELETE);
-            deleteWrapper.set("is_delete", Constants.DELETE);
-            organizationUnitAlarmMapper.update(null, deleteWrapper);
+            deleteWrapper.eq("organization_id",orgId);
+            deleteWrapper.eq("version_id",versionId);
+            deleteWrapper.eq("is_delete",Constants.NOT_DELETE);
+            deleteWrapper.set("is_delete",Constants.DELETE);
+            organizationUnitAlarmMapper.update(null,deleteWrapper);
         }
     }
 }
diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java
index 26f3540..452227f 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java
+++ b/screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java
@@ -165,6 +165,16 @@
         VersionDTO dto = new VersionDTO();
         //������
         Integer id = form.getId();
+        //������������������������������������������������������������
+        QueryWrapper<OrganizationUnitAlarm> queryWrapper = new QueryWrapper<>();
+        queryWrapper.eq("is_delete",Constants.NOT_DELETE);
+        queryWrapper.eq("version_id",id);
+        List<OrganizationUnitAlarm> organizationUnitAlarms = organizationUnitAlarmMapper.selectList(queryWrapper);
+        if(!ObjectUtils.isEmpty(organizationUnitAlarms)){
+            dto.setCode(ResponseCodeEnum.VERSION_USED.getCode());
+            dto.setMsg(ResponseCodeEnum.VERSION_USED.getMsg());
+            return dto;
+        }
         //������������������������������������������
         Version oldVersion = versionMapper.selectById(id);
         //������������
@@ -191,21 +201,67 @@
         //������
         List<VersionSensorUnit> sensorUnits = form.getSensorUnits();
         Integer versionId = form.getVersionId();
-        //������������������������������������
-        UpdateWrapper deleteWrapper = new UpdateWrapper();
-        deleteWrapper.eq("version_id", versionId);
-        deleteWrapper.set("is_delete", Constants.DELETE);
-        versionSensorUnitMapper.update(null, deleteWrapper);
         //������������������id������code
         for (VersionSensorUnit sensorUnit : sensorUnits) {
             Sensor sensor = sensorMapper.selectById(sensorUnit.getSensorId());
             sensorUnit.setSensorCode(sensor.getCode());
         }
-        //���������������������������������
-        for (VersionSensorUnit sensorUnit : sensorUnits) {
-            sensorUnit.setVersionId(versionId);
+        //������������������������������������
+        QueryWrapper<VersionSensorUnit> queryOldWrapper = new QueryWrapper<>();
+        queryOldWrapper.eq("version_id",versionId);
+        queryOldWrapper.eq("is_delete",Constants.NOT_DELETE);
+        List<VersionSensorUnit> oldSensorUnits = versionSensorUnitMapper.selectList(queryOldWrapper);
+        //������������������������(������������������������)
+        List<VersionSensorUnit> insertList = new ArrayList<>();
+        List<VersionSensorUnit> deleteList = new ArrayList<>();
+        sensorUnits.forEach(value->{
+            value.setVersionId(versionId);
+            if(!oldSensorUnits.contains(value))
+                insertList.add(value);
+        });
+        oldSensorUnits.forEach(value->{
+            if(!sensorUnits.contains(value))
+                deleteList.add(value);
+        });
+        //������������
+        UpdateWrapper deleteWrapper = new UpdateWrapper();
+        List<Integer> deleteIds = new ArrayList<>();
+        deleteList.forEach(value->deleteIds.add(value.getId()));
+        deleteWrapper.in("id",deleteIds);
+        deleteWrapper.set("is_delete", Constants.DELETE);
+        versionSensorUnitMapper.update(null, deleteWrapper);
+        //������������
+        for (VersionSensorUnit sensorUnit : insertList) {
             versionSensorUnitMapper.insert(sensorUnit);
         }
+        //���������������������������
+        QueryWrapper<OrganizationUnitAlarm> queryOrgUnitAlarmWrapper = new QueryWrapper<>();
+        queryOrgUnitAlarmWrapper.select("distinct organization_id");
+        queryOrgUnitAlarmWrapper.eq("version_id",versionId);
+        queryOrgUnitAlarmWrapper.eq("is_delete",Constants.NOT_DELETE);
+        List<OrganizationUnitAlarm> organizationUnitAlarms = organizationUnitAlarmMapper.selectList(queryOrgUnitAlarmWrapper);
+        List<Integer> organizationIds = new ArrayList<>();
+        organizationUnitAlarms.forEach(value->organizationIds.add(value.getOrganizationId()));
+        for (Integer organizationId : organizationIds) {
+            //������������
+            for (VersionSensorUnit versionSensorUnit : deleteList) {
+                UpdateWrapper deleteOrganizationUnitAlarmWrapper = new UpdateWrapper();
+                deleteOrganizationUnitAlarmWrapper.eq("orgniazation_id",organizationId);
+                deleteOrganizationUnitAlarmWrapper.eq("version_id",versionId);
+                deleteOrganizationUnitAlarmWrapper.eq("sensor_code",versionSensorUnit.getSensorCode());
+                organizationUnitAlarmMapper.update(null,deleteOrganizationUnitAlarmWrapper);
+            }
+            //������������
+            for (VersionSensorUnit versionSensorUnit : insertList) {
+                OrganizationUnitAlarm organizationUnitAlarm = new OrganizationUnitAlarm();
+                organizationUnitAlarm.setOrganizationId(organizationId);
+                organizationUnitAlarm.setVersionId(versionId);
+                organizationUnitAlarm.setSensorCode(versionSensorUnit.getSensorCode());
+                organizationUnitAlarm.setUnitKey(versionSensorUnit.getUnitKey());
+                organizationUnitAlarm.setShowUnitKey(versionSensorUnit.getUnitKey());
+                organizationUnitAlarmMapper.insert(organizationUnitAlarm);
+            }
+        }
         //������������������
         dto.setCode(ResponseCodeEnum.SUCCESS.getCode());
         dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg());
diff --git a/screen-manage/src/main/java/com/moral/api/util/CacheUtils.java b/screen-manage/src/main/java/com/moral/api/util/CacheUtils.java
index 8fa6e54..4975afd 100644
--- a/screen-manage/src/main/java/com/moral/api/util/CacheUtils.java
+++ b/screen-manage/src/main/java/com/moral/api/util/CacheUtils.java
@@ -71,7 +71,10 @@
         redisTemplate.delete(RedisConstants.DICT_TYPE_KEY);
     }
 
-    public static void flushDeviceAlarmUnit() {
+    public static void flushDeviceAlarmInfo() {
+        //������������
+        redisTemplate.delete(RedisConstants.DEVICE_INFO);
+        //������������������
         List<Device> devices = deviceMapper.queryDeviceUnitAlarmInfo();
         Map<String, SysDictData> unitMap = sysDictDataService.getDictDatasByType("unit");
         //���������������������������������������������

--
Gitblit v1.8.0