2023-02-16 15:28:15 +08:00
|
|
|
|
package com.zhgd.xmgl.task;
|
|
|
|
|
|
|
|
|
|
|
|
import cn.hutool.core.collection.CollUtil;
|
|
|
|
|
|
import com.alibaba.fastjson.JSONArray;
|
|
|
|
|
|
import com.alibaba.fastjson.JSONObject;
|
2023-08-04 09:48:49 +08:00
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import com.zhgd.xmgl.modules.electrical.entity.ElectricalData;
|
|
|
|
|
|
import com.zhgd.xmgl.modules.electrical.entity.ElectricalDev;
|
2023-08-04 09:48:49 +08:00
|
|
|
|
import com.zhgd.xmgl.modules.electrical.mapper.ElectricalDataMapper;
|
2024-01-30 14:43:36 +08:00
|
|
|
|
import com.zhgd.xmgl.modules.electrical.mapper.ElectricalDevMapper;
|
|
|
|
|
|
import com.zhgd.xmgl.modules.electrical.service.IElectricAlarmService;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import com.zhgd.xmgl.modules.electrical.service.IElectricalDataService;
|
|
|
|
|
|
import com.zhgd.xmgl.modules.electrical.service.IElectricalDevService;
|
2024-01-02 18:35:40 +08:00
|
|
|
|
import com.zhgd.xmgl.modules.project.entity.Project;
|
|
|
|
|
|
import com.zhgd.xmgl.modules.project.mapper.ProjectMapper;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import com.zhgd.xmgl.util.XiwonUtil;
|
|
|
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
|
|
|
|
import net.javacrumbs.shedlock.core.SchedulerLock;
|
2024-01-30 14:43:36 +08:00
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import org.springframework.http.HttpStatus;
|
|
|
|
|
|
import org.springframework.scheduling.annotation.Scheduled;
|
|
|
|
|
|
import org.springframework.stereotype.Component;
|
2023-08-04 09:48:49 +08:00
|
|
|
|
import org.springframework.web.bind.annotation.GetMapping;
|
|
|
|
|
|
import org.springframework.web.bind.annotation.RestController;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
|
|
|
|
|
|
import javax.annotation.Resource;
|
2024-01-30 14:43:36 +08:00
|
|
|
|
import java.util.Date;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
|
import java.util.List;
|
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
import java.util.concurrent.CompletableFuture;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @author 邱平毅
|
|
|
|
|
|
* @ClassName ElectricalTask
|
|
|
|
|
|
* @date 2022/11/15 14:02
|
|
|
|
|
|
* @Version 1.0
|
|
|
|
|
|
* 电箱定时任务
|
|
|
|
|
|
*/
|
|
|
|
|
|
@Slf4j
|
|
|
|
|
|
@Component
|
2024-01-02 18:35:40 +08:00
|
|
|
|
@RestController
|
2023-02-16 15:28:15 +08:00
|
|
|
|
public class ElectricalTask {
|
|
|
|
|
|
@Resource
|
|
|
|
|
|
private IElectricalDataService electricalDataService;
|
2023-08-04 09:48:49 +08:00
|
|
|
|
@Resource
|
|
|
|
|
|
private ElectricalDataMapper electricalDataMapper;
|
2024-01-02 18:35:40 +08:00
|
|
|
|
@Resource
|
|
|
|
|
|
private ProjectMapper projectMapper;
|
2024-01-30 14:43:36 +08:00
|
|
|
|
@Autowired
|
|
|
|
|
|
private IElectricAlarmService electricAlarmService;
|
|
|
|
|
|
@Autowired
|
|
|
|
|
|
private ElectricalDevMapper electricalDevMapper;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
@Resource
|
|
|
|
|
|
private IElectricalDevService electricalDevService;
|
|
|
|
|
|
|
|
|
|
|
|
@Resource
|
|
|
|
|
|
private XiwonUtil xiwonUtil;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 获取最新电量使用情况 每5分钟触发任务
|
|
|
|
|
|
*/
|
|
|
|
|
|
@SchedulerLock(name = "getElectricRealTimeData", lockAtMostFor = 1000 * 60 * 5, lockAtLeastFor = 1000 * 60 * 3)
|
|
|
|
|
|
@Scheduled(cron = "0 0/5 * * * ?")
|
2024-01-03 10:39:52 +08:00
|
|
|
|
@GetMapping("/xmgl/task/getElectricRealTimeData")
|
2023-02-16 15:28:15 +08:00
|
|
|
|
public void getElectricRealTimeData() {
|
2024-01-02 18:35:40 +08:00
|
|
|
|
log.info("获取最新电量使用情况 每5分钟触发任务");
|
2024-01-20 10:18:46 +08:00
|
|
|
|
List<Project> projectList = projectMapper.selectList(new LambdaQueryWrapper<Project>()
|
|
|
|
|
|
.ne(Project::getXiwonAppId, "")
|
|
|
|
|
|
.isNotNull(Project::getXiwonAppId)
|
|
|
|
|
|
.ne(Project::getXiwonAppSecret, "")
|
|
|
|
|
|
.isNotNull(Project::getXiwonAppSecret)
|
|
|
|
|
|
);
|
|
|
|
|
|
for (Project project : projectList) {
|
|
|
|
|
|
// 获取所有
|
|
|
|
|
|
List<ElectricalDev> devList = electricalDevService.list(new LambdaQueryWrapper<ElectricalDev>().eq(ElectricalDev::getProjectSn, project.getProjectSn()));
|
|
|
|
|
|
devList.forEach(dev -> CompletableFuture.supplyAsync(() -> {
|
2024-01-30 13:59:07 +08:00
|
|
|
|
return doGetElectricRealTimeData(dev, project);
|
2024-01-20 10:18:46 +08:00
|
|
|
|
}).exceptionally(throwable -> {
|
|
|
|
|
|
log.error("err:", throwable);
|
|
|
|
|
|
return null;
|
|
|
|
|
|
})
|
2023-08-04 09:48:49 +08:00
|
|
|
|
);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2023-02-16 15:28:15 +08:00
|
|
|
|
|
2024-01-30 13:59:07 +08:00
|
|
|
|
private boolean doGetElectricRealTimeData(ElectricalDev dev, Project project) {
|
|
|
|
|
|
// 请求参数
|
|
|
|
|
|
Map<String, Object> map = new HashMap<>(4);
|
|
|
|
|
|
map.put("state", 0);
|
|
|
|
|
|
map.put("pageSize", "1");
|
|
|
|
|
|
map.put("pageNum", "1");
|
2023-08-04 09:48:49 +08:00
|
|
|
|
// 设备sn
|
|
|
|
|
|
String devSn = dev.getDevSn();
|
|
|
|
|
|
ElectricalData newestData = electricalDataMapper.selectOne(new LambdaQueryWrapper<ElectricalData>().eq(ElectricalData::getDevSn, devSn).orderByDesc(ElectricalData::getUploadTime).last("limit 1"));
|
|
|
|
|
|
// 请求携稳的接口
|
2024-01-20 10:18:46 +08:00
|
|
|
|
JSONObject realTimeData = xiwonUtil.postForm("/electric/realTimeData", project.getXiwonAppId(), project.getXiwonAppSecret(), map, JSONObject.class, (() -> {
|
2023-08-04 09:48:49 +08:00
|
|
|
|
if (newestData != null && newestData.getXiewenId() != null) {
|
|
|
|
|
|
map.put("dataId", newestData.getXiewenId());
|
|
|
|
|
|
}
|
|
|
|
|
|
return map.put("deviceSn", devSn);
|
|
|
|
|
|
}));
|
2024-01-20 10:18:46 +08:00
|
|
|
|
|
2024-01-02 18:35:40 +08:00
|
|
|
|
log.info("携稳接口响应数据(配电箱):{}", JSONArray.toJSONString(realTimeData));
|
2023-08-04 09:48:49 +08:00
|
|
|
|
Integer code = realTimeData.getInteger("code");
|
|
|
|
|
|
// code校验是否成功请求
|
|
|
|
|
|
if (code == HttpStatus.OK.value()) {
|
2024-01-30 14:43:36 +08:00
|
|
|
|
ElectricalDev tempElectricalDev = new ElectricalDev();
|
|
|
|
|
|
tempElectricalDev.setId(dev.getId());
|
|
|
|
|
|
tempElectricalDev.setRealTime(new Date());
|
|
|
|
|
|
electricalDevMapper.updateById(tempElectricalDev);
|
2023-08-04 09:48:49 +08:00
|
|
|
|
JSONArray dataArray = realTimeData.getJSONArray("data");
|
|
|
|
|
|
if (CollUtil.isNotEmpty(dataArray)) {
|
|
|
|
|
|
// 解析请求到的参数,保存到我们的数据库
|
|
|
|
|
|
JSONObject data = dataArray.getJSONObject(0);
|
|
|
|
|
|
ElectricalData electricalData = new ElectricalData(devSn, data.getString("dataTime"), data.getString("voltageA"), data.getString("voltageB"),
|
|
|
|
|
|
data.getString("voltageC"), data.getString("currentA"), data.getString("currentB"), data.getString("currentC"),
|
|
|
|
|
|
data.getString("leakage"), data.getString("temperatureA"), data.getString("temperatureB"), data.getString("temperatureC"), data.getString("temperatureD"));
|
|
|
|
|
|
electricalData.setXiewenId(data.getLong("id"));
|
|
|
|
|
|
electricalDataService.saveElectricalData(electricalData);
|
2024-01-30 14:43:36 +08:00
|
|
|
|
electricAlarmService.addAlarm(electricalData, dev);
|
|
|
|
|
|
|
2023-08-04 09:48:49 +08:00
|
|
|
|
} else {
|
|
|
|
|
|
log.error("设备sn:{},当前无数据!", devSn);
|
|
|
|
|
|
}
|
|
|
|
|
|
} else {
|
|
|
|
|
|
log.error("设备sn:{},请求失败!当前code:{},msg:{}", devSn, code, realTimeData.getString("msg"));
|
|
|
|
|
|
}
|
|
|
|
|
|
return true;
|
2023-02-16 15:28:15 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|