| 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.DataCd83CloseVo; | 
|---|
|  |  |  | import com.dy.common.util.DateTime; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoPr.PrController; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmOpenCloseValveHistory; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmOpenCloseValveLast; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoSe.SeClient; | 
|---|
|  |  |  | import com.dy.rtuMw.server.msCenter.MsCenterUnit; | 
|---|
|  |  |  | import com.dy.rtuMw.server.msCenter.MsObj; | 
|---|
|  |  |  | 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 17:18 | 
|---|
|  |  |  | * @LastEditTime 2024/1/16 17:18 | 
|---|
|  |  |  | * @Description | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 处理控制器关阀上报 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public class TkDealCloseValveReport extends TaskSurpport { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private static final Logger log = LogManager.getLogger(TkDealCloseValveReport.class.getName()) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //类ID,一定与Tree.xml配置文件中配置一致 | 
|---|
|  |  |  | public static final String taskId = "TkDealCloseValveReport" ; | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行节点任务: 处理控制器关阀上报 | 
|---|
|  |  |  | * @param data 需要处理的数据 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public void execute(Object data) { | 
|---|
|  |  |  | Data d = (Data) data; | 
|---|
|  |  |  | DataV1 dV1 = (DataV1) d.getSubData(); | 
|---|
|  |  |  | Object cdObj = dV1.subData; | 
|---|
|  |  |  | if (cdObj != null && cdObj instanceof DataCd83CloseVo) { | 
|---|
|  |  |  | Object[] objs = this.getTaskResults(TkPreGenObjs.taskId) ; | 
|---|
|  |  |  | DbSv sv = (DbSv)objs[0] ; | 
|---|
|  |  |  | PrController controller = (PrController)objs[1] ; | 
|---|
|  |  |  | SeClient clientVo = (SeClient)objs[3] ;//这个值对象中只有id和name会有值 | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | this.toMsCenter(clientVo, controller, d.getRtuAddr(), dV1, (DataCd83CloseVo)cdObj) ; | 
|---|
|  |  |  | this.doDeal(sv, clientVo, controller, d.getRtuAddr(), dV1, (DataCd83CloseVo)cdObj) ; | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | log.error("保存控制器开阀上报时发生异常", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 把开阀消息存入消息中心 | 
|---|
|  |  |  | * @param clientVo | 
|---|
|  |  |  | * @param controller | 
|---|
|  |  |  | * @param rtuAddr | 
|---|
|  |  |  | * @param dV1 | 
|---|
|  |  |  | * @param dataCd83CloseVo | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void toMsCenter(SeClient clientVo, PrController controller, String rtuAddr, DataV1 dV1, DataCd83CloseVo dataCd83CloseVo){ | 
|---|
|  |  |  | if(clientVo != null && controller != null){ | 
|---|
|  |  |  | MsObj msObj = new MsObj() ; | 
|---|
|  |  |  | msObj.put("name", "关阀"); | 
|---|
|  |  |  | msObj.put("clientId", clientVo.getId()); | 
|---|
|  |  |  | msObj.put("clientName", clientVo.getName()); | 
|---|
|  |  |  | msObj.put("clientAddress", clientVo.getAddress()); | 
|---|
|  |  |  | msObj.put("icCardNo", dataCd83CloseVo.icCardNo); | 
|---|
|  |  |  | msObj.put("rtuAddr", rtuAddr); | 
|---|
|  |  |  | msObj.put("intakeId", controller.getIntakeId()); | 
|---|
|  |  |  | msObj.put("dt", dV1.dt); | 
|---|
|  |  |  | MsCenterUnit.getInstance().pushMs(msObj); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 保存数据 | 
|---|
|  |  |  | * @param sv 服务 | 
|---|
|  |  |  | * @param clientVo 农户对象(不为空时,只有id和name有值) | 
|---|
|  |  |  | * @param controller 控制器对象 | 
|---|
|  |  |  | * @param rtuAddr 控制器地址 | 
|---|
|  |  |  | * @param dV1 上报数据 | 
|---|
|  |  |  | * @param dataCd83CloseVo 关阀上报数据对象 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void doDeal(DbSv sv, SeClient clientVo, PrController controller, String rtuAddr, DataV1 dV1, DataCd83CloseVo dataCd83CloseVo) throws Exception { | 
|---|
|  |  |  | RmOpenCloseValveLast poLast = sv.getRmOpenCloseValveLast(controller.getIntakeId()) ; | 
|---|
|  |  |  | if(poLast == null){ | 
|---|
|  |  |  | //数据库中不存在该控制器的开关阀数据 | 
|---|
|  |  |  | //首先生成最新数据及历史数据,并先保存 | 
|---|
|  |  |  | poLast = this.newRmOpenCloseValveLast(clientVo, controller, rtuAddr, dV1, dataCd83CloseVo); | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, null); | 
|---|
|  |  |  | //保存最新数据 | 
|---|
|  |  |  | sv.saveRmOpenCloseValveLast(poLast); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //数据库中存在该控制器的开关阀数据 | 
|---|
|  |  |  | if(poLast.closeDt != null && poLast.clIcCardAddr != null && poLast.clIcCardNo != null){ | 
|---|
|  |  |  | if(poLast.closeDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83CloseVo.closeDt)) | 
|---|
|  |  |  | && poLast.clIcCardAddr.equals(dataCd83CloseVo.icCardAddr) | 
|---|
|  |  |  | && poLast.clIcCardNo.equals(dataCd83CloseVo.icCardNo)){ | 
|---|
|  |  |  | //重复上报,原因是下行数据处理慢了,就重复上报了 | 
|---|
|  |  |  | return ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(poLast.clType == null){ | 
|---|
|  |  |  | //原记录不存在关阀数据,所以当前关阀上报是新的一次关阀 | 
|---|
|  |  |  | if(poLast.opType == null || poLast.openDt == null){ | 
|---|
|  |  |  | //原记录中不存在开阀数据(即开阀与关阀数据都没有,这种情况一般不存在),没办法进行匹配 | 
|---|
|  |  |  | //生成并保存新的关阀上报历史数据记录 | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, null); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //原记录中存在开阀数据,进行历史数据匹配 | 
|---|
|  |  |  | RmOpenCloseValveHistory poHistory = null ; | 
|---|
|  |  |  | if(poLast.lastHistoryId != null){ | 
|---|
|  |  |  | poHistory = sv.getRmOpenCloseValveHistory(poLast.lastHistoryId) ; | 
|---|
|  |  |  | if(poHistory != null){ | 
|---|
|  |  |  | if(poHistory.openDt != null){ | 
|---|
|  |  |  | //上面已经判断了poLast.openDt == null,所以此处一般会是poHistory.openDt != null | 
|---|
|  |  |  | if(poHistory.openDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83CloseVo.openDt))){ | 
|---|
|  |  |  | //匹配成功 | 
|---|
|  |  |  | //当前关阀是原记录中开阀的对应关阀 | 
|---|
|  |  |  | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, poHistory, dV1, dataCd83CloseVo, false) ; | 
|---|
|  |  |  | sv.updateRmOpenCloseValveHistory(poHistory); | 
|---|
|  |  |  | }else if(poHistory.openDt.after(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83CloseVo.openDt))){ | 
|---|
|  |  |  | //匹配失败(对于after:等于或晚于都返回true) | 
|---|
|  |  |  | //本地最新数据中的开阀时间晚于当前关阀上报中的开阀时间,说明是补报 | 
|---|
|  |  |  | this.dealSupplyReport() ; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //匹配失败 | 
|---|
|  |  |  | //本地最新数据中的开阀时间早于当前关阀上报中的开阀时间,说明是新的一次关阀报,而且对应关阀报的上一次开阀报未收到 | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //这种情况不存在,认为匹配失败 | 
|---|
|  |  |  | //当前关阀不是原记录中开阀的对应关阀,生成并保存新的关阀上报历史数据记录 | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //没有历史数据,这种情况不存在,认为匹配失败,生成并保存新的关阀上报历史数据记录 | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //没有历史数据,这种情况不存在,认为匹配失败,生成并保存新的关阀上报历史数据记录 | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, true); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else if(poLast.opType != null){ | 
|---|
|  |  |  | //原记录存在关阀数据,也存在开阀数据,首先进行开关阀时间对比 | 
|---|
|  |  |  | if(poLast.closeDt != null && poLast.closeDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83CloseVo.closeDt))){ | 
|---|
|  |  |  | //重复上报了,不进行处理 | 
|---|
|  |  |  | }else if(poLast.closeDt != null && poLast.closeDt.after(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83CloseVo.closeDt))){ | 
|---|
|  |  |  | //补报的许久之前的数据(对于after:等于或晚于都返回true) | 
|---|
|  |  |  | this.dealSupplyReport() ; | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | //是新的上报关阀数据 | 
|---|
|  |  |  | //进行历史数据匹配 | 
|---|
|  |  |  | RmOpenCloseValveHistory poHistory = null ; | 
|---|
|  |  |  | if(poLast.lastHistoryId != null) { | 
|---|
|  |  |  | poHistory = sv.getRmOpenCloseValveHistory(poLast.lastHistoryId); | 
|---|
|  |  |  | if (poHistory != null) { | 
|---|
|  |  |  | if(poHistory.openDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83CloseVo.openDt))){ | 
|---|
|  |  |  | //匹配上了 | 
|---|
|  |  |  | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, poHistory, dV1, dataCd83CloseVo, false) ; | 
|---|
|  |  |  | sv.updateRmOpenCloseValveHistory(poHistory); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //上个关阀报未上报 | 
|---|
|  |  |  | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, null, dV1, dataCd83CloseVo, true) ; | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //这种情况不存在,但为安全也进行处理,也认为上个关阀报未上报 | 
|---|
|  |  |  | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, null, dV1, dataCd83CloseVo, true) ; | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //这种情况不存在,但为安全也进行处理,也认为上个关阀报未上报 | 
|---|
|  |  |  | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, null, dV1, dataCd83CloseVo, true) ; | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //if(po.opType == null) | 
|---|
|  |  |  | //原记录不存在开阀数据也不存在关阀数据,这种情况不存在,但为安全也进行处理,也认为上个关阀报未上报 | 
|---|
|  |  |  | this.updateCloseValve(clientVo, controller, rtuAddr, poLast, null, dV1, dataCd83CloseVo, true) ; | 
|---|
|  |  |  | //生成并保存新的关阀上报历史数据记录,没有对应的开发数据 | 
|---|
|  |  |  | this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV1, dataCd83CloseVo, poLast, null); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | sv.updateRmOpenCloseValveLast(poLast); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 处理补报,暂时无逻辑 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void dealSupplyReport(){ | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 保存新的关阀上报历史数据记录,并把ID赋值给最新记录的 lastHistoryId | 
|---|
|  |  |  | * @param sv | 
|---|
|  |  |  | * @param controller | 
|---|
|  |  |  | * @param rtuAddr | 
|---|
|  |  |  | * @param dV1 | 
|---|
|  |  |  | * @param dataCd83CloseVo | 
|---|
|  |  |  | * @param poLast | 
|---|
|  |  |  | * @param clearLastOpenValue | 
|---|
|  |  |  | * @throws Exception | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void newHistoryDataDeal(DbSv sv, | 
|---|
|  |  |  | SeClient clientVo, | 
|---|
|  |  |  | PrController controller, | 
|---|
|  |  |  | String rtuAddr, | 
|---|
|  |  |  | DataV1 dV1, | 
|---|
|  |  |  | DataCd83CloseVo dataCd83CloseVo, | 
|---|
|  |  |  | RmOpenCloseValveLast poLast, | 
|---|
|  |  |  | Boolean clearLastOpenValue)throws Exception { | 
|---|
|  |  |  | RmOpenCloseValveHistory poHistory = this.newRmOpenCloseValveHistory(clientVo, controller, rtuAddr, dV1, dataCd83CloseVo) ; | 
|---|
|  |  |  | sv.saveRmOpenCloseValveHistory(poHistory); | 
|---|
|  |  |  | //由最新数据持有历史数据中的最新记录ID,以方便快速查询 | 
|---|
|  |  |  | poLast.lastHistoryId = poHistory == null ? null: poHistory.id ; | 
|---|
|  |  |  | if(clearLastOpenValue != null && clearLastOpenValue.booleanValue()){ | 
|---|
|  |  |  | poLast.clearOpenValue(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 生成新的关阀上报最新数据记录 | 
|---|
|  |  |  | * @param clientVo | 
|---|
|  |  |  | * @param controller | 
|---|
|  |  |  | * @param rtuAddr | 
|---|
|  |  |  | * @param dV1 | 
|---|
|  |  |  | * @param dataCd83CloseVo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | * @throws Exception | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private RmOpenCloseValveLast newRmOpenCloseValveLast(SeClient clientVo, | 
|---|
|  |  |  | PrController controller, | 
|---|
|  |  |  | String rtuAddr, | 
|---|
|  |  |  | DataV1 dV1, | 
|---|
|  |  |  | DataCd83CloseVo dataCd83CloseVo)throws Exception { | 
|---|
|  |  |  | RmOpenCloseValveLast po = new RmOpenCloseValveLast() ; | 
|---|
|  |  |  | po.clientId = clientVo==null?null:clientVo.getId() ; | 
|---|
|  |  |  | po.clientName = clientVo==null?null:clientVo.getName() ; | 
|---|
|  |  |  | po.controllerId = controller==null?null:controller.getId() ; | 
|---|
|  |  |  | po.intakeId = controller==null?null:controller.getIntakeId() ; | 
|---|
|  |  |  | po.rtuAddr = rtuAddr ; | 
|---|
|  |  |  | po.valueFrom(dV1, dataCd83CloseVo); | 
|---|
|  |  |  | return po ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 生成新的关阀上报历史数据记录 | 
|---|
|  |  |  | * @param clientVo | 
|---|
|  |  |  | * @param controller | 
|---|
|  |  |  | * @param rtuAddr | 
|---|
|  |  |  | * @param dV1 | 
|---|
|  |  |  | * @param dataCd83CloseVo | 
|---|
|  |  |  | * @return | 
|---|
|  |  |  | * @throws Exception | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private RmOpenCloseValveHistory newRmOpenCloseValveHistory(SeClient clientVo, | 
|---|
|  |  |  | PrController controller, | 
|---|
|  |  |  | String rtuAddr, | 
|---|
|  |  |  | DataV1 dV1, | 
|---|
|  |  |  | DataCd83CloseVo dataCd83CloseVo)throws Exception { | 
|---|
|  |  |  | RmOpenCloseValveHistory po = new RmOpenCloseValveHistory() ; | 
|---|
|  |  |  | po.clientId = clientVo==null?null:clientVo.getId() ; | 
|---|
|  |  |  | po.clientName = clientVo==null?null:clientVo.getName() ; | 
|---|
|  |  |  | po.controllerId = controller==null?null:controller.getId() ; | 
|---|
|  |  |  | po.intakeId = controller==null?null:controller.getIntakeId() ; | 
|---|
|  |  |  | po.rtuAddr = rtuAddr ; | 
|---|
|  |  |  | po.valueFrom(dV1, dataCd83CloseVo); | 
|---|
|  |  |  | return po ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 更新数据 | 
|---|
|  |  |  | * @param clientVo | 
|---|
|  |  |  | * @param controller | 
|---|
|  |  |  | * @param poLast | 
|---|
|  |  |  | * @param poHistory | 
|---|
|  |  |  | * @param dV1 | 
|---|
|  |  |  | * @param dataCd83CloseVo | 
|---|
|  |  |  | * @param clearLastOpenValue | 
|---|
|  |  |  | * @throws Exception | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void updateCloseValve(SeClient clientVo, | 
|---|
|  |  |  | PrController controller, | 
|---|
|  |  |  | String rtuAddr, | 
|---|
|  |  |  | RmOpenCloseValveLast poLast, | 
|---|
|  |  |  | RmOpenCloseValveHistory poHistory, | 
|---|
|  |  |  | DataV1 dV1, | 
|---|
|  |  |  | DataCd83CloseVo dataCd83CloseVo, | 
|---|
|  |  |  | boolean clearLastOpenValue) throws Exception { | 
|---|
|  |  |  | poLast.clientId = clientVo==null?null:clientVo.getId() ; | 
|---|
|  |  |  | poLast.clientName = clientVo==null?null:clientVo.getName() ; | 
|---|
|  |  |  | poLast.controllerId = controller==null?null:controller.getId(); | 
|---|
|  |  |  | poLast.intakeId = controller==null?null:controller.getIntakeId(); | 
|---|
|  |  |  | poLast.rtuAddr = rtuAddr; | 
|---|
|  |  |  | poLast.updateFrom(dV1, dataCd83CloseVo, clearLastOpenValue); | 
|---|
|  |  |  | if(poHistory != null){ | 
|---|
|  |  |  | poHistory.clientId = clientVo==null?null:clientVo.getId() ; | 
|---|
|  |  |  | poHistory.clientName = clientVo==null?null:clientVo.getName() ; | 
|---|
|  |  |  | poHistory.controllerId = controller==null?null:controller.getId(); | 
|---|
|  |  |  | poHistory.intakeId = controller==null?null:controller.getIntakeId(); | 
|---|
|  |  |  | poHistory.rtuAddr = rtuAddr; | 
|---|
|  |  |  | poHistory.updateFrom(dV1, dataCd83CloseVo, false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|