| 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.RmCommandHistory; | 
| 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.Date; | 
|   | 
| /** | 
|  * @Author: liurunyu | 
|  * @Date: 2025/6/25 15:52 | 
|  * @Description | 
|  */ | 
| public class TkDealCommandResponseSdV1 extends TaskSurpport { | 
|   | 
|     private static final Logger log = LogManager.getLogger(TkDealCommandResponseSdV1.class.getName()) ; | 
|   | 
|     //类ID,一定与Tree.xml配置文件中配置一致 | 
|     public static final String taskId = "TkDealCommandResponseSdV1" ; | 
|   | 
|     /** | 
|      * 执行节点任务:处理命令响应上报 | 
|      * @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{ | 
|             RmCommandHistory po = sv.getCommandLog(msg.commandId) ; | 
|             if(po != null){ | 
|                 po = this.updateCommandLogPo(po, msg) ; | 
|                 sv.updateCommandLog(po); | 
|             }else{ | 
|                 log.error("未得到MQTT命令日志(" + msg.getCommandId() + ")"); | 
|             } | 
|         }catch (Exception e){ | 
|             log.error("保存MQTT命令结果发生异常", e); | 
|         } | 
|     } | 
|   | 
|     public RmCommandHistory updateCommandLogPo(RmCommandHistory po, MqttSubMsg msg) throws Exception{ | 
|         po.setResultTime(new Date()); | 
|         po.setResult((byte)1); | 
|         po.setResultText(msg.metaData); | 
|         return po ; | 
|     } | 
|   | 
| } |