From 3075910e10bb60fa2775afb4dbad8d5dba488abb Mon Sep 17 00:00:00 2001
From: zhanzhiqin <895896009@qq.com>
Date: 星期五, 22 七月 2022 09:56:36 +0800
Subject: [PATCH] fix

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java |   72 +++++++++++++++++++-----------------
 1 files changed, 38 insertions(+), 34 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java
index 21791b3..cc85b97 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/VnnoxService.java
@@ -1,13 +1,16 @@
 package com.sandu.ximon.admin.service;
 
 import com.sandu.common.execption.BusinessException;
+import com.sandu.common.util.SpringContextHolder;
 import com.sandu.ximon.admin.config.VnnoxConstant;
 import com.sandu.ximon.admin.dto.nova.AirDataProgram;
 import com.sandu.ximon.admin.dto.nova.PlayerLayout;
 import com.sandu.ximon.admin.dto.nova.PlayerPage;
 import com.sandu.ximon.admin.dto.nova.PlayerWidget;
 import com.sandu.ximon.admin.manager.iot.frame.inner.report.A5AtmosphereHeartbeatReportInnerFrame;
+import com.sandu.ximon.admin.security.SecurityUtils;
 import com.sandu.ximon.admin.utils.RedisUtils;
+import com.sandu.ximon.admin.utils.StoreOperationRecordsUtils;
 import com.sandu.ximon.admin.utils.VnnoxAPIUtil;
 import com.sandu.ximon.admin.utils.VnnoxProgramAPIUtil;
 import com.sandu.ximon.admin.utils.request.VnnoxScreenStatusType;
@@ -17,6 +20,7 @@
 import com.sandu.ximon.dao.domain.LedPlayerEntity;
 import com.sandu.ximon.dao.domain.LedPlayerInfoEntity;
 import com.sandu.ximon.dao.domain.LedV2RegisterResultEntity;
+import com.sandu.ximon.dao.enums.PoleBindingEnums;
 import lombok.AllArgsConstructor;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -34,13 +38,13 @@
 @AllArgsConstructor
 public class VnnoxService {
 
-    // @Autowired
+
     private VnnoxAPIUtil vnnoxAPIUtil;
-    // @Autowired
+
     private RedisUtils redisUtils;
-    // @Autowired
+
     private LedPlayerEntityService ledPlayerEntityService;
-    // @Autowired
+
     private VnnoxProgramAPIUtil vnnoxProgramAPIUtil;
 
     /**
@@ -111,10 +115,7 @@
             type = VnnoxScreenStatusType.OPEN;
         }
 
-        VnnoxResult vnnoxResult = vnnoxAPIUtil.screenStatus(
-                playerList.stream().map(item -> item.getPlayerId()).collect(Collectors.toList()),
-                type
-        );
+        VnnoxResult vnnoxResult = vnnoxAPIUtil.screenStatus(playerList.stream().map(item -> item.getPlayerId()).collect(Collectors.toList()), type);
         //  鏍规嵁灞忓箷鐘舵�佽皟鏁碦EDIS鏍囪瘑浣�
         for (String playerId : vnnoxResult.getSuccess()) {
             redisUtils.set(VnnoxConstant.REDIS_SCREEN_STATUS + playerId, screenStatus, VnnoxConstant.REDIS_MAX_SAVE_TIME);
@@ -123,10 +124,7 @@
     }
 
     public VnnoxResult volChange(List<LedPlayerEntity> playerList, Integer vol) {
-        VnnoxResult vnnoxResult = vnnoxAPIUtil.volChange(
-                playerList.stream().map(item -> item.getPlayerId()).collect(Collectors.toList()),
-                vol
-        );
+        VnnoxResult vnnoxResult = vnnoxAPIUtil.volChange(playerList.stream().map(item -> item.getPlayerId()).collect(Collectors.toList()), vol);
         //  鏍规嵁闊抽噺璋冩暣REDIS鏍囪瘑浣�
         for (String playerId : vnnoxResult.getSuccess()) {
             redisUtils.set(VnnoxConstant.REDIS_VOL + playerId, vol, VnnoxConstant.REDIS_MAX_SAVE_TIME);
@@ -135,10 +133,7 @@
     }
 
     public VnnoxResult brightnessChange(List<LedPlayerEntity> playerList, Integer brightness) {
-        VnnoxResult vnnoxResult = vnnoxAPIUtil.brightnessChange(
-                playerList.stream().map(item -> item.getPlayerId()).collect(Collectors.toList()),
-                brightness
-        );
+        VnnoxResult vnnoxResult = vnnoxAPIUtil.brightnessChange(playerList.stream().map(item -> item.getPlayerId()).collect(Collectors.toList()), brightness);
         //  鏍规嵁浜害璋冩暣REDIS鏍囪瘑浣�
         for (String playerId : vnnoxResult.getSuccess()) {
             redisUtils.set(VnnoxConstant.REDIS_BRIGHTNESS + playerId, brightness, VnnoxConstant.REDIS_MAX_SAVE_TIME);
@@ -229,9 +224,26 @@
         if (byId == null) {
             throw new BusinessException("鏈壘鍒拌璁惧");
         }
+        if (SecurityUtils.getClientId() != null) {
+            boolean belong = SpringContextHolder.getBean(PoleBindingService.class).isBelong(byId.getSn(), PoleBindingEnums.VONNOX);
+            if (!belong) {
+                throw new BusinessException("璇ヨ澶囦笉灞炰簬鎮�,涓嶈兘淇敼璁惧淇℃伅");
+            }
+        }
         LedPlayerEntity led = new LedPlayerEntity();
         led.setId(id);
         led.setName(name);
+        /**
+         * 璇虹摝璁惧缂栬緫 鏃ュ織璁板綍寮�濮�
+         */
+        List<String> listCode = new ArrayList<>(1);
+        listCode.add(byId.getSn());
+        String content = "{ 璁惧id:" + led.getId() + "璁惧code锛�" + byId.getSn() + "璇虹摝playId:" + led.getPlayerId() + "璇虹摝璁惧鍘熷悕:" + byId.getName() + "璇虹摝璁惧鏇存敼鍚庣殑鍚嶇О:" + led.getName() + "}";
+
+        StoreOperationRecordsUtils.storeOperationData(listCode, null, "璇虹摝璁惧缂栬緫", content);
+        /**
+         * 璇虹摝璁惧缂栬緫 鏃ュ織璁板綍缁撴潫
+         */
         return ledPlayerEntityService.updateById(led);
     }
 
@@ -269,7 +281,6 @@
 
             //  璁剧疆缂╃暐鍥捐闂矾寰�
             result = redisUtils.get(VnnoxConstant.REDIS_SCREEN_SHOT + playerId);
-            System.out.println(playerId + "鐨勮矾寰勭粨鏋�:-----------------------------" + result);
             if (null != result) {
                 playerEntity.setScreenShotUrl(result);
             } else {
@@ -295,6 +306,14 @@
         list.add(playerPage);
         playerProgram.setPages(list);
         playerProgram.setNoticeUrl(VnnoxConstant.NOTIFY_URL);
+        /**
+         * 璇虹摝鎺ㄩ�佸ぇ姘旀暟鎹� 鏃ュ織璁板綍寮�濮�
+         ////         */
+//        String content = "{璇虹摝playerId锛�" + playerId + ",鑺傜洰鍐呭锛�" + JSON.toJSONString(playerProgram) + " }";
+//        StoreOperationRecordsUtils.storeOperationData(null, null, "澶ф皵鏁版嵁鎺ㄩ�佸埌璇虹摝", content);
+        /**
+         * 璇虹摝鎺ㄩ�佸ぇ姘旀暟鎹� 鏃ュ織璁板綍缁撴潫
+         */
 
         return vnnoxProgramAPIUtil.normalProgram(playerProgram).getData();
     }
@@ -303,15 +322,8 @@
     private List<PlayerWidget> generateWaterAndSensorWidget(A5AtmosphereHeartbeatReportInnerFrame.HeartBeatDataPackage poleSensorEntity) {
         List widgetList = new ArrayList<>();
         List<String> list = new ArrayList<>();
-//        if (Objects.nonNull(waterDataEntity)) {
-//            list.add("姘磋川鐜鐩戞祴瀹炴椂鏁版嵁锛�");
-//            list.add("ph锛�"+waterDataEntity.getPh());
-//            list.add("婧惰В姘э細"+waterDataEntity.getDoData() + "(mg/L)");
-//            list.add("鐢靛鐜囷細"+waterDataEntity.getEc() + "(10^(-6)S)");
-//            list.add("娴婂害锛�"+waterDataEntity.getNtu() + "NTU");
-//        }
         if (Objects.nonNull(poleSensorEntity)) {
-//            list.add("鐜鐩戞祴锛�");
+            list.add("鐜鐩戞祴锛�");
             list.add("娓╁害锛�" + poleSensorEntity.getTemperature() + "掳");
             list.add("婀垮害锛�" + poleSensorEntity.getHumidity() + "%");
             list.add("pm25锛�" + poleSensorEntity.getPm25() + "渭g/m鲁");
@@ -320,15 +332,7 @@
             list.add("CO2锛�" + poleSensorEntity.getCo2() + "ppm");
         }
 
-        widgetList.add(new PlayerWidget().generateScrollUpTextWidget(
-                "water",
-                1,
-                100000L,
-                list,
-                "#FFFFFF",
-                15,
-                new PlayerLayout("0%", "5%", "100%", "100%")
-        ));
+        widgetList.add(new PlayerWidget().generateScrollUpTextWidget("weather", 1, 100000L, list, "#FFFFFF", 15, new PlayerLayout("0%", "5%", "100%", "100%")));
 
         return widgetList;
     }

--
Gitblit v1.9.3