|  |  |  | 
|---|
|  |  |  | package com.dy.rtuMw.server.rtuData.p206V1_0_0; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1_0_0.upVos.*; | 
|---|
|  |  |  | import com.dy.common.util.DateTime; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmAlarmStateHistory; | 
|---|
|  |  |  | import com.dy.rtuMw.server.rtuData.TaskSurpport; | 
|---|
|  |  |  | import com.dy.rtuMw.server.rtuData.dbSv.DbSv; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.Data; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1_0_0.DataAlarmVo; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1_0_0.DataStateVo; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1_0_0.DataV1_0_1; | 
|---|
|  |  |  | import com.dy.common.util.DateTime; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoPr.PrController; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmAlarmStateHistory; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmAlarmStateLast; | 
|---|
|  |  |  | import org.apache.logging.log4j.LogManager; | 
|---|
|  |  |  | import org.apache.logging.log4j.Logger; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @Author liurunyu | 
|---|
|  |  |  | * @Date 2024/1/15 21:59 | 
|---|
|  |  |  | * @LastEditTime 2024/1/15 21:59 | 
|---|
|  |  |  | * @Date 2024/6/11 17:19 | 
|---|
|  |  |  | * @Description | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | public class TkDealAlarmStatus extends TaskSurpport { | 
|---|
|  |  |  | 
|---|
|  |  |  | Object subD = d.getSubData() ; | 
|---|
|  |  |  | if(subD != null){ | 
|---|
|  |  |  | DataV1_0_1 dV1_0_1 = (DataV1_0_1)subD ; | 
|---|
|  |  |  | if(dV1_0_1 != null){ | 
|---|
|  |  |  | //dV1_0_1.dataCd81Vo 与 dV1_0_1.dataCdC0Vo 不会同时有值 | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | //                    if(dV1_0_1.dataCd81Vo != null){ | 
|---|
|  |  |  | //                        if(dV1_0_1.dataCd81Vo.alarmVo != null || dV1_0_1.dataCd81Vo.stateVo != null){ | 
|---|
|  |  |  | //                            Object[] objs = this.getTaskResults(TkPreGenObjs.taskId) ; | 
|---|
|  |  |  | //                            DbSv sv = (DbSv)objs[0] ; | 
|---|
|  |  |  | //                            PrController controller = (PrController)objs[1] ; | 
|---|
|  |  |  | //                            this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dV1_0_1.dataCd81Vo.rtuDt, dV1_0_1, dV1_0_1.dataCd81Vo.alarmVo, dV1_0_1.dataCd81Vo.stateVo) ; | 
|---|
|  |  |  | //                            this.saveHistory(sv, controller, d.getRtuAddr(), dV1_0_1.dataCd81Vo.rtuDt, dV1_0_1, dV1_0_1.dataCd81Vo.alarmVo, dV1_0_1.dataCd81Vo.stateVo) ; | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                    } else if(dV1_0_1.dataCdC0Vo != null){ | 
|---|
|  |  |  | //                        if(dV1_0_1.dataCdC0Vo.alarmVo != null || dV1_0_1.dataCdC0Vo.stateVo != null){ | 
|---|
|  |  |  | //                            Object[] objs = this.getTaskResults(TkPreGenObjs.taskId) ; | 
|---|
|  |  |  | //                            DbSv sv = (DbSv)objs[0] ; | 
|---|
|  |  |  | //                            PrController controller = (PrController)objs[1] ; | 
|---|
|  |  |  | //                            this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dV1_0_1.dataCdC0Vo.rtuDt, dV1_0_1, dV1_0_1.dataCdC0Vo.alarmVo, dV1_0_1.dataCdC0Vo.stateVo) ; | 
|---|
|  |  |  | //                            this.saveHistory(sv, controller, d.getRtuAddr(), dV1_0_1.dataCdC0Vo.rtuDt, dV1_0_1, dV1_0_1.dataCdC0Vo.alarmVo, dV1_0_1.dataCdC0Vo.stateVo) ; | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | if(dV1_0_1 != null && dV1_0_1.subData != null){ | 
|---|
|  |  |  | //dV1_0_1.dataCd81Vo、 dV1_0_1.dataCd84Vo 与 dV1_0_1.dataCdC0Vo 不会同时有值 | 
|---|
|  |  |  | Object cdObj = dV1_0_1.subData ; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | if (cdObj instanceof DataCd81Vo) { | 
|---|
|  |  |  | DataCd81Vo dataCd81Vo = (DataCd81Vo)cdObj ; | 
|---|
|  |  |  | if (dataCd81Vo.alarmVo != null || dataCd81Vo.stateVo != null) { | 
|---|
|  |  |  | Object[] objs = this.getTaskResults(TkPreGenObjs.taskId); | 
|---|
|  |  |  | DbSv sv = (DbSv) objs[0]; | 
|---|
|  |  |  | PrController controller = (PrController) objs[1]; | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCd81Vo.rtuDt, dV1_0_1, dataCd81Vo.alarmVo, dataCd81Vo.stateVo); | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), dataCd81Vo.rtuDt, dV1_0_1, dataCd81Vo.alarmVo, dataCd81Vo.stateVo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if (cdObj instanceof DataCd84Vo) { | 
|---|
|  |  |  | DataCd84Vo dataCd84Vo = (DataCd84Vo)cdObj ; | 
|---|
|  |  |  | if (dataCd84Vo.alarmVo != null || dataCd84Vo.stateVo != null) { | 
|---|
|  |  |  | Object[] objs = this.getTaskResults(TkPreGenObjs.taskId); | 
|---|
|  |  |  | DbSv sv = (DbSv) objs[0]; | 
|---|
|  |  |  | PrController controller = (PrController) objs[1]; | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCd84Vo.rtuDt, dV1_0_1, dataCd84Vo.alarmVo, dataCd84Vo.stateVo); | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), dataCd84Vo.rtuDt, dV1_0_1, dataCd84Vo.alarmVo, dataCd84Vo.stateVo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else if (cdObj instanceof DataCdC0Vo) { | 
|---|
|  |  |  | DataCdC0Vo dataCdC0Vo = (DataCdC0Vo)cdObj ; | 
|---|
|  |  |  | if (dataCdC0Vo.alarmVo != null || dataCdC0Vo.stateVo != null) { | 
|---|
|  |  |  | Object[] objs = this.getTaskResults(TkPreGenObjs.taskId); | 
|---|
|  |  |  | DbSv sv = (DbSv) objs[0]; | 
|---|
|  |  |  | PrController controller = (PrController) objs[1]; | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCdC0Vo.rtuDt, dV1_0_1, dataCdC0Vo.alarmVo, dataCdC0Vo.stateVo); | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), dataCdC0Vo.rtuDt, dV1_0_1, dataCdC0Vo.alarmVo, dataCdC0Vo.stateVo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | log.error("保存控制器报警和状态数据时发生异常", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param stateVo 状态对象 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void saveOrUpdateLast(DbSv sv, PrController controller, String rtuAddr, String rtuDt, DataV1_0_1 dV1_0_1, DataAlarmVo alarmVo, DataStateVo stateVo) throws Exception { | 
|---|
|  |  |  | //        RmAlarmStateLast po = sv.getRmAlarmStateLast(rtuAddr) ; | 
|---|
|  |  |  | //        if(po == null){ | 
|---|
|  |  |  | //            po = new RmAlarmStateLast(null, controller==null?null:controller.getId(), controller==null?null:controller.getIntakeId(), | 
|---|
|  |  |  | //                    rtuAddr, | 
|---|
|  |  |  | //                    DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1_0_1.dt), | 
|---|
|  |  |  | //                    DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(rtuDt), | 
|---|
|  |  |  | //                    alarmVo==null?null:alarmVo.batteryVolt, alarmVo==null?null:alarmVo.loss, alarmVo==null?null:alarmVo.meter, alarmVo==null?null:alarmVo.valve, | 
|---|
|  |  |  | //                    stateVo==null?null:stateVo.icCard, stateVo==null?null:stateVo.working, stateVo==null?null:stateVo.valve) ; | 
|---|
|  |  |  | //            sv.saveRmAlarmStateLast(po) ; | 
|---|
|  |  |  | //        }else{ | 
|---|
|  |  |  | //            po = this.update(controller, po, rtuDt, dV1_0_1, alarmVo, stateVo) ; | 
|---|
|  |  |  | //            sv.updateRmAlarmStateLast(po); | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | RmAlarmStateLast po = sv.getRmAlarmStateLast(rtuAddr) ; | 
|---|
|  |  |  | if(po == null){ | 
|---|
|  |  |  | po = new RmAlarmStateLast(null, controller==null?null:controller.getId(), controller==null?null:controller.getIntakeId(), | 
|---|
|  |  |  | rtuAddr, | 
|---|
|  |  |  | DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1_0_1.dt), | 
|---|
|  |  |  | DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(rtuDt), | 
|---|
|  |  |  | stateVo==null?null:stateVo.working,//状态-阀门/泵(1打开、0关闭) | 
|---|
|  |  |  | (byte)0,//剩余水量报警   (1:小于报警上限报警 0:正常) | 
|---|
|  |  |  | (byte)0,//剩余水量为0关泵/阀   (1:剩余水量为0关泵  0:正常) | 
|---|
|  |  |  | (byte)0,//年用水量大于限制水量报警(1:报警 0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.meter,// 流量计故障(1:报警,0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.loss,// 漏损(偷水)报警(1:报警, 0:正常) | 
|---|
|  |  |  | (byte)0,//流量计损坏(正常通讯但瞬时为0)报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//电表故障报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//剩余金额为0(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//控制器内门报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//控制器外门打开报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//交流缺项报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//交流过流报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//三相电欠压报警(1:报警,0:正常) | 
|---|
|  |  |  | stateVo==null?null:stateVo.icCard,//IC卡状态(1、有效,0:无效) ; | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.batteryVolt,//电池电压(1:报警,0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.valve//阀门报警(1:报警,0:正常) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | sv.saveRmAlarmStateLast(po) ; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | po = this.update(controller, po, rtuDt, dV1_0_1, alarmVo, stateVo) ; | 
|---|
|  |  |  | this.updateVirCardNoUseState(sv, controller, stateVo) ; | 
|---|
|  |  |  | sv.updateRmAlarmStateLast(po); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | * @param stateVo 状态对象 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void saveHistory(DbSv sv, PrController controller, String rtuAddr, String rtuDt, DataV1_0_1 dV1_0_1, DataAlarmVo alarmVo, DataStateVo stateVo) throws Exception { | 
|---|
|  |  |  | //        RmAlarmStateHistory po = new RmAlarmStateHistory(null, controller==null?null:controller.getId(), controller==null?null:controller.getIntakeId(), | 
|---|
|  |  |  | //                rtuAddr, | 
|---|
|  |  |  | //                DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1_0_1.dt), | 
|---|
|  |  |  | //                DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(rtuDt), | 
|---|
|  |  |  | //                alarmVo==null?null:alarmVo.batteryVolt, alarmVo==null?null:alarmVo.loss, alarmVo==null?null:alarmVo.meter, alarmVo==null?null:alarmVo.valve, | 
|---|
|  |  |  | //                stateVo==null?null:stateVo.icCard, stateVo==null?null:stateVo.working, stateVo==null?null:stateVo.valve) ; | 
|---|
|  |  |  | //        sv.saveRmAlarmStateHistory(po) ; | 
|---|
|  |  |  | RmAlarmStateHistory po = new RmAlarmStateHistory(null, controller==null?null:controller.getId(), controller==null?null:controller.getIntakeId(), | 
|---|
|  |  |  | rtuAddr, | 
|---|
|  |  |  | DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1_0_1.dt), | 
|---|
|  |  |  | DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(rtuDt), | 
|---|
|  |  |  | stateVo==null?null:stateVo.working,//状态-阀门/泵(1打开、0关闭) | 
|---|
|  |  |  | (byte)0,//剩余水量报警   (1:小于报警上限报警 0:正常) | 
|---|
|  |  |  | (byte)0,//剩余水量为0关泵/阀   (1:剩余水量为0关泵  0:正常) | 
|---|
|  |  |  | (byte)0,//年用水量大于限制水量报警(1:报警 0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.meter,// 流量计故障(1:报警,0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.loss,// 漏损(偷水)报警(1:报警, 0:正常) | 
|---|
|  |  |  | (byte)0,//流量计损坏(正常通讯但瞬时为0)报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//电表故障报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//剩余金额为0(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//控制器内门报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//控制器外门打开报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//交流缺项报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//交流过流报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//三相电欠压报警(1:报警,0:正常) | 
|---|
|  |  |  | stateVo==null?null:stateVo.icCard,//IC卡状态(1、有效,0:无效) ; | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.batteryVolt,//电池电压(1:报警,0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.valve//阀门报警(1:报警,0:正常) | 
|---|
|  |  |  | ); | 
|---|
|  |  |  | sv.saveRmAlarmStateHistory(po) ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private RmAlarmStateLast update(PrController controller, RmAlarmStateLast po, String rtuDt, DataV1_0_1 dV1_0_1, DataAlarmVo alarmVo, DataStateVo stateVo) throws Exception { | 
|---|
|  |  |  | //        po.controllerid = controller==null?null:controller.getId() ; | 
|---|
|  |  |  | //        po.intakeid = controller==null?null:controller.getIntakeId() ; | 
|---|
|  |  |  | // | 
|---|
|  |  |  | //        po.dt = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1_0_1.dt) ; | 
|---|
|  |  |  | //        po.rtudt = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(rtuDt) ; | 
|---|
|  |  |  | //        if(alarmVo != null){ | 
|---|
|  |  |  | //            po.bateryvolt = alarmVo.batteryVolt ; | 
|---|
|  |  |  | //            po.loss = alarmVo.loss ; | 
|---|
|  |  |  | //            po.meter = alarmVo.meter ; | 
|---|
|  |  |  | //            po.valve = alarmVo.valve ; | 
|---|
|  |  |  | //        }else{ | 
|---|
|  |  |  | //            po.bateryvolt = null ; | 
|---|
|  |  |  | //            po.loss = null ; | 
|---|
|  |  |  | //            po.meter = null ; | 
|---|
|  |  |  | //            po.valve = null ; | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        if(stateVo != null){ | 
|---|
|  |  |  | //           po.iccard = stateVo.icCard ; | 
|---|
|  |  |  | //           po.working = stateVo.working ; | 
|---|
|  |  |  | //           po.valvestate = stateVo.valve ; | 
|---|
|  |  |  | //        }else{ | 
|---|
|  |  |  | //            po.iccard = null ; | 
|---|
|  |  |  | //            po.working = null ; | 
|---|
|  |  |  | //            po.valvestate = null ; | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | po.controllerId = controller==null?null:controller.getId() ; | 
|---|
|  |  |  | po.intakeId = controller==null?null:controller.getIntakeId() ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | po.dt = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(dV1_0_1.dt) ; | 
|---|
|  |  |  | po.rtuDt = DateTime.dateFrom_yyyy_MM_dd_HH_mm_ss(rtuDt) ; | 
|---|
|  |  |  | if(alarmVo != null){ | 
|---|
|  |  |  | po.alarmBatteryVolt = alarmVo.batteryVolt ; | 
|---|
|  |  |  | po.alarmLoss = alarmVo.loss ; | 
|---|
|  |  |  | po.alarmWaterMeterBreak = alarmVo.meter ; | 
|---|
|  |  |  | po.alarmValve = alarmVo.valve ; | 
|---|
|  |  |  | }/*else{ | 
|---|
|  |  |  | po.alarmBatteryVolt = null ; | 
|---|
|  |  |  | po.alarmLoss = null ; | 
|---|
|  |  |  | po.alarmWaterMeterBreak = null ; | 
|---|
|  |  |  | po.alarmValve = null ; | 
|---|
|  |  |  | }*/ | 
|---|
|  |  |  | if(stateVo != null){ | 
|---|
|  |  |  | po.stateIcEnable = stateVo.icCard ; | 
|---|
|  |  |  | po.valveState = stateVo.working ; | 
|---|
|  |  |  | //po.valvestate = stateVo.valve ; | 
|---|
|  |  |  | }/*else{ | 
|---|
|  |  |  | po.stateIcEnable = null ; | 
|---|
|  |  |  | po.valveState = null ; | 
|---|
|  |  |  | //po.valvestate = null ; | 
|---|
|  |  |  | }*/ | 
|---|
|  |  |  | return po ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 虚拟卡在取水中的占用状态改为非应用状态 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void updateVirCardNoUseState(DbSv sv, | 
|---|
|  |  |  | PrController controller, | 
|---|
|  |  |  | DataStateVo stateVo){ | 
|---|
|  |  |  | if(stateVo != null){ | 
|---|
|  |  |  | if(stateVo.working != null && stateVo.working.byteValue() == 0){ | 
|---|
|  |  |  | //阀门关闭状态 | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | //虚拟卡在取水中的占用状态改为非应用状态 | 
|---|
|  |  |  | sv.updateVirCardNoUseState(controller.getIntakeId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|