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.*;
import com.moral.api.mapper.OrganizationUnitAlarmMapper;
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.CacheUtils;
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(required = false)
    private OrganizationUnitAlarmMapper organizationUnitAlarmMapper;
    @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);
        if (!ObjectUtils.isEmpty(updateSensorMap.get("code")) && !oldSensor.getCode().equals(updateSensorMap.get("code"))) {
            QueryWrapper wrapper_OUA = new QueryWrapper<>();
            wrapper_OUA.eq("is_delete", Constants.NOT_DELETE);
            wrapper_OUA.eq("sensor_code", oldSensor.getCode());
            OrganizationUnitAlarm organizationUnitAlarm = new OrganizationUnitAlarm();
            organizationUnitAlarm.setSensorCode(updateSensorMap.get("code").toString());
            organizationUnitAlarmMapper.update(organizationUnitAlarm, wrapper_OUA);
        }
        //刷新deviceInfo缓存
        CacheUtils.refreshDeviceAlarmInfo();
        CacheUtils.refreshSpecialDeviceAlarmInfo();
        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