From 25e3153ff1256c321d4985070b5f07db930026ec Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期三, 20 四月 2022 11:48:47 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/VnnoxController.java |   95 +++++++++++++++++++++++++++++++----------------
 1 files changed, 63 insertions(+), 32 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/VnnoxController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/VnnoxController.java
index c9e1fc6..2a9e286 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/VnnoxController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/VnnoxController.java
@@ -7,17 +7,25 @@
 import com.sandu.common.object.BaseConditionVO;
 import com.sandu.common.util.ResponseUtil;
 import com.sandu.ximon.admin.param.VnnoxParam;
+import com.sandu.ximon.admin.security.PermissionConfig;
 import com.sandu.ximon.admin.security.SecurityUtils;
 import com.sandu.ximon.admin.service.LedPlayerEntityService;
+import com.sandu.ximon.admin.service.PoleBindingService;
+import com.sandu.ximon.admin.service.PoleService;
 import com.sandu.ximon.admin.service.VnnoxService;
+import com.sandu.ximon.admin.utils.VnnoxAPIUtil;
 import com.sandu.ximon.admin.utils.response.VnnoxResult;
 import com.sandu.ximon.dao.domain.LedPlayerEntity;
 import com.sandu.ximon.dao.domain.LedV2RegisterResultEntity;
+import com.sandu.ximon.dao.domain.PoleBinding;
 import com.sandu.ximon.dao.enums.AdministratorEnums;
+import com.sandu.ximon.dao.enums.MenuEnum;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
 import java.net.URISyntaxException;
+import java.util.ArrayList;
+import java.util.List;
 import java.util.Map;
 
 /**
@@ -30,88 +38,97 @@
 //@AllArgsConstructor
 @RequestMapping("/v1/Vnnox")
 public class VnnoxController {
-
+    @Autowired
+    private PermissionConfig permissionConfig;
     @Autowired
     private VnnoxService vnnoxService;
     @Autowired
     private LedPlayerEntityService ledPlayerEntityService;
+    @Autowired
+    private VnnoxAPIUtil vnnoxAPIUtil;
+    @Autowired
+    private PoleBindingService bindingService;
+    @Autowired
+    private PoleService poleService;
 
     /**
      * 鎴睆
+     *
      * @param vnnoxWebRequest
      * @return
      */
-    @GetMapping("/screenShot")
+    @PostMapping("/screenShot")
     public ResponseVO<Object> screenShot(@RequestBody VnnoxParam vnnoxWebRequest) {
         Map<String, String> map = vnnoxService.getScreenShotUrl(vnnoxWebRequest.getId());
+        if (map.get("code").equals("500")) {
+            return ResponseUtil.fail(map.get("msg"));
+        }
         return ResponseUtil.success(map.get("url"));
     }
 
     /**
      * 閲嶅惎
+     *
      * @param vnnoxWebRequest
      * @return
      */
-    @GetMapping("/reboot")
+    @PostMapping("/reboot")
     public ResponseVO<Object> reboot(@RequestBody VnnoxParam vnnoxWebRequest) {
         VnnoxResult vnnoxResult = vnnoxService.reboot(vnnoxWebRequest.getPlayerList());
         return ResponseUtil.success(vnnoxResult);
     }
 
     /**
-     *
      * @param vnnoxWebRequest
-     * @return
+     * @return 寮�鍏冲睆骞�
      */
-    @GetMapping("/screenStatusChange")
+    @PostMapping("/screenStatusChange")
     public ResponseVO<Object> screenStatusChange(@RequestBody VnnoxParam vnnoxWebRequest) {
-        VnnoxResult vnnoxResult = vnnoxService.screenStatusChange(vnnoxWebRequest.getPlayerList(),vnnoxWebRequest.getScreenStatus());
+        VnnoxResult vnnoxResult = vnnoxService.screenStatusChange(vnnoxWebRequest.getPlayerList(), vnnoxWebRequest.getScreenStatus());
         return ResponseUtil.success(vnnoxResult);
     }
 
     /**
      * 闊抽噺璋冭妭
+     *
      * @param vnnoxWebRequest
      * @return
      */
-    @GetMapping("/volChange")
+    @PostMapping("/volChange")
     public ResponseVO<Object> volChange(@RequestBody VnnoxParam vnnoxWebRequest) {
-        VnnoxResult vnnoxResult = vnnoxService.volChange(vnnoxWebRequest.getPlayerList(),vnnoxWebRequest.getVol());
+        VnnoxResult vnnoxResult = vnnoxService.volChange(vnnoxWebRequest.getPlayerList(), vnnoxWebRequest.getVol());
         return ResponseUtil.success(vnnoxResult);
     }
 
     /**
      * 浜害璋冭妭
+     *
      * @param vnnoxWebRequest
      * @return
      */
-    @GetMapping("/brightnessChange")
+    @PostMapping("/brightnessChange")
     public ResponseVO<Object> brightnessChange(@RequestBody VnnoxParam vnnoxWebRequest) {
-        VnnoxResult vnnoxResult = vnnoxService.brightnessChange(vnnoxWebRequest.getPlayerList(),vnnoxWebRequest.getBrightness());
+        VnnoxResult vnnoxResult = vnnoxService.brightnessChange(vnnoxWebRequest.getPlayerList(), vnnoxWebRequest.getBrightness());
         return ResponseUtil.success(vnnoxResult);
     }
 
-  /*  @RequestMapping("/changeLedName")
-    public R changeLedName(@RequestBody VnnoxParam vnnoxWebRequest) {
-        vnnoxService.changeLedName(vnnoxWebRequest.getId(),vnnoxWebRequest.getPlayerName());
-        return ResponseUtil.success();
-    }*/
 
     @PostMapping("/validateSN")
     public ResponseVO<Object> validateSN(@RequestBody Map map) throws URISyntaxException {
-        String sn = (String)map.get("sn");
-        String name = (String)map.get("name");
-        LedV2RegisterResultEntity ledV2RegisterResultEntity = vnnoxService.validateSN(name,sn);
+        String sn = (String) map.get("sn");
+        String name = (String) map.get("name");
+        LedV2RegisterResultEntity ledV2RegisterResultEntity = vnnoxService.validateSN(name, sn);
         return ResponseUtil.success(ledV2RegisterResultEntity);
     }
 
     @PostMapping("/updateLedName/{id}")
-    public ResponseVO<Object> updateLedName(@PathVariable Long id,@RequestBody Map map) {
-        String name = (String)map.get("name");
+    public ResponseVO<Object> updateLedName(@PathVariable Long id, @RequestBody Map map) {
+        String name = (String) map.get("name");
         boolean b = vnnoxService.updateDataName(id, name);
-        if(b){
+        if (b) {
             return ResponseUtil.success("鏇存敼鎴愬姛");
-        }{
+        }
+        {
             return ResponseUtil.success("鏇存敼澶辫触");
         }
 
@@ -120,15 +137,29 @@
 
     @GetMapping("/list")
     public ResponseVO<Object> list(BaseConditionVO baseConditionVO, @RequestParam(value = "keyword", required = false) String keyword) {
-        PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
-        LambdaQueryWrapper<LedPlayerEntity> wrapper = Wrappers.lambdaQuery(LedPlayerEntity.class);
-
-        if(AdministratorEnums.CUSTOMER.getCode().equals(SecurityUtils.getAdministratorIdentity())) {
-            //wrapper.eq(LedPlayerEntity::get)
-            return ResponseUtil.success(""); //  todo
-        }else {
-            wrapper.like(LedPlayerEntity::getPlayerName,keyword);
-            return ResponseUtil.success(ledPlayerEntityService.list(wrapper));
+        if (!permissionConfig.check(MenuEnum.LED_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
         }
+        return ResponseUtil.successPage(ledPlayerEntityService.ledPlayerEntityList(baseConditionVO, keyword));
+    }
+
+    @GetMapping("/onLineList")
+    public ResponseVO<Object> onLineList(BaseConditionVO baseConditionVO, @RequestParam(value = "keyword", required = false) String keyword) {
+
+            List<LedPlayerEntity> list = ledPlayerEntityService.ledPlayerEntityList(baseConditionVO, keyword);
+            List<LedPlayerEntity> entities = vnnoxService.setCacheInfo(vnnoxAPIUtil.syncCurrentInfo(list));
+            List<LedPlayerEntity> online = new ArrayList<>();
+            for (LedPlayerEntity ledPlayer : entities) {
+                if (ledPlayer.getOnlineStatus() == 1) {
+                    online.add(ledPlayer);
+                }
+            }
+            return ResponseUtil.success(online);
+
+    }
+
+    @GetMapping("/getVnnoxInfo/{sn}")
+    public ResponseVO<Object> getBySnAndPlayerId(@PathVariable String sn) {
+        return ResponseUtil.success(ledPlayerEntityService.getBySnAndPlayerSn(sn));
     }
 }

--
Gitblit v1.9.3