From 9298cd7d807f3a586c067c8bb283dcf4b50a7021 Mon Sep 17 00:00:00 2001 From: Jay <csj123456> Date: 星期三, 16 四月 2025 11:11:34 +0800 Subject: [PATCH] 新增氧气优化指标任务 --- shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunScheduleO2ExecuteTask.java | 94 +++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 94 insertions(+), 0 deletions(-) diff --git a/shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunScheduleO2ExecuteTask.java b/shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunScheduleO2ExecuteTask.java new file mode 100644 index 0000000..1baf8cd --- /dev/null +++ b/shasteel-biz/src/main/java/com/iailab/module/shasteel/job/task/RunScheduleO2ExecuteTask.java @@ -0,0 +1,94 @@ +package com.iailab.module.shasteel.job.task; + +import com.iailab.module.model.api.mcs.McsApi; +import com.iailab.module.model.api.mcs.dto.AlarmMessageRespDTO; +import com.iailab.module.model.api.mcs.dto.StScheduleSchemeDTO; +import com.iailab.module.model.api.mdk.MdkApi; +import com.iailab.module.model.api.mdk.dto.MdkScheduleReqDTO; +import com.iailab.module.model.api.mdk.dto.MdkScheduleRespDTO; +import com.iailab.module.model.enums.ScheduleTriggerMethodEnum; +import org.apache.commons.lang3.StringUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; +import org.springframework.util.CollectionUtils; + +import java.util.*; + +/** + * 氧气优化指标 + * 定时触发,30 0/1 * * * ? + * + * @author Jay + */ +@Component("runScheduleO2ExecuteTask") +public class RunScheduleO2ExecuteTask implements ITask { + private Logger logger = LoggerFactory.getLogger(getClass()); + + @Autowired + private McsApi mcsApi; + + @Autowired + private MdkApi mdkApi; + + @Override + public void run(String params) { + logger.info("RunScheduleO2ExecuteTask,参数为:{}", params); + try { + Calendar calendar = Calendar.getInstance(); + calendar.set(Calendar.MILLISECOND, 0); + calendar.set(Calendar.SECOND, 0); + Date scheduleTime = calendar.getTime(); + if (StringUtils.isEmpty(params)) { + logger.info("参数为空"); + return; + } + + // 根据条件查找方案 + List<StScheduleSchemeDTO> schemeList = mcsApi.listScheduleScheme(ScheduleTriggerMethodEnum.JOB.getCode(), params); + if (CollectionUtils.isEmpty(schemeList)) { + logger.info("方案为空"); + return; + } + for (StScheduleSchemeDTO scheme : schemeList) { + MdkScheduleReqDTO dto = new MdkScheduleReqDTO(); + dto.setScheduleTime(scheduleTime); + dto.setScheduleCode(scheme.getCode()); + MdkScheduleRespDTO mdkScheduleRespDTO = mdkApi.doSchedule(dto); + if (mdkScheduleRespDTO.getResult().get("faWarning") != null && + StringUtils.isNotEmpty(mdkScheduleRespDTO.getResult().get("faWarning").toString())) { + this.saveAlarmMessage("法液空合同执行度", mdkScheduleRespDTO.getResult().get("faWarning"), scheme.getScheduleObj(), scheduleTime); + } + if (mdkScheduleRespDTO.getResult().get("yingWarning") != null && + StringUtils.isNotEmpty(mdkScheduleRespDTO.getResult().get("yingWarning").toString())) { + this.saveAlarmMessage("盈德合同执行度", mdkScheduleRespDTO.getResult().get("yingWarning"), scheme.getScheduleObj(), scheduleTime); + } + } + logger.info(params + "调度方案执行完成"); + } catch (Exception ex) { + logger.error("RunScheduleO2ExecuteTask运行异常"); + ex.printStackTrace(); + } + logger.info("RunScheduleO2ExecuteTask运行完成"); + } + + private void saveAlarmMessage(String title, Object content, String scheduleObj, Date scheduleTime) { + if (content == null) { + logger.info(title + "预警信息为空,不产生预警"); + return; + } + String contentStr = content.toString(); + if (StringUtils.isBlank(contentStr)) { + logger.info(title + "预警信息为空,不产生预警"); + return; + } + AlarmMessageRespDTO alarm = new AlarmMessageRespDTO(); + alarm.setTitle(title); + alarm.setContent(contentStr); + alarm.setAlarmObj(scheduleObj); + alarm.setAlarmType(""); + alarm.setAlarmTime(scheduleTime); + mcsApi.createAlarmMessage(alarm); + } +} \ No newline at end of file -- Gitblit v1.9.3