From 2109463fab2eb1caed189e4f258e0e763c5cea7b Mon Sep 17 00:00:00 2001
From: WJC <wjc@hdlchina.com.cn>
Date: 星期四, 07 十一月 2019 11:58:53 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev-tzy' into dev-wjc

---
 ZigbeeApp/Shared/Phone/UserCenter/DoorLock/DoorLockCommonInfo.cs |  275 ++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 242 insertions(+), 33 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/DoorLock/DoorLockCommonInfo.cs b/ZigbeeApp/Shared/Phone/UserCenter/DoorLock/DoorLockCommonInfo.cs
index ca94064..9fa27b6 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/DoorLock/DoorLockCommonInfo.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/DoorLock/DoorLockCommonInfo.cs
@@ -24,6 +24,29 @@
         public static int InValidDateSecond = 0;
         #endregion
 
+        public static async System.Threading.Tasks.Task<List<Shared.Phone.UserCenter.MemberInfoRes>> LocalAccountList()
+        {
+            return await System.Threading.Tasks.Task.Run(async () =>
+            {
+                List<Shared.Phone.UserCenter.MemberInfoRes> localAccountList = new List<Shared.Phone.UserCenter.MemberInfoRes> { };
+                List<Shared.Phone.UserCenter.MemberInfoRes> SubAccounList = new List<Shared.Phone.UserCenter.MemberInfoRes> { };
+                if (UserCenterResourse.UserInfo.AuthorityNo == 1 || UserCenterResourse.UserInfo.AuthorityNo == 2)
+                {
+                    SubAccounList = await ZigBee.Device.DoorLock.GetSubAccountByDistributedMark();
+                }
+
+                // 娉ㄦ剰锛歋ubAccountDistributedMark杩欎釜鍊煎緢鏈夌敤,鈥滄坊鍔犻棬閿佲�濆埌浜戠淇℃伅涓紝CloudAccountId濡傛灉鏄瓙璐︽埛锛屽垯鏄疭ubAccountDistributedMark杩欎釜鍊煎緢鏈夌敤锛屽鏋滄槸绠$悊鍛樻垨鑰呬富浜哄垯鏄櫥褰曞埌G
+                var masterAccount = new Shared.Phone.UserCenter.MemberInfoRes();
+                masterAccount.Account = Shared.Common.Config.Instance.Account;
+                masterAccount.AccountType = Shared.Common.Config.Instance.AccountType;
+                masterAccount.SubAccountDistributedMark = Shared.Common.Config.Instance.Guid;
+                masterAccount.UserName = UserCenterResourse.UserInfo.UserName;
+                localAccountList.Add(masterAccount);
+                localAccountList.AddRange(SubAccounList);
+                return localAccountList;
+            });
+        }
+
         /// <summary>
         ///  鑾峰彇闂ㄩ攣鍖呭惈璁惧淇℃伅鍜岃处鎴蜂俊鎭�
         /// </summary>
@@ -34,6 +57,14 @@
                  //  璇诲彇璁惧涓殑淇℃伅
                  doorLock.localDoorLockUserList.Clear();
                  var getDoorLockInfo = await doorLock.GetDoorlockUserInfoAsync();
+                 if (getDoorLockInfo == null)
+                 {
+                     doorLock.IsFailedToGetDoorLockInfo[curAccountObj.SubAccountDistributedMark] = true;
+                 }
+                 else
+                 {
+                     doorLock.IsFailedToGetDoorLockInfo[curAccountObj.SubAccountDistributedMark] = false;
+                 }
                  if (getDoorLockInfo != null && getDoorLockInfo.doorLockUserDetailData != null)
                  {
                      var dataList = getDoorLockInfo.doorLockUserDetailData.UserObjList;
@@ -53,24 +84,15 @@
 
                  //  璇诲彇浜戠闂ㄩ攣璁惧涓殑淇℃伅
                  var localDoorLockObj = new ZigBee.Device.DoorLock.GetDoorLockData() { };
-
-                 if (UserCenterResourse.UserInfo.AuthorityNo != 1)
-                 {
-                     localDoorLockObj.LoginAccessToken = UserCenterLogic.GetConnectMainToken();
-                     localDoorLockObj.IsOtherAccountCtrl = true;
-                 }
-
-                 localDoorLockObj.CloudAccountId = curAccountObj.SubAccountDistributedMark;
-
-                 {
-                     localDoorLockObj.DoorLockId = doorLock.DeviceAddr + "_" + doorLock.DeviceEpoint;
-                 }
-                 var getDoorLockInfoList = await ZigBee.Device.DoorLock.GetDoorLockInfoFromServer("DoorLock/GetDoorLockPager", localDoorLockObj);
-
+                 var getDoorLockInfoList = await Shared.Phone.UserCenter.DoorLock.DoorLockCommonInfo.GetDoorLockAllInfolist(doorLock, curAccountObj.SubAccountDistributedMark);
                  if (getDoorLockInfoList != null)
                  {
                      foreach (var curDoorLockUser in getDoorLockInfoList.PageData)
                      {
+                         if (curDoorLockUser.DoorLockLocalUserId == null || curDoorLockUser.DoorLockLocalUserId == "")
+                         {
+                             continue;
+                         }
                          if (doorLock.localDoorLockUserList.ContainsKey(int.Parse(curDoorLockUser.DoorLockLocalUserId)))
                          {
                              var doorLockObj = new ZigBee.Device.DoorLock.LocaDoorLockObj() { };
@@ -82,28 +104,215 @@
                              doorLockObj.ConnectedAccount = curDoorLockUser.CloudAccountId;
                              doorLock.localDoorLockUserList[int.Parse(curDoorLockUser.DoorLockLocalUserId)] = doorLockObj;
                          }
-                         else
-                         {
-                             //闂ㄩ攣涓笉瀛樺湪鐢ㄦ埛ID锛屼簯绔瓨鍦紝闇�瑕佸湪杩欓噷鍒犻櫎浜戠瀛樺湪鐨勬暟鎹�
-                             var deleteDoorLockData = new ZigBee.Device.DoorLock.DeleteDoorLockData();
-                             if (UserCenterResourse.UserInfo.AuthorityNo != 1)
-                             {
-                                 deleteDoorLockData.LoginAccessToken = UserCenterLogic.GetConnectMainToken();
-                                 deleteDoorLockData.IsOtherAccountCtrl = true;
-                             }
-                             if (doorLock.DeviceAddr != null)
-                             {
-                                 deleteDoorLockData.DoorLockId = doorLock.DeviceAddr + "_" + doorLock.DeviceEpoint;
-                             }
-                             deleteDoorLockData.DoorLockLocalUserId = curDoorLockUser.DoorLockLocalUserId;
-                             deleteDoorLockData.PrimaryId = curDoorLockUser.Id;
-                             deleteDoorLockData.DelDoorLockDelType = 2;
-                             var result = await ZigBee.Device.DoorLock.SendDoorLockToServer("DoorLock/DelDoorLock", deleteDoorLockData);
-                         }
                      }
+
+                     //鑾峰彇浜戠瀛樺偍鐨勯棬閿佹垚鍛樹俊鎭�
+                     //foreach (var curDoorLockUser in getDoorLockInfoList.PageData)
+                     //{
+                     //    var doorLockObj = new ZigBee.Device.DoorLock.LocaDoorLockObj();
+                     //    if (curDoorLockUser.DoorLockLocalUserId != null)
+                     //    {
+                     //        doorLockObj.UserID = int.Parse(curDoorLockUser.DoorLockLocalUserId);
+                     //        doorLockObj.UnlockType = curDoorLockUser.OpenLockMode;
+                     //        doorLockObj.UserName = curDoorLockUser.UserIdRemarks;
+                     //    }
+                     //    doorLockObj.PrimaryId = curDoorLockUser.Id;
+                     //    doorLockObj.EntryTime = curDoorLockUser.EntryTime;
+                     //    doorLockObj.ConnectedAccount = curDoorLockUser.CloudAccountId;
+                     //    if (doorLock.localDoorLockAccountList.ContainsKey(curDoorLockUser.CloudAccountId) == false)
+                     //    {
+                     //        doorLock.localDoorLockAccountList.Add(doorLockObj.ConnectedAccount, doorLockObj);
+                     //    }
+                     //    else
+                     //    {
+                     //        doorLock.localDoorLockAccountList[doorLockObj.ConnectedAccount] = doorLockObj;
+                     //    }
+
+                     //}
+                     doorLock.ReSave();
                  }
                  return doorLock.localDoorLockUserList;
              }));
+        }
+
+        /// <summary>
+        ///  鑾峰彇浜戠瀛樺偍鐨勯棬閿佷俊鎭�
+        /// </summary>
+        public static async System.Threading.Tasks.Task<Dictionary<int, LocaDoorLockObj>> GetCloudLocalDoorLocklist(ZigBee.Device.DoorLock doorLock, string subAccountDistributedMark)
+        {
+            return await System.Threading.Tasks.Task.Run((Func<System.Threading.Tasks.Task<Dictionary<int, LocaDoorLockObj>>>)(async () =>
+            {
+                //  璇诲彇浜戠闂ㄩ攣璁惧涓殑淇℃伅
+                var localDoorLockObj = new ZigBee.Device.DoorLock.GetDoorLockData() { };
+
+                if (UserCenterResourse.UserInfo.AuthorityNo != 1)
+                {
+                    localDoorLockObj.LoginAccessToken = UserCenterLogic.GetConnectMainToken();
+                    localDoorLockObj.IsOtherAccountCtrl = true;
+                }
+
+                localDoorLockObj.CloudAccountId = subAccountDistributedMark;
+                if (doorLock.DeviceAddr != null)
+                {
+                    localDoorLockObj.DoorLockId = doorLock.DeviceAddr + "_" + doorLock.DeviceEpoint;
+                }
+
+                var getDoorLockInfoList = await ZigBee.Device.DoorLock.GetDoorLockInfoFromServer("DoorLock/GetDoorLockPager", localDoorLockObj);
+
+                if (getDoorLockInfoList != null)
+                {
+                    foreach (var curDoorLockUser in getDoorLockInfoList.PageData)
+                    {
+                        if (curDoorLockUser.DoorLockLocalUserId == null || curDoorLockUser.DoorLockLocalUserId == "")
+                        {
+                            continue;
+                        }
+                        if (doorLock.localDoorLockUserList.ContainsKey(int.Parse(curDoorLockUser.DoorLockLocalUserId)))
+                        {
+                            var doorLockObj = new ZigBee.Device.DoorLock.LocaDoorLockObj() { };
+                            doorLockObj.UserID = int.Parse(curDoorLockUser.DoorLockLocalUserId);
+                            doorLockObj.UnlockType = curDoorLockUser.OpenLockMode;
+                            doorLockObj.PrimaryId = curDoorLockUser.Id;
+                            doorLockObj.EntryTime = curDoorLockUser.EntryTime;
+                            doorLockObj.UserName = curDoorLockUser.UserIdRemarks;
+                            doorLockObj.ConnectedAccount = curDoorLockUser.CloudAccountId;
+                            doorLock.localDoorLockUserList[int.Parse(curDoorLockUser.DoorLockLocalUserId)] = doorLockObj;
+                        }
+                    }
+
+                    doorLock.ReSave();
+                }
+                return doorLock.localDoorLockUserList;
+            }));
+        }
+
+        /// <summary>
+        ///  鑾峰彇浜戠瀛樺偍鐨勬垚鍛樹俊鎭�
+        /// </summary>
+        public static async System.Threading.Tasks.Task<List<ZigBee.Device.DoorLock.CloudDoorLockObj>> GetAccountDoorLockUserList(ZigBee.Device.DoorLock doorLock, string subAccountDistributedMark)
+        {
+            List<ZigBee.Device.DoorLock.CloudDoorLockObj> curAccountDoorLockUserList = new List<ZigBee.Device.DoorLock.CloudDoorLockObj> { };
+            return await System.Threading.Tasks.Task.Run((Func<System.Threading.Tasks.Task<List<ZigBee.Device.DoorLock.CloudDoorLockObj>>>)(async () =>
+            {
+                //  璇诲彇浜戠闂ㄩ攣璁惧涓殑淇℃伅
+                var getDoorLockInfoList = await Shared.Phone.UserCenter.DoorLock.DoorLockCommonInfo.GetDoorLockAllInfolist(doorLock, subAccountDistributedMark);
+                if (getDoorLockInfoList != null)
+                {
+                    //鑾峰彇浜戠瀛樺偍鐨勯棬閿佹垚鍛樹俊鎭�
+                    foreach (var curDoorLockUser in getDoorLockInfoList.PageData)
+                    {
+                        if (curDoorLockUser.CloudAccountId == "" || curDoorLockUser.CloudAccountId != subAccountDistributedMark)
+                        {
+                            continue;
+                        }
+                        else
+                        {
+                            curAccountDoorLockUserList.Add(curDoorLockUser);
+                        }
+                    }
+                }
+                return curAccountDoorLockUserList;
+            }));
+        }
+
+        /// <summary>
+        ///  鑾峰彇褰撳墠璐︽埛闂ㄩ攣鐨勬墍鏈変俊鎭�
+        /// </summary>
+        public static async System.Threading.Tasks.Task<ZigBee.Device.DoorLock.GetDoorLockDataRes> GetDoorLockAllInfolist(ZigBee.Device.DoorLock doorLock, string subAccountDistributedMark)
+        {
+            return await System.Threading.Tasks.Task.Run((Func<System.Threading.Tasks.Task<ZigBee.Device.DoorLock.GetDoorLockDataRes>>)(async () =>
+           {
+               //  璇诲彇浜戠闂ㄩ攣璁惧涓殑淇℃伅
+               var localDoorLockObj = new ZigBee.Device.DoorLock.GetDoorLockData() { };
+
+               if (UserCenterResourse.UserInfo.AuthorityNo != 1)
+               {
+                   localDoorLockObj.LoginAccessToken = UserCenterLogic.GetConnectMainToken();
+                   localDoorLockObj.IsOtherAccountCtrl = true;
+               }
+
+               localDoorLockObj.CloudAccountId = subAccountDistributedMark;
+               if (doorLock.DeviceAddr != null)
+               {
+                   localDoorLockObj.DoorLockId = doorLock.DeviceAddr + "_" + doorLock.DeviceEpoint;
+               }
+
+               var getDoorLockInfoList = await ZigBee.Device.DoorLock.GetDoorLockInfoFromServer("DoorLock/GetDoorLockPager", localDoorLockObj);
+               return getDoorLockInfoList;
+           }));
+        }
+
+        /// <summary>
+        ///  鑾峰彇浜戠瀛樺偍鐨勯棬閿佹垚鍛樹俊鎭�
+        /// </summary>
+        public static async System.Threading.Tasks.Task<Dictionary<int, LocaDoorLockObj>> GetLocaDoorLockAccountlist(ZigBee.Device.DoorLock doorLock, Shared.Phone.UserCenter.MemberInfoRes curAccountObj)
+        {
+            return await System.Threading.Tasks.Task.Run((Func<System.Threading.Tasks.Task<Dictionary<int, LocaDoorLockObj>>>)(async () =>
+            {
+                //  璇诲彇浜戠闂ㄩ攣璁惧涓殑淇℃伅
+                var localDoorLockObj = new ZigBee.Device.DoorLock.GetDoorLockData() { };
+                if (UserCenterResourse.UserInfo.AuthorityNo != 1)
+                {
+                    localDoorLockObj.LoginAccessToken = UserCenterLogic.GetConnectMainToken();
+                    localDoorLockObj.IsOtherAccountCtrl = true;
+                }
+                localDoorLockObj.CloudAccountId = curAccountObj.SubAccountDistributedMark;
+                {
+                    localDoorLockObj.DoorLockId = doorLock.DeviceAddr + "_" + doorLock.DeviceEpoint;
+                }
+                var getDoorLockInfoList = await ZigBee.Device.DoorLock.GetDoorLockInfoFromServer("DoorLock/GetDoorLockPager", localDoorLockObj);
+                if (getDoorLockInfoList != null)
+                {
+                    foreach (var curDoorLockUser in getDoorLockInfoList.PageData)
+                    {
+                        var doorLockObj = new ZigBee.Device.DoorLock.LocaDoorLockObj() { };
+                        if (curDoorLockUser.DoorLockLocalUserId != null)
+                        {
+                            doorLockObj.UserID = int.Parse(curDoorLockUser.DoorLockLocalUserId);
+                            doorLockObj.UnlockType = curDoorLockUser.OpenLockMode;
+                            doorLockObj.UserName = curDoorLockUser.UserIdRemarks;
+                        }
+                        doorLockObj.PrimaryId = curDoorLockUser.Id;
+                        doorLockObj.EntryTime = curDoorLockUser.EntryTime;
+                        doorLockObj.ConnectedAccount = curDoorLockUser.CloudAccountId;
+                        if (doorLock.localDoorLockAccountList.ContainsKey(curDoorLockUser.CloudAccountId) == false)
+                        {
+                            doorLock.localDoorLockAccountList.Add(doorLockObj.ConnectedAccount, doorLockObj);
+                        }
+                        else
+                        {
+                            doorLock.localDoorLockAccountList[curDoorLockUser.DoorLockLocalUserId] = doorLockObj;
+                        }
+
+                    }
+                }
+                return doorLock.localDoorLockUserList;
+            }));
+        }
+
+        /// <summary>
+        ///  鑾峰彇鏈湴鍖归厤鎴愬憳鐨勯棬閿佺敤鎴蜂俊鎭垪琛�
+        /// </summary>
+        public static async System.Threading.Tasks.Task<Dictionary<int, LocaDoorLockObj>> GetMatchDoorlockAccountList(ZigBee.Device.DoorLock doorLock, Shared.Phone.UserCenter.MemberInfoRes curAccountObj)
+        {
+            return await System.Threading.Tasks.Task.Run((Func<System.Threading.Tasks.Task<Dictionary<int, LocaDoorLockObj>>>)(async () =>
+            {
+                var curAccountDoorLockUserList = new Dictionary<int, ZigBee.Device.DoorLock.LocaDoorLockObj>();
+                foreach (var curUserId in doorLock.localDoorLockAccountList.Keys)
+                {
+                    var curDoorLockUser = doorLock.localDoorLockAccountList[curUserId];
+
+                    if (curDoorLockUser.ConnectedAccount == "" || curDoorLockUser.ConnectedAccount != curAccountObj.SubAccountDistributedMark)
+                    {
+                        continue;
+                    }
+                    else
+                    {
+                        curAccountDoorLockUserList.Add(curDoorLockUser.UserID, curDoorLockUser);
+                    }
+                }
+                return curAccountDoorLockUserList;
+            }));
         }
 
         /// <summary>
@@ -156,7 +365,7 @@
             /// <para>绠$悊鍛�10涓紝0~9锛�</para>
            ///<para>鏅�氱敤鎴�220涓紝10~234</para>
            ///<para>涓�娆℃�х敤鎴�10涓紝235~245</para>
            ///<para>涓存椂瀵嗙爜瀵嗙爜10涓紝245~255锛�</para>
            ///<para>鍏朵腑鎸囩汗100锛屽瘑鐮�100锛屽崱56</para>
             ///<para>闂ㄩ攣鏈湴褰曞叆鐨勫瘑鐮併�佹寚绾广�佹劅搴斿崱閮芥湁鍞竴瀵瑰簲鐨勭敤鎴稩d</para>
             /// </summary>
-            public int UserID;
+            public int UserID = -1;
             /// <summary>
             /// 寮�閿佺被鍨�
             /// <para>甯哥敤锛�</para>

--
Gitblit v1.8.0