| package com.dy.rtuMw.server.rtuData.p206V2; | 
|   | 
| import com.dy.common.mw.protocol.Data; | 
| import com.dy.common.mw.protocol.p206V2.DataV2; | 
| import com.dy.common.mw.protocol.p206V2.upVos.DataCd83OpenVo; | 
| 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:16 | 
|  * @LastEditTime 2024/1/16 17:16 | 
|  * @Description | 
|  * 处理控制器开阀上报 | 
|  */ | 
| public class TkDealOpenValveReportV2 extends TaskSurpport { | 
|   | 
|     private static final Logger log = LogManager.getLogger(TkDealOpenValveReportV2.class.getName()) ; | 
|   | 
|     //类ID,一定与Tree.xml配置文件中配置一致 | 
|     public static final String taskId = "TkDealOpenValveReportV2" ; | 
|   | 
|     /** | 
|      * 执行节点任务: 处理控制器开阀上报 | 
|      * @param data 需要处理的数据 | 
|      */ | 
|     @Override | 
|     public void execute(Object data) { | 
|         Data d = (Data) data; | 
|         DataV2 dV2 = (DataV2) d.getSubData(); | 
|         Object cdObj = dV2.subData; | 
|         if (cdObj != null && cdObj instanceof DataCd83OpenVo) { | 
|             Object[] objs = this.getTaskResults(TkPreGenObjsV2.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(), dV2, (DataCd83OpenVo)cdObj) ; | 
|                 this.doDeal(sv, clientVo, controller, d.getRtuAddr(), dV2, (DataCd83OpenVo)cdObj) ; | 
|             }catch (Exception e){ | 
|                 log.error("保存控制器开阀上报时发生异常", e); | 
|             } | 
|         } | 
|     } | 
|   | 
|     /** | 
|      * 把开阀消息存入消息中心 | 
|      * @param clientVo | 
|      * @param controller | 
|      * @param rtuAddr | 
|      * @param dV2 | 
|      * @param dataCd83OpenVo | 
|      */ | 
|     private void toMsCenter(SeClient clientVo, PrController controller, String rtuAddr, DataV2 dV2, DataCd83OpenVo dataCd83OpenVo){ | 
|         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", dataCd83OpenVo.icCardNo); | 
|             msObj.put("rtuAddr", rtuAddr); | 
|             msObj.put("intakeId", controller.getIntakeId()); | 
|             msObj.put("dt", dV2.dt); | 
|             MsCenterUnit.getInstance().pushMs(msObj); | 
|         } | 
|     } | 
|     /** | 
|      * 业务处理 | 
|      * @param sv 服务 | 
|      * @param clientVo 农户对象(不为空时,只有id和name有值) | 
|      * @param controller 控制器对象 | 
|      * @param rtuAddr 控制器地址 | 
|      * @param dV2 上报数据 | 
|      * @param dataCd83OpenVo 开阀上报数据对象 | 
|      */ | 
|     private void doDeal(DbSv sv, SeClient clientVo, PrController controller, String rtuAddr, DataV2 dV2, DataCd83OpenVo dataCd83OpenVo) throws Exception { | 
|         RmOpenCloseValveLast poLast = sv.getRmOpenCloseValveLast(controller.getIntakeId()) ; | 
|         if(poLast == null){ | 
|             //数据库中不存在该控制器的开关阀数据 | 
|             //首先生成开关阀的最新数据及历史数据,并先保存 | 
|             poLast = this.newRmOpenCloseValveLast(clientVo, controller, rtuAddr, dV2, dataCd83OpenVo); | 
|             this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV2, dataCd83OpenVo, poLast); | 
|             sv.saveRmOpenCloseValveLast(poLast); | 
|         }else{ | 
|             //数据库中存在该控制器的开关阀数据 | 
|             if(poLast.openDt != null && poLast.opIcCardAddr != null && poLast.opIcCardNo != null){ | 
|                 if(poLast.openDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83OpenVo.openDt)) | 
|                     && poLast.opIcCardAddr.equals(dataCd83OpenVo.icCardAddr) | 
|                     && poLast.opIcCardNo.equals(dataCd83OpenVo.icCardNo)){ | 
|                     //重复上报,原因是下行数据处理慢了,就重复上报了 | 
|                     return ; | 
|                 } | 
|             } | 
|              if(poLast.opType != null){ | 
|                 //原记录存在开阀数据,首先进行时间对比 | 
|                  if(poLast.openDt != null && poLast.openDt.equals(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83OpenVo.openDt))){ | 
|                      //重复上报的开阀数据,不进行处理 | 
|                  }else if(poLast.openDt != null && poLast.openDt.after(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83OpenVo.openDt))){ | 
|                     //补报的许久之前的开阀数据(对于after:等于或晚于都返回true) | 
|                     this.dealSupplyReport() ; | 
|                 }else { | 
|                     //当前开阀上报是新的一次开阀,不管原记录是否存在关阀数据,一律清空关阀数据 | 
|                     this.updateOpenValve(clientVo, controller, rtuAddr, poLast, null, dV2, dataCd83OpenVo, true) ; | 
|                     //生成并保存新的开阀上报历史数据记录 | 
|                     this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV2, dataCd83OpenVo, poLast); | 
|                 } | 
|             }else if(poLast.clType != null){ | 
|                 //原记录不存在开阀数据,但存在关阀数据,首先进行时间比对 | 
|                  if(poLast.clOpenDt != null && poLast.clOpenDt.before(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83OpenVo.openDt))){ | 
|                      //当前上报是新的开阀数据,把最新(last)数据中的关阀内容清空 | 
|                      this.updateOpenValve(clientVo, controller, rtuAddr, poLast, null, dV2, dataCd83OpenVo, true) ; | 
|                      //生成并保存新的开阀上报历史数据记录 | 
|                      this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV2, dataCd83OpenVo, poLast); | 
|                  }else if(poLast.clOpenDt != null && poLast.clOpenDt.after(DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dataCd83OpenVo.openDt))){ | 
|                     //补报的许久之前的开阀报数据(对于after:等于或晚于都返回true) | 
|                     this.dealSupplyReport() ; | 
|                 }else { | 
|                     //当前上报的开阀数据与原来的关阀数据同一时间,这种情况应该不存在,但也处理 | 
|                     RmOpenCloseValveHistory poHistory = null ; | 
|                     if(poLast.lastHistoryId != null){ | 
|                         poHistory = sv.getRmOpenCloseValveHistory(poLast.lastHistoryId) ; | 
|                     } | 
|                     this.updateOpenValve(clientVo, controller, rtuAddr, poLast, poHistory, dV2, dataCd83OpenVo, false) ; | 
|                     if(poHistory != null){ | 
|                         sv.updateRmOpenCloseValveHistory(poHistory); | 
|                     } | 
|                 } | 
|             }else{ | 
|                 //if(poLast.opType == null && po.clType == null) | 
|                 //原记录不存在开阀数据也不存在关阀数据,这种情况不存在,但为安全也进行处理 | 
|                 this.updateOpenValve(clientVo, controller, rtuAddr, poLast, null, dV2, dataCd83OpenVo, true) ; | 
|                 //生成并保存新的开阀上报历史数据记录 | 
|                 this.newHistoryDataDeal(sv, clientVo, controller, rtuAddr, dV2, dataCd83OpenVo, poLast); | 
|             } | 
|   | 
|             sv.updateRmOpenCloseValveLast(poLast); | 
|         } | 
|     } | 
|   | 
|     /** | 
|      * 处理补报,暂时无逻辑 | 
|      */ | 
|     private void dealSupplyReport(){ | 
|     } | 
|   | 
|     /** | 
|      * 保存新的开阀上报历史数据记录,并把ID赋值给最新记录的 lastHistoryId | 
|      * @param sv | 
|      * @param clientVo | 
|      * @param controller | 
|      * @param rtuAddr | 
|      * @param dV2 | 
|      * @param dataCd83OpenVo | 
|      * @param poLast | 
|      * @throws Exception | 
|      */ | 
|     private void newHistoryDataDeal(DbSv sv, SeClient clientVo, PrController controller, String rtuAddr, DataV2 dV2, DataCd83OpenVo dataCd83OpenVo, RmOpenCloseValveLast poLast)throws Exception { | 
|         RmOpenCloseValveHistory poHistory = this.newRmOpenCloseValveHistory(clientVo, controller, rtuAddr, dV2, dataCd83OpenVo) ; | 
|         sv.saveRmOpenCloseValveHistory(poHistory); | 
|         //由最新数据持有历史数据中的最新记录ID,以方便快速查询 | 
|         poLast.lastHistoryId = poHistory == null ? null: poHistory.id ; | 
|     } | 
|   | 
|     /** | 
|      * 生成新的开阀上报最新数据记录 | 
|      * @param clientVo | 
|      * @param controller | 
|      * @param rtuAddr | 
|      * @param dV2 | 
|      * @param dataCd83OpenVo | 
|      * @return | 
|      * @throws Exception | 
|      */ | 
|     private RmOpenCloseValveLast newRmOpenCloseValveLast(SeClient clientVo, PrController controller, String rtuAddr, DataV2 dV2, DataCd83OpenVo dataCd83OpenVo)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(dV2, dataCd83OpenVo); | 
|         return po ; | 
|     } | 
|   | 
|   | 
|     /** | 
|      * 生成新的开阀上报历史数据记录 | 
|      * @param clientVo | 
|      * @param controller | 
|      * @param rtuAddr | 
|      * @param dV2 | 
|      * @param dataCd83OpenVo | 
|      * @return | 
|      * @throws Exception | 
|      */ | 
|     private RmOpenCloseValveHistory newRmOpenCloseValveHistory(SeClient clientVo, PrController controller, String rtuAddr, DataV2 dV2, DataCd83OpenVo dataCd83OpenVo)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(dV2, dataCd83OpenVo); | 
|         return po ; | 
|     } | 
|   | 
|   | 
|     /** | 
|      * 更新数据 | 
|      * @param clientVo | 
|      * @param controller | 
|      * @param poLast | 
|      * @param poHistory | 
|      * @param dV2 | 
|      * @param dataCd83OpenVo | 
|      * @param clearLastCloseValve | 
|      * @throws Exception | 
|      */ | 
|     private void updateOpenValve(SeClient clientVo, | 
|                                  PrController controller, | 
|                                  String rtuAddr, | 
|                                  RmOpenCloseValveLast poLast, | 
|                                  RmOpenCloseValveHistory poHistory, | 
|                                  DataV2 dV2, | 
|                                  DataCd83OpenVo dataCd83OpenVo, | 
|                                  boolean clearLastCloseValve) 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(dV2, dataCd83OpenVo, clearLastCloseValve); | 
|         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(dV2, dataCd83OpenVo, false); | 
|         } | 
|     } | 
| } |