package com.dy.rtuMw.server.rtuData.pSdV1; import com.dy.common.mw.protocol4Mqtt.MqttSubMsg; import com.dy.common.mw.protocol4Mqtt.pSdV1.upVos.SoilVo; import com.dy.common.springUtil.SpringContextUtil; import com.dy.pipIrrGlobal.pojoPr.PrStSoil; import com.dy.rtuMw.server.ServerProperties; import com.dy.rtuMw.server.rtuData.TaskSurpport; import com.dy.rtuMw.server.rtuData.dbSv.DbSv; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import java.util.HashMap; import java.util.Map; /** * @Author: liurunyu * @Date: 2025/6/25 11:25 * @Description */ public class TkPreGenObjs4SoilSdV1 extends TaskSurpport { private static Logger log = LogManager.getLogger(TkPreGenObjs4SoilSdV1.class.getName()) ; //类ID,一定与Tree.xml配置文件中配置一致 public static final String taskId = "TkPreGenObjs4SoilSdV1" ; //处理上条数据的时刻 private static final Map dealDataAtDateTime = new HashMap<>(); /** * 执行节点任务 * @param data 需要处理的数据 */ @Override public void execute(Object data) { //前面的任务已经判断了data不为空 MqttSubMsg msg = (MqttSubMsg)data ; if(msg.vo4Up != null && msg.vo4Up instanceof SoilVo){ //墒情数据 SoilVo stVo = (SoilVo)msg.vo4Up ; Long lastAt = dealDataAtDateTime.get(msg.deviceId + stVo.no); Long now = System.currentTimeMillis() ; if(lastAt == null || ((now - lastAt) >= ServerProperties.mqttAcceptDataMinInterval)) { dealDataAtDateTime.put(msg.deviceId + stVo.no, now); DbSv sv = SpringContextUtil.getBean(DbSv.class); if (sv != null) { PrStSoil stPo = sv.getStSoilByFBoxIdAndNo(msg.deviceId, stVo.no); if (stPo != null) { this.taskResult = new Object[]{sv, stPo}; this.toNextTasks(data); } } else { log.error("严重错误,未能得到DbSv对象"); } } } } }