| New file | 
|  |  |  | 
|---|
|  |  |  | package com.dy.rtuMw.server.rtuData.p206V1; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.dy.common.mw.protocol.Data; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1.DataV1; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1.upVos.DataCdC0Vo; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoPr.PrController; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmOnHourReportHistory; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmOnHourReportLast; | 
|---|
|  |  |  | import com.dy.rtuMw.server.ServerProperties; | 
|---|
|  |  |  | 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 2024/1/16 14:11 | 
|---|
|  |  |  | * @LastEditTime 2024/1/16 14:11 | 
|---|
|  |  |  | * @Description 控制器自报实时数据(功能码为C0)(定点上报) | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public class TkDealOnHourReport extends TaskSurpport { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private static final Logger log = LogManager.getLogger(TkDealOnHourReport.class.getName()) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //类ID,一定与Tree.xml配置文件中配置一致 | 
|---|
|  |  |  | public static final String taskId = "TkDealOnHourReport" ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行节点任务:控制器自报数据(功能码为C0) | 
|---|
|  |  |  | * @param data 需要处理的数据 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void execute(Object data) { | 
|---|
|  |  |  | Data d = (Data) data; | 
|---|
|  |  |  | DataV1 dV1 = (DataV1) d.getSubData();//前面任务已经判断不为null | 
|---|
|  |  |  | Object cdObj = dV1.subData; | 
|---|
|  |  |  | if (cdObj != null && cdObj instanceof DataCdC0Vo){ | 
|---|
|  |  |  | Object[] objs = this.getTaskResults(TkPreGenObjs.taskId) ; | 
|---|
|  |  |  | DbSv sv = (DbSv)objs[0] ; | 
|---|
|  |  |  | PrController controller = (PrController)objs[1] ; | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | this.doDeal(sv, controller, d.getRtuAddr(), dV1, (DataCdC0Vo)cdObj); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | log.error("保存控制器定点上报数据时发生异常", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 处理阀上报数据 | 
|---|
|  |  |  | * @param sv 服务 | 
|---|
|  |  |  | * @param controller 控制器对象 | 
|---|
|  |  |  | * @param rtuAddr 控制器地址 | 
|---|
|  |  |  | * @param cdData 协议数据 | 
|---|
|  |  |  | * @param cdData 功能数据 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void doDeal(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, DataCdC0Vo cdData) throws Exception { | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, rtuAddr, dV1, cdData); | 
|---|
|  |  |  | this.saveHistory(sv, controller, rtuAddr, dV1, cdData); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 保存自报最新数据 | 
|---|
|  |  |  | * @param sv 服务 | 
|---|
|  |  |  | * @param controller 控制器对象 | 
|---|
|  |  |  | * @param rtuAddr 控制器地址 | 
|---|
|  |  |  | * @param cdData 自报数据对象 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void saveOrUpdateLast(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, DataCdC0Vo cdData) throws Exception { | 
|---|
|  |  |  | RmOnHourReportLast po = sv.getRmOnHourReportLast(controller.getIntakeId()) ; | 
|---|
|  |  |  | if(po == null){ | 
|---|
|  |  |  | po = new RmOnHourReportLast(); | 
|---|
|  |  |  | po.controllerId = controller==null?null:controller.getId(); | 
|---|
|  |  |  | po.intakeId = controller==null?null:controller.getIntakeId(); | 
|---|
|  |  |  | po.rtuAddr = rtuAddr; | 
|---|
|  |  |  | po.valueFrom(dV1, cdData); | 
|---|
|  |  |  | sv.saveRmOnHourReportLast(po) ; | 
|---|
|  |  |  | if(po.lossAmount >= ServerProperties.intakeAlarmLossMinValue){ | 
|---|
|  |  |  | this.sendMessage(controller, po.lossAmount); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | po.controllerId = controller==null?null:controller.getId(); | 
|---|
|  |  |  | po.intakeId = controller==null?null:controller.getIntakeId(); | 
|---|
|  |  |  | po.valueFrom(dV1, cdData); | 
|---|
|  |  |  | sv.updateRmOnHourReportLast(po); | 
|---|
|  |  |  | if(po.lossAmount >= ServerProperties.intakeAlarmLossMinValue){ | 
|---|
|  |  |  | this.sendMessage(controller, po.lossAmount); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 保存或更新控制器该上报历史数据 | 
|---|
|  |  |  | * @param sv 服务bean | 
|---|
|  |  |  | * @param controller 控制器对象 | 
|---|
|  |  |  | * @param rtuAddr 控制器地址 | 
|---|
|  |  |  | * @param dV1 协议数据 | 
|---|
|  |  |  | * @param cdData 功能数据 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void saveHistory(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, DataCdC0Vo cdData)throws Exception { | 
|---|
|  |  |  | RmOnHourReportHistory po = new RmOnHourReportHistory(); | 
|---|
|  |  |  | po.controllerId = controller==null?null:controller.getId(); | 
|---|
|  |  |  | po.intakeId = controller==null?null:controller.getIntakeId(); | 
|---|
|  |  |  | po.rtuAddr = rtuAddr; | 
|---|
|  |  |  | po.valueFrom(dV1, cdData); | 
|---|
|  |  |  | sv.saveRmOnHourReportHistory(po); ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 向钉钉发送消息 | 
|---|
|  |  |  | * @param controller | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void sendMessage(PrController controller, Double lossAmount){ | 
|---|
|  |  |  | String ms = "取水口“" + controller.getIntakeName() + "”漏水报警,今日漏损量" + lossAmount + "立方米"; | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | SendMsCache.cacheMs(ms); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | log.error("缓存钉钉消息异常:", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|