|  |  |  | 
|---|
|  |  |  | package com.dy.rtuMw.server.rtuData.p206V1_0_0; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V1_0_0.upVos.*; | 
|---|
|  |  |  | import com.dy.common.springUtil.SpringContextUtil; | 
|---|
|  |  |  | import com.dy.common.util.DateTime; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.config.DingTalk; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmAlarmStateHistory; | 
|---|
|  |  |  | 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 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); | 
|---|
|  |  |  | if(dataCd81Vo.stateVo != null && dataCd81Vo.stateVo.valveState != null && dataCd81Vo.stateVo.valveState.byteValue() == DataStateVo.ValveCloseState){ | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | this.taskResult = new Object[]{controller.getIntakeId(), DataStateVo.ValveCloseState} ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } 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); | 
|---|
|  |  |  | /** 阀开工作报,阀门状态一定是打开状态,所以不设置下面数据以备后续任务设置虚拟卡状态 | 
|---|
|  |  |  | if(dataCd84Vo.stateVo != null && dataCd84Vo.stateVo.valveState != null && dataCd84Vo.stateVo.valveState.byteValue() == DataStateVo.ValveCloseState){ | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | this.taskResult = new Object[]{controller.getIntakeId(), DataStateVo.ValveCloseState} ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }*/ | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } 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); | 
|---|
|  |  |  | if(dataCdC0Vo.stateVo != null && dataCdC0Vo.stateVo.valveState != null && dataCdC0Vo.stateVo.valveState.byteValue() == DataStateVo.ValveCloseState){ | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | this.taskResult = new Object[]{controller.getIntakeId(), DataStateVo.ValveCloseState} ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } 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(controller.getIntakeId()) ; | 
|---|
|  |  |  | if(po == null){ | 
|---|
|  |  |  | po = new RmAlarmStateLast(); | 
|---|
|  |  |  | po.controllerId = controller==null?null:controller.getId() ; | 
|---|
|  |  |  | po.intakeId = controller==null?null:controller.getIntakeId() ; | 
|---|
|  |  |  | po.rtuAddr = rtuAddr ; | 
|---|
|  |  |  | po.valueFrom(dV1_0_1, rtuDt, alarmVo, stateVo); | 
|---|
|  |  |  | if(alarmVo.hasAlarmExcludeLoss()){ | 
|---|
|  |  |  | po.sendMsTime = System.currentTimeMillis() ; | 
|---|
|  |  |  | this.sendMessage(controller, alarmVo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | sv.saveRmAlarmStateLast(po) ; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | if(po.sendMsTime == null){ | 
|---|
|  |  |  | if(alarmVo.hasAlarmExcludeLoss()) { | 
|---|
|  |  |  | po.sendMsTime = System.currentTimeMillis(); | 
|---|
|  |  |  | this.sendMessage(controller, alarmVo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | if(alarmVo.hasAlarmExcludeLoss()){ | 
|---|
|  |  |  | Long now = System.currentTimeMillis() ; | 
|---|
|  |  |  | if(((now - po.sendMsTime) / (1000 * 60)) > ServerProperties.sendDingDingAlarmMsInterval){ | 
|---|
|  |  |  | //大于规定的间隔时间 | 
|---|
|  |  |  | po.sendMsTime = System.currentTimeMillis() ; | 
|---|
|  |  |  | this.sendMessage(controller, alarmVo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | po = this.update(controller, po, rtuDt, dV1_0_1, alarmVo, 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() ; | 
|---|
|  |  |  | po.controllerId = controller==null?null:controller.getId() ; | 
|---|
|  |  |  | po.intakeId = controller==null?null:controller.getIntakeId() ; | 
|---|
|  |  |  | po.rtuAddr = rtuAddr ; | 
|---|
|  |  |  | po.valueFrom(dV1_0_1, rtuDt, alarmVo, stateVo); | 
|---|
|  |  |  | 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.updateFrom(dV1_0_1, rtuDt, alarmVo, stateVo); | 
|---|
|  |  |  | return po ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 向钉钉发送消息 | 
|---|
|  |  |  | * @param controller | 
|---|
|  |  |  | * @param alarmVo | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void sendMessage(PrController controller, DataAlarmVo alarmVo){ | 
|---|
|  |  |  | String ms = "取水口“" + controller.getIntakeName() + "”产生报警:" + alarmVo.alarmContentExcludeLoss() ; | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | SendMsCache.cacheMs(ms); | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | log.error("缓存钉钉消息异常:", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|