package com.moral.api.service.impl;
import com.alibaba.fastjson.JSONObject;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.moral.api.entity.HistorySecondCruiser;
import com.moral.api.entity.Sensor;
import com.moral.api.entity.SpecialDevice;
import com.moral.api.mapper.HistorySecondCruiserMapper;
import com.moral.api.mapper.SpecialDeviceMapper;
import com.moral.api.pojo.dto.cruiser.CruiserDTO;
import com.moral.api.service.DeviceService;
import com.moral.api.service.HistorySecondCruiserService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.moral.api.service.SpecialDeviceService;
import com.moral.constant.Constants;
import com.moral.constant.RedisConstants;
import com.moral.util.DateUtils;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils;
import org.springframework.util.ObjectUtils;
import java.sql.Wrapper;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
/**
*
* 走航车秒数据表 服务实现类
*
*
* @author moral
* @since 2021-09-02
*/
@Slf4j
@Service
public class HistorySecondCruiserServiceImpl extends ServiceImpl implements HistorySecondCruiserService {
@Autowired
private HistorySecondCruiserMapper historySecondCruiserMapper;
@Autowired
private SpecialDeviceService specialDeviceService;
@Autowired
private SpecialDeviceMapper specialDeviceMapper;
@Autowired
private RedisTemplate redisTemplate;
@Override
public void insertHistorySecond(Map data) {
Date batchTime = DateUtils.getDate((String) data.remove(Constants.SENSOR_CODE_SPECIAL_BATCH), DateUtils.yyyyMMddHHmmss_EN);
Date time = DateUtils.getDate((String) data.get("DataTime"), DateUtils.yyyyMMddHHmmss_EN);
String mac = data.get("mac").toString();
//根据mac从redis中获取因子
SpecialDevice specialDevice = (SpecialDevice) redisTemplate.opsForHash().get(RedisConstants.SPECIAL_DEVICE_INFO, mac);
List sensors = specialDevice.getVersion().getSensors();
//过滤因子
data = data.entrySet().stream()
.filter(m -> {
boolean flag = false;
String key = m.getKey();
if (!"mac".equals(key) && !"DataTime".equals(key)) {
for (Sensor sensor : sensors) {
if (sensor.getCode().equals(key)) {
flag = true;
break;
}
}
return flag;
}
return true;
}).collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue));
//数据校准
data = specialDeviceService.adjustSpecialDeviceData(data);
HistorySecondCruiser historySecondCruiser = new HistorySecondCruiser();
historySecondCruiser.setMac(mac);
historySecondCruiser.setTime(time);
historySecondCruiser.setValue(JSONObject.toJSONString(data));
historySecondCruiser.setOrganizationId(specialDevice.getOrganizationId());
historySecondCruiser.setBatch(batchTime);
historySecondCruiserMapper.insert(historySecondCruiser);
}
/**
* 获取所有走航车信息
* @return
*/
@Override
public List selectCruisers() {
QueryWrapper wrapper = new QueryWrapper<>();
wrapper.eq("is_delete",Constants.NOT_DELETE);
List specialDevices = specialDeviceMapper.selectList(wrapper);
return specialDevices;
}
/**
* 查看走航车轨迹
* @param params
* @return
*/
@Override
public List getCruiserInFo(Map params) {
params.put("dateFormat", "%Y-%m-%d %H:%i:%s");
List data = historySecondCruiserMapper.getCruiserInfo(params);
List rsCruiser = data.stream().distinct().collect(Collectors.toList());
rsCruiser.removeIf(o->{
if (ObjectUtils.isEmpty(o.getFlyLon()) || ObjectUtils.isEmpty(o.getFlyLat())) {
return true;
}
double lon = o.getFlyLon();
double lat = o.getFlyLat();
if (lon < 70 || lon > 150 || lat < 20 || lat > 60) {
return true;
}
return false;
});
if(CollectionUtils.isEmpty(data)){
return null;
}
log.info(data.size()+"");
log.info(rsCruiser.size()+"");
return rsCruiser;
}
}