From e861c8ea2fd047f31d5b4827fb2a598af60e9378 Mon Sep 17 00:00:00 2001
From: liuhaonan <konodioda2333@vip.qq.com>
Date: 星期一, 11 四月 2022 13:49:49 +0800
Subject: [PATCH] ip音柱文件上传

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightService.java |   17 ++++++++++++++++-
 1 files changed, 16 insertions(+), 1 deletions(-)

diff --git a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightService.java b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightService.java
index 65aeaad..d966d0f 100644
--- a/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightService.java
+++ b/ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightService.java
@@ -22,6 +22,8 @@
 import com.sandu.ximon.dao.bo.LightBo;
 import com.sandu.ximon.dao.domain.Light;
 import com.sandu.ximon.dao.domain.LightReportData;
+import com.sandu.ximon.dao.domain.Pole;
+import com.sandu.ximon.dao.domain.PoleBinding;
 import com.sandu.ximon.dao.enums.DeviceRespStatusEnums;
 import com.sandu.ximon.dao.mapper.LightMapper;
 import lombok.AllArgsConstructor;
@@ -46,6 +48,8 @@
 
     private final RedisService redisService;
     private final LightReportDataService lightReportDataService;
+    private final PoleBindingService bindingService;
+    private final PoleService poleService;
 
     /**
      * 褰曞叆褰撳墠璁惧鐮佺殑璺伅鏁版嵁
@@ -94,6 +98,17 @@
         if (CollectionUtil.isNotEmpty(deviceCodeList)) {
             List<LightReportData> reportDataList = lightReportDataService.getNewestReportByDeviceCode(deviceCodeList);
             for (LightBo lightBo : listLight) {
+                deviceCodeList.forEach(code -> {
+                            PoleBinding bind = bindingService.getPoleIdByMac(code);
+                            if (bind != null&&lightBo.getDeviceCode().equals(bind.getDeviceCode())) {
+                                Long poleId = bind.getPoleId();
+                                    Pole pole = poleService.getById(poleId);
+                                    lightBo.setPoleId(pole.getId());
+                                    lightBo.setPoleCode(pole.getDeviceCode());
+                                    lightBo.setPoleName(pole.getPoleName());
+                            }
+                        }
+                );
                 for (LightReportData lightReportData : reportDataList) {
                     if (StrUtil.equals(lightBo.getDeviceCode(), lightReportData.getDeviceCode())) {
                         lightBo.setReportTime(lightReportData.getCreateTime());
@@ -152,7 +167,7 @@
                     light.setLightPercent(param.getBrightness());
                     update(light, Wrappers.lambdaUpdate(Light.class).eq(Light::getDeviceCode, param.getDeviceCode()));
                 }
-            }catch (BusinessException e){
+            } catch (BusinessException e) {
                 map.put("status", DeviceRespStatusEnums.OTHER_ERROR.getCode());
                 resultList.add(map);
             }

--
Gitblit v1.9.3