From 8bf69a5124d12aeca128ef93432e2412b9cc54ac Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期五, 22 十一月 2024 10:46:11 +0800
Subject: [PATCH] MQTT测试Demo

---
 pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java |  101 ++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 85 insertions(+), 16 deletions(-)

diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java b/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java
index 0fdd253..3646149 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-remote/src/main/java/com/dy/pipIrrRemote/rtuUpgrage/RtuUpgradeCtrl.java
@@ -122,6 +122,23 @@
         vo.softBytesCalculate = ppo.programCalculateBytes ;
         vo.softByteSrc16 = ppo.programCrc16 ;
     }
+    /**
+     *  鐩戣锛�
+     * 閲嶇疆锛屾紨绀虹殑閲嶇疆
+     * @return 鎿嶄綔缁撴灉
+     */
+    @GetMapping(path = "/demoReset")
+    @SsoAop()
+    public BaseResponse<Boolean> demoReset(){
+        if(RtuUpgradeStateReceiverCtrl.cache == null){
+            //return BaseResponseUtils.buildError("褰撳墠娌℃湁鍗囩骇浠诲姟") ;
+            //姝e紡杩愯鏃讹紝涓嬮潰涓よ鍘绘帀锛屼笂闈竴琛屾墦寮�
+            RtuUpgradeStateReceiverCtrl ctrl = SpringContextUtil.getBean(RtuUpgradeStateReceiverCtrl.class);
+            ctrl.resetDemo();
+            ctrl.demo();
+        }
+        return BaseResponseUtils.buildSuccess(true) ;
+    }
 
     /**
      *  鐩戣锛�
@@ -134,7 +151,7 @@
                     responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE,
                     description = "杩斿洖鎿嶄綔鎴愬姛涓庡惁鏁版嵁锛圔aseResponse.content:Boolean锛�",
                     content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE,
-                            schema = @Schema(implementation = Boolean.class))}
+                            schema = @Schema(implementation = VoWatch.class))}
             )
     })
     @GetMapping(path = "/curUpgradeState")
@@ -155,25 +172,23 @@
         vo.upgrade = this.sv.selectTaskDetail(RtuUpgradeStateReceiverCtrl.cache.ugTaskId);
         vo.overall = RtuUpgradeStateReceiverCtrl.cache.ugOverallState ;
         vo.rtus = new ArrayList<>() ;
-        if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0){
-            if(qvo.rtuAddr != null && !qvo.rtuAddr.trim().equals("")){
-                qvo.pageCurr = 1 ;
-                final String queryAddr = qvo.rtuAddr ;
-                RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.stream().filter(rtu -> rtu.rtuAddr.equals(queryAddr)).forEach(ugRtu -> {
-                    VoWatch.VoWatchRtu rtu = new VoWatch.VoWatchRtu() ;
-                    rtu.fromCache(ugRtu) ;
-                    vo.rtus.add(rtu) ;
-                }); ;
-            }else{
+        List<UpgradeRtu> listFiltered = null ;
+        if(RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList != null && RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() > 0) {
+            listFiltered = filterByQuery(qvo) ;
+            if (listFiltered.size() > 0) {
                 if(qvo.pageCurr < 1){
                     qvo.pageCurr = 1 ;
                 }
                 int start = (qvo.pageCurr - 1) * qvo.pageSize ;
-                if(start >= RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size()){
-                    start = RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size() - 1 ;
+                if(start >= listFiltered.size()){
+                    if(listFiltered.size()%qvo.pageSize > 0){
+                        start = listFiltered.size() - listFiltered.size()%qvo.pageSize ;
+                    }else{
+                        start = listFiltered.size() - qvo.pageSize ;
+                    }
                 }
-                for(int i = start; i < (start + qvo.pageSize) && i < RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.size(); i++){
-                    UpgradeRtu ugRtu = RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.get(i) ;
+                for(int i = start; i < (start + qvo.pageSize) && i < listFiltered.size(); i++){
+                    UpgradeRtu ugRtu = listFiltered.get(i) ;
                     VoWatch.VoWatchRtu rtu = new VoWatch.VoWatchRtu() ;
                     rtu.fromCache(ugRtu) ;
                     vo.rtus.add(rtu) ;
@@ -183,7 +198,61 @@
         rsVo.obj = vo ;
         rsVo.pageSize = qvo.pageSize ;
         rsVo.pageCurr = qvo.pageCurr ;
-        rsVo.calculateAndSet(0L + vo.rtus.size(), null);
+        rsVo.calculateAndSet(0L + (listFiltered==null?0:listFiltered.size()), null);
         return BaseResponseUtils.buildSuccess(rsVo) ;
     }
+
+    private List<UpgradeRtu> filterByQuery(QueryVo qvo){
+        if (qvo.status != null || qvo.result != null) {
+            final Integer qvoStatus = qvo.status ;
+            final Integer qvoResult = qvo.result ;
+            final String qvoRtuAddr = qvo.rtuAddr ;
+            return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList.stream().filter(rtu -> {
+                boolean ok = false;
+                if (qvoStatus != null) {
+                    if (qvoStatus.intValue() == 1) {
+                        if (rtu.state == UpgradeRtu.STATE_RUNNING) {
+                            ok = true;
+                        }else{
+                            ok = false ;
+                        }
+                    } else if (qvoStatus.intValue() == 0) {
+                        if (rtu.isOver) {
+                            ok = true;
+                        }else{
+                            ok = false ;
+                        }
+                    }
+                }
+                if (qvoResult != null) {
+                    if (qvoResult.intValue() == 1) {
+                        if (rtu.state == UpgradeRtu.STATE_SUCCESS) {
+                            ok = true;
+                        }else{
+                            ok = false ;
+                        }
+                    } else if (qvoResult.intValue() == 0) {
+                        if (rtu.state == UpgradeRtu.STATE_OFFLINE
+                                || rtu.state == UpgradeRtu.STATE_FAILONE
+                                || rtu.state == UpgradeRtu.STATE_FAIL
+                                || rtu.state == UpgradeRtu.STATE_FAILOFFLINE) {
+                            ok = true;
+                        }else{
+                            ok = false ;
+                        }
+                    }
+                }
+                if(qvoRtuAddr != null && !qvoRtuAddr.trim().equals("")){
+                    if(rtu.rtuAddr.equals(qvoRtuAddr)){
+                        ok = true;
+                    }else{
+                        ok = false ;
+                    }
+                }
+                return ok;
+            }).toList() ;
+        }else{
+            return RtuUpgradeStateReceiverCtrl.cache.ugRtuStateList ;
+        }
+    }
 }

--
Gitblit v1.8.0