From e7bc156f901b06e5af54cfe86fe53e7491af7b7f Mon Sep 17 00:00:00 2001
From: kaiyu <404897439@qq.com>
Date: Thu, 20 May 2021 10:22:27 +0800
Subject: [PATCH] Merge branch 'dev' of http://blit.7drlb.com:8888/r/moral into dev

---
 screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java |   79 +++++++++++++++++++++++++++++++++++++--
 1 files changed, 74 insertions(+), 5 deletions(-)

diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java
index fae31a5..d1da7a9 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java
+++ b/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java
@@ -5,13 +5,17 @@
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.moral.api.entity.ManageRole;
 import com.moral.api.entity.Sensor;
+import com.moral.api.entity.VersionSensorUnit;
 import com.moral.api.mapper.SensorMapper;
+import com.moral.api.mapper.VersionSensorUnitMapper;
 import com.moral.api.service.SensorService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.moral.api.util.LogUtils;
 import com.moral.constant.Constants;
+import com.moral.constant.RedisConstants;
 import com.moral.constant.ResponseCodeEnum;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.ObjectUtils;
@@ -40,8 +44,14 @@
     @Autowired(required = false)
     private SensorMapper sensorMapper;
 
+    @Autowired(required = false)
+    private VersionSensorUnitMapper versionSensorUnitMapper;
+
     @Autowired
     LogUtils logUtils;
+
+    @Autowired
+    RedisTemplate redisTemplate;
 
     @Override
     @Transactional
@@ -75,6 +85,8 @@
         logUtils.saveOperationForManage(request,content,Constants.INSERT_OPERATE_TYPE);
         resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode());
         resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
+        //������������
+        refreshCache();
         return resultMap;
     }
 
@@ -116,19 +128,36 @@
         HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
         String content = "������������:"+oldSensor.getName()+";";
         for (Object key:updateSensorMap.keySet()) {
-            if (key.toString().equals("name")){
-                content = content+"���������:"+oldSensor.getName()+"->"+updateSensorMap.get(key)+";";
+            if (key.toString().equals("name")&&updateSensorMap.get(key)!=null){
+                content = content+"���������:"+oldSensor.getName()+"->"+updateSensorMap.get(key)+";";
             }
-            if (key.toString().equals("code")){
+            if (key.toString().equals("code")&&updateSensorMap.get(key)!=null){
+                QueryWrapper<VersionSensorUnit> wrapper_Version = new QueryWrapper<>();
+                wrapper_Version.eq("sensor_code",oldSensor.getCode());
+                wrapper_Version.eq("is_delete","0");
+                VersionSensorUnit versionSensorUnit = new VersionSensorUnit();
+                versionSensorUnit.setSensorCode(updateSensorMap.get(key).toString());
+                versionSensorUnitMapper.update(versionSensorUnit,wrapper_Version);
                 content = content+"������:"+oldSensor.getCode()+"->"+updateSensorMap.get(key)+";";
             }
-            if (key.toString().equals("desc")){
+            if (key.toString().equals("desc")&&updateSensorMap.get(key)!=null){
                 content = content+"������:"+oldSensor.getDesc()+"->"+updateSensorMap.get(key)+";";
+            }
+            if (key.toString().equals("upper")&&updateSensorMap.get(key)!=null){
+                content = content+"������:"+oldSensor.getDesc()+"->"+updateSensorMap.get(key)+";";
+            }
+            if (key.toString().equals("lower")&&updateSensorMap.get(key)!=null){
+                content = content+"������:"+oldSensor.getDesc()+"->"+updateSensorMap.get(key)+";";
+            }
+            if (key.toString().equals("default_util")&&updateSensorMap.get(key)!=null){
+                content = content+"������������:"+oldSensor.getDesc()+"->"+updateSensorMap.get(key)+";";
             }
         }
         logUtils.saveOperationForManage(request,content,Constants.UPDATE_OPERATE_TYPE);
         resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode());
         resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
+        //������������
+        refreshCache();
         return resultMap;
     }
 
@@ -185,14 +214,22 @@
             return resultMap;
         }
         Sensor deleteSensor = new Sensor();
-        deleteSensor.setIsDelete("1");
+        deleteSensor.setIsDelete(Constants.DELETE);
         sensorMapper.update(deleteSensor,wrapper);
+        QueryWrapper<VersionSensorUnit> wrapper_Version = new QueryWrapper<>();
+        wrapper_Version.eq("sensor_code",sensor.getCode());
+        wrapper_Version.eq("is_delete","0");
+        VersionSensorUnit versionSensorUnit = new VersionSensorUnit();
+        versionSensorUnit.setIsDelete(Constants.DELETE);
+        versionSensorUnitMapper.update(versionSensorUnit,wrapper_Version);
         //������������������
         HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
         String content = "������������:"+sensor.getName()+";";
         logUtils.saveOperationForManage(request,content,Constants.DELETE_OPERATE_TYPE);
         resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode());
         resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
+        //������������
+        refreshCache();
         return resultMap;
     }
 
@@ -235,4 +272,36 @@
         resultMap.put("totalPageNumber",totalPageNumber);
         return resultMap;
     }
+
+    public Map<String,Sensor> getAllSensorFromCache(){
+        Map<String,Sensor> sensors = redisTemplate.opsForHash().entries(RedisConstants.SENSOR_KEY);
+        if(ObjectUtils.isEmpty(sensors))
+            sensors =  getAllSensorFromDB();
+        //������������
+        refreshCache(sensors);
+        return sensors;
+    }
+
+    private Map<String,Sensor> getAllSensorFromDB(){
+        QueryWrapper<Sensor> wrapper = new QueryWrapper<>();
+        wrapper.eq("is_delete",Constants.NOT_DELETE);
+        List<Sensor> sensors = sensorMapper.selectList(wrapper);
+        Map<String,Sensor> result = new HashMap<>();
+        for (Sensor sensor : sensors) {
+            result.put(sensor.getCode(),sensor);
+        }
+        return result;
+    }
+
+    private void refreshCache(){
+        Map<String, Sensor> sensors = getAllSensorFromDB();
+        refreshCache(sensors);
+    }
+
+    private void refreshCache(Map<String,Sensor> sensors){
+        //������������
+        redisTemplate.delete(RedisConstants.SENSOR_KEY);
+        //������������
+        redisTemplate.opsForHash().putAll(RedisConstants.SENSOR_KEY,sensors);
+    }
 }

--
Gitblit v1.8.0