wisdomisite-java/src/main/java/com/zhgd/xmgl/task/ElectricalTask.java

226 lines
10 KiB
Java
Raw Normal View History

2023-02-16 15:28:15 +08:00
package com.zhgd.xmgl.task;
import cn.hutool.core.collection.CollUtil;
2024-05-18 01:06:42 +08:00
import cn.hutool.http.HttpRequest;
import cn.hutool.http.HttpResponse;
import com.alibaba.fastjson.JSON;
2023-02-16 15:28:15 +08:00
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
2024-05-18 01:06:42 +08:00
import com.baidubce.services.iotshc.model.token.GetTokenRequest;
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;
2024-05-18 01:06:42 +08:00
import org.springframework.beans.factory.annotation.Value;
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;
2024-03-25 15:13:09 +08:00
import org.springframework.web.bind.annotation.RequestMapping;
2023-08-04 09:48:49 +08:00
import org.springframework.web.bind.annotation.RestController;
2023-02-16 15:28:15 +08:00
import javax.annotation.Resource;
2024-05-18 01:06:42 +08:00
import java.util.*;
2023-02-16 15:28:15 +08:00
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;
2024-05-18 01:06:42 +08:00
@Value("${sada.host}")
private String sadaHost;
2023-02-16 15:28:15 +08:00
/**
* 获取最新电量使用情况 每5分钟触发任务
*/
@SchedulerLock(name = "getElectricRealTimeData", lockAtMostFor = 1000 * 60 * 5, lockAtLeastFor = 1000 * 60 * 3)
@Scheduled(cron = "0 0/5 * * * ?")
2024-03-25 15:13:09 +08:00
@RequestMapping("/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-05-18 01:06:42 +08:00
/**
2024-05-18 09:10:57 +08:00
* 获取电箱情况 每5分钟触发任务
2024-05-18 01:06:42 +08:00
*/
2024-05-18 19:36:29 +08:00
@Scheduled(cron = "0 30 * * * ?")
2024-05-18 01:06:42 +08:00
@RequestMapping("/xmgl/task/getElectricData")
public void getElectricData() {
log.info("获取设备数据 每1分钟触发任务");
JSONObject obj = getToken();
if (obj == null) {
log.error("获取token失败");
}
String token = obj.getString("token");
String hashId = obj.getJSONObject("account").getJSONObject("currentProject").getString("hashId");
List<String> devList = doGetElectricalData(token, hashId);
devList.forEach(dev -> CompletableFuture.supplyAsync(() -> {
return doAddElectricalData(dev, token);
}).exceptionally(throwable -> {
log.error("err:", throwable);
return null;
})
);
}
private List<String> doGetElectricalData(String token, String hashId) {
HttpRequest post = HttpRequest.get(sadaHost + "/box/project/" + hashId);
post.header("Auth", token);
HttpResponse execute = post.execute();
boolean ok = execute.isOk();
if (ok) {
log.info("电箱数据" + execute.body());
List<String> devList = new ArrayList<>();
JSONObject result = JSONObject.parseObject(execute.body());
JSONArray result1 = result.getJSONArray("result");
for (int i = 0; i < result1.size(); i++) {
devList.add(result1.getJSONObject(i).getString("hashId"));
}
return devList;
}
return null;
}
private boolean doAddElectricalData(String devId, String token) {
HttpRequest post = HttpRequest.get(sadaHost + "/metric/box/" + devId);
post.header("Auth", token);
HttpResponse execute = post.execute();
boolean ok = execute.isOk();
if (ok) {
log.info("电箱实时数据" + execute.body());
JSONObject result = JSONObject.parseObject(execute.body()).getJSONObject("result");
JSONObject metric = result.getJSONObject("metric");
2025-05-15 16:30:39 +08:00
JSONArray jsonArray = result.getJSONArray("temperatures");
if (CollUtil.isNotEmpty(jsonArray)) {
String temperatures = String.format("%.1f", Double.parseDouble(jsonArray.getJSONObject(0).getString("temperature")));
ElectricalData electricalData = new ElectricalData(devId,
metric.getString("modified"),
String.format("%.1f", Double.parseDouble(metric.getString("voltage_a"))),
String.format("%.1f", Double.parseDouble(metric.getString("voltage_b"))),
String.format("%.1f", Double.parseDouble(metric.getString("voltage_c"))),
String.format("%.1f", Double.parseDouble(metric.getString("current_a"))),
String.format("%.1f", Double.parseDouble(metric.getString("current_b"))),
String.format("%.1f", Double.parseDouble(metric.getString("current_c"))),
String.format("%.1f", Double.parseDouble(result.getJSONArray("leakages").getJSONObject(0).getString("leakage"))),
temperatures, temperatures, temperatures,
temperatures);
electricalDataService.saveElectricalData(electricalData);
}
2024-05-18 01:06:42 +08:00
return true;
}
return false;
}
private JSONObject getToken() {
JSONObject param = new JSONObject();
param.put("username", "赤峰智慧工地-zcr");
param.put("password", "IXNOI9mk35");
HttpRequest post = HttpRequest.post(sadaHost + "/v2/api-token-auth");
post.body(JSON.toJSONString(param));
HttpResponse execute = post.execute();
boolean ok = execute.isOk();
if (ok) {
log.info(execute.body());
JSONObject result = JSONObject.parseObject(execute.body());
return result.getJSONObject("result");
}
return null;
}
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
}
}