From 959dcca95276888cd9c092d93d276ef9aa580aef Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期三, 30 四月 2025 16:26:19 +0800
Subject: [PATCH] 1、增加远程透传命令; 2、表阀一体机协议优化;

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealAlarmStatus.java |  134 ++++++++++++++++++++++++++++++++++----------
 1 files changed, 104 insertions(+), 30 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealAlarmStatus.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealAlarmStatus.java
index 354af9f..0498b50 100644
--- a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealAlarmStatus.java
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/rtuData/p206V1/TkDealAlarmStatus.java
@@ -1,9 +1,12 @@
 package com.dy.rtuMw.server.rtuData.p206V1;
 
 import com.dy.common.mw.protocol.p206V1.upVos.*;
+import com.dy.common.util.DateTime;
 import com.dy.pipIrrGlobal.pojoRm.RmAlarmStateHistory;
 import com.dy.rtuMw.server.ServerProperties;
 import com.dy.rtuMw.server.forMs.SendMsCache;
+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 com.dy.common.mw.protocol.Data;
@@ -12,6 +15,9 @@
 import com.dy.pipIrrGlobal.pojoRm.RmAlarmStateLast;
 import org.apache.logging.log4j.LogManager;
 import org.apache.logging.log4j.Logger;
+
+import java.util.HashMap;
+import java.util.Map;
 
 /**
  * @Author liurunyu
@@ -24,6 +30,10 @@
 
     //绫籌D锛屼竴瀹氫笌Tree.xml閰嶇疆鏂囦欢涓厤缃竴鑷�
     public static final String taskId = "TkDealAlarmStatus" ;
+
+    //鏄惁鍦ㄦ煇涓椂鍒伙紙骞存湀鏃ユ椂锛変繚瀛樹簡鎶ヨ鐘舵�佹暟鎹�
+    private static final Map<String, Long> onceSaveAlarmData4Rtus = new HashMap<>();
+
 
     /**
      * 鎵ц鑺傜偣浠诲姟锛氭姤璀﹀強鐘舵��
@@ -44,15 +54,20 @@
                         //闅忔満鑷姤鎶�
                         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, dataCd81Vo.alarmVo, dataCd81Vo.stateVo);
-                            this.saveHistory(sv, controller, d.getRtuAddr(), dataCd81Vo.rtuDt, dV1, 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} ;
-                                    toNext = true ;
+                            if(this.needSave2Db( d.getRtuAddr())){
+                                //鍦ㄤ竴涓皬鏃跺唴娌℃湁瀛樺偍鎶ヨ鏁版嵁
+                                Object[] objs = this.getTaskResults(TkPreGenObjs.taskId);
+                                DbSv sv = (DbSv) objs[0];
+                                PrController controller = (PrController) objs[1];
+                                this.toMsCenter(controller, d.getRtuAddr(), dV1, dataCd81Vo.alarmVo, dataCd81Vo.stateVo);
+                                this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCd81Vo.rtuDt, dV1, dataCd81Vo.alarmVo, dataCd81Vo.stateVo);
+                                this.saveHistory(sv, controller, d.getRtuAddr(), dataCd81Vo.rtuDt, dV1, dataCd81Vo.alarmVo, dataCd81Vo.stateVo);
+                                this.cacheSaveTime(d.getRtuAddr());
+                                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} ;
+                                        toNext = true ;
+                                    }
                                 }
                             }
                         }
@@ -60,32 +75,42 @@
                         //闃�寮�宸ヤ綔鎶�
                         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, dataCd84Vo.alarmVo, dataCd84Vo.stateVo);
-                            this.saveHistory(sv, controller, d.getRtuAddr(), dataCd84Vo.rtuDt, dV1, 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} ;
-                                    toNext = true ;
-                                }
-                            }*/
+                            if(this.needSave2Db( d.getRtuAddr())) {
+                                //鍦ㄤ竴涓皬鏃跺唴娌℃湁瀛樺偍鎶ヨ鏁版嵁
+                                Object[] objs = this.getTaskResults(TkPreGenObjs.taskId);
+                                DbSv sv = (DbSv) objs[0];
+                                PrController controller = (PrController) objs[1];
+                                this.toMsCenter(controller, d.getRtuAddr(), dV1, dataCd84Vo.alarmVo, dataCd84Vo.stateVo);
+                                this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCd84Vo.rtuDt, dV1, dataCd84Vo.alarmVo, dataCd84Vo.stateVo);
+                                this.saveHistory(sv, controller, d.getRtuAddr(), dataCd84Vo.rtuDt, dV1, dataCd84Vo.alarmVo, dataCd84Vo.stateVo);
+                                this.cacheSaveTime(d.getRtuAddr());
+                                /** 闃�寮�宸ヤ綔鎶ワ紝闃�闂ㄧ姸鎬佷竴瀹氭槸鎵撳紑鐘舵�侊紝鎵�浠ヤ笉璁剧疆涓嬮潰鏁版嵁浠ュ鍚庣画浠诲姟璁剧疆铏氭嫙鍗$姸鎬�
+                                 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} ;
+                                 toNext = true ;
+                                 }
+                                 }*/
+                            }
                         }
                     } 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, dataCdC0Vo.alarmVo, dataCdC0Vo.stateVo);
-                            this.saveHistory(sv, controller, d.getRtuAddr(), dataCdC0Vo.rtuDt, dV1, 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} ;
-                                    toNext = true ;
+                            if(this.needSave2Db( d.getRtuAddr())) {
+                                //鍦ㄤ竴涓皬鏃跺唴娌℃湁瀛樺偍鎶ヨ鏁版嵁
+                                Object[] objs = this.getTaskResults(TkPreGenObjs.taskId);
+                                DbSv sv = (DbSv) objs[0];
+                                PrController controller = (PrController) objs[1];
+                                this.toMsCenter(controller, d.getRtuAddr(), dV1, dataCdC0Vo.alarmVo, dataCdC0Vo.stateVo);
+                                this.saveOrUpdateLast(sv, controller, d.getRtuAddr(), dataCdC0Vo.rtuDt, dV1, dataCdC0Vo.alarmVo, dataCdC0Vo.stateVo);
+                                this.saveHistory(sv, controller, d.getRtuAddr(), dataCdC0Vo.rtuDt, dV1, dataCdC0Vo.alarmVo, dataCdC0Vo.stateVo);
+                                this.cacheSaveTime(d.getRtuAddr());
+                                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} ;
+                                        toNext = true ;
+                                    }
                                 }
                             }
                         }
@@ -99,6 +124,55 @@
             }
         }
     }
+
+    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 dV1 鏁版嵁瀵硅薄
+     * @param alarmVo 鎶ヨ瀵硅薄
+     * @param stateVo 鐘舵�佸璞�
+     */
+    private void toMsCenter(PrController controller, String rtuAddr, DataV1 dV1, DataAlarmVo alarmVo, DataStateVo stateVo){
+        if(alarmVo != null && controller != null && alarmVo.hasAlarm()){
+            MsObj msObj = new MsObj() ;
+            msObj.put("name", "鎶ヨ");
+            msObj.put("rtuAddr", rtuAddr);
+            msObj.put("intakeId", controller.getIntakeId());
+            msObj.put("alarm", alarmVo.alarmContent());
+            msObj.put("dt", dV1.dt);
+            MsCenterUnit.getInstance().pushMs(msObj);
+        }
+        if(stateVo != null && controller != null && stateVo.valveState != null){
+            MsObj msObj = new MsObj() ;
+            msObj.put("name", "闃�鎬�");
+            msObj.put("rtuAddr", rtuAddr);
+            msObj.put("intakeId", controller.getIntakeId());
+            msObj.put("state", stateVo.valveState);
+            msObj.put("stateName", stateVo.valveState==0?"寮�":"鍏�");
+            msObj.put("dt", dV1.dt);
+            MsCenterUnit.getInstance().pushMs(msObj);
+        }
+    }
+
     /**
      * 淇濆瓨鎶ヨ鐘舵�佹渶鏂版暟鎹�
      * @param sv 鏈嶅姟

--
Gitblit v1.8.0