package com.moral.api.service.impl;
import com.alibaba.fastjson.JSON;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
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.SysDictData;
import com.moral.api.entity.VersionSensorUnit;
import com.moral.api.mapper.SensorMapper;
import com.moral.api.mapper.SysDictDataMapper;
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 com.moral.util.TokenUtils;
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;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
*
* 服务实现类
*
*
* @author moral
* @since 2021-05-08
*/
@Service
@Transactional
public class SensorServiceImpl extends ServiceImpl implements SensorService {
@Autowired(required = false)
private SensorMapper sensorMapper;
@Autowired(required = false)
private VersionSensorUnitMapper versionSensorUnitMapper;
@Autowired(required = false)
private SysDictDataMapper sysDictDataMapper;
@Autowired
LogUtils logUtils;
@Autowired
RedisTemplate redisTemplate;
@Override
@Transactional
public Map insertOne(Sensor sensor) {
Map resultMap = new HashMap<>();
if (sensor.getName()==null || sensor.getCode()==null){
resultMap.put("code",ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode());
resultMap.put("msg",ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
return resultMap;
}
QueryWrapper wrapper_name = new QueryWrapper<>();
wrapper_name.eq("name",sensor.getName());
wrapper_name.eq("is_delete","0");
if (sensorMapper.selectCount(wrapper_name)!=0){
resultMap.put("code",ResponseCodeEnum.SENSOR_IS_EXIST.getCode());
resultMap.put("msg",ResponseCodeEnum.SENSOR_IS_EXIST.getMsg());
return resultMap;
}
QueryWrapper wrapper_code = new QueryWrapper<>();
wrapper_code.eq("code",sensor.getCode());
wrapper_code.eq("is_delete","0");
if (sensorMapper.selectCount(wrapper_code)!=0){
resultMap.put("code",ResponseCodeEnum.SENSOR_KEY_IS_USED.getCode());
resultMap.put("msg",ResponseCodeEnum.SENSOR_KEY_IS_USED.getMsg());
return resultMap;
}
sensorMapper.insertOne(sensor);
//操作插入日志
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
String content = "添加因子:"+sensor.getName()+";";
logUtils.saveOperationForManage(request,content,Constants.INSERT_OPERATE_TYPE);
resultMap.put("code",ResponseCodeEnum.SUCCESS.getCode());
resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
//刷新缓存
refreshCache();
return resultMap;
}
@Override
@Transactional
public Map updateSensor(Map updateSensorMap) {
Map resultMap = new HashMap<>();
if(ObjectUtils.isEmpty(updateSensorMap.get("id"))){
resultMap.put("code",ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode());
resultMap.put("msg",ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
return resultMap;
}
if (updateSensorMap.get("name")==""){
resultMap.put("code",ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode());
resultMap.put("msg",ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
return resultMap;
}
if(updateSensorMap.get("code")==""){
resultMap.put("code",ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode());
resultMap.put("msg",ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
return resultMap;
}
Sensor oldSensor = sensorMapper.getSensorById(Integer.parseInt(updateSensorMap.get("id").toString()));
if (ObjectUtils.isEmpty(oldSensor)){
resultMap.put("code",ResponseCodeEnum.SENSOR_IS_NOT_EXIST.getCode());
resultMap.put("msg",ResponseCodeEnum.SENSOR_IS_NOT_EXIST.getMsg());
return resultMap;
}
QueryWrapper wrapper_code = new QueryWrapper<>();
wrapper_code.eq("code",updateSensorMap.get("code"));
wrapper_code.eq("is_delete","0");
List sensorList = sensorMapper.selectList(wrapper_code);
if (sensorList.size()!=0&&!sensorList.get(0).getId().toString().equals(updateSensorMap.get("id").toString())){
resultMap.put("code",ResponseCodeEnum.SENSOR_KEY_IS_USED.getCode());
resultMap.put("msg",ResponseCodeEnum.SENSOR_KEY_IS_USED.getMsg());
return resultMap;
}
sensorMapper.updateSensor(updateSensorMap);
HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
String content = "修改因子:"+oldSensor.getName()+";";
for (Object key:updateSensorMap.keySet()) {
if (key.toString().equals("name")&&updateSensorMap.get(key)!=null){
content = content+"因子名:"+oldSensor.getName()+"->"+updateSensorMap.get(key)+";";
}
if (key.toString().equals("code")&&updateSensorMap.get(key)!=null){
/*QueryWrapper 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")&&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_unit_key")&&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;
}
@Override
public Map getAllSensor(Map map) {
Map resultMap = new HashMap<>();
int current = Integer.parseInt(map.get("current").toString());
int size = Integer.parseInt(map.get("size").toString());
Page page = new Page(current,size);
QueryWrapper wrapper = new QueryWrapper();
wrapper.eq("is_delete",0);
int totleNum = sensorMapper.selectCount(wrapper);
if (!ObjectUtils.isEmpty(map.get("orderType"))){
String orderType = map.get("orderType").toString();
if (orderType.equals(Constants.ORDER_DESC)){
wrapper.orderByDesc("update_time");
}else {
wrapper.orderByAsc("update_time");
}
}
Page resultPage = sensorMapper.selectPage(page,wrapper);
List sensors = resultPage.getRecords();
SimpleDateFormat SDF = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
List