From b9276c27abdac33f7e3fefccb4600a98db465c6e Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期三, 11 五月 2022 16:49:10 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java |   95 +++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 90 insertions(+), 5 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java
index 8352cea..da0bab3 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/controller/LightController.java
@@ -1,20 +1,28 @@
 package com.sandu.ximon.admin.controller;
 
+import com.sandu.common.domain.CommonPage;
 import com.sandu.common.domain.ResponseVO;
 import com.sandu.common.object.BaseConditionVO;
+import com.sandu.common.security.annotation.AnonymousAccess;
 import com.sandu.common.util.ResponseUtil;
+import com.sandu.ximon.admin.param.LightControlParam;
+import com.sandu.ximon.admin.param.LightPowerSettingParam;
 import com.sandu.ximon.admin.param.LightRemarkParam;
+import com.sandu.ximon.admin.security.PermissionConfig;
 import com.sandu.ximon.admin.service.LightReportDataService;
 import com.sandu.ximon.admin.service.LightReportErrorService;
 import com.sandu.ximon.admin.service.LightService;
 import com.sandu.ximon.dao.bo.LightBo;
 import com.sandu.ximon.dao.bo.LightReportDataBo;
 import com.sandu.ximon.dao.bo.LightReportErrorBo;
+import com.sandu.ximon.dao.enums.MenuEnum;
 import lombok.AllArgsConstructor;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
 
+import java.util.ArrayList;
 import java.util.List;
+import java.util.Map;
 
 /**
  * 璺伅鐩稿叧鎺у埗绫�
@@ -29,16 +37,23 @@
     private final LightService lightService;
     private final LightReportDataService lightReportDataService;
     private final LightReportErrorService lightReportErrorService;
+    private PermissionConfig permissionConfig;
 
 
     @GetMapping("/list")
     public ResponseVO<Object> listLight(BaseConditionVO conditionVO, @RequestParam(required = false) String keyword) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         List<LightBo> list = lightService.listLight(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword);
         return ResponseUtil.successPage(list);
     }
 
     @PostMapping("/remark")
     public ResponseVO<Object> addRemark(@RequestBody @Validated LightRemarkParam param) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_REMARK.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
         boolean result = lightService.addRemark(param);
         if (result) {
             return ResponseUtil.success("娣诲姞鎴愬姛");
@@ -54,14 +69,84 @@
      * @return
      */
     @GetMapping("/report/list")
-    public ResponseVO<Object> listReportData(BaseConditionVO conditionVO, @RequestParam(required = false) String keyword, @RequestParam(required = false) String deviceCode) {
-        List<LightReportDataBo> list = lightReportDataService.listReportData(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword, deviceCode);
-        return ResponseUtil.successPage(list);
+    public ResponseVO<Object> listReportData(BaseConditionVO conditionVO
+            , @RequestParam(required = false) String keyword, @RequestParam(required = false) String deviceCode) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_DATA.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        CommonPage commonPage = lightReportDataService.listReportData(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword, deviceCode);
+        List<LightReportDataBo> lightReportDataBos = (List<LightReportDataBo>) commonPage.getList();
+
+        if (lightReportDataBos == null) {
+            return ResponseUtil.success(CommonPage.restPage(new ArrayList<>()));
+        }
+        CommonPage commonPage1 = CommonPage.restPage(lightReportDataBos);
+        commonPage1.setTotal(commonPage.getTotal());
+        commonPage1.setTotalPage(commonPage.getTotalPage());
+
+        return ResponseUtil.success(commonPage1);
+    }
+
+    /**
+     * 瀵煎嚭Excel
+     *
+     * @param conditionVO
+     * @param keyword
+     * @param deviceCode
+     * @return
+     */
+    @GetMapping("/report/exportList")
+    public ResponseVO<Object> exportList(BaseConditionVO conditionVO, @RequestParam(required = false) String keyword, @RequestParam(required = false) String deviceCode) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_EXPORT_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        String url = lightReportDataService.exportList(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword, deviceCode);
+        return ResponseUtil.success(url);
     }
 
     @GetMapping("/error/list")
-    public ResponseVO<Object> listReportError(BaseConditionVO conditionVO, @RequestParam(required = false) String keyword) {
-        List<LightReportErrorBo> list = lightReportErrorService.listReportError(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword);
+    public ResponseVO<Object> listReportError(BaseConditionVO conditionVO, @RequestParam(required = false) String keyword
+            , @RequestParam(required = false) Integer errorCode) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_ERROR_LIST.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        List<LightReportErrorBo> list = lightReportErrorService.listReportError(conditionVO.getPageNo(), conditionVO.getPageSize(), keyword, errorCode);
         return ResponseUtil.success(list);
     }
+
+
+    // 浜害鎺у埗
+    @PostMapping("/control")
+    public ResponseVO<Object> controlBrightness(@RequestBody @Validated List<LightControlParam> paramList) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_CONTROL.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        List<Map<String, Object>> list = lightService.controlBrightness(paramList);
+        return ResponseUtil.success(list);
+    }
+
+    @PostMapping("/Energy")
+    @AnonymousAccess
+    public ResponseVO<Object> Energy() {
+        return ResponseUtil.success(lightService.controlEnergy());
+    }
+
+    @AnonymousAccess
+    @PostMapping("/EnergySaving")
+    public ResponseVO<Object> controlEnergySaving() {
+        return ResponseUtil.success(lightService.controlEnergySaving());
+    }
+
+
+    /**
+     * 璁剧疆鍔熺巼
+     */
+    @PostMapping("/setPower")
+    public ResponseVO<Object> setPower(@RequestBody LightPowerSettingParam lightPowerSettingParam) {
+        if (!permissionConfig.check(MenuEnum.LIGHT_SET_POWER.getCode())) {
+            return ResponseUtil.fail("缂哄皯瀵瑰簲鐢ㄦ埛鏉冮檺");
+        }
+        boolean resule = lightService.setPower(lightPowerSettingParam);
+        return ResponseUtil.success(resule);
+    }
 }

--
Gitblit v1.9.3