From ea58523b67ad59002a1191c3c564258c5b81f6f2 Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期二, 06 五月 2025 17:35:16 +0800 Subject: [PATCH] Revert "1、实现万用token(0000-0000-1234-9876-5); 2、web端单独实现命令结果等待器,并修改相关部分; 3、web端实现透传命令; 4、修改一些不当注释; 5、优化一些代码。" --- pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/local/CommandInnerDeaLer.java | 172 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 172 insertions(+), 0 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 new file mode 100644 index 0000000..d2f4740 --- /dev/null +++ b/pipIrr-platform/pipIrr-mw/pipIrr-mw-rtu/src/main/java/com/dy/rtuMw/server/local/CommandInnerDeaLer.java @@ -0,0 +1,172 @@ +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.common.mw.protocol.rtuState.RtuStatus; +import com.dy.rtuMw.server.local.localProtocol.*; + +import java.util.HashMap; +import java.util.Map; + +/** + * @Author liurunyu + * @Date 2023/12/21 15:56 + * @LastEditTime 2023/12/21 15:56 + * @Description + */ +public class CommandInnerDeaLer { + /** + * 澶勭悊鍐呴儴鍛戒护 + * @param com + * @return + */ + public Command deal(Command com) throws Exception{ + String code = com.getCode() ; + if(code.equals(CodeLocal.clock)){ + return this.clock(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.allRtuStates)){ + return this.allRtuStates(com) ; + }else if(code.equals(CodeLocal.partRtuStates)){ + return this.someRtuStates(com) ; + }else if(code.equals(CodeLocal.oneRtuStates)){ + return this.oneRtuStates(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()) ; + } + + /** + * 鏌ヨ閫氫俊涓棿浠舵椂閽� + * @throws Exception + */ + private Command clock(Command command) throws Exception{ + ClockVo c = new ClockDeal().deal() ; + return ReturnCommand.successed("鏌ヨ閫氫俊涓棿浠舵椂閽�", command.getId(), command.getCode(), c) ; + } + + /** + * 鏌ヨ鎵�鏈塕TU鍦ㄧ嚎鎯呭喌 + * @throws Exception + */ + 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) ; + } + + /** + * 鏌ヨ鎵�鏈塕TU鐘舵�� + * @throws Exception + */ + private Command allRtuStates(Command command) throws Exception{ + Map<String, RtuStatus> map = new RtuStatusDeal().dealAll() ; + return ReturnCommand.successed("鏌ヨ鎵�鏈塕TU鐘舵�佺粨鏋�", command.getId(), command.getCode(), map) ; + } + + /** + * 鏌ヨ閮ㄥ垎RTU鐘舵�� + * @throws Exception + */ + private Command someRtuStates(Command command) throws Exception{ + if(command.param != null && command.param instanceof String && !command.param.equals("")){ + String[] rtuAddrGrp = ((String)command.param).split(","); + Map<String, RtuStatus> map = new RtuStatusDeal().dealSome(rtuAddrGrp) ; + return ReturnCommand.successed("鏌ヨ閮ㄥ垎RTU鐘舵�佺粨鏋�", command.getId(), command.getCode(), map) ; + }else{ + return ReturnCommand.errored("鍑洪敊锛屽懡浠ゅ弬鏁板簲璇ユ槸鎵�鏌ヨRTU鐨勫湴鍧�涓�", command.getId(), command.getCode()) ; + } + } + + /** + * 鏌ヨ閮ㄥ垎RTU鐘舵�� + * @throws Exception + */ + private Command oneRtuStates(Command command) throws Exception{ + if(command.param != null && command.param instanceof String && !command.param.equals("")){ + String rtuAddr = (String)command.param; + RtuStatus rtuStatus = new RtuStatusDeal().dealOne(rtuAddr) ; + return ReturnCommand.successed("鏌ヨ涓�涓猂TU鐘舵�佺粨鏋�", command.getId(), command.getCode(), rtuStatus) ; + }else{ + return ReturnCommand.errored("鍑洪敊锛屽懡浠ゅ弬鏁板簲璇ユ槸鎵�鏌ヨRTU鐨勫湴鍧�", command.getId(), command.getCode()) ; + } + } + + /** + * 鏌ヨ鎵�鏈塕TU鍗忚閰嶇疆 + * @throws Exception + */ + private Command allProtocols(Command command) throws Exception{ + RtuProtocolVo mc = new RtuProtocolsDeal().deal() ; + 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