From 14949a6a6e7dec654d13e75f46b24319a624ff8b Mon Sep 17 00:00:00 2001 From: jinpengyong <jpy123456> Date: Mon, 30 Oct 2023 17:13:34 +0800 Subject: [PATCH] Merge branch 'dev' of http://blit.7drlb.com:8888/r/moral into wb --- screen-manage/src/main/java/com/moral/api/service/impl/DeviceServiceImpl.java | 55 ++++++++++++++++++++++--------------------------------- 1 files changed, 22 insertions(+), 33 deletions(-) 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 9ae3b93..0fdd0b8 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 @@ -4,6 +4,7 @@ import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; +import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.googlecode.aviator.AviatorEvaluator; import com.googlecode.aviator.Expression; @@ -22,8 +23,6 @@ import com.moral.constant.RedisConstants; import com.moral.util.ConvertUtils; import com.moral.util.DateUtils; -import com.sun.javafx.collections.MappingChange; - import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; @@ -192,7 +191,7 @@ //������������������redis setDeviceInfoToRedis(mac, deviceInfo); //������deviceInfo������ - CacheUtils.refreshDeviceAlarmInfo(); + CacheUtils.refreshDeviceAlarmInfo(mac); //������������������ HttpServletRequest request = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest(); StringBuilder content = new StringBuilder(); @@ -444,11 +443,10 @@ return deviceInfo; } - @Autowired - private HistoryHourlyMapper historyHourlyMapper; @Override public Map<String, Object> adjustDeviceData(Map<String, Object> deviceData,String code) { - String mac = deviceData.remove("mac").toString(); +// String mac = deviceData.remove("mac").toString(); + String mac = deviceData.get("mac").toString(); //���redis������������������ Map<String, Object> adjustFormula = redisTemplate.opsForHash().entries(RedisConstants.ADJUST + "_" + mac); if (!ObjectUtils.isEmpty(adjustFormula)) { @@ -459,27 +457,7 @@ if (govMpInfo.get("guid") != null) { aqiMap = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, govMpInfo.get("guid").toString()); } - if (code.equals("2")){ - if (ObjectUtils.isEmpty(aqiMap.get("a21005")) || ObjectUtils.isEmpty(aqiMap.get("a21026")) - || ObjectUtils.isEmpty(aqiMap.get("a21004")) || ObjectUtils.isEmpty(aqiMap.get("a34002")) - || ObjectUtils.isEmpty(aqiMap.get("a34004")) || ObjectUtils.isEmpty(aqiMap.get("a05024")) - || ObjectUtils.isEmpty(aqiMap)){ - HashMap<String, Object> result = new HashMap<>(); - String dataTime = deviceData.get("DataTime").toString(); - Date time = DateUtils.getDate(dataTime, DateUtils.yyyyMMddHHmmss_EN); - String yearAndMonth = DateUtils.dateToDateString(DateUtils.addHours(time, -2), DateUtils.yyyyMM_EN); - SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:00:00"); - String format = simpleDateFormat.format(DateUtils.addHours(time, -2)); - result.put("timeUnits",yearAndMonth); - result.put("mac",mac); - result.put("time",format); - Map<String, Object> map = historyHourlyMapper.selectHistoryHourly(result); - if (!ObjectUtils.isEmpty(map)){ - return JSON.parseObject(map.get("value").toString(), Map.class); - } - } - } - return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap); + return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap,code); } deviceData.remove("DataTime"); return deviceData; @@ -487,7 +465,8 @@ @Override public Map<String, Object> adjustSpecialDeviceData(Map<String, Object> deviceData) { - String mac = deviceData.remove("mac").toString(); +// String mac = deviceData.remove("mac").toString(); + String mac = deviceData.get("mac").toString(); //���redis������������������ Map<String, Object> adjustFormula = redisTemplate.opsForHash().entries(RedisConstants.ADJUST + "_" + mac); if (!ObjectUtils.isEmpty(adjustFormula)) { @@ -498,14 +477,13 @@ if (ObjectUtils.isEmpty(aqiMap)) { aqiMap = (Map<String, Object>) redisTemplate.opsForHash().get(RedisConstants.AQI_DATA, cityCode); } - return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap); + return adjustDataUtils.adjust(deviceData, adjustFormula, ObjectUtils.isEmpty(aqiMap) ? null : aqiMap,"0"); } deviceData.remove("DataTime"); return deviceData; } @Override - @Transactional public void judgeDeviceState(Map<String, Object> deviceData) { String mac = deviceData.remove("mac").toString(); Device device = (Device) redisTemplate.opsForHash().get(RedisConstants.DEVICE_INFO, mac); @@ -541,9 +519,10 @@ } } //������������������ - UpdateWrapper<Device> updateWrapper = new UpdateWrapper<>(); - updateWrapper.eq("id", device.getId()).set("state", String.valueOf(state)); - deviceMapper.update(null, updateWrapper); + Device device1 = new Device(); + device1.setId(device.getId()); + device1.setState(String.valueOf(state)); + deviceMapper.updateById(device1); } @Override @@ -645,4 +624,14 @@ organizationUnitAlarmMapper.update(null, deleteWrapper); } } + + @Override + public void setRedisDevice() { + List<Device> list = lambdaQuery().eq(Device::getIsDelete,0).list(); + for(Device d : list){ + redisTemplate.opsForHash().delete(RedisConstants.DEVICE, d.getMac()); + Map<String, Object> deviceInfo = selectDeviceInfoById(d.getId()); + setDeviceInfoToRedis(d.getMac(), deviceInfo); + } + } } -- Gitblit v1.8.0