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/Function.cs |   72 ++++++++++++++++++++++++++---------
 1 files changed, 53 insertions(+), 19 deletions(-)

diff --git a/HDL_ON/Entity/Function/Function.cs b/HDL_ON/Entity/Function/Function.cs
index 29ec0d6..4063399 100644
--- a/HDL_ON/Entity/Function/Function.cs
+++ b/HDL_ON/Entity/Function/Function.cs
@@ -30,7 +30,6 @@
         public Function()
         {
         }
-      
 
         #region base info
         /// <summary>
@@ -43,10 +42,10 @@
         /// 浜у搧鏃堕棿鎴筹細4bytes	浠�2020骞�1鏈�1鏃ョ畻鍑虹殑鏃堕棿鎴�0.1s涓哄崟浣� 
         /// 浜у搧绫诲埆锛�01	璋冨厜鍣ㄣ��02 缁х數鍣ㄣ��03	骞叉帴鐐规ā鍧椼��04	浼犳劅鍣ㄣ��05 闈㈡澘
         /// 鐗╂ā鍨嬬被鍨嬶細
-		///     01	寮�鍏崇被锛�01 寮�鍏炽��02 鎻掑骇銆�03	
-		///     02	鐓ф槑锛� 01 寮�鍏炽��02	璋冨厜銆�03	鑹叉俯銆�04	LED
+        ///     01	寮�鍏崇被锛�01 寮�鍏炽��02 鎻掑骇銆�03	
+        ///     02	鐓ф槑锛� 01 寮�鍏炽��02	璋冨厜銆�03	鑹叉俯銆�04	LED
         ///     03	閬槼锛� 01	绐楀笜鐢垫満銆�02 鐧惧彾绐椼��03 寮�鍚堝笜銆�04 鍗峰笜
-		///     04	鎭掓俯鍣細01 绌鸿皟銆�02 鍦版殩銆�03 姣涚粏绌鸿皟
+        ///     04	鎭掓俯鍣細01 绌鸿皟銆�02 鍦版殩銆�03 姣涚粏绌鸿皟
         ///     05	鏂伴		
         ///     06	褰遍煶		
         ///     07	闊充箰		
@@ -125,6 +124,10 @@
         /// 鏄惁鏀惰棌
         /// </summary>
         public bool collect = false;
+        /// <summary>
+        /// 鏄惁鍦ㄧ嚎
+        /// </summary>
+        public bool online = true;
         /// <summary>
         /// 浜戠鏁版嵁鍒涘缓鐨勬椂闂�
         /// </summary>
@@ -230,7 +233,7 @@
         /// </summary>
         public int fixedSerialNumber = int.MaxValue;
 
-        public string GetBusId ()
+        public string GetBusId()
         {
             string busId = "";
             if (bus_Data != null)
@@ -247,9 +250,9 @@
         public string GetRoomListName()
         {
             string roomNameList = "";
-            foreach(var roomId in roomIds)
+            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;
@@ -280,12 +283,29 @@
         /// <summary>
         /// 淇濆瓨鍔熻兘鏁版嵁
         /// </summary>
-        public void SaveFunctionData()
+        public void SaveFunctionData(bool upSevser)
         {
-            var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
-            FileUtils.WriteFileByBytes( savePath, ssd);
-            MainPage.Log($"Save FunctionData {this.functionType} : {this.sid}");
+            if (upSevser)
+            {
+                var pm = new DAL.Server.HttpServerRequest();
+                var pack = pm.UpdataDevcieInfo(this);
+                if (pack.Code == DAL.Server.StateCode.SUCCESS)
+                {
+                    var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
+                    Common.FileUtlis.Files.WriteFileByBytes(savePath, ssd);
+                }
+                else
+                {
+                    Utlis.ShowTip(Language.StringByID(StringId.EditFunctionInfoFail) + "\r\nCode:" + pack.Code);
+                }
+            }
+            else
+            {
+                var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
+                Common.FileUtlis.Files.WriteFileByBytes(savePath, ssd);
+            }
         }
+      
 
         /// <summary>
         /// 杞崲鎴愬満鏅姛鑳藉璞�
@@ -297,6 +317,7 @@
             foreach (var attr in attributes)
             {
                 sFunc.status.Add(new SceneFunctionStatus() { key = attr.key, value = attr.curValue.ToString() });
+                sFunc.sid = this.sid;
             }
             return sFunc;
         }
@@ -309,9 +330,9 @@
         /// <summary>
         /// 鑾峰彇鏈湴鎺у埗鏁版嵁
         /// </summary>
-        public GatewayAlinkControlObj GetGatewayAlinkControlData(Dictionary<string, string> commandDictionary)
+        public AlinkFunctionStatusObj GetGatewayAlinkControlData(Dictionary<string, string> commandDictionary)
         {
-            var sendDataObj = new GatewayAlinkControlObj();
+            var sendDataObj = new AlinkFunctionStatusObj();
             sendDataObj.id = Control.Ins.msg_id.ToString();
             sendDataObj.time_stamp = Control.Ins.Get_TimeStamp();
 
@@ -319,7 +340,7 @@
             var acd = new AlinkControlData();
             acd.sid = sid;
             var aca = new AlinkControlAttributes();
-            foreach(var dic in commandDictionary)
+            foreach (var dic in commandDictionary)
             {
                 aca.key = dic.Key;
                 aca.value = dic.Value;
@@ -334,7 +355,7 @@
         /// 鑾峰彇Api鎺у埗鏁版嵁
         /// </summary>
         /// <returns></returns>
-        public ApiAlinkControlActionObj GetApiControlData(Dictionary<string,string> keyValues)
+        public ApiAlinkControlActionObj GetApiControlData(Dictionary<string, string> keyValues)
         {
             ApiAlinkControlActionObj aaao = new ApiAlinkControlActionObj();
             aaao.deviceId = this.deviceId;
@@ -368,18 +389,29 @@
         public string spk = "";
 
         public List<AlinkControlAttributes> attributes = new List<AlinkControlAttributes>();
+        //[Newtonsoft.Json.JsonIgnore]
+        public BusData bus = new BusData();
     }
 
     /// <summary>
-    /// 鏈湴鎺у埗
     /// A鍗忚鎺у埗鏁版嵁鐨勫璞�
     /// </summary>
-    public class GatewayAlinkControlObj
+    public class AlinkFunctionStatusObj
     {
         public List<AlinkControlData> objects = new List<AlinkControlData>();
 
         public string time_stamp = "";
         public string id = "";
+    }
+    /// <summary>
+    /// 鏈湴鐘舵�佽鍙�
+    /// A鍗忚鐘舵�佽鍙栨牸寮忓璞�
+    /// </summary>
+    public class AlinkReadFunctionStatusObj
+    {
+        public string id = "0";
+        public List<Dictionary<string, string>> objects = new List<Dictionary<string, string>>();
+        public string time_stamp = "";
     }
     /// <summary>
     /// A鍗忚鎺у埗鏁版嵁
@@ -423,11 +455,11 @@
         /// <summary>
         /// 鏈�澶у��
         /// </summary>
-        public int max;
+        public int max=100;
         /// <summary>
         /// 鏈�灏忓��
         /// </summary>
-        public int min;
+        public int min=0;
         /// <summary>
         /// 鏁版嵁绫诲瀷
         /// </summary>
@@ -763,6 +795,7 @@
     public class BusData
     {
         public string addresses = "FFFF";
+        [Newtonsoft.Json.JsonIgnore]
         public byte SubnetID
         {
             get
@@ -770,6 +803,7 @@
                 return Convert.ToByte(addresses.Substring(0, 2), 16);
             }
         }
+        [Newtonsoft.Json.JsonIgnore]
         public byte DeviceID
         {
             get

--
Gitblit v1.8.0