From 9c8baf7e7e1169ebdf7d5f7ed33ab29dd5fcbf18 Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期一, 14 十二月 2020 17:45:17 +0800
Subject: [PATCH] 2020-12-14 1.解锁设置问题修复,增加面容ID验证。2.错误码对接增加。

---
 HDL_ON/Entity/Function/Scene.cs |  113 +++++++++++++++++++++++++++++---------------------------
 1 files changed, 59 insertions(+), 54 deletions(-)

diff --git a/HDL_ON/Entity/Function/Scene.cs b/HDL_ON/Entity/Function/Scene.cs
index c8d208e..67d0c57 100644
--- a/HDL_ON/Entity/Function/Scene.cs
+++ b/HDL_ON/Entity/Function/Scene.cs
@@ -24,6 +24,14 @@
 
     public class Scene 
     {
+        public Scene()
+        {
+            sid = NewSid();
+            if (!DB_ResidenceData.Instance.CheckWhetherGatewayIdIsNull())
+            {
+                gatewayId = DB_ResidenceData.Instance.HomeGateway.gatewayId;
+            }
+        }
         /// <summary>
         /// 浜戠鍞竴ID
         /// </summary>
@@ -48,6 +56,10 @@
         /// 鎵�灞炴埧闂村垪琛�
         /// </summary>
         public List<string> roomIds = new List<string>();
+        /// <summary>
+        /// 鎵�灞炴埧闂村垪琛�
+        /// </summary>
+        public List<string> uids = new List<string>();
         /// <summary>
         /// 寤舵椂
         /// </summary>
@@ -134,21 +146,18 @@
         public List<ScenePushConfig> pushConfigs = new List<ScenePushConfig>();
 
         /// <summary>
-        /// 鐢熸垚鍦烘櫙sid
+        /// 鐢熸垚閫昏緫sid鏂规硶
         /// </summary>
-        public void NewSid()
+        public string NewSid()
         {
-            string sSceneid = "";
+            string sceneId = "";
             try
             {
                 string sOidBeginsWith = "000101";//鍘傚晢 + 閫氳鏂瑰紡
                 DateTime dt = DateTime.Now;
-
-
                 DateTime startTime = TimeZoneInfo.ConvertTimeToUtc(new DateTime(2020, 1, 1));
                 long m = (long)((dt - startTime).TotalMilliseconds / 10);
                 string sTimeSpan = "00000000";
-
 
                 byte[] arry = new byte[4];
                 arry[0] = (byte)(m & 0xFF);
@@ -167,25 +176,29 @@
                     sTimeSpan = "00000000";
                 }
 
-                sSceneid = sOidBeginsWith + sTimeSpan;
+                sceneId = sOidBeginsWith + sTimeSpan;
 
-                sSceneid += "0A";
-                sSceneid += "0A01";
-                //0A01 鐗╂ā鍨嬩负鍦烘櫙锛� 0001 琛ㄧず 1 鍙峰満鏅姛鑳�
-                int iTopSceneId = 1;
+                sceneId += "0A";
+                sceneId += "0A01";
+                int maxId = 1;
 
-                Random random = new Random();
-                iTopSceneId = random.Next(0, 255);
-                iTopSceneId += random.Next(0, 255);
 
-                sSceneid += iTopSceneId.ToString("X4");//鍦烘櫙鍙� 涓や釜byte 
-                sSceneid += "1100";
-                sid = sSceneid;
+                for (int i = 0; i < FunctionList.List.scenes.Count; i++)
+                {
+                    string s = FunctionList.List.scenes[i].sid.Substring(20, 4);
+                    int iThisSceneId = Convert.ToInt16(s, 16);
+                    if (iThisSceneId > maxId)
+                        maxId = iThisSceneId;
+                }
+
+                sceneId += (maxId + 1).ToString("X4");
+                sceneId += "0000";
             }
             catch
             {
-                sid = sSceneid;
+                return sceneId;
             }
+            return sceneId;
         }
 
         /// <summary>
@@ -197,7 +210,7 @@
             string roomNameList = "";
             foreach (var roomId in roomIds)
             {
-                var findRoom = DB_ResidenceData.residenceData.Rooms.Find(obj => obj.uid == roomId);
+                var findRoom = SpatialInfo.CurrentSpatial.RoomList.Find(obj => obj.roomId == roomId);
                 if (findRoom == null)
                 {
                     continue;
@@ -230,12 +243,18 @@
         /// <summary>
         /// 淇濆瓨鍔熻兘鏁版嵁
         /// </summary>
-        public void SaveSceneData()
+        public void SaveSceneData(bool upServer)
         {
-            var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
-            FileUtils.WriteFileByBytes(savePath, ssd);
-            MainPage.Log($"Save Scene Data : {savePath}");
-            UploadScene();
+            if (upServer)
+            {
+                UploadScene();
+            }
+            else
+            {
+                var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
+                Common.FileUtlis.Files.WriteFileByBytes(savePath, ssd);
+                MainPage.Log($"Save Scene Data : {savePath}");
+            }
         }
 
         /// <summary>
@@ -245,44 +264,30 @@
         {
             var pm = new HttpServerRequest();
             ResponsePackNew revPack;
-            if (DeleteSign)
+            if (string.IsNullOrEmpty(createTime) && string.IsNullOrEmpty(modifyTime))
             {
-                var resCode = pm.DeleteScene(userSceneId);
-            }
-            else
-            {
-                if (string.IsNullOrEmpty(createTime) && string.IsNullOrEmpty(modifyTime))
+                revPack = pm.AddScene(this);
+                if (revPack.Code == StateCode.SUCCESS)
                 {
-                    revPack = pm.AddScene(this);
-                    if (revPack.Code == StateCode.SUCCESS)
-                    {
-                        var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
-                        FileUtils.WriteFileByBytes(savePath, ssd);
-                    }
+                    var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
+                    Common.FileUtlis.Files.WriteFileByBytes(savePath, ssd);
                 }
-                else if (!string.IsNullOrEmpty(createTime) && !string.IsNullOrEmpty(modifyTime))
+            }
+            else if (!string.IsNullOrEmpty(createTime) && !string.IsNullOrEmpty(modifyTime))
+            {
+                revPack = pm.EditScene(this);
+                if (revPack.Code == StateCode.SUCCESS)
                 {
-                    revPack = pm.EditScene(this);
-                    if (revPack.Code == StateCode.SUCCESS)
+                    var scenes = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Scene>>(revPack.Data.ToString());
+                    var tempScene = scenes.Find((obj) => obj.sid == sid);
+                    if (tempScene != null)
                     {
-                        var scenes = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Scene>>(revPack.Data.ToString());
-                        var tempScene = scenes.Find((obj) => obj.sid == sid);
-                        if (tempScene != null)
-                        {
-                            var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(tempScene));
-                            FileUtils.WriteFileByBytes(savePath, ssd);
-                        }
+                        var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(tempScene));
+                        Common.FileUtlis.Files.WriteFileByBytes(savePath, ssd);
                     }
                 }
             }
         }
-
-        /// <summary>
-        /// 鍒犻櫎鏍囪
-        /// 闇�瑕佸垹闄ゆ暟鎹椂锛屾爣璁颁负锛歵rue
-        /// 鐢变簯绔垹闄ゆ垚鍔熶箣鍚庯紝杩斿洖鏁版嵁鍐嶆竻闄ゆ湰鍦版暟鎹�
-        /// </summary>
-        public bool DeleteSign = false;
 
         /// <summary>
         /// 浜戠鏁版嵁鍒涘缓鐨勬椂闂�
@@ -328,7 +333,7 @@
         /// <returns></returns>
         Function ConvertFunctionObject()
         {
-            var localFunction = DB_ResidenceData.functionList.GetAllDeviceFunctionList().Find((obj) => obj.sid == sid);
+            var localFunction = FunctionList.List.GetDeviceFunctionList().Find((obj) => obj.sid == sid);
             foreach (var s in status)
             {
                 localFunction.attributes.Add(new FunctionAttributes() { key = s.key, curValue = s.value, value = new List<string>() { s.value } });

--
Gitblit v1.8.0