package com.dy.rtuMw.server.rtuData.p206V202404; import com.dy.common.mw.protocol.Data; import com.dy.common.mw.protocol.p206V202404.DataV202404; import com.dy.common.mw.protocol.p206V202404.upVos.DataCd80_5BVo; import com.dy.pipIrrGlobal.pojoPr.PrController; import com.dy.pipIrrGlobal.pojoRm.RmWorkReportHistory; import com.dy.pipIrrGlobal.pojoRm.RmWorkReportLast; 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: 2024/6/14 9:19 * @Description 处理控制器工作报(功能码80) */ public class TkDealWorkingReportV202404 extends TaskSurpport { private static final Logger log = LogManager.getLogger(TkDealWorkingReportV202404.class.getName()); //类ID,一定与Tree.xml配置文件中配置一致 public static final String taskId = "TkDealWorkingReportV202404"; /** * 执行节点任务:报警及状态 * * @param data 需要处理的数据 */ @Override public void execute(Object data) { Data d = (Data)data ; DataV202404 dV202404 = (DataV202404)d.getSubData() ; Object cdObj = dV202404.subData ; //前面任务已经判断cdObj不为null try { Object[] objs = this.getTaskResults(TkPreGenObjsV202404.taskId); DbSv sv = (DbSv) objs[0]; PrController controller = (PrController) objs[1]; if (cdObj instanceof DataCd80_5BVo) { DataCd80_5BVo cdData = (DataCd80_5BVo) (cdObj); this.doDeal(sv, controller, d.getRtuAddr(), dV202404, (DataCd80_5BVo)cdObj); } } catch (Exception e) { log.error("保存处理控制器工作报数据时发生异常", e); } } /** * 处理阀开工作报数据 * @param sv 服务 * @param controller 控制器对象 * @param rtuAddr 控制器地址 * @param dataV202404 协议数据 * @param cdData 功能数据 */ private void doDeal(DbSv sv, PrController controller, String rtuAddr, DataV202404 dataV202404, DataCd80_5BVo cdData) throws Exception { this.saveOrUpdateLast(sv, controller, rtuAddr, dataV202404, cdData); this.saveHistory(sv, controller, rtuAddr, dataV202404, cdData); } /** * 保存或更新控制器工作报最新数据 * @param sv 服务bean * @param controller 控制器对象 * @param rtuAddr 控制器地址 * @param dataV202404 协议数据 * @param cdData 功能数据 */ private void saveOrUpdateLast(DbSv sv, PrController controller, String rtuAddr, DataV202404 dataV202404, DataCd80_5BVo cdData)throws Exception { RmWorkReportLast po = sv.getRmWorkReportLast(controller.getIntakeId()) ; if(po == null){ po = new RmWorkReportLast(); po.controllerId = controller==null?null:controller.getId(); po.intakeId = controller==null?null:controller.getIntakeId(); po.rtuAddr = rtuAddr; po.valueFrom(dataV202404, cdData); sv.saveRmWorkReportLast(po) ; }else{ po.controllerId = controller==null?null:controller.getId(); po.intakeId = controller==null?null:controller.getIntakeId(); po.valueFrom(dataV202404, cdData); sv.updateRmWorkReportLast(po); } } /** * 保存控制器工作报历史数据 * @param sv 服务bean * @param controller 控制器对象 * @param rtuAddr 控制器地址 * @param dataV202404 协议数据 * @param cdData 功能数据 */ private void saveHistory(DbSv sv, PrController controller, String rtuAddr, DataV202404 dataV202404, DataCd80_5BVo cdData)throws Exception { RmWorkReportHistory po = new RmWorkReportHistory(); po.controllerId = controller==null?null:controller.getId(); po.intakeId = controller==null?null:controller.getIntakeId(); po.rtuAddr = rtuAddr; po.valueFrom(dataV202404, cdData); sv.saveRmWorkReportHistory(po); ; } }