package com.dy.rtuMw.server.rtuData.pSdV1; import com.dy.common.mw.protocol4Mqtt.MqttSubMsg; import com.dy.common.mw.protocol4Mqtt.pSdV1.upVos.ManureVo; import com.dy.pipIrrGlobal.pojoPr.PrStManure; import com.dy.pipIrrGlobal.pojoRm.RmManureHistory; import com.dy.pipIrrGlobal.pojoRm.RmManureLast; import com.dy.rtuMw.server.forMs.SendMsCache; 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; /** * @Author: liurunyu * @Date: 2025/6/25 11:37 * @Description */ public class TkDealManureSdV1 extends TaskSurpport { private static Logger log = LogManager.getLogger(TkDealManureSdV1.class.getName()); //类ID,一定与Tree.xml配置文件中配置一致 public static final String taskId = "TkDealManureSdV1"; /** * 执行节点任务 * * @param data 需要处理的数据 */ @Override public void execute(Object data) { //前面的任务已经判断了data不为空且为水肥数据 MqttSubMsg msg = (MqttSubMsg) data; ManureVo stVo = (ManureVo) msg.vo4Up; Object[] objs = this.getTaskResults(TkPreGenObjs4ManureSdV1.taskId); DbSv sv = (DbSv) objs[0]; PrStManure stPo = (PrStManure) objs[1]; try{ this.doDeal(sv, stPo, msg, stVo); }catch (Exception e){ log.error("保存水肥数据时发生异常", e); } } /** * 处理上行消息数据 * @param sv 服务 * @param stPo 实体对象 * @param msg 上行的订阅消息 * @param stVo 上行的设备数据 */ private void doDeal(DbSv sv, PrStManure stPo, MqttSubMsg msg, ManureVo stVo) throws Exception { RmManureHistory hpo = this.saveHistory(sv, stPo, msg, stVo); this.saveOrUpdateLast(sv, stPo, msg, stVo, hpo); } /** * 处理上行消息数据 * @param sv 服务 * @param stPo 实体对象 * @param msg 上行的订阅消息 * @param stVo 上行的设备数据 * @param hpo 历史记录最新数据 */ private void saveOrUpdateLast(DbSv sv, PrStManure stPo, MqttSubMsg msg, ManureVo stVo, RmManureHistory hpo) throws Exception { RmManureLast po = sv.getRmManureLast(stPo.id) ; if(po == null){ po = new RmManureLast(); po.valueFrom(msg, stVo); po.manureId = stPo.id ; po.lastHistoryId = hpo==null?null:hpo.id ; sv.saveRmManureLast(po) ; if(stVo.alarm != null && stVo.alarm == 1){ this.sendMessage(stPo, msg, stVo); } }else{ po.valueFrom(msg, stVo); po.manureId = stPo.id ; po.lastHistoryId = hpo==null?null:hpo.id ; sv.updateRmManureLast(po); if(stVo.alarm != null && stVo.alarm == 1){ this.sendMessage(stPo, msg, stVo); } } } /** * 处理上行消息数据 * @param sv 服务 * @param stPo 实体对象 * @param msg 上行的订阅消息 * @param stVo 上行的设备数据 */ private RmManureHistory saveHistory(DbSv sv, PrStManure stPo, MqttSubMsg msg, ManureVo stVo) throws Exception { RmManureHistory po = new RmManureHistory(); po.valueFrom(msg, stVo); po.manureId = stPo.id ; sv.saveRmManureHistory(po); return po ; } /** * 向钉钉发送消息 * @param stPo * @param msg * @param stVo */ private void sendMessage(PrStManure stPo, MqttSubMsg msg, ManureVo stVo){ String ms = "水肥机“" + stPo.name + "”注肥泵报警"; try{ SendMsCache.cacheMs(ms); }catch (Exception e){ log.error("缓存钉钉消息异常:", e); } } }