From ec63fb17c5ba3e5b2a5a4106c25b4e249a2f980f Mon Sep 17 00:00:00 2001
From: liuhaonan <31457034@qq.com>
Date: 星期二, 22 十一月 2022 18:44:51 +0800
Subject: [PATCH] changes

---
 ximon-admin/src/main/java/com/sandu/ximon/admin/service/LightService.java |  208 ++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 192 insertions(+), 16 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 04b7579..714e1f3 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
@@ -3,6 +3,8 @@
 import cn.hutool.core.collection.CollectionUtil;
 import cn.hutool.core.util.HexUtil;
 import cn.hutool.core.util.StrUtil;
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
 import com.aliyuncs.iot.model.v20180120.BatchGetDeviceStateResponse;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.github.pagehelper.PageHelper;
@@ -14,8 +16,11 @@
 import com.sandu.ximon.admin.dto.LightTaskDto;
 import com.sandu.ximon.admin.manager.iot.frame.A5Frame;
 import com.sandu.ximon.admin.manager.iot.frame.inner.report.A5LightHeartbeatReportInnerFrame;
+import com.sandu.ximon.admin.manager.iot.frame.inner.report.A5LightOperationReportInnerFrame;
 import com.sandu.ximon.admin.manager.iot.frame.inner.request.A5LightBrightnessReqInnerFrame;
+import com.sandu.ximon.admin.manager.iot.frame.inner.request.A5LightSetCalendarReqInnerFrame;
 import com.sandu.ximon.admin.manager.iot.frame.inner.response.A5LightBrightnessRespInnerFrame;
+import com.sandu.ximon.admin.manager.iot.rrpc.dto.CommonFrame;
 import com.sandu.ximon.admin.manager.iot.rrpc.dto.WrapResponseCommonFrame;
 import com.sandu.ximon.admin.manager.iot.rrpc.enums.A5OrderEnum;
 import com.sandu.ximon.admin.manager.iot.rrpc.mainboard.MainBoardInvokeSyncService;
@@ -43,11 +48,10 @@
 
 import java.math.BigDecimal;
 import java.time.LocalDateTime;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.stream.Collectors;
+
+import static com.sandu.ximon.admin.localMQTT.callback.StatusMqttCallBack.localMqttConnectStatusMap;
 
 /**
  * @author chenjiantian
@@ -142,7 +146,8 @@
 
         // 鑾峰彇鏈�杩戠殑涓婃姤鏃堕棿
         List<String> deviceCodeList = listLight.stream().map(Light::getDeviceCode).collect(Collectors.toList());
-        //鎷嗗垎list
+
+//        //鎷嗗垎list
         List<List<String>> split = CollectionUtil.split(deviceCodeList, 100);
 
         List<BatchGetDeviceStateResponse.DeviceStatus> deviceStatuses = null;
@@ -200,13 +205,17 @@
      */
     public Light getLight(String deviceCode) {
         Light one = getOne(Wrappers.<Light>lambdaQuery().eq(Light::getDeviceCode, deviceCode));
-        Object o = redisService.get(LightKey.REPORT_MAC.key(deviceCode));
-        if (o != null) {
-            one.setOnlineStatus(1);
+        if (one == null) {
+            return null;
         } else {
-            one.setOnlineStatus(0);
+            Object o = redisService.get(LightKey.REPORT_MAC.key(deviceCode));
+            if (o != null) {
+                one.setOnlineStatus(1);
+            } else {
+                one.setOnlineStatus(0);
+            }
+            return one;
         }
-        return one;
     }
 
     /**
@@ -259,13 +268,17 @@
 
         List<Map<String, Object>> resultList = new ArrayList<>();
         for (LightControlParam param : paramList) {
-            A5LightBrightnessReqInnerFrame lightControlFrame = new A5LightBrightnessReqInnerFrame(param.getBrightness(), param.getLightAddress());
-            A5Frame a5Frame = new A5Frame(A5OrderEnum.REQUEST_LIGHT_DATA.getCode(), lightControlFrame);
+            A5LightBrightnessReqInnerFrame
+                    lightControlFrame = new A5LightBrightnessReqInnerFrame(param.getBrightness(), param.getLightAddress());
+            A5Frame a5Frame = new A5Frame(
+                    A5OrderEnum.REQUEST_LIGHT_DATA.getCode(),
+                    lightControlFrame);
             Map<String, Object> map = new HashMap<>();
             try {
                 map.put("deviceCode", param.getDeviceCode());
                 WrapResponseCommonFrame<A5LightBrightnessRespInnerFrame> frame
-                        = MainBoardInvokeSyncService.getInstance().sendRRPC(param.getDeviceCode(), a5Frame, A5LightBrightnessRespInnerFrame.class);
+                        = MainBoardInvokeSyncService.getInstance().sendRRPC
+                        (param.getDeviceCode(), a5Frame, A5LightBrightnessRespInnerFrame.class);
                 //瀛樺偍鎺у埗甯ф寚浠�
                 StoreOperationRecordsUtils.storeInnerFrameData(param.getDeviceCode(), "鍗曠伅甯�-浜害鎺у埗", a5Frame, frame);
 
@@ -931,10 +944,15 @@
     public void setCacheData() {
 
         List<String> collect = list().stream().map(Light::getDeviceCode).collect(Collectors.toList());
+//        collect.forEach(
+//                code -> {
+//                    redisUtils.delete(DeviceRedisKey.LIGHT_DEVICE + code);
+//                }
+//        );
         List<List<String>> split = CollectionUtil.split(collect, 100);
 
-        List<BatchGetDeviceStateResponse.DeviceStatus> deviceStatuses = null;
-        List<RedisDeviceStatus> statusList = null;
+        List<BatchGetDeviceStateResponse.DeviceStatus> deviceStatuses = new ArrayList<>();
+        List<RedisDeviceStatus> statusList = new ArrayList<>();
         for (List<String> splist : split) {
             deviceStatuses = MainBoardInvokeSyncService.getInstance().batchGetDeviceState(splist);
             if (deviceStatuses != null) {
@@ -945,6 +963,10 @@
                         device.setStatus(0);
                     } else if ("OFFLINE".equals(deviceStatus.getStatus())) {
                         device.setStatus(1);
+                    } else if ("UNACTIVE".equals(deviceStatus.getStatus())) {
+                        device.setStatus(0);
+                    } else if ("DISABLE".equals(deviceStatus.getStatus())) {
+                        device.setStatus(0);
                     } else {
                         device.setStatus(2);
                     }
@@ -955,10 +977,164 @@
         }
 
         statusList.forEach(status -> {
-            redisUtils.set(DeviceRedisKey.LIGHT_DEVICE + status.getDeviceId(), status);
+            redisUtils.set(DeviceRedisKey.LIGHT_DEVICE + status.getDeviceId(), JSON.toJSONString(status));
         });
 
     }
 
 
+    /**
+     * 璁剧疆鏃ュ巻锛堝悓蹇冭烦鍖呬腑鐨�6瀛楄妭鏃ユ湡鏃堕棿锛�
+     *
+     * @return
+     */
+    public String SetCalendar(Long lightId, String address) {
+        Calendar cal = Calendar.getInstance();
+        //鑾峰彇褰撳墠鏃堕棿
+        int year = cal.get(Calendar.YEAR);
+        int month = cal.get(Calendar.MONTH);
+        int day = cal.get(Calendar.DATE);
+        int hour = cal.get(Calendar.HOUR_OF_DAY);
+        int min = cal.get(Calendar.MINUTE);
+        int sec = cal.get(Calendar.SECOND);
+
+        if (!"0001".equals(address) && !"0002".equals(address)) {
+            throw new BusinessException("鐏ご鍦板潃閿欒锛�");
+        }
+
+        Light one = getById(lightId);
+        if (one == null) {
+            System.out.println("鍗曠伅涓嶅瓨鍦紒");
+        }
+
+        A5LightSetCalendarReqInnerFrame setCalendarReqInnerFrame =
+                new A5LightSetCalendarReqInnerFrame(address, year % 100, month + 1, day, hour, min, sec);
+
+        A5Frame a5Frame = new A5Frame(A5OrderEnum.REQUEST_LIGHT_DATA.getCode(), setCalendarReqInnerFrame);
+        System.out.println(a5Frame + "            -----a5Frame");
+
+        CommonFrame commonFrame = MainBoardInvokeSyncService.getInstance().sendRRPC(one.getDeviceCode(), a5Frame);
+        StoreOperationRecordsUtils.storeInnerFrameData(one.getDeviceCode(), "鍗曠伅甯�-璁剧疆鏃ュ巻", a5Frame, commonFrame);
+
+        System.out.println(commonFrame + "            -----commonFrame");
+
+        A5LightOperationReportInnerFrame operationReportInnerFrame = new A5LightOperationReportInnerFrame().transformFrame(commonFrame.getPayload());
+        if (operationReportInnerFrame.isValidate()) {
+            return operationReportInnerFrame.getState();
+        } else {
+            throw new BusinessException("鏁版嵁鏍¢獙閿欒锛岃閲嶆柊璇锋眰");
+        }
+    }
+
+    /**
+     * 鍗曠伅涓诲姩鍚屾鏃堕棿璇锋眰
+     */
+    public void timeSynchronizationInitiative(String deviceCode, String lightAddress) {
+        //鍗曠伅淇℃伅
+        Light light = getLight(deviceCode);
+//        if (light == null) {
+//            log.error("鍗曠伅涓诲姩鍚屾鏃堕棿璇锋眰寮傚父锛屽崟鐏俊鎭笉瀛樺湪锛�");
+//            return;
+//        }
+        //鍗曠伅浠诲姟淇℃伅
+        LightTaskPoleRelation lightTaskPoleRelation = SpringContextHolder.getBean(LightTaskPoleRelationService.class)
+                .getOne(Wrappers.lambdaQuery(LightTaskPoleRelation.class)
+                        .eq(LightTaskPoleRelation::getDeviceCode, deviceCode).eq(LightTaskPoleRelation::getLightAddress, lightAddress));
+
+        LightTask lightTask = null;
+        //鐏ご娌℃湁浠诲姟
+        if (lightTaskPoleRelation != null) {
+            if (lightTaskPoleRelation.getDeviceScheduled() != null) {
+                lightTask = JSONObject.parseObject(lightTaskPoleRelation.getDeviceScheduled(), LightTask.class);
+            }
+        }
+
+        timeSynchronization(light, lightAddress, lightTask);
+
+    }
+
+    /**
+     * 鍗曠伅鏃堕棿鍚屾
+     *
+     * @param light     鍗曠伅淇℃伅瀹炰綋
+     * @param lightTask 鍗曠伅浠诲姟瀹炰綋锛堜负绌烘爣璇嗗崟鐏病鏈夊畾鏃朵换鍔★級
+     */
+    public void timeSynchronization(Light light, String lightAddress, LightTask lightTask) {
+        new Thread(new Runnable() {
+            @Override
+            public void run() {
+                //鑾峰彇褰撳墠鏃堕棿鏃躲�佸垎
+                Calendar cal = Calendar.getInstance();
+
+                if (lightTask != null) {
+                    String closeOrder = lightTask.getCloseOrder();
+                    String openOrder = lightTask.getOpenOrder();
+                    String controlOrder = lightTask.getControlOrder() == null ? null : lightTask.getControlOrder();
+
+                    List<String> timeList = new ArrayList<>();
+                    timeList.add(openOrder.substring(0, 4));
+                    timeList.add(closeOrder.substring(0, 4));
+                    if (controlOrder != null && controlOrder.length() % 7 == 0) {
+                        for (int i = 0; i < controlOrder.length() / 7; i++) {
+                            timeList.add(controlOrder.substring(i * 7, i * 7 + 4));
+                        }
+                    } else {
+                        log.error("鎺х伅鎸囦护涓嶆纭紝鏁版嵁闀垮害涓嶄负7鐨勫�嶆暟锛�");
+                        return;
+                    }
+                    //鏃堕棿鎺掑簭
+                    timeList = timeList.stream().sorted().collect(Collectors.toList());
+
+                    int count = 0;
+                    boolean haveTime = false;
+
+                    while (!haveTime && count <= 144) {
+                        haveTime = judgeTime(cal, timeList);
+                        cal.add(Calendar.MINUTE, 10);
+                        count++;
+                    }
+                    if (haveTime) {
+                        log.error("瀛樺湪瀹氭椂浠诲姟锛�" + light.getLightId()+","+light.getDeviceCode());
+//                        try {
+//                            long longTime = cal.getTimeInMillis() - System.currentTimeMillis();
+//                            log.error("鐫$湢鏃堕棿锛堟绉掞級锛�" + longTime);
+//                            Thread.sleep(longTime);
+//                            SetCalendar(light.getLightId(), lightAddress);
+//                        } catch (InterruptedException e) {
+//                            e.printStackTrace();
+//                        }
+                    } else {
+                        log.error("鐏潌ID涓猴細" + light.getLightId() + "锛岀伅澶村湴鍧�涓猴細" + lightAddress + "娌℃湁鎵惧埌鍙悓姝ョ殑鏃堕棿锛岃妫�鏌ヤ换鍔★紒");
+                    }
+
+                } else {
+                    SetCalendar(light.getLightId(), lightAddress);
+                }
+            }
+        }).start();
+    }
+
+    /**
+     * 鍒ゆ柇鏃堕棿鏄惁鍙互鎵ц鍚屾鎸囦护
+     *
+     * @param time
+     * @param timeList
+     * @return true 鍙互鎵ц  ,false  涓嶅彲鎵ц
+     */
+    private boolean judgeTime(Calendar time, List<String> timeList) {
+        int hour = time.get(Calendar.HOUR_OF_DAY);
+        int min = time.get(Calendar.MINUTE);
+        int allMin = hour * 60 + min;
+        for (String value : timeList) {
+            int targetHour = Integer.valueOf(value.substring(0, 2));
+            int targetMin = Integer.valueOf(value.substring(2, 4));
+            int allTargetMin = targetHour * 60 + targetMin;
+            if (allMin >= allTargetMin - 10 && allMin <= allTargetMin + 10) {
+                return false;
+            } else {
+                continue;
+            }
+        }
+        return true;
+    }
 }

--
Gitblit v1.9.3