From f1c3921b08bb22ac6f5db22d620e01d7e8e5c49f Mon Sep 17 00:00:00 2001
From: WJC <wjc@hdlchina.com.cn>
Date: 星期一, 30 十二月 2019 13:32:33 +0800
Subject: [PATCH] 2019-12-30-1

---
 ZigbeeApp/Shared/Phone/Device/Logic/Send.cs |  330 +++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 284 insertions(+), 46 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs b/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
old mode 100755
new mode 100644
index baa7047..63cc505
--- a/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Logic/Send.cs
@@ -5,6 +5,8 @@
 using ZigBee.Common;
 using Shared.Common;
 using System.Collections.Specialized;
+using System.Net;
+using System.IO;
 
 namespace Shared.Phone.Device.Logic
 {
@@ -380,6 +382,16 @@
                                 };
                                 conditions.Add(sInfo);
                                 break;
+                            case 7:
+                                var diliInfo = new JObject
+                                {
+                                    ["Type"] = int.Parse(dictionary["Type"]),
+                                    ["IsValid"] = int.Parse(dictionary["IsValid"]),
+                                    ["AtHome"] = int.Parse(dictionary["AtHome"]),
+                                    ["WhoSiteUId"] =dictionary["WhoSiteUId"],
+                                };
+                                conditions.Add(diliInfo);
+                                break;
                         }
                     }
                     var actions = new JArray();
@@ -467,6 +479,7 @@
                                         {
                                             ["Type"] = int.Parse(dictionary["Type"]),
                                             ["Account"] = dictionary["Account"],
+                                            ["UserId"] = dictionary["UserId"],
 
                                         };
                                         accounts.Add(accounts1);
@@ -697,7 +710,7 @@
             });
         }
         // <summary>
-        /// 閫氳繃璁惧鎵惧埌鍖哄煙(鎴块棿)鍚嶇О
+        /// 閫氳繃璁惧鎵惧埌鍖哄煙(鎴块棿)鍚嶇О
         /// </summary>
         /// <param name="btnregionname">Btnregionname.</param>
         /// <param name="device">Device.</param>
@@ -710,7 +723,82 @@
         public static List<Common.Room> GetRoomList(string floorId)
         {
             return Common.Room.Lists.FindAll((obj) => obj.FloorId == floorId);
+            //var list1 = new List<Common.Room>();
+            /////鎵惧埌鏌愭ゼ灞傛埧闂村垪琛紱
+            //var list = Common.Room.Lists.FindAll((obj) => obj.FloorId == floorId);
+            //for (int i = 0; i < list.Count; i++)
+            //{
+            //    if (str == "device")
+            //    {
+            //        if (list[i].DeviceUIList.Count != 0)
+            //        {   ///杩囨护鎺夋病鏈夎澶囩殑鎴块棿
+            //            list1.Add(list[i]);
+            //        }
+            //    }
+            //    else
+            //    {
+            //        if (list[i].SceneUIList.Count != 0)
+            //        {   ///杩囨护鎺夋病鏈夊満鏅殑鎴块棿
+            //            list1.Add(list[i]);
+            //        }
+            //    }
+            //}
+            /////杩斿洖鎴块棿鍒楄〃锛�
+            //return list1;
+        }
 
+
+        /// <summary>
+        /// 鑾峰彇鍦烘櫙淇℃伅鐨勬柟娉�
+        /// </summary>
+        /// <param name="SceneId"></param>
+        /// <returns></returns>
+        public static async System.Threading.Tasks.Task<SceneUI> GetScene(int SceneId)
+        {
+            SceneUI sceneui = null;
+            return await System.Threading.Tasks.Task.Run(async () =>
+            {
+                Action<string, string> action = (topic, data) =>
+                {
+                    var gatewayID = topic.Split('/')[0];
+                    var jObjectdata = JObject.Parse(data);
+                    if (jObjectdata == null)
+                    {
+                        return;
+                    }
+
+                    if (topic == $"{gatewayID}/Scene/GetDeviceList_Respon")
+                    {
+                        sceneui = new SceneUI();
+                        sceneui.Name = jObjectdata["Data"]["ScenesName"].ToString();
+                        sceneui.Id = int.Parse(jObjectdata["Data"]["ScenesId"].ToString());
+                        
+                    }
+                };
+                var mainGateWay = ZbGateway.MainGateWay;
+                if (mainGateWay == null)
+                {
+                    Console.WriteLine("娌℃湁涓荤綉鍏�");
+                    return sceneui;
+                }
+                mainGateWay.GwResDataAction += action;
+
+                var jObject = new JObject { { "Cluster_ID", 0 }, { "Command", 806 } };
+                var jObjectdata1 = new JObject { { "ScenesId", SceneId } };
+                jObject.Add("Data", jObjectdata1);
+                mainGateWay?.Send("Scene/GetDeviceList", jObject.ToString());
+                var dateTime = DateTime.Now;
+                while ((DateTime.Now - dateTime).TotalMilliseconds < 3 * 1000)
+                {
+                    await System.Threading.Tasks.Task.Delay(100);
+                    if (sceneui!=null)
+                    {
+                        break;
+                    }
+                }
+                ZbGateway.MainGateWay.GwResDataAction -= action;
+                return sceneui;
+            });
         }
         #endregion
 
@@ -719,7 +807,7 @@
         /// <summary>
         /// 鑾峰彇鑷繁+鍏朵粬鎴愬憳淇℃伅
         /// </summary>
-        /// <param name="doorlockMac">闂ㄩ攣Mac</param>
+        /// <param name="doorlockMac">闂ㄩ攣Mac+绔彛</param>
         /// <returns></returns>
         public static async System.Threading.Tasks.Task<List<MembershipIfon>> AllMembers(string doorlockMac)
         {
@@ -730,6 +818,7 @@
             currUserIfon.CloudAccountId = Config.Instance.Guid;
             if (string.IsNullOrEmpty(UserCenter.UserCenterResourse.UserInfo.UserName))
             {
+                ///濡傛灉鏄电О涓虹┖锛屾鏃讹紝鐧婚檰璐﹀彿涓洪粯璁ゆ樀绉帮紱
                 currUserIfon.UserName = UserCenter.UserCenterResourse.UserInfo.Account;
             }
             else
@@ -738,12 +827,18 @@
             }
             foreach (var o in AllUserIfon)
             {
+                if (o.IsFreezeUser || string.IsNullOrEmpty(o.UserId))
+                {
+                    ///杩囨护鎺夊喕缁撶殑鎴愬憳鍜孶serId涓虹┖鐨勬暟鎹紱
+                    continue;
+                }
                 if (string.IsNullOrEmpty(currUserIfon.DoorLockMacPort))
                 {
                     currUserIfon.DoorLockMacPort = o.DoorLockMacPort;
                 }
                 if (o.CloudAccountId == Config.Instance.Guid)
                 {
+
                     UnlockingMode unlockingMode = new UnlockingMode();
                     unlockingMode.OpenMode = o.OpenMode;
                     unlockingMode.UserId = o.UserId;
@@ -769,6 +864,7 @@
                     userIfon.CloudAccountId = user.SubAccountDistributedMark;
                     if (string.IsNullOrEmpty(user.UserName))
                     {
+                        ///濡傛灉鏄电О涓虹┖锛屾鏃讹紝鐧婚檰璐﹀彿涓洪粯璁ゆ樀绉帮紱
                         userIfon.UserName = user.Account;
 
                     }
@@ -779,6 +875,11 @@
                     }
                     for (int j = 0; j < AllUserIfon.Count; j++)
                     {
+                        if (AllUserIfon[j].IsFreezeUser || string.IsNullOrEmpty(AllUserIfon[j].UserId))
+                        {
+                            ///杩囨护鎺夊喕缁撶殑鎴愬憳鍜孶serId涓虹┖鐨勬暟鎹紱
+                            continue;
+                        }
                         if (string.IsNullOrEmpty(userIfon.DoorLockMacPort))
                         {
                             userIfon.DoorLockMacPort = AllUserIfon[j].DoorLockMacPort;
@@ -834,6 +935,7 @@
                 user.CloudAccountId = data["CloudAccountId"].ToString();
                 user.DoorLockMacPort = data["DoorLockId"].ToString();
                 user.ModeName = data["UserIdRemarks"].ToString();
+                user.IsFreezeUser = Convert.ToBoolean(data["IsFreezeUser"].ToString());
                 list.Add(user);
             }
             return list;
@@ -841,8 +943,8 @@
 
         public static async System.Threading.Tasks.Task<string> ReadUserList(string doorlockMac)
         {
-            string s = null; 
-            var str = await WebClientAsync(0, CommonPage.RequestHttpsHost+"/App/GetHomePager");//涓嶅悓鍖哄煙鍩熷悕鍓嶇紑涓嶄竴鏍�
+            string s = null;
+            var str = await WebClientAsync(0, CommonPage.RequestHttpsHost + "/App/GetHomePager");//涓嶅悓鍖哄煙鍩熷悕鍓嶇紑涓嶄竴鏍�
            // var str = await WebClientAsync(0, "https://global.hdlcontrol.com/HangZhouHdlCloudApi/App/GetHomePager");
             var jObject = JObject.Parse(str);
             if (jObject == null || jObject["StateCode"].ToString() != "Success")
@@ -886,7 +988,7 @@
             }
             return s;
         }
-     
+
         public static async System.Threading.Tasks.Task<string> ReadUserDoorLock(Residential residential)
         {
 
@@ -908,47 +1010,15 @@
             return await WebClientAsync(2, lockifon.Url, lockifon);
         }
 
-        /// <summary>
-        /// 璇锋眰鏈嶅姟鍣ㄧ殑鏂规硶
-        /// </summary>
-        /// <param name="postValues">post鍙傛暟</param>
-        /// <param name="url"></param>
-        /// <returns></returns>
-        public static async System.Threading.Tasks.Task<string> WebClientAsync(int value, string url, Residential residential = null)
+              //鎵撳嵃NameValueCollection()鏄剧ず绱㈠紩, 閿�,鍊�    
+        public static void PrintKeysAndValues2(NameValueCollection myCol)
         {
-
-            NameValueCollection postValues = new NameValueCollection();
-
-            if (value == 0)
+            for (int i = 0; i < myCol.Count; i++)
             {
-                postValues.Add("RequestVersion", CommonPage.RequestVersion);
-                postValues.Add("ReqDto.LoginAccessToken", Config.Instance.Token);
-                postValues.Add("ReqDto.PageSetting.PageSize", Int32.MaxValue.ToString());//
-
+                //鎵撳嵃鏄剧ず绱㈠紩, 閿�,鍊�  
+                Console.WriteLine("[{0}]{1,-10} {2}", i, myCol.GetKey(i), myCol.Get(i));
             }
-            else if (value == 1)
-            {
-                postValues.Add("RequestVersion", CommonPage.RequestVersion);
-                postValues.Add("LoginAccessToken", Config.Instance.Token);
-                postValues.Add("MainAccountId", residential.MainUserDistributedMark);
-                postValues.Add("SharedHid", residential.Id);
-            }
-            else if (value == 2)
-            {
-                postValues.Add("RequestVersion", CommonPage.RequestVersion);
-                postValues.Add("LoginAccessToken", residential.Token);
-                postValues.Add("HomeId", residential.Id);
-                postValues.Add("DoorLockId", residential.doorlockmac);//闂ㄩ攣Mac
-                postValues.Add("IsOtherAccountCtrl", residential.IsOtherAccountCtrl.ToString());
-                postValues.Add("PageSetting.PageSize", Int32.MaxValue.ToString());
-            }
-            System.Net.WebClient webClient = new System.Net.WebClient();
-            byte[] responseArray = webClient.UploadValues(url, postValues);
-            var s = System.Text.Encoding.UTF8.GetString(responseArray);
-            return s;
-
         }
-
         public class Residential
         {
             /// <summary>
@@ -972,7 +1042,7 @@
             public string doorlockmac;
         }
 
-        public class MembershipIfon 
+        public class MembershipIfon
         {
             /// <summary>
             /// 璇嗗埆鐢ㄦ埛韬唤
@@ -990,7 +1060,10 @@
             /// 鐢ㄦ埛鏄电О
             /// </summary>
             public string UserName = string.Empty;
-
+            /// <summary>
+            /// 鏄惁鍐荤粨璇ユ垚鍛橈紙true宸插喕缁擄級
+            /// </summary>
+            public bool IsFreezeUser;
 
         }
 
@@ -1033,15 +1106,17 @@
             /// 闂ㄩ攣Mac+Port,璇嗗埆闂ㄩ攣锛�
             /// </summary>
             public string DoorLockMacPort = string.Empty;
+            /// <summary>
+            /// 鏄惁鍐荤粨璇ユ垚鍛橈紙true宸插喕缁擄級
+            /// </summary>
+            public bool IsFreezeUser;
 
         }
-
 
         /// <summary>
         /// 闂ㄩ攣鍒楄〃
         /// </summary>
         public static List<MembershipIfon> LockList = new List<MembershipIfon>();
-
         /// <summary>
         /// 褰撳墠闂ㄩ攣
         /// </summary>
@@ -1051,5 +1126,168 @@
         /// </summary>
         public static UserCenter.MemberInfoRes UserMemberInfoRes = null;
         #endregion
+
+        #region  璇锋眰鏈嶅姟鍣ㄦ柟娉�---
+        /// <summary>
+        /// 璇锋眰鏁版嵁鐨勫皝瑁呮柟娉�
+        /// </summary>
+        /// <param name="command">璇嗗埆鍛戒护鍒ゆ柇瀛楃涓�</param>
+        /// <param name="url">璇锋眰鍦板潃</param>
+        /// <param name="method">璇锋眰鏂瑰紡涓篜OST/GET</param>
+        /// <param name="obj">瀛樺偍鍙戦�佹暟鎹殑瀵硅薄</param>
+        /// <returns></returns>
+        public static async System.Threading.Tasks.Task<string>Data(string command, string url, string method, object obj = null)
+        {
+            var getUrl = CommonPage.RequestHttpsHost + url;//璇锋眰鍦板潃锛�
+            var jObject = new JObject();
+            if (UserCenter.UserCenterResourse.UserInfo.AuthorityNo == 1)
+            {
+                jObject.Add("IsOtherAccountCtrl", false);
+            }
+            else
+            {
+                jObject.Add("IsOtherAccountCtrl", true);
+            }
+            switch (command)
+            {
+                case "娣诲姞/鏇存柊":
+                    {
+                        jObject.Add("RequestVersion", CommonPage.RequestVersion);
+                        jObject.Add("LoginAccessToken", Config.Instance.Token);
+                        jObject.Add("HomeId", Config.Instance.HomeId);
+                        jObject.Add("LogicID", Common.Logic.CurrentLogic.LogicId);
+                        jObject.Add("PushUserIds", new JArray { Config.Instance.Guid });
+                        jObject.Add("PushContent", Common.Logic.CurrentLogic.LogicCustomPushText);
+
+                    }
+                    break;
+                case "鍒犻櫎":
+                    {
+                        jObject.Add("RequestVersion", CommonPage.RequestVersion);
+                        jObject.Add("LoginAccessToken", Config.Instance.Token);
+                        jObject.Add("HomeId", Config.Instance.HomeId);
+                        jObject.Add("LogicID", Common.Logic.CurrentLogic.LogicId);
+                    }
+                    break;
+            }
+            return await HttpWebRequest(getUrl, jObject.ToString(), method);
+        }
+        /// <summary>
+        ///  璇锋眰鏈嶅姟鍣ㄧ殑鏂规硶(鏀寔璇锋眰鏂瑰紡涓篜OST/GET)
+        /// </summary>
+        /// <param name="getUrl">璇锋眰鐨勫湴鍧�</param>
+        /// <param name="str">璇锋眰鏁版嵁</param>
+        /// <param name="method">璇锋眰鏂瑰紡涓篜OST/GET</param>
+        /// <param name="second">瓒呮椂鏃堕棿</param>
+        /// <returns></returns>
+        public static async System.Threading.Tasks.Task<string>HttpWebRequest(string getUrl, string str, string method,int second= 3)
+        {
+            HttpWebRequest request = WebRequest.Create(getUrl) as HttpWebRequest; //鍒涘缓璇锋眰
+            request.Method = method; //璇锋眰鏂瑰紡涓篜OST/GET
+            request.ContentType = "application/json";
+            request.Timeout = second * 1000;//瓒呮椂鏃堕棿
+            if (method == "POST")
+            {
+                byte[] jsonbyte = System.Text.Encoding.UTF8.GetBytes(str);
+                request.ContentLength = jsonbyte.Length;
+                Stream postStream = request.GetRequestStream();
+                postStream.Write(jsonbyte, 0, jsonbyte.Length);
+                postStream.Close();
+            }
+            //鍙戦�佽姹傚苟鑾峰彇鐩稿簲鍥炲簲鏁版嵁       
+            HttpWebResponse res;
+            try
+            {
+                res = (HttpWebResponse)request.GetResponse();
+            }
+            catch (WebException ex)
+            {
+                res = (HttpWebResponse)ex.Response;
+            }
+            StreamReader sr = new StreamReader(res.GetResponseStream(), System.Text.Encoding.UTF8);
+            string content = sr.ReadToEnd(); //鑾峰緱鍝嶅簲瀛楃涓�
+            return content;
+        }
+        /// <summary>
+        /// 璇锋眰鏈嶅姟鍣ㄧ殑鏂规硶
+        /// </summary>
+        /// <param name="value">鍖哄垎鍙戦�佸懡浠ょ殑鏁版嵁鍒ゆ柇鍊�</param>
+        /// <param name="url">璇锋眰鐨勫湴鍧�</param>
+        /// <param name="residential">瑁呮暟鎹殑瀵硅薄</param>
+        /// <returns></returns>
+        public static async System.Threading.Tasks.Task<string> WebClientAsync(int value, string url, Residential residential = null)
+        {
+            NameValueCollection postValues = new NameValueCollection();
+            switch (value)
+            {
+                case 0:
+                    {
+                        postValues.Add("RequestVersion", CommonPage.RequestVersion);
+                        postValues.Add("ReqDto.LoginAccessToken", Config.Instance.Token);
+                        postValues.Add("ReqDto.PageSetting.PageSize", Int32.MaxValue.ToString());//
+                    }
+                    break;
+                case 1:
+                    {
+                        postValues.Add("RequestVersion", CommonPage.RequestVersion);
+                        postValues.Add("LoginAccessToken", Config.Instance.Token);
+                        postValues.Add("MainAccountId", residential.MainUserDistributedMark);
+                        postValues.Add("SharedHid", residential.Id);
+
+                    }
+                    break;
+                case 2:
+                    {
+                        postValues.Add("RequestVersion", CommonPage.RequestVersion);
+                        postValues.Add("LoginAccessToken", residential.Token);
+                        postValues.Add("HomeId", residential.Id);
+                        postValues.Add("DoorLockId", residential.doorlockmac);//闂ㄩ攣Mac+绔彛
+                        postValues.Add("IsOtherAccountCtrl", residential.IsOtherAccountCtrl.ToString());
+                        postValues.Add("PageSetting.PageSize", Int32.MaxValue.ToString());
+                    }
+                    break;
+            }
+            //PrintKeysAndValues2(postValues);
+            System.Net.WebClient webClient = new System.Net.WebClient();
+            byte[] responseArray = webClient.UploadValues(url, postValues);
+            var s = System.Text.Encoding.UTF8.GetString(responseArray);
+            return s;
+        }
+        #endregion
+
+        #region  瀛樺彇鏈湴鏂囦欢鐨勬柟娉� ---鏆傛椂涓嶇敤鍚堝苟璇ユ柟娉�---
+        /// <summary>
+        /// 鏂囦欢淇濆瓨
+        /// </summary>
+        /// <param name="FileName">鏂囦欢璺緞</param>
+        /// <param name="obj">闇�瑕佸簭鍒楀寲鏁版嵁</param>
+        public static void SaveLocalFile(string FileName, object obj)
+        {
+            //鍏堝簭鍒楀寲鏁版嵁锛�
+            var data = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
+            //鏁版嵁杞崲涓哄瓧鑺傛祦锛�
+            var byteData = System.Text.Encoding.UTF8.GetBytes(data);
+            //鍐欏叆鏁版嵁锛�
+            Shared.IO.FileUtils.WriteFileByBytes(FileName, byteData);
+        }
+
+        /// <summary>
+        /// 鏂囦欢璇诲彇
+        /// </summary>
+        /// <param name="FileName">鏂囦欢璺緞</param>
+        /// <returns></returns>
+        public static string ReadLocalFile(string FileName)
+        {
+            if (System.IO.File.Exists(FileName) == false)
+            {
+                ///鍒ゆ柇鏄惁鏈夋枃浠�;
+                return null;
+            }
+            //璇诲嚭淇濆瓨璇ヨ矾寰勭殑鏂囦欢锛�
+            var varByte = Shared.IO.FileUtils.ReadFile(FileName);
+            //瀛楄妭娴佽浆鎹负瀛楃涓诧紱
+            return System.Text.Encoding.UTF8.GetString(varByte);
+        }
+        #endregion
     }
 }

--
Gitblit v1.8.0