From 763789a6797ffe6ab09b4e2a35ed4a8d4a3b29c5 Mon Sep 17 00:00:00 2001
From: liuhaonan <konodioda2333@vip.qq.com>
Date: 星期一, 25 四月 2022 14:51:43 +0800
Subject: [PATCH] 验证码实现

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PoleController.java |   75 +++++++++++++++++++++++++++++++++----
 1 files changed, 67 insertions(+), 8 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PoleController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PoleController.java
index 145d97e..2a58f9c 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PoleController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/PoleController.java
@@ -2,25 +2,30 @@
 
 import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.util.ArrayUtil;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.github.pagehelper.PageHelper;
 import com.sandu.common.domain.CommonPage;
 import com.sandu.common.domain.ResponseVO;
 import com.sandu.common.object.BaseConditionVO;
 import com.sandu.common.util.ResponseUtil;
+import com.sandu.common.util.SpringContextHolder;
 import com.sandu.ximon.admin.dto.DeviceStatus;
 import com.sandu.ximon.admin.param.PoleBindParam;
 import com.sandu.ximon.admin.param.PoleBindingParam;
 import com.sandu.ximon.admin.param.PoleParam;
 import com.sandu.ximon.admin.param.PoleStatesParam;
+import com.sandu.ximon.admin.security.PermissionConfig;
 import com.sandu.ximon.admin.service.AirEquipmentService;
-import com.sandu.ximon.admin.service.IPBroadcastService;
+import com.sandu.ximon.admin.service.IpVolumeService;
 import com.sandu.ximon.admin.service.MonitorService;
 import com.sandu.ximon.admin.service.PoleService;
 import com.sandu.ximon.dao.domain.Pole;
+import com.sandu.ximon.dao.enums.MenuEnum;
 import lombok.AllArgsConstructor;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
 
+import java.sql.Wrapper;
 import java.util.List;
 
 /**
@@ -35,8 +40,9 @@
 
     private final PoleService poleService;
     private MonitorService monitorService;
-    private IPBroadcastService broadcastTerminalV2Service;
+    private IpVolumeService broadcastTerminalV2Service;
     private AirEquipmentService airEquipmentService;
+    private final PermissionConfig permissionConfig;
 
     @PostMapping("/add")
     public ResponseVO<Object> addPole(@RequestBody @Validated PoleParam param) {
@@ -55,8 +61,11 @@
 
     @PostMapping("/list")
     public ResponseVO<Object> listPole(BaseConditionVO baseConditionVO, @RequestBody PoleStatesParam param) {
+        if (!permissionConfig.check(MenuEnum.POLE_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
-        List<Pole> results = poleService.queryAllStatesAndList(baseConditionVO.getPageNo(), baseConditionVO.getPageSize(),param);
+        List<Pole> results = poleService.queryAllStatesAndList(baseConditionVO.getPageNo(), baseConditionVO.getPageSize(), param);
         CommonPage commonPage = CommonPage.restPage(results);
         int size = results.size();
         commonPage.setTotal((long) size);
@@ -65,15 +74,23 @@
             commonPage.setTotalPage(size / baseConditionVO.getPageSize());
         }
         return ResponseUtil.success(commonPage);
-       // return ResponseUtil.success(poles);
+        // return ResponseUtil.success(poles);
     }
 
     @GetMapping("/listPoleAndState")
     public ResponseVO<Object> listPoleAndState(BaseConditionVO baseConditionVO, @RequestParam(value = "keyword", required = false) String keyword,
                                                @RequestParam(value = "groupid", required = false) Long groupid) {
         PageHelper.startPage(baseConditionVO.getPageNo(), baseConditionVO.getPageSize());
-        List<Pole> poles = poleService.queryStatesAndList(baseConditionVO.getPageNo(), baseConditionVO.getPageSize(),keyword,groupid);
+        List<Pole> poles = poleService.queryStatesAndList(baseConditionVO.getPageNo(), baseConditionVO.getPageSize(), keyword, groupid);
         return ResponseUtil.successPage(poles);
+    }
+
+    /**
+     * 鍦ㄧ嚎鏁伴噺
+     */
+    @GetMapping("/online")
+    public ResponseVO<Object> online() {
+        return ResponseUtil.success(poleService.poleCount());
     }
 
 
@@ -104,9 +121,15 @@
     public ResponseVO<Object> bindPole(@PathVariable Long poleId, @RequestBody @Validated PoleBindingParam param) {
         boolean result = poleService.bindPole(poleId, param);
         if (result) {
-            //璁惧绫诲瀷锛�0璺伅锛�1led灞忓箷锛�2鍏呯數妗╋紝3澶ф皵鐩戞祴锛�4姘磋川鐩戞祴锛�5ip闊虫煴锛�6lcd骞垮憡鏈猴紝7鎽勫儚澶达紝8鏉嗕綋鍊炬祴锛�9涓�閿晳鍔�
+            //璁惧绫诲瀷锛�0璺伅锛�1nove锛�2鍏呯數妗╋紝3澶ф皵鐩戞祴锛�4姘磋川鐩戞祴锛�5ip闊虫煴锛�6lcd骞垮憡鏈猴紝7鎽勫儚澶达紝8鏉嗕綋鍊炬祴锛�9涓�閿晳鍔�, 10鐔欒
             switch (param.getDeviceType()) {
                 case 0:
+                    Pole pole = poleService.getById(poleId);
+                    if (pole != null) {
+                        pole.setPoleName(param.getDeviceName());
+                        pole.setDeviceCode(param.getDeviceCode());
+                        poleService.updateById(pole);
+                    }
                     break;
                 case 1:
                     break;
@@ -128,6 +151,8 @@
                     break;
                 case 9:
                     break;
+                case 10:
+                    break;
                 default:
                     break;
             }
@@ -142,12 +167,17 @@
      * 鐏潌缁戝畾璁惧
      */
     @PostMapping("/unBind/{poleId}")
-    public ResponseVO<Object> unBindPole(@PathVariable Long poleId, @RequestBody @Validated PoleBindingParam param) {
+    public ResponseVO<Object> unBindPole(@PathVariable Long poleId, @RequestBody PoleBindingParam param) {
         boolean result = poleService.unBindPole(poleId, param.getDeviceCode());
         if (result) {
-            //璁惧绫诲瀷锛�0璺伅锛�1led灞忓箷锛�2鍏呯數妗╋紝3澶ф皵鐩戞祴锛�4姘磋川鐩戞祴锛�5ip闊虫煴锛�6lcd骞垮憡鏈猴紝7鎽勫儚澶达紝8鏉嗕綋鍊炬祴锛�9涓�閿晳鍔�
+            //璁惧绫诲瀷锛�0璺伅锛�1led灞忓箷锛�2鍏呯數妗╋紝3澶ф皵鐩戞祴锛�4姘磋川鐩戞祴锛�5ip闊虫煴锛�6lcd骞垮憡鏈猴紝7鎽勫儚澶达紝8鏉嗕綋鍊炬祴锛�9涓�閿晳鍔�, 10鐔欒
             switch (param.getDeviceType()) {
                 case 0:
+                    //鍒犻櫎鐏潌鐨刣evicescode
+                    Pole pole = poleService.getOne(Wrappers.lambdaQuery(Pole.class).eq(Pole::getId, poleId));
+                    if (pole != null) {
+                        poleService.updateDeviceCode(pole.getId());
+                    }
                     break;
                 case 1:
                     break;
@@ -168,6 +198,8 @@
                 case 8:
                     break;
                 case 9:
+                    break;
+                case 10:
                     break;
                 default:
                     break;
@@ -200,4 +232,31 @@
     }
 
 
+    /**
+     * 鏌ユ壘鑷繁鎷ユ湁鐨勭伅鏉�
+     */
+    @PostMapping("/getOwnerPole/{cilentId}")
+    public ResponseVO<Object> getOwnerPole(BaseConditionVO baseConditionVO, @RequestParam(value = "keyword", required = false) String keyword
+            , @PathVariable Long cilentId) {
+        List<Pole> results = poleService.getOwnerPole(baseConditionVO, keyword, cilentId);
+//        CommonPage commonPage = CommonPage.restPage(results);
+//        int size = results.size();
+//        commonPage.setTotal((long) size);
+//        commonPage.setTotalPage(size / baseConditionVO.getPageSize() + 1);
+//        if (size % baseConditionVO.getPageSize() == 0) {
+//            commonPage.setTotalPage(size / baseConditionVO.getPageSize());
+//        }
+//        return ResponseUtil.success(commonPage);
+        return ResponseUtil.success(results);
+    }
+
+    /**
+     * 鏌ョ湅鐏潌缁戝畾鐨勮澶�
+     */
+    @PostMapping("/getPoleBindDevice/{poleId}")
+    public ResponseVO<Object> getPoleBindDevice(@PathVariable Long poleId) {
+        return ResponseUtil.success(poleService.getBindByPoleId(poleId));
+    }
+
+
 }

--
Gitblit v1.9.3