From e6f64dc1c6a24c3f6f38fcb312ed45aa9d57b68f Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期五, 01 十一月 2024 11:34:01 +0800
Subject: [PATCH] 2024-11-01 虚拟卡常用充值金额实现自动初始化

---
 pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/local/CommandInnerDeaLer.java |   80 +++++++++++++++++++++++++++++++++++++--
 1 files changed, 75 insertions(+), 5 deletions(-)

diff --git a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/local/CommandInnerDeaLer.java b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/local/CommandInnerDeaLer.java
index 0d783a9..3148b1d 100644
--- a/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/local/CommandInnerDeaLer.java
+++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/local/CommandInnerDeaLer.java
@@ -1,7 +1,11 @@
 package com.dy.rtuMw.server.local;
 
+import com.dy.common.mw.UnitCallbackInterface;
+import com.dy.common.mw.channel.tcp.TcpUnit;
 import com.dy.common.mw.protocol.Command;
 import com.dy.rtuMw.server.local.localProtocol.*;
+
+import java.util.HashMap;
 
 /**
  * @Author liurunyu
@@ -19,10 +23,20 @@
         String code = com.getCode() ;
         if(code.equals(CodeLocal.clock)){
             return this.clock(com) ;
-        }else if(code.equals(CodeLocal.onLine)){
-            return this.onLine(com) ;
+        }else if(code.equals(CodeLocal.onAllLine)){
+            return this.onAllLine(com) ;
+        }else if(code.equals(CodeLocal.onPartLine)){
+            return this.onPartLine(com) ;
+        }else if(code.equals(CodeLocal.onLineStatistics)){
+            return this.onLineStateStatistics(com) ;
         }else if(code.equals(CodeLocal.allProtocols)){
             return this.allProtocols(com) ;
+        }else if(code.equals(CodeLocal.stopTcpSv)){
+            return this.stopTcpSv(com) ;
+        }else if(code.equals(CodeLocal.recoverTcpSv)){
+            return this.recoverTcpSv(com) ;
+        }else if(code.equals(CodeLocal.mwState)){
+            return this.mwInfo(com) ;
         }
         return ReturnCommand.errored("鍑洪敊锛屾敹鍒板唴閮ㄥ懡浠ょ殑鍔熻兘鐮佷笉鑳借瘑鍒紒", com.getId(), com.getCode()) ;
     }
@@ -40,9 +54,32 @@
      * 鏌ヨ鎵�鏈塕TU鍦ㄧ嚎鎯呭喌
      * @throws Exception
      */
-    private Command onLine(Command command) throws Exception{
-        RtuOnLineVo ol = new RtuOnLineDeal().deal() ;
-        return ReturnCommand.successed("鏌ヨ鎵�鏈夋祴绔欏湪绾挎儏鍐电粨鏋�", command.getId(), command.getCode(), ol) ;
+    private Command onAllLine(Command command) throws Exception{
+        HashMap<String, Boolean> map = new RtuOnLineDeal().dealAll() ;
+        return ReturnCommand.successed("鏌ヨ鎵�鏈塕TU鍦ㄧ嚎鎯呭喌缁撴灉", command.getId(), command.getCode(), map) ;
+    }
+
+    /**
+     * 鏌ヨ閮ㄥ垎RTU鍦ㄧ嚎鎯呭喌
+     * @throws Exception
+     */
+    private Command onPartLine(Command command) throws Exception{
+        if(command.param != null && command.param instanceof String && !command.param.equals("")){
+            String[] rtuAddrGrp = ((String)command.param).split(",");
+            HashMap<String, Boolean> map = new RtuOnLineDeal().dealPart(rtuAddrGrp) ;
+            return ReturnCommand.successed("鏌ヨ閮ㄥ垎RTU鍦ㄧ嚎鎯呭喌缁撴灉", command.getId(), command.getCode(), map) ;
+        }else{
+            return ReturnCommand.errored("鍑洪敊锛屽懡浠ゅ弬鏁板簲璇ユ槸鎵�鏌ヨRTU鐨勫湴鍧�涓�",  command.getId(), command.getCode()) ;
+        }
+    }
+
+    /**
+     * 缁熻鍦ㄧ嚎涓庝笉鍦ㄧ嚎鎯呭喌
+     * @throws Exception
+     */
+    private Command onLineStateStatistics(Command command) throws Exception{
+        RtuOnLineStateStatisticsVo vo = new RtuOnLineStateStatisticsDeal().deal() ;
+        return ReturnCommand.successed("鏌ヨ鎵�鏈塕TU鍦ㄧ嚎鎯呭喌缁撴灉", command.getId(), command.getCode(), vo) ;
     }
 
     /**
@@ -54,4 +91,37 @@
         return ReturnCommand.successed("鏌ヨ鎵�鏈夐�氫俊鍗忚閰嶇疆", command.getId(), command.getCode(), mc) ;
     }
 
+    /**
+     * 鍋滄TCP鏈嶅姟锛屼笉鍐嶆帴鍏ユ柊鐨凾CP杩炴帴锛屽凡缁廡CP杩炴帴鐨勫叏閮ㄦ柇杩炴帴
+     * @throws Exception
+     */
+    private Command stopTcpSv(Command command) throws Exception{
+        TcpUnit.getInstance().stop(new UnitCallbackInterface(){
+            public void call(Object obj) throws Exception {
+            }
+        });
+        return ReturnCommand.successed("宸茬粡鍚姩鍋滄TCP鏈嶅姟", command.getId(), command.getCode(), null) ;
+    }
+
+    /**
+     * 鎭㈠TCP鏈嶅姟锛屾帴鍏ユ柊鐨凾CP杩炴帴
+     * @throws Exception
+     */
+    private Command recoverTcpSv(Command command) throws Exception{
+        TcpUnit.getInstance().recover();
+        return ReturnCommand.successed("宸茬粡鍚姩鎭㈠TCP鏈嶅姟", command.getId(), command.getCode(), null) ;
+    }
+
+
+
+    /**
+     * 鏌ヨ閫氫俊涓棿浠惰繍琛屾儏鍐�
+     * @throws Exception
+     */
+    private Command mwInfo(Command command) throws Exception{
+        MwInfoVo mwInfo = new MwInfoDeal().deal() ;
+        return ReturnCommand.successed("鏌ヨ閫氫俊涓棿浠惰繍琛屾儏鍐�", command.getId(), command.getCode(), mwInfo) ;
+    }
+
+
 }

--
Gitblit v1.8.0