|  |  |  | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoPr.PrController; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmAlarmStateHistory; | 
|---|
|  |  |  | import com.dy.pipIrrGlobal.pojoRm.RmAlarmStateLast; | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.HashMap; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * @Author liurunyu | 
|---|
|  |  |  | 
|---|
|  |  |  | //类ID,一定与Tree.xml配置文件中配置一致 | 
|---|
|  |  |  | public static final String taskId = "TkDealAlarmStatusV202404" ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //是否在某个时刻(年月日时)保存了报警状态数据 | 
|---|
|  |  |  | private static final Map<String, Long> onceSaveAlarmData4Rtus = new HashMap<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 执行节点任务:报警及状态 | 
|---|
|  |  |  | * @param data 需要处理的数据 | 
|---|
|  |  |  | 
|---|
|  |  |  | DataV202404 dV202404 = (DataV202404)d.getSubData() ; | 
|---|
|  |  |  | Object cdObj = dV202404.subData ; | 
|---|
|  |  |  | //前面任务已经判断cdObj不为null | 
|---|
|  |  |  | boolean toNext = false ; | 
|---|
|  |  |  | try{ | 
|---|
|  |  |  | Object[] objs = this.getTaskResults(TkPreGenObjsV202404.taskId) ; | 
|---|
|  |  |  | DbSv sv = (DbSv)objs[0] ; | 
|---|
|  |  |  | PrController controller = (PrController)objs[1] ; | 
|---|
|  |  |  | if(cdObj instanceof DataCd81Vo){ | 
|---|
|  |  |  | //设备终端随机自报 | 
|---|
|  |  |  | DataCd81Vo cdData = (DataCd81Vo)(cdObj) ; | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | if(this.needSave2Db( d.getRtuAddr())) { | 
|---|
|  |  |  | //在一个小时内没有存储报警数据 | 
|---|
|  |  |  | DataCd81Vo cdData = (DataCd81Vo)(cdObj) ; | 
|---|
|  |  |  | this.toMsCenter(controller, d.getRtuAddr(), dV202404, cdData, dV202404.dt); | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.cacheSaveTime(d.getRtuAddr()); | 
|---|
|  |  |  | if(cdData.statePump != null && cdData.statePump.byteValue() == AlarmVo.DevCloseState){ | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | this.taskResult = new Object[]{controller.getIntakeId(), AlarmVo.DevCloseState} ; | 
|---|
|  |  |  | toNext = true ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else if(cdObj instanceof DataCd80_5BVo){ | 
|---|
|  |  |  | //设备终端工作上报 + 查询设备终端实时值 | 
|---|
|  |  |  | DataCd80_5BVo cdData = (DataCd80_5BVo)(cdObj) ; | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | if(this.needSave2Db( d.getRtuAddr())) { | 
|---|
|  |  |  | //在一个小时内没有存储报警数据 | 
|---|
|  |  |  | DataCd80_5BVo cdData = (DataCd80_5BVo)(cdObj) ; | 
|---|
|  |  |  | this.toMsCenter(controller, d.getRtuAddr(), dV202404, cdData, dV202404.dt); | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.cacheSaveTime(d.getRtuAddr()); | 
|---|
|  |  |  | if(cdData.statePump != null && cdData.statePump.byteValue() == AlarmVo.DevCloseState){ | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | this.taskResult = new Object[]{controller.getIntakeId(), AlarmVo.DevCloseState} ; | 
|---|
|  |  |  | toNext = true ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else if(cdObj instanceof DataCd93_A3Vo){ | 
|---|
|  |  |  | //平台/APP远程关闭水泵/阀门   +  刷卡关泵/阀上报 | 
|---|
|  |  |  | DataCd93_A3Vo cdData = (DataCd93_A3Vo)(cdObj) ; | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.endDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.endDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | if(this.needSave2Db( d.getRtuAddr())) { | 
|---|
|  |  |  | //在一个小时内没有存储报警数据 | 
|---|
|  |  |  | DataCd93_A3Vo cdData = (DataCd93_A3Vo)(cdObj) ; | 
|---|
|  |  |  | this.toMsCenter(controller, d.getRtuAddr(), dV202404, cdData, dV202404.dt); | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.endDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.endDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.cacheSaveTime(d.getRtuAddr()); | 
|---|
|  |  |  | if(cdData.statePump != null && cdData.statePump.byteValue() == AlarmVo.DevCloseState){ | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | this.taskResult = new Object[]{controller.getIntakeId(), AlarmVo.DevCloseState} ; | 
|---|
|  |  |  | toNext = true ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else if(cdObj instanceof DataCd84Vo){ | 
|---|
|  |  |  | //设备终端刷卡开泵/阀上报 | 
|---|
|  |  |  | DataCd84Vo cdData = (DataCd84Vo)(cdObj) ; | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.openDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.openDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | if(this.needSave2Db( d.getRtuAddr())) { | 
|---|
|  |  |  | //在一个小时内没有存储报警数据 | 
|---|
|  |  |  | DataCd84Vo cdData = (DataCd84Vo)(cdObj) ; | 
|---|
|  |  |  | this.toMsCenter(controller, d.getRtuAddr(), dV202404, cdData, dV202404.dt); | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.openDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.openDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.cacheSaveTime(d.getRtuAddr()); | 
|---|
|  |  |  | if(cdData.statePump != null && cdData.statePump.byteValue() == AlarmVo.DevCloseState){ | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | this.taskResult = new Object[]{controller.getIntakeId(), AlarmVo.DevCloseState} ; | 
|---|
|  |  |  | toNext = true ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }else if(cdObj instanceof DataCdC2Vo){ | 
|---|
|  |  |  | //设备终端开关水泵/阀门成功/失败上报 | 
|---|
|  |  |  | DataCdC2Vo cdData = (DataCdC2Vo)(cdObj) ; | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | if(this.needSave2Db( d.getRtuAddr())) { | 
|---|
|  |  |  | //在一个小时内没有存储报警数据 | 
|---|
|  |  |  | DataCdC2Vo cdData = (DataCdC2Vo)(cdObj) ; | 
|---|
|  |  |  | this.toMsCenter(controller, d.getRtuAddr(), dV202404, cdData, dV202404.dt); | 
|---|
|  |  |  | this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.saveHistory(sv, controller, d.getRtuAddr(), cdData.rtuDt, cdData, dV202404.dt) ; | 
|---|
|  |  |  | this.cacheSaveTime(d.getRtuAddr()); | 
|---|
|  |  |  | if(cdData.statePump != null && cdData.statePump.byteValue() == AlarmVo.DevCloseState){ | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | this.taskResult = new Object[]{controller.getIntakeId(), AlarmVo.DevCloseState} ; | 
|---|
|  |  |  | toNext = true ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }catch (Exception e){ | 
|---|
|  |  |  | log.error("保存控制器报警和状态数据时发生异常", e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(toNext){ | 
|---|
|  |  |  | this.toNextTasks(d); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private boolean needSave2Db(String rtuAddr){ | 
|---|
|  |  |  | if(!onceSaveAlarmData4Rtus.containsKey(rtuAddr)){ | 
|---|
|  |  |  | return true ; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | Long time = onceSaveAlarmData4Rtus.get(rtuAddr) ; | 
|---|
|  |  |  | Long ymdh = Long.parseLong(DateTime.yyyyMMddHH()) ; | 
|---|
|  |  |  | if(ymdh.longValue() == time.longValue()){ | 
|---|
|  |  |  | //同一个小时内 | 
|---|
|  |  |  | return false ; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | return true ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | private void cacheSaveTime(String rtuAddr){ | 
|---|
|  |  |  | onceSaveAlarmData4Rtus.put(rtuAddr, Long.parseLong(DateTime.yyyyMMddHH())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 报警状态数据存入消息中心 | 
|---|
|  |  |  | * @param controller 控制器对象 | 
|---|
|  |  |  | * @param rtuAddr 控制器地址 | 
|---|
|  |  |  | * @param dataV202404 数据对象 | 
|---|
|  |  |  | * @param alarmVo 报警+状态对象 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void toMsCenter(PrController controller, String rtuAddr, DataV202404 dataV202404,  AlarmVo alarmVo, String dt){ | 
|---|
|  |  |  | if(alarmVo != null && controller != null){ | 
|---|
|  |  |  | if(alarmVo.hasAlarm()){ | 
|---|
|  |  |  | MsObj msObj = new MsObj() ; | 
|---|
|  |  |  | msObj.put("name", "报警"); | 
|---|
|  |  |  | msObj.put("rtuAddr", rtuAddr); | 
|---|
|  |  |  | msObj.put("intakeId", controller.getIntakeId()); | 
|---|
|  |  |  | msObj.put("state", alarmVo.alarmContent()); | 
|---|
|  |  |  | msObj.put("dt", dt); | 
|---|
|  |  |  | MsCenterUnit.getInstance().pushMs(msObj); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if(alarmVo.statePump != null){ | 
|---|
|  |  |  | MsObj msObj = new MsObj() ; | 
|---|
|  |  |  | msObj.put("name", "阀态"); | 
|---|
|  |  |  | msObj.put("rtuAddr", rtuAddr); | 
|---|
|  |  |  | msObj.put("intakeId", controller.getIntakeId()); | 
|---|
|  |  |  | msObj.put("state", alarmVo.statePump); | 
|---|
|  |  |  | msObj.put("stateName", alarmVo.statePump==1?"开":"关"); | 
|---|
|  |  |  | msObj.put("dt", dt); | 
|---|
|  |  |  | MsCenterUnit.getInstance().pushMs(msObj); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 保存报警状态最新数据 | 
|---|
|  |  |  | * @param sv 服务 | 
|---|
|  |  |  | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmWaterMeterBreak, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmEleMeterFault, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarm0MoneyRemain, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmInnerDoor, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmOuterDoor, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmDoor, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmDoor,//2025-02-19机箱外门报警项改为电池电压了 | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmEleMiss, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmEleExceed, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmEleLowVolt, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.stateIcEnable, | 
|---|
|  |  |  | (byte)0,//电池电压(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//阀门报警(1:报警,0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmBatteryVolt,//电池电压(1:报警,0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmBlockValve,//阀门堵转报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//供电方式(0: 220V,1:蓄电池) | 
|---|
|  |  |  | System.currentTimeMillis() | 
|---|
|  |  |  | ) ; | 
|---|
|  |  |  | sv.saveRmAlarmStateLast(po) ; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | po = this.update(po, controller, rtuDt, alarmVo, receiveDt) ; | 
|---|
|  |  |  | this.updateVirCardNoUseState(sv, controller, alarmVo) ; | 
|---|
|  |  |  | sv.updateRmAlarmStateLast(po); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmWaterMeterBreak, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmEleMeterFault, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarm0MoneyRemain, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmInnerDoor, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmOuterDoor, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmDoor, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmDoor,//2025-02-19机箱外门报警项改为电池电压了 | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmEleMiss, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmEleExceed, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmEleLowVolt, | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.stateIcEnable, | 
|---|
|  |  |  | (byte)0,//电池电压(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0,//阀门报警(1:报警,0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmBatteryVolt,//电池电压(1:报警,0:正常) | 
|---|
|  |  |  | alarmVo==null?null:alarmVo.alarmBlockValve,//阀门堵转报警(1:报警,0:正常) | 
|---|
|  |  |  | (byte)0//供电方式(0: 220V,1:蓄电池) | 
|---|
|  |  |  | ) ; | 
|---|
|  |  |  | sv.saveRmAlarmStateHistory(po) ; | 
|---|
|  |  |  | 
|---|
|  |  |  | po.alarmWaterMeterBreak = alarmVo.alarmWaterMeterBreak ; | 
|---|
|  |  |  | po.alarmEleMeterFault = alarmVo.alarmEleMeterFault ; | 
|---|
|  |  |  | po.alarm0MoneyRemain = alarmVo.alarm0MoneyRemain ; | 
|---|
|  |  |  | po.alarmInnerDoor = alarmVo.alarmInnerDoor ; | 
|---|
|  |  |  | po.alarmOuterDoor = alarmVo.alarmOuterDoor ; | 
|---|
|  |  |  | po.alarmInnerDoor = alarmVo.alarmDoor; | 
|---|
|  |  |  | po.alarmOuterDoor = alarmVo.alarmDoor; | 
|---|
|  |  |  | po.alarmEleMiss = alarmVo.alarmEleMiss ; | 
|---|
|  |  |  | po.alarmEleExceed = alarmVo.alarmEleExceed ; | 
|---|
|  |  |  | po.alarmEleLowVolt = alarmVo.alarmEleLowVolt ; | 
|---|
|  |  |  | po.stateIcEnable = alarmVo.stateIcEnable ; | 
|---|
|  |  |  | po.alarmBatteryVolt = alarmVo.alarmBatteryVolt ; | 
|---|
|  |  |  | po.alarmValve = alarmVo.alarmBlockValve; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return po ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 虚拟卡在取水中的占用状态改为非应用状态 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | private void updateVirCardNoUseState(DbSv sv, | 
|---|
|  |  |  | PrController controller, | 
|---|
|  |  |  | AlarmVo alarmVo){ | 
|---|
|  |  |  | if(alarmVo != null){ | 
|---|
|  |  |  | if(alarmVo.statePump != null && alarmVo.statePump.byteValue() == 0){ | 
|---|
|  |  |  | //阀门关闭状态 | 
|---|
|  |  |  | if(controller != null && controller.getIntakeId() != null){ | 
|---|
|  |  |  | //虚拟卡在取水中的占用状态改为非应用状态 | 
|---|
|  |  |  | sv.updateVirCardNoUseState(controller.getIntakeId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|