From 48ba446936b51fffafa7c3600c0dadc6ac0e8c20 Mon Sep 17 00:00:00 2001 From: 陈嘉乐 <cjl@hdlchina.com.cn> Date: 星期五, 10 七月 2020 10:52:13 +0800 Subject: [PATCH] 2020-07-10-01 --- ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs | 1120 +++++++++++++++++++++++++++++++++++++++++++++++----------- 1 files changed, 909 insertions(+), 211 deletions(-) diff --git a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs index 0970bc3..4244dad 100755 --- a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs +++ b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs @@ -1,6 +1,9 @@ 锘縰sing Shared.Common; using System; using System.Collections.Generic; +using System.Collections.Specialized; +using System.IO; +using System.Net; using System.Text; using System.Threading.Tasks; using ZigBee.Device; @@ -36,6 +39,11 @@ m_Current = value; } } + /// <summary> + /// 鍒嗕韩鐨勮澶囨枃浠�(key:璁惧涓婚敭,value:璁惧鏂囦欢) + /// </summary> + private Dictionary<string, string> dicShardDeviceFile = new Dictionary<string, string>(); + #endregion #region 鈻� 鑾峰彇鍒嗕韩鏂囦欢_______________________ @@ -45,13 +53,13 @@ /// </summary> /// <param name="listDistributedMark"></param> /// <returns></returns> - public async Task<List<string>> SetShardFileToLocation(List<string> listDistributedMark) + private async Task<List<string>> SetShardFileToLocation(List<string> listDistributedMark) { if (listDistributedMark.Count == 0) { return new List<string>(); } - ProgressBar.SetMaxValue(listDistributedMark.Count); + int listMarkCount = listDistributedMark.Count; List<string> listFile = new List<string>(); //鏂囦欢澶� @@ -59,17 +67,18 @@ //涓嶅厑璁告寜绯荤粺鐨勮繑鍥為敭 Shared.Common.CommonPage.BackKeyCanClick = false; - UserCenterResourse.Option.AppCanSignout = false; + UserCenterResourse.AccountOption.AppCanSignout = false; - foreach (string keys in listDistributedMark) + for (int i = 0; i < listDistributedMark.Count; i++) { - var dataPra = new { DistributedMark = keys, HouseDistributedMark = Common.Config.Instance.Home.Id, IsOtherAccountControl = Common.Config.Instance.isAdministrator }; + string keys = listDistributedMark[i]; + var dataPra = new { DistributedMark = keys, HouseDistributedMark = Common.Config.Instance.Home.Id, IsOtherAccountControl = Common.Config.Instance.Home.IsOthreShare }; var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/GetOneShareData", false, dataPra); if (result == null) { //鍏佽鎸夌郴缁熺殑杩斿洖閿� Shared.Common.CommonPage.BackKeyCanClick = true; - UserCenterResourse.Option.AppCanSignout = true; + UserCenterResourse.AccountOption.AppCanSignout = true; return null; } var dataResult = Newtonsoft.Json.JsonConvert.DeserializeObject<GetShardInfoResult>(result); @@ -78,12 +87,12 @@ //淇濆瓨鍒版寚瀹氭枃浠跺す涓� Global.WriteFileToDirectoryByBytes(strDir, dataResult.ShareName, dataResult.ShareDataBytes); //璁剧疆杩涘害鍊� - ProgressBar.SetValue(1); + ProgressFormBar.Current.SetValue(i + 1, listMarkCount); } //鍏佽鎸夌郴缁熺殑杩斿洖閿� Shared.Common.CommonPage.BackKeyCanClick = true; - UserCenterResourse.Option.AppCanSignout = true; + UserCenterResourse.AccountOption.AppCanSignout = true; return listFile; } @@ -181,6 +190,20 @@ Shared.IO.FileUtils.WriteFileByBytes(fullName, byteData); } + /// <summary> + /// 娣诲姞妤煎眰瀵硅薄鍒扮紦瀛� + /// </summary> + /// <param name="dic">妤煎眰</param> + public void AddShardFile(Dictionary<string, string> dic) + { + var data = Newtonsoft.Json.JsonConvert.SerializeObject(dic); + var byteData = System.Text.Encoding.UTF8.GetBytes(data); + + string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.DownLoadShardDirectory, DirNameResourse.ShardFloorFile); + //鍐欏叆鍐呭 + Shared.IO.FileUtils.WriteFileByBytes(fullName, byteData); + } + #endregion #region 鈻� 鍒犻櫎鍒嗕韩鏂囦欢_______________________ @@ -203,6 +226,7 @@ /// </summary> public void ClearShardDirectory() { + this.dicShardDeviceFile.Clear(); //鍒涘缓鏂囦欢澶� string strDir = System.IO.Path.Combine(DirNameResourse.LocalMemoryDirectory, DirNameResourse.DownLoadShardDirectory); Global.CreateEmptyDirectory(strDir, true); @@ -224,7 +248,7 @@ } //鑾峰彇涓讳汉鍒嗕韩缁欐垚鍛樼殑鏂囦欢鍒楄〃 - var infoPra = new { DistributedMark = Config.Instance.Guid, HouseDistributedMark = Common.Config.Instance.Home.Id , IsOtherAccountControl = Common.Config.Instance.isAdministrator }; + var infoPra = new { DistributedMark = Config.Instance.Guid, HouseDistributedMark = Common.Config.Instance.Home.Id, IsOtherAccountControl = Common.Config.Instance.Home.IsOthreShare }; var listNotShow = new List<string>() { "NotSetAgain" }; var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/GetShareDataBySubAccount", false, infoPra, listNotShow); if (string.IsNullOrEmpty(result) == true) @@ -261,11 +285,9 @@ //浠庝簯绔幏鍙栦笅鏉ユ枃浠� if (listAddMark.Count > 0) { - //寮哄埗鎸囧畾鏂囨湰闄勫姞淇℃伅锛氬叡浜暟鎹悓姝ヤ腑 - string msg = Language.StringByID(R.MyInternationalizationString.uShardDataIsSynchronizing); - //寮�鍚繘搴︽潯 - ProgressBar.Show(msg); - ProgressBar.SetAppendText(msg); + //寮�鍚繘搴︽潯 鍏变韩鏁版嵁鍚屾涓� + ProgressFormBar.Current.Start(); + ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uShardDataIsSynchronizing)); //灏嗗垎浜殑鏁版嵁瀛樺叆鏈湴(鑾峰彇鐨勬槸鏈湴娌℃湁鐨�) this.ClearShardDirectory(); @@ -273,19 +295,21 @@ if (listDbFile == null) { //鍏抽棴 - ProgressBar.Close(); + ProgressFormBar.Current.Close(); return false; } //鐢熸垚鏂囦欢 foreach (string fileName in listDbFile) { - var data = this.GetShardFileContent(fileName); - Global.WriteFileByBytesByHomeId(fileName, data); + var oldPath = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.DownLoadShardDirectory, fileName); + var newPath = System.IO.Path.Combine(Config.Instance.FullPath, fileName); + System.IO.File.Copy(oldPath, newPath, true); + if (fileName.StartsWith("Room_") == true) { //鎴块棿鏂囦欢鐗规畩澶勭悊 - Config.Instance.Home.AddRoomListFilePath(fileName); + Config.Instance.Home.AddRoomId(fileName.Replace("Room_", string.Empty).Replace(".json", string.Empty)); } } //娓呯┖鍏变韩鏂囦欢澶� @@ -309,11 +333,9 @@ //鍙湁鎴愬憳鎵嶆湁杩欎釜姒傚康 return true; } - //寮哄埗鎸囧畾鏂囨湰闄勫姞淇℃伅锛氬叡浜暟鎹悓姝ヤ腑 - string msg = Language.StringByID(R.MyInternationalizationString.uShardDataIsSynchronizing); - //寮�鍚繘搴︽潯 - ProgressBar.Show(msg); - ProgressBar.SetAppendText(msg); + //寮�鍚繘搴︽潯 鍏变韩鏁版嵁鍚屾涓� + ProgressFormBar.Current.Start(); + ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uShardDataIsSynchronizing)); if (dicUpdateTime == null) { @@ -326,13 +348,13 @@ { listShardFile = new HashSet<string>(); //鑾峰彇涓讳汉鍒嗕韩缁欐垚鍛樼殑鏂囦欢鍒楄〃 - var infoPra = new { DistributedMark = Config.Instance.Guid, HouseDistributedMark = Common.Config.Instance.Home.Id, IsOtherAccountControl = Common.Config.Instance.isAdministrator }; + var infoPra = new { DistributedMark = Config.Instance.Guid, HouseDistributedMark = Common.Config.Instance.Home.Id, IsOtherAccountControl = Common.Config.Instance.Home.IsOthreShare }; var listNotShow = new List<string>() { "NotSetAgain" }; var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/GetShareDataBySubAccount", false, infoPra, listNotShow); if (string.IsNullOrEmpty(result) == true) { //鍏抽棴 - ProgressBar.Close(); + ProgressFormBar.Current.Close(); return false; } var listShardData = Newtonsoft.Json.JsonConvert.DeserializeObject<List<GetShardInfoResult>>(result); @@ -343,17 +365,30 @@ } } + //娓呯┖妤煎眰鏁版嵁 + Common.Config.Instance.Home.FloorDics.Clear(); //鐒跺悗妫�娴嬫湰鍦扮殑鏂囦欢 var listLocalFile = Global.FileListByHomeId(); foreach (string fileName in listLocalFile) { + if (fileName == DirNameResourse.ShardFloorFile) + { + //妤煎眰鏂囦欢 + var varData = Global.ReadFileByHomeId(fileName); + var dicFloor = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary<string, string>>(Encoding.UTF8.GetString(varData)); + Common.Config.Instance.Home.FloorDics = dicFloor; + //鏆傛椂涓嶄繚瀛�,鐣欏湪鏈�鍚庨潰鎵嶄繚瀛� + Global.DeleteFilebyHomeId(fileName); + } + if (listShardFile.Contains(fileName) == true) { //鏈湴鐨勮繖涓枃浠惰繕鍒嗕韩鐫�,娌℃湁闂 continue; } + //妫�娴嬫湰鍦拌澶囨枃浠�,鏄惁瀛樺湪宸茬粡鍙栨秷浜嗗叡浜簡鐨� - if (fileName.StartsWith(Common.LocalDevice.deviceFirstName) == true) + if (fileName.StartsWith("Device_") == true) { //鍒犻櫎鎺夎繖涓澶囨枃浠� Global.DeleteFilebyHomeId(fileName); @@ -373,10 +408,8 @@ //鍒犻櫎鎺夎繖涓埧闂存枃浠� Global.DeleteFilebyHomeId(fileName); dicUpdateTime.Remove(fileName); - if (Config.Instance.Home.RoomFilePathList.Contains(fileName) == true) - { - Config.Instance.Home.RemoveRoomListFilePath(fileName); - } + + Config.Instance.Home.RemoveRoomId(nowRoom.Id); } //妫�娴嬫湰鍦板満鏅枃浠�,鏄惁瀛樺湪宸茬粡鍙栨秷浜嗗叡浜簡鐨� else if (fileName.StartsWith("Scene_") == true) @@ -393,12 +426,16 @@ dicUpdateTime.Remove(fileName); } } + + //淇濆瓨妤煎眰鏁版嵁 + Common.Config.Instance.Home.Save(false); + //缃戝叧鏂囦欢闈炲悎娉曟�ф槸鍒锋柊璁惧鍒楄〃鐨勫嚱鏁伴噷闈㈠疄鐜� //淇濆瓨鍏ㄩ儴鍒嗕韩鏂囦欢鐨勬洿鏂版棩鏈� this.SaveAllShardFileAgoUpdateTime(dicUpdateTime); //鍏抽棴 - ProgressBar.Close(); + ProgressFormBar.Current.Close(); return true; } @@ -414,7 +451,7 @@ private Dictionary<string, string> GetAllShardFileAgoUpdateTime() { var dicTime = new Dictionary<string, string>(); - var data = Global.ReadFileByDirectory(DirNameResourse.LocalMemoryDirectory, DirNameResourse.ShardFileUpdateFile); + var data = Global.ReadFileByDirectory(DirNameResourse.LocalMemoryDirectory, DirNameResourse.ShardFileUpdateTimeFile); if (data == null) { //鐩爣鏂囦欢涓嶅瓨鍦� @@ -432,7 +469,256 @@ { var data = Newtonsoft.Json.JsonConvert.SerializeObject(dicTime); var byteData = System.Text.Encoding.UTF8.GetBytes(data); - Global.WriteFileToDirectoryByBytes(DirNameResourse.LocalMemoryDirectory, DirNameResourse.ShardFileUpdateFile, byteData); + Global.WriteFileToDirectoryByBytes(DirNameResourse.LocalMemoryDirectory, DirNameResourse.ShardFileUpdateTimeFile, byteData); + } + + #endregion + + //----------------------------------鍒嗗壊绾�(鏁版嵁棰勫)------------------------------------------------- + + #region 鈻� 鏁版嵁棰勫___________________________ + + /// <summary> + /// 鑾峰彇鎴愬憳鍏变韩鍒楄〃鐒跺悗淇濆瓨鍒版湰鍦�(鐢ㄥ畬涔嬪悗鏈�濂借皟鐢ㄦ竻绌� ClearShardDirectory鍑芥暟娓呯┖) + /// </summary> + /// <param name="memberShardInfo"> + /// <para>鎴愬憳鐨勫垎浜暟鎹�</para> + /// <para>濡傛灉涓嶇煡閬撹繖鏄粈涔堜笢瑗�,灏盢ew涓�涓�,鐒跺悗缂撳瓨璧锋潵,璋冪敤鍏朵粬鍑芥暟閮介渶瑕佽繖涓笢瑗�</para> + /// <para>New鐨勬椂鍊欒寰楀SubAccountDistributedMark璧嬪��,瀹冩槸鎴愬憳鍒楄〃鎺ュ彛杩斿洖鐨凷ubAccountDistributedMark</para> + /// </param> + /// <returns></returns> + public async Task<bool> GetMemberShardContentListAndSetToLocation(MemberShardInfoData memberShardInfo) + { + if (memberShardInfo.Refresh == false) + { + //浠庢湰鍦拌幏鍙栨垚鍛樼殑鍒嗕韩鍒楄〃 + this.GetMemberShardContentListFromLocal(memberShardInfo); + return true; + } + memberShardInfo.Refresh = false; + + //姝e湪鑾峰彇鍒嗕韩鏁版嵁 + ProgressFormBar.Current.Start(); + ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uShardContentGetting)); + + var infoPra = new + { + DistributedMark = memberShardInfo.SubAccountDistributedMark, + HouseDistributedMark = Shared.Common.Config.Instance.HomeId, + IsOtherAccountControl = Common.Config.Instance.Home.IsOthreShare + }; + var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/GetShareDataBySubAccount", false, infoPra); + if (result == null) + { + //鍏抽棴杩涘害鏉� + ProgressFormBar.Current.Close(); + return false; + } + var listData = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ReceiveShardInfoResult>>(result); + //鍏堟竻绌哄叡浜枃浠跺す + this.ClearShardDirectory(); + + var listMark = new List<string>(); + foreach (var data in listData) + { + //鎬ц兘浼樺寲锛氬鏋滄湰鍦版嫢鏈夎繖涓枃浠剁殑璇�,鐩存帴浣跨敤閭d釜鏂囦欢 + string fileName = data.ShareName; + //璁板綍璧峰畠鐨勪富閿� + memberShardInfo.dicAllShardKeys[fileName] = data.DistributedMark; + + if (fileName.StartsWith("Room_") == true || fileName.StartsWith("Scene_") == true) + { + //鎴块棿鏂囦欢鍜屽満鏅枃浠堕渶瑕侀噸鏂板弽搴忓垪鍖� + listMark.Add(data.DistributedMark); + continue; + } + if (Shared.Common.Global.IsExistsByHomeId(fileName) == true) + { + //鍏朵粬鏂囦欢鐨勮瘽锛屽鏋滄湰鍦板瓨鍦紝鍒欎互鏈湴鏂囦欢涓哄噯 + this.AddShardFile(fileName); + continue; + } + listMark.Add(data.DistributedMark); + } + + //灏嗗垎浜殑鏁版嵁瀛樺叆鏈湴,杩斿洖鐨勬槸鏂囦欢鍚嶅瓧(寮傚父鏃惰繑鍥瀗ull) + var listFile = await this.SetShardFileToLocation(listMark); + if (listFile == null) + { + //鍏抽棴杩涘害鏉� + ProgressFormBar.Current.Close(); + return false; + } + + //浠庢湰鍦拌幏鍙栨垚鍛樼殑鍒嗕韩鍒楄〃 + this.GetMemberShardContentListFromLocal(memberShardInfo); + + //鍏抽棴杩涘害鏉� + ProgressFormBar.Current.Close(); + + return true; + } + + /// <summary> + /// 浠庢湰鍦拌幏鍙栨垚鍛樼殑鍒嗕韩鍒楄〃 + /// </summary> + /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜暟鎹殑缂撳瓨(璋冪敤杩欎釜鍑芥暟浼氬埛鏂拌繖涓彉閲忕殑淇℃伅)</param> + private void GetMemberShardContentListFromLocal(MemberShardInfoData memberShardInfo) + { + memberShardInfo.dicShardRoom = new Dictionary<string, Common.Room>(); + this.dicShardDeviceFile.Clear(); + + //keys:涓婚敭 value:鏂囦欢鍚� + var dicDeviceFile = new Dictionary<string, string>(); + //keys:鍦烘櫙id value:鏂囦欢鍚� + var dicSceneFile = new Dictionary<int, string>(); + + var listFile = this.GetLocalAllShardFile(); + //鍏堝垵濮嬪寲鎴块棿 + foreach (string fileName in listFile) + { + try + { + if (fileName.StartsWith("Room_") == true) + { + //鎴块棿鏂囦欢 + var byteData = this.GetShardFileContent(fileName); + if (byteData != null) + { + string valueData = System.Text.Encoding.UTF8.GetString(byteData); + var roomTemp = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.Room>(valueData); + memberShardInfo.dicShardRoom[fileName] = roomTemp; + } + } + else if (fileName == DirNameResourse.ShardFloorFile) + { + //妤煎眰鏂囦欢 + var byteData = this.GetShardFileContent(fileName); + if (byteData != null) + { + string valueData = System.Text.Encoding.UTF8.GetString(byteData); + memberShardInfo.dicShardFloor = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary<string, string>>(valueData); + } + } + else if (fileName.StartsWith("Device_") == true) + { + string[] Arry = fileName.Split(new string[] { "_" }, StringSplitOptions.RemoveEmptyEntries); + string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(Arry[2], Convert.ToInt32(Arry[3])); + this.dicShardDeviceFile[mainKeys] = fileName; + + //璁惧鏂囦欢 + dicDeviceFile[mainKeys] = fileName; + } + else if (fileName.StartsWith("Scene_") == true) + { + //鍦烘櫙鏂囦欢 + dicSceneFile[(Convert.ToInt32(fileName.Replace("Scene_", string.Empty).Replace(".json", string.Empty)))] = fileName; + } + } + catch (Exception ex) { HdlLogLogic.Current.WriteLog(ex); } + } + + //妫�鏌ヨ澶囩殑鍖归厤鎯呭喌 + foreach (var tempRoom in memberShardInfo.dicShardRoom.Values) + { + //妫�鏌ヨ澶� + for (int i = 0; i < tempRoom.ListDevice.Count; i++) + { + string deviceKeys = tempRoom.ListDevice[i]; + if (dicDeviceFile.ContainsKey(deviceKeys) == false) + { + //绉婚櫎鎺夎繖涓笉瀵瑰姴鐨勮矾寰� + tempRoom.ListDevice.RemoveAt(i); + i--; + continue; + } + //杩欎釜璁惧鏂囦欢鍖归厤寰楀埌鎴块棿 + dicDeviceFile.Remove(deviceKeys); + } + //妫�鏌ュ満鏅� + for (int i = 0; i < tempRoom.ListSceneId.Count; i++) + { + int intId = tempRoom.ListSceneId[i]; + if (dicSceneFile.ContainsKey(intId) == false) + { + //绉婚櫎鎺夎繖涓笉瀵瑰姴鐨勮矾寰� + tempRoom.ListSceneId.RemoveAt(i); + i--; + continue; + } + var byteData = this.GetShardFileContent(dicSceneFile[intId]); + //杩欎釜鍦烘櫙鏂囦欢鍖归厤寰楀埌鎴块棿 + dicSceneFile.Remove(intId); + if (byteData == null) + { + //绉婚櫎鎺夎繖涓笉瀵瑰姴鐨勮矾寰� + tempRoom.ListSceneId.RemoveAt(i); + i--; + continue; + } + string valueData = System.Text.Encoding.UTF8.GetString(byteData); + var tempUi = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.SceneUI>(valueData); + + //鑾峰彇鍦烘櫙閲岄潰鐨勫叏閮ㄧ洰鏍�(2019.11.05杩藉姞鎿嶄綔,鏈夊彲鑳介偅涓澶囨槸鐢卞満鏅祵濂楁潵鐨�,鎵�浠ュ畠鏈夊彲鑳戒笉灞炰簬浠讳綍鎴块棿) + foreach (var data in tempUi.AdjustTargetList) + { + //璁惧 + if (data.Type == 0) + { + string mainkey = LocalDevice.Current.GetDeviceMainKeys(data.DeviceAddr, data.Epoint); + if (dicShardDeviceFile.ContainsKey(mainkey) == true ) + { + //杩欎釜璁惧鏂囦欢鍖归厤寰楀埌 + dicDeviceFile.Remove(mainkey); + } + } + if (data.Type == 1) + { + //杩欎釜鍦烘櫙鏂囦欢鍖归厤寰楀埌 + dicSceneFile.Remove(data.ElseScenesId); + } + } + } + } + //濡傛灉瀛樺湪鍖归厤涓嶄笂鐨勬枃浠� + if (dicDeviceFile.Count != 0 || dicSceneFile.Count != 0) + { + //鍒涘缓涓�涓复鏃舵埧闂存潵瀛樺偍 + var roomTemp = new Room(); + roomTemp.Id = "Other"; + roomTemp.FloorId = "Other"; + memberShardInfo.dicShardRoom[roomTemp.FileName] = roomTemp; + roomTemp.Name = Language.StringByID(R.MyInternationalizationString.uUnallocated); + //杩樺師璁惧瀵硅薄 + foreach (string deviceKeys in dicDeviceFile.Keys) + { + roomTemp.ListDevice.Add(deviceKeys); + } + //杩樺師鍦烘櫙瀵硅薄 + foreach (int intId in dicSceneFile.Keys) + { + roomTemp.ListSceneId.Add(intId); + } + } + } + + + #endregion + + #region 鈻� 鑾峰彇璁惧鏂囦欢鍚峗____________________ + + /// <summary> + /// 鑾峰彇璁惧鏂囦欢鍚�,涓嶅瓨鍦ㄦ椂,杩斿洖绌哄瓧绗︿覆(浠呴檺鍒嗕韩浜嗙殑璁惧) + /// </summary> + /// <param name="deviceKeys">璁惧涓婚敭</param> + /// <returns></returns> + public string GetShardDeviceFileName(string deviceKeys) + { + if (this.dicShardDeviceFile.ContainsKey(deviceKeys) == true) + { + return this.dicShardDeviceFile[deviceKeys]; + } + return string.Empty; } #endregion @@ -447,10 +733,16 @@ /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜暟鎹�</param> /// <param name="nowRoom">褰撳墠鐨勬埧闂村璞�</param> /// <param name="listDevice">閫夋嫨涓婁紶鐨勮澶�</param> - /// <param name="listScene">閫夋嫨涓婁紶鐨勫満鏅�</param> + /// <param name="listScene">閫夋嫨涓婁紶鐨勫満鏅�(涓嶈鑾峰彇瀹冮噷闈㈢殑缁戝畾鍒楄〃)</param> + /// <param name="BarMaxValue">杩涘害鏉$殑鏈�澶у��,濡傛灉涓嶄负-1,鍒欏唴閮ㄤ笉浼氳嚜鍔ㄥ脊鍑鸿繘搴︽潯</param> + /// <param name="listCheckFile">鏂囦欢閲嶅涓婁紶妫�娴�</param> public async Task<bool> DoUploadSharedContent(MemberShardInfoData memberShardInfo, Common.Room nowRoom, - List<CommonDevice> listDevice, List<Common.SceneUI> listScene) + List<CommonDevice> listDevice, List<Common.SceneUI> listScene, int BarMaxValue = -1, HashSet<string> listCheckFile = null) { + if (listDevice.Count == 0 && listScene.Count == 0) + { + return true; + } var listCheck = new HashSet<string>(); //鑾峰彇鍦烘櫙閲岄潰宓屽鐨勫瓙璁惧鍜屽瓙鍦烘櫙 @@ -462,76 +754,147 @@ this.GetSceneDeviceList(SceneTemp, listCheck, listChirdScene, listChirdDevice); } + //杩欎釜涔熸槸澶囦唤 + int BackgroundImageType = 0; + string BackgroundImage = string.Empty; + if (memberShardInfo.dicShardRoom.ContainsKey(nowRoom.FileName) == true) + { + BackgroundImageType = memberShardInfo.dicShardRoom[nowRoom.FileName].BackgroundImageType; + BackgroundImage = memberShardInfo.dicShardRoom[nowRoom.FileName].BackgroundImage; + } //闃叉鍑虹幇閿欒,鏆傛椂淇濆瓨涓や釜鍒楄〃(铏界劧娌¢偅涔堥夯鐑︼紝涓嶈繃鏃㈢劧宸茬粡杩欐牱鍐欎簡灏辫繖鏍蜂簡) var dicBackDevice = new Dictionary<string, List<string>>(); - var dicBackScene = new Dictionary<string, List<string>>(); + var dicBackScene = new Dictionary<string, List<int>>(); //涓存椂澶囦唤鎴块棿璁惧鍒楄〃 this.BackupRoomDevicelistTemporary(memberShardInfo, dicBackDevice, dicBackScene); - Common.Room roomTemp = null; - if (memberShardInfo.dicShardRoom.ContainsKey(nowRoom.FileName) == false) - { - //鍏嬮殕涓�涓璞� - roomTemp = nowRoom.CloneRoomClass(); - memberShardInfo.dicShardRoom[nowRoom.FileName] = roomTemp; - } - roomTemp = memberShardInfo.dicShardRoom[nowRoom.FileName]; - //鑾峰彇涓婁紶鐨勬枃浠�,鐒跺悗灏嗘枃浠跺鍒跺埌鎸囧畾鏂囦欢澶� - var listFile = this.GetUploadListFile(ref roomTemp, listDevice, listScene, listChirdDevice, listChirdScene); + var listDelPic = new List<string>(); + var listFile = this.GetUploadListFile(memberShardInfo, nowRoom, listDevice, listScene, listChirdDevice, listChirdScene, listDelPic); //涓嶅厑璁告寜绯荤粺鐨勮繑鍥為敭 Shared.Common.CommonPage.BackKeyCanClick = false; - UserCenterResourse.Option.AppCanSignout = false; + UserCenterResourse.AccountOption.AppCanSignout = false; - //鎵撳紑杩涘害鏉� - ProgressBar.Show(); - //璁剧疆鏈�澶у�� - ProgressBar.SetMaxValue(listFile.Count); + if (BarMaxValue == -1) + { + //鎵撳紑杩涘害鏉� + ProgressBar.Show(); + //璁剧疆鏈�澶у�� + ProgressBar.SetMaxValue(listFile.Count); + } + else + { + //璁剧疆鏈�澶у�� + ProgressBar.SetMaxValue(BarMaxValue); + } + //涓婁紶鍒嗕韩 - var result = await this.DoUploadShardContent(memberShardInfo, nowRoom, listFile); - //鍏抽棴杩涘害鏉� - ProgressBar.Close(); + var result = await this.DoUploadShardContent(memberShardInfo, listFile, listCheckFile); + if (result == true) + { + //鍒犻櫎鎸囧畾鑷畾涔夊浘鐗� + result = await this.DoDeleteSharedContent(memberShardInfo, listDelPic); + } + if (BarMaxValue == -1) + { + //鍏抽棴杩涘害鏉� + ProgressBar.Close(); + } //鍏佽鎸夌郴缁熺殑杩斿洖閿� Shared.Common.CommonPage.BackKeyCanClick = true; - UserCenterResourse.Option.AppCanSignout = true; + UserCenterResourse.AccountOption.AppCanSignout = true; if (result == false) { //鎭㈠鍘熸暟鎹� + if (memberShardInfo.TempRoom == null) + { + memberShardInfo.dicShardRoom[nowRoom.FileName].BackgroundImageType = BackgroundImageType; + memberShardInfo.dicShardRoom[nowRoom.FileName].BackgroundImage = BackgroundImage; + } this.RecoverRoomDevicelistTemporary(memberShardInfo, dicBackDevice, dicBackScene, listFile); - return false; } + else + { + //瑕嗙洊鏁版嵁 + if (memberShardInfo.TempRoom != null) + { + memberShardInfo.dicShardRoom[nowRoom.FileName] = memberShardInfo.TempRoom; + } + } + memberShardInfo.TempRoom = null; - return true; + return result; } /// <summary> /// 鑾峰彇涓婁紶鐨勬枃浠跺悕 /// </summary> - /// <param name="roomTemp">闇�瑕佷笂浼犲埌浜戠鐨勬埧闂村璞�</param> - /// <param name="listDevice">鍒嗕韩鐨勮澶囧垪琛�</param> - /// <param name="listScene">鍒嗕韩鐨勫満鏅垪琛�</param> + /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜暟鎹�</param> + /// <param name="nowRoom">闇�瑕佷笂浼犲埌浜戠鐨勬埧闂村璞�(娉ㄦ剰,杩欎釜鎴块棿鏄富浜虹殑鎴块棿瀵硅薄,鑰屼笉鏄櫄鎷熺殑)</param> + /// <param name="listDevice">鍒嗕韩鐨勮澶囧垪琛�(娉ㄦ剰,杩欎釜涓滆タ鏄富浜虹殑)</param> + /// <param name="listScene">鍒嗕韩鐨勫満鏅垪琛�(娉ㄦ剰,杩欎釜涓滆タ鏄富浜虹殑)</param> /// <param name="listChirdDevice">鍦烘櫙閲岄潰閫掑綊鑾峰彇鐨勮澶�</param> /// <param name="listChirdScene">鍦烘櫙閲岄潰閫掑綊鑾峰彇鐨勫満鏅�</param> + /// <param name="listDelPic">闇�瑕佸垹闄ょ殑鍥剧墖</param> /// <returns></returns> - private List<string> GetUploadListFile(ref Common.Room roomTemp, List<CommonDevice> listDevice, List<Common.SceneUI> listScene, - List<CommonDevice> listChirdDevice, List<Common.SceneUI> listChirdScene) + private List<string> GetUploadListFile(MemberShardInfoData memberShardInfo, Common.Room nowRoom, List<CommonDevice> listDevice, List<Common.SceneUI> listScene, + List<CommonDevice> listChirdDevice, List<Common.SceneUI> listChirdScene, List<string> listDelPic) { var listFile = new List<string>(); - var listOtaCheck = new List<string>(); + + Common.Room roomTemp = null; + if (memberShardInfo.dicShardRoom.ContainsKey(nowRoom.FileName) == false) + { + //鍏嬮殕涓�涓璞� + roomTemp = HdlRoomLogic.Current.CloneRoomClass(nowRoom); + memberShardInfo.TempRoom = roomTemp; + //鏂板垎浜殑鎴块棿,濡傛灉鍥剧墖鏄嚜瀹氫箟鐨�,骞朵笖杩欎釜鍥剧墖鏄瓨鍦ㄧ殑,鍒欎笂浼犲浘鐗� + if (roomTemp.BackgroundImageType != 0 && Common.Global.IsExistsByHomeId(roomTemp.BackgroundImage) == true) + { + //鑷畾涔夌殑鍥剧墖,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰� + listFile.Add(roomTemp.BackgroundImage); + this.AddShardFile(roomTemp.BackgroundImage); + } + } + else + { + roomTemp = memberShardInfo.dicShardRoom[nowRoom.FileName]; + //濡傛灉浜戠鍒嗕韩鐨勬埧闂寸殑鍥剧墖鍜屼富浜虹殑涓嶄竴鏍风殑鏃跺�� + if (roomTemp.BackgroundImage != nowRoom.BackgroundImage) + { + if (roomTemp.BackgroundImageType != 0) + { + //鍒犻櫎鑷畾涔夊浘鐗� + listDelPic.Add(roomTemp.BackgroundImage); + } + if (nowRoom.BackgroundImageType != 0 && Common.Global.IsExistsByHomeId(nowRoom.BackgroundImage) == true) + { + //鑷畾涔夌殑鍥剧墖,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰� + listFile.Add(nowRoom.BackgroundImage); + this.AddShardFile(nowRoom.BackgroundImage); + } + //鍙樻洿鍥剧墖璁剧疆 + roomTemp.BackgroundImageType = nowRoom.BackgroundImageType; + roomTemp.BackgroundImage = nowRoom.BackgroundImage; + } + } + foreach (var device in listDevice) { //璁惧 listFile.Add(device.FilePath); - HdlShardLogic.Current.AddShardFile(device.FilePath); + this.AddShardFile(device.FilePath); - //璁惧鐨刄I - var deviceUi = $"DeviceUI_{device.FilePath}"; - if (roomTemp.DeviceUIFilePathList.Contains(deviceUi) == false) + //鍔犵偣缂撳瓨 + string mainKeys = LocalDevice.Current.GetDeviceMainKeys(device); + this.dicShardDeviceFile[mainKeys] = device.FilePath; + + if (roomTemp.ListDevice.Contains(mainKeys) == false) { - roomTemp.DeviceUIFilePathList.Add(deviceUi); + roomTemp.ListDevice.Add(mainKeys); } } //閫掑綊鑾峰彇鐨勮澶囦笉闇�瑕佸姞鍏ュ埌鎴块棿 @@ -539,44 +902,62 @@ { //璁惧 listFile.Add(device.FilePath); - HdlShardLogic.Current.AddShardFile(device.FilePath); + this.AddShardFile(device.FilePath); + + //鍔犵偣缂撳瓨 + this.dicShardDeviceFile[LocalDevice.Current.GetDeviceMainKeys(device)] = device.FilePath; } //鍦烘櫙 foreach (var secene in listScene) { - listFile.Add(secene.FileName); - HdlShardLogic.Current.AddShardFile(secene); - - if (roomTemp.SceneUIFilePathList.Contains(secene.FileName) == false) + if (secene.IconPathType != 0 && Common.Global.IsExistsByHomeId(secene.IconPath) == true) { - roomTemp.SceneUIFilePathList.Add(secene.FileName); + //鑷畾涔夌殑鍥剧墖,瀹冨瓨鍦ㄤ簬鏈湴 + listFile.Add(secene.IconPath); + this.AddShardFile(secene.IconPath); + } + + listFile.Add(secene.FileName); + this.AddShardFile(secene); + + if (roomTemp.ListSceneId.Contains(secene.Id) == false) + { + roomTemp.ListSceneId.Add(secene.Id); } } //閫掑綊鑾峰彇鐨勫満鏅笉闇�瑕佸姞鍏ュ埌鎴块棿 foreach (var secene in listChirdScene) { listFile.Add(secene.FileName); - HdlShardLogic.Current.AddShardFile(secene); + this.AddShardFile(secene); } //鎴块棿鏂囦欢涔熺粰杩囧幓 listFile.Add(roomTemp.FileName); - HdlShardLogic.Current.AddShardFile(roomTemp); + this.AddShardFile(roomTemp); + + //鍙嶆妤煎眰鏂囦欢寰堝皬,涓�璧风粰杩囧幓鍚� + if (roomTemp.FloorId != string.Empty) + { + memberShardInfo.dicShardFloor[roomTemp.FloorId] = HdlResidenceLogic.Current.GetFloorNameById(roomTemp.FloorId); + } + this.AddShardFile(memberShardInfo.dicShardFloor); + listFile.Add(DirNameResourse.ShardFloorFile); return listFile; } /// <summary> - /// 浠庣綉鍏宠幏鍙栧満鏅殑鐩爣璁惧鍒楄〃 + /// 鑾峰彇鍦烘櫙鐨勭洰鏍囪澶囧垪琛�(杩欎釜涓嶈兘浠庡垎浜暟鎹腑鑾峰彇) /// </summary> /// <param name="scene">鍦烘櫙</param> /// <param name="listCheck">閲嶅妫�娴嬬敤</param> /// <param name="listSceneUI">娣诲姞鍒嗕韩鐨勫満鏅垪琛�</param> /// <param name="listDevice">娣诲姞鍒嗕韩鐨勮澶囧垪琛�</param> /// <returns></returns> - private void GetSceneDeviceList(Common.SceneUI scene, HashSet<string> listCheck, List<Common.SceneUI> listSceneUI, List<CommonDevice> listDevice) + public void GetSceneDeviceList(Common.SceneUI scene, HashSet<string> listCheck, List<Common.SceneUI> listSceneUI, List<CommonDevice> listDevice) { - foreach (var data in scene.AddSceneMemberDataList) + foreach (var data in scene.AdjustTargetList) { //璁惧 if (data.Type == 0) @@ -607,7 +988,7 @@ listCheck.Add(mainKeys); //鑾峰彇鍦烘櫙瀵硅薄 - var sceneUi = Room.CurrentRoom.GetSceneUIBySceneId(data.ElseScenesId); + var sceneUi = HdlSceneLogic.Current.GetSceneUIBySceneId(data.ElseScenesId); if (sceneUi != null) { listSceneUI.Add(sceneUi); @@ -624,57 +1005,205 @@ /// 涓婁紶鍒嗕韩(杩斿洖浜戠鍒嗕韩鏂囦欢鐨勪富閿�:DistributedMark) /// </summary> /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜暟鎹�</param> - /// <param name="nowRoom">褰撳墠鐨勬埧闂村璞�</param> /// <param name="listFile">涓婁紶鐨勬枃浠跺悕</param> + /// <param name="listCheckFile">閲嶅鏂囦欢涓婁紶妫�娴�</param> /// <returns></returns> - private async Task<bool> DoUploadShardContent(MemberShardInfoData memberShardInfo, Common.Room nowRoom, List<string> listFile) + private async Task<bool> DoUploadShardContent(MemberShardInfoData memberShardInfo, List<string> listFile, HashSet<string> listCheckFile) { var dicKeys = new Dictionary<string, string>(); for (int i = 0; i < listFile.Count; i++) { string fileName = listFile[i]; - var info = new UploadShardContent(); - info.SubAccountDistributedMark = memberShardInfo.SubAccountDistributedMark; - info.ShareName = fileName; - info.ShareDataBytes = HdlShardLogic.Current.GetShardFileContent(fileName); - - //杩藉姞鍏变韩 - if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == false) + if (listCheckFile != null) { - var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/AddShareData", false, info); - if (string.IsNullOrEmpty(result) == true) + if (listCheckFile.Contains(fileName) == true) + { + //閲嶅鏂囦欢涓嶅啀涓婁紶 + continue; + } + listCheckFile.Add(fileName); + } + if (fileName.EndsWith(".png") == true) + { + //涓婁紶鍥剧墖 + var result = this.UpLoadBigBackupFileToDB(memberShardInfo, fileName); + if (result == null) { return false; } - //杩欓噷鏈夌偣鐗规畩锛屾帴鍙f槸鐩存帴杩斿洖涓婚敭鍥炴潵鐨勶紝鑰屼笉鏄疛soin dicKeys[fileName] = result; } else { - info.DistributedMark = memberShardInfo.dicAllShardKeys[fileName]; - var result = await UserCenterLogic.GetResultStatuByRequestHttps("ZigbeeDataShare/EditShareData", false, info); - if (result == false) + var info = new UploadShardContent(); + info.SubAccountDistributedMark = memberShardInfo.SubAccountDistributedMark; + info.ShareName = fileName; + info.ShareDataBytes = HdlShardLogic.Current.GetShardFileContent(fileName); + + //杩藉姞鍏变韩 + if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == false) { - return false; + var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/AddShareData", false, info); + if (result == null) + { + return false; + } + //杩欓噷鏈夌偣鐗规畩锛屾帴鍙f槸鐩存帴杩斿洖涓婚敭鍥炴潵鐨勶紝鑰屼笉鏄疛soin + dicKeys[fileName] = result; } - dicKeys[fileName] = info.DistributedMark; + else + { + info.DistributedMark = memberShardInfo.dicAllShardKeys[fileName]; + var result = await UserCenterLogic.GetResultStatuByRequestHttps("ZigbeeDataShare/EditShareData", false, info); + if (result == false) + { + return false; + } + dicKeys[fileName] = info.DistributedMark; + } } //璁剧疆杩涘害鍊� ProgressBar.SetValue(1); } //濡傛灉娌℃湁閿欒,鍒欐坊鍔犱复鏃剁紦瀛� - var listShard = memberShardInfo.dicAllMemberShard[nowRoom.FileName]; foreach (var keys in dicKeys.Keys) { - if (listShard.Contains(keys) == false) - { - listShard.Add(keys); - } memberShardInfo.dicAllShardKeys[keys] = dicKeys[keys]; } return true; } + + /// <summary> + /// 涓婁紶鍥剧墖鏂囦欢鍒颁簯绔� + /// </summary> + /// <param name="fullDir">鏂囦欢澶圭殑鍏ㄨ矾寰�</param> + /// <param name="listPicFile">鍥剧墖鏂囦欢鍒楄〃</param> + /// <returns></returns> + private string UpLoadBigBackupFileToDB(MemberShardInfoData memberShardInfo, string fileName) + { + string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.DownLoadShardDirectory, fileName); + if (System.IO.File.Exists(fullName) == false) + { + return null; + } + var nvc = new NameValueCollection(); + nvc.Add("ShareName", fileName); + nvc.Add("HouseDistributedMark", Common.Config.Instance.Home.Id); + nvc.Add("SubAccountDistributedMark", memberShardInfo.SubAccountDistributedMark); + nvc.Add("ShareDataBytes", Convert.ToBase64String(this.GetShardFileContent(fileName))); + + //杩藉姞鍏变韩 + if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == false) + { + //杩欓噷鏈夌偣鐗规畩锛屾帴鍙f槸鐩存帴杩斿洖涓婚敭鍥炴潵鐨勶紝鑰屼笉鏄疛soin + var result = this.DoUpLoadBigBackupFileToDB("ZigbeeDataShare/AddShareData", fullName, nvc); + return result; + } + else + { + nvc.Add("DistributedMark", memberShardInfo.dicAllShardKeys[fileName]); + var result = this.DoUpLoadBigBackupFileToDB("ZigbeeDataShare/EditShareData", fullName, nvc); + if (result == null) + { + return null; + } + return memberShardInfo.dicAllShardKeys[fileName]; + } + } + + /// <summary> + /// 鎵ц涓婁紶澶ф枃浠� + /// </summary> + /// <param name="RequestName">璇锋眰鎺ュ彛</param> + /// <param name="fullFileName">鏂囦欢鍚嶅瓧(鍚矾寰�)</param> + /// <param name="nvc"></param> + /// <returns></returns> + private string DoUpLoadBigBackupFileToDB(string RequestName, string fullFileName, NameValueCollection nvc) + { + string paramName = "file"; + string contentType = "application/octet-stream"; + string requestUrl = $"{CommonPage.RequestHttpsHost}/{RequestName}"; + + string boundary = "---------------------------" + DateTime.Now.Ticks.ToString("x"); + byte[] boundarybytes = System.Text.Encoding.ASCII.GetBytes("\r\n--" + boundary + "\r\n"); + + var wr = (HttpWebRequest)WebRequest.Create(requestUrl); + wr.ContentType = "multipart/form-data; boundary=" + boundary; + wr.Method = "POST"; + wr.KeepAlive = true; + wr.Credentials = System.Net.CredentialCache.DefaultCredentials; + + wr.Headers.Add(HttpRequestHeader.Authorization, Config.Instance.Token); + + var rs = wr.GetRequestStream(); + + string formdataTemplate = "Content-Disposition: form-data; name=\"{0}\"\r\n\r\n{1}"; + foreach (string key in nvc.Keys) + { + rs.Write(boundarybytes, 0, boundarybytes.Length); + string formitem = string.Format(formdataTemplate, key, nvc[key]); + byte[] formitembytes = System.Text.Encoding.UTF8.GetBytes(formitem); + rs.Write(formitembytes, 0, formitembytes.Length); + } + rs.Write(boundarybytes, 0, boundarybytes.Length); + + string headerTemplate = "Content-Disposition: form-data; name=\"{0}\"; filename=\"{1}\"\r\nContent-Type: {2}\r\n\r\n"; + string header = string.Format(headerTemplate, paramName, fullFileName, contentType); + byte[] headerbytes = System.Text.Encoding.UTF8.GetBytes(header); + rs.Write(headerbytes, 0, headerbytes.Length); + + var fileStream = new FileStream(fullFileName, FileMode.Open, FileAccess.Read); + byte[] buffer = new byte[4096]; + int bytesRead = 0; + while ((bytesRead = fileStream.Read(buffer, 0, buffer.Length)) != 0) + { + rs.Write(buffer, 0, bytesRead); + } + fileStream.Close(); + + byte[] trailer = System.Text.Encoding.ASCII.GetBytes("\r\n--" + boundary + "--\r\n"); + rs.Write(trailer, 0, trailer.Length); + rs.Close(); + + WebResponse wresp = null; + try + { + wresp = wr.GetResponse(); + Stream stream2 = wresp.GetResponseStream(); + StreamReader reader2 = new StreamReader(stream2); + + string result = reader2.ReadToEnd(); + + var data = Newtonsoft.Json.JsonConvert.DeserializeObject<Shared.Common.ResponseEntity.ResponsePack>(result); + + bool flage = UserCenterLogic.CheckNotEorrorMsg(data, requestUrl); + if (flage == true) + { + //缂栬緫鐨勬椂鍊欙紝杩欎釜涓滆タ浼氭槸null + return data.ResponseData == null ? "1" : data.ResponseData.ToString(); + } + + //Log鍑哄姏 + IMessageCommon.Current.GetMsgByRequestName(RequestName, data, nvc); + + return null; + } + catch + { + return null; + } + finally + { + if (wresp != null) + { + wresp.Close(); + wresp = null; + } + wr = null; + } + } + #endregion @@ -687,15 +1216,15 @@ /// <param name="dicBackDevice">绌虹殑璁惧澶囦唤鍒楄〃</param> /// <param name="dicBackScene">绌虹殑鍦烘櫙澶囦唤鍒楄〃</param> private void BackupRoomDevicelistTemporary(MemberShardInfoData memberShardInfo, Dictionary<string, List<string>> dicBackDevice, - Dictionary<string, List<string>> dicBackScene) + Dictionary<string, List<int>> dicBackScene) { foreach (var roomKeys in memberShardInfo.dicShardRoom.Keys) { dicBackDevice[roomKeys] = new List<string>(); - dicBackScene[roomKeys] = new List<string>(); + dicBackScene[roomKeys] = new List<int>(); - dicBackDevice[roomKeys].AddRange(memberShardInfo.dicShardRoom[roomKeys].DeviceUIFilePathList); - dicBackScene[roomKeys].AddRange(memberShardInfo.dicShardRoom[roomKeys].SceneUIFilePathList); + dicBackDevice[roomKeys].AddRange(memberShardInfo.dicShardRoom[roomKeys].ListDevice); + dicBackScene[roomKeys].AddRange(memberShardInfo.dicShardRoom[roomKeys].ListSceneId); } } @@ -707,12 +1236,12 @@ /// <param name="dicBackScene">涓存椂澶囦唤鐨勫満鏅浠藉垪琛�</param> /// <param name="listFile">涓婁紶鐨勬枃浠跺悕</param> private void RecoverRoomDevicelistTemporary(MemberShardInfoData memberShardInfo, Dictionary<string, List<string>> dicBackDevice, - Dictionary<string, List<string>> dicBackScene, List<string> listFile) + Dictionary<string, List<int>> dicBackScene, List<string> listFile) { foreach (string fileName in listFile) { //鐢熸垚鐨勬枃浠跺叏閮ㄥ垹闄�,鎴块棿鏂囦欢鐨勮瘽,涓嬮潰浼氶噸鏂扮敓鎴� - HdlShardLogic.Current.DeleteShardFile(fileName); + this.DeleteShardFile(fileName); } foreach (var roomKeys in memberShardInfo.dicShardRoom.Keys) @@ -721,14 +1250,14 @@ { continue; } - memberShardInfo.dicShardRoom[roomKeys].DeviceUIFilePathList.Clear(); - memberShardInfo.dicShardRoom[roomKeys].DeviceUIFilePathList.AddRange(dicBackDevice[roomKeys]); + memberShardInfo.dicShardRoom[roomKeys].ListDevice.Clear(); + memberShardInfo.dicShardRoom[roomKeys].ListDevice.AddRange(dicBackDevice[roomKeys]); - memberShardInfo.dicShardRoom[roomKeys].SceneUIFilePathList.Clear(); - memberShardInfo.dicShardRoom[roomKeys].SceneUIFilePathList.AddRange(dicBackScene[roomKeys]); + memberShardInfo.dicShardRoom[roomKeys].ListSceneId.Clear(); + memberShardInfo.dicShardRoom[roomKeys].ListSceneId.AddRange(dicBackScene[roomKeys]); //瑕嗙洊鎴块棿鏂囦欢 - HdlShardLogic.Current.AddShardFile(memberShardInfo.dicShardRoom[roomKeys]); + this.AddShardFile(memberShardInfo.dicShardRoom[roomKeys]); } } @@ -752,36 +1281,32 @@ var roomTemp = memberShardInfo.dicShardRoom[nowRoom.FileName]; //闃叉鍑洪敊,鍏堝浠藉垪琛� var listBackDevice = new List<string>(); - listBackDevice.AddRange(roomTemp.DeviceUIFilePathList); - var listBackScene = new List<string>(); - listBackScene.AddRange(roomTemp.SceneUIFilePathList); + listBackDevice.AddRange(roomTemp.ListDevice); + var listBackScene = new List<int>(); + listBackScene.AddRange(roomTemp.ListSceneId); var listMark = new List<string>(); //瑕佸垹闄ょ殑鏂囦欢鍚嶅瓧 var listDeleteFile = new List<string>(); - //杩欎釜鏄彧绉婚櫎缂撳瓨鐨勬枃浠跺悕瀛� - var listDeleteFileEx = new List<string>(); - //浜戠鐨勬寚瀹氭埧闂寸殑鍏变韩鏂囦欢鍒楄〃 - var dicShardFile = memberShardInfo.dicAllMemberShard[nowRoom.FileName]; + //闄や簡瑕佸垹闄ょ殑鐩爣澶栵紝杩樺垎浜殑鏁版嵁 - var listHadShard = this.GetAllShardedFileNameFromDictionary(memberShardInfo, nowRoom, listDevice, listSceneUI); + var listHadShardKeys = this.GetAllShardedKeysFromDictionary(memberShardInfo, nowRoom, listDevice, listSceneUI); //鍏堝紕璁惧 foreach (var device in listDevice) { string deviceFileName = device.FilePath; - + string mainKeys = LocalDevice.Current.GetDeviceMainKeys(device); //绉婚櫎璺緞鍒楄〃 - roomTemp.DeviceUIFilePathList.Remove($"DeviceUI_{device.FilePath}"); - if (listHadShard.Contains(deviceFileName) == true) + roomTemp.ListDevice.Remove(mainKeys); + if (listHadShardKeys.Contains(mainKeys) == true) { - //鍏朵粬鎴块棿鍒嗕韩鏈夎繖涓澶�,鎵�浠ヤ笉鍒犻櫎杩欎釜璁惧鐨勬牴婧愭枃浠�,鍙槸鎶婃埧闂寸殑璁惧鍒楄〃璺緞绉婚櫎 - listDeleteFileEx.Add(deviceFileName); + //鍏朵粬鍦烘櫙鍒嗕韩鏈夎繖涓澶�,鎵�浠ヤ笉鍒犻櫎杩欎釜璁惧鐨勬牴婧愭枃浠�,鍙槸鎶婃埧闂寸殑璁惧鍒楄〃璺緞绉婚櫎 continue; } //璁惧涓婚敭 - if (dicShardFile.Contains(deviceFileName) == true) + if (memberShardInfo.dicAllShardKeys.ContainsKey(deviceFileName) == true) { listMark.Add(memberShardInfo.dicAllShardKeys[deviceFileName]); } @@ -792,47 +1317,90 @@ foreach (var sceneUI in listSceneUI) { //绉婚櫎缂撳瓨 - roomTemp.SceneUIFilePathList.Remove(sceneUI.FileName); + roomTemp.ListSceneId.Remove(sceneUI.Id); //鍏朵粬鍦烘櫙杩樺祵濂楃潃杩欎釜鍦烘櫙,鎵�浠ヤ笉鍒犻櫎杩欎釜鍦烘櫙鐨勬牴婧愭枃浠�,鍙槸鎶婃埧闂寸殑鍦烘櫙鍒楄〃璺緞绉婚櫎 //浣嗘槸瀹冪粦瀹氱殑璁惧鐩爣瑕佸垹闄� - if (listHadShard.Contains(sceneUI.FileName) == true) + if (listHadShardKeys.Contains(sceneUI.Id.ToString()) == true) { - listDeleteFileEx.Add(sceneUI.FileName); + continue; } - else + //鑾峰彇瑕佸垹闄ょ殑鍒嗕韩涓婚敭 + if (memberShardInfo.dicAllShardKeys.ContainsKey(sceneUI.FileName) == true) { - //鑾峰彇瑕佸垹闄ょ殑鍒嗕韩涓婚敭 - if (dicShardFile.Contains(sceneUI.FileName) == true) + listMark.Add(memberShardInfo.dicAllShardKeys[sceneUI.FileName]); + } + listDeleteFile.Add(sceneUI.FileName); + + //鍒犻櫎鑷畾涔夊浘鐗�,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰� + if (sceneUI.IconPathType != 0) + { + string[] Arry = sceneUI.IconPath.Split(new string[] { "/" }, StringSplitOptions.RemoveEmptyEntries); + string sceneFile = Arry[Arry.Length - 1]; + listDeleteFile.Add(sceneFile); + if (memberShardInfo.dicAllShardKeys.ContainsKey(sceneFile) == true) { - listMark.Add(memberShardInfo.dicAllShardKeys[sceneUI.FileName]); + listMark.Add(memberShardInfo.dicAllShardKeys[sceneFile]); } - listDeleteFile.Add(sceneUI.FileName); } //鎵ц鍒犻櫎宓屽鐨勮澶� - var listTemp = new HashSet<string>(); - this.GetSceneBindFileName(sceneUI, ref listTemp); - foreach (var fileName in listTemp) + var dicDeviceKeys = new Dictionary<string, string>(); + var listBindScene = new List<SceneUI>(); + this.GetSceneBindListKeys(sceneUI, ref dicDeviceKeys, ref listBindScene); + //璁惧鐨� + foreach (var myKeys in dicDeviceKeys.Keys) { - if (listHadShard.Contains(fileName) == true) + if (listHadShardKeys.Contains(myKeys) == true) { continue; } //鑾峰彇瑕佸垹闄ょ殑鍒嗕韩涓婚敭 - if (dicShardFile.Contains(fileName) == true) + string fileName = dicDeviceKeys[myKeys]; + if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == true) { listMark.Add(memberShardInfo.dicAllShardKeys[fileName]); } listDeleteFile.Add(fileName); } + //鍦烘櫙鐨� + foreach (var seceUi in listBindScene) + { + if (seceUi.IconPathType != 0) + { + //鍒犻櫎鑷畾涔夊満鏅浘鐗�,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰� + string[] Arry = seceUi.IconPath.Split(new string[] { "/" }, StringSplitOptions.RemoveEmptyEntries); + string sceneFile = Arry[Arry.Length - 1]; + listDeleteFile.Add(sceneFile); + if (memberShardInfo.dicAllShardKeys.ContainsKey(sceneFile) == true) + { + listMark.Add(memberShardInfo.dicAllShardKeys[sceneFile]); + } + } + } } //濡傛灉杩欎釜鎴块棿鐨勫垎浜澶囧拰鍦烘櫙鍏ㄩ儴鍒犻櫎鐨勮瘽,鎶婂垎浜埧闂存枃浠朵篃涓�璧峰垹闄� - if (roomTemp.DeviceUIFilePathList.Count == 0 && roomTemp.SceneUIFilePathList.Count == 0) + if (roomTemp.ListDevice.Count == 0 && roomTemp.ListSceneId.Count == 0) { - listMark.Add(memberShardInfo.dicAllShardKeys[nowRoom.FileName]); + //鎴块棿鍒犻櫎 + if (memberShardInfo.dicAllShardKeys.ContainsKey(nowRoom.FileName) == true) + { + listMark.Add(memberShardInfo.dicAllShardKeys[nowRoom.FileName]); + } listDeleteFile.Add(nowRoom.FileName); + + if (nowRoom.BackgroundImageType != 0) + { + //鍒犻櫎鑷畾涔夋埧闂村浘鐗�,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰� + string[] Arry = nowRoom.BackgroundImage.Split(new string[] { "/" }, StringSplitOptions.RemoveEmptyEntries); + string roomFile = Arry[Arry.Length - 1]; + listDeleteFile.Add(roomFile); + if (memberShardInfo.dicAllShardKeys.ContainsKey(roomFile) == true) + { + listMark.Add(memberShardInfo.dicAllShardKeys[roomFile]); + } + } } //鎵ц绉婚櫎鍒嗕韩鏁版嵁 @@ -840,28 +1408,38 @@ //鍚屾鎴块棿鏂囦欢 if (result == true && listDeleteFile.Contains(roomTemp.FileName) == false) { - //鎵ц涓婁紶瀵硅薄 + //鎵ц涓婁紶鎴块棿瀵硅薄 result = await this.DoUploadRoomObject(memberShardInfo, roomTemp); } - if (result == true) + //鍚屾妤煎眰鏁版嵁 + if (result == true && listDeleteFile.Contains(roomTemp.FileName) == true) { - foreach (var exFile in listDeleteFileEx) + int floorCount = 0; + foreach (var myRoom in memberShardInfo.dicShardRoom.Values) { - //鍙Щ闄ょ紦瀛�,涓嶅垹闄や簯绔� - if (dicShardFile.Contains(exFile) == true) + //2020.03.24杩藉姞:涓嶈兘鏄嚜韬埧闂� + if (myRoom.FloorId == roomTemp.FloorId && myRoom.Id != roomTemp.Id) { - dicShardFile.Remove(exFile); + floorCount++; } } + if (floorCount == 0) + { + //濡傛灉璇ユゼ灞傚凡缁忓垹瀹屾埧闂翠簡,鍒欐洿鏂版ゼ灞� + memberShardInfo.dicShardFloor.Remove(roomTemp.FloorId); + //鎵ц涓婁紶瀵硅薄 + result = await this.DoUploadFloorObject(memberShardInfo); + } } - else + + if (result == false) { //鎭㈠ - roomTemp.DeviceUIFilePathList.Clear(); - roomTemp.DeviceUIFilePathList.AddRange(listBackDevice); + roomTemp.ListDevice.Clear(); + roomTemp.ListDevice.AddRange(listBackDevice); - roomTemp.SceneUIFilePathList.Clear(); - roomTemp.SceneUIFilePathList.AddRange(listBackScene); + roomTemp.ListSceneId.Clear(); + roomTemp.ListSceneId.AddRange(listBackScene); } return result; } @@ -909,8 +1487,6 @@ } //鍏抽棴杩涘害鏉� ProgressBar.Close(); - - var dicShard = memberShardInfo.dicAllMemberShard[nowRoom.FileName]; for (int i = 0; i < listDeleteFile.Count; i++) { string fileName = listDeleteFile[i]; @@ -918,16 +1494,50 @@ { //鏈�鍚庝竴涓浐瀹氬彲鑳芥槸鎴块棿鏂囦欢,鐩存帴绉婚櫎鏁翠釜瀵硅薄 memberShardInfo.dicShardRoom.Remove(fileName); - memberShardInfo.dicAllMemberShard.Remove(fileName); - } - else - { - //绉婚櫎鎸囧畾鏂囦欢 - dicShard.Remove(fileName); } memberShardInfo.dicAllShardKeys.Remove(fileName); - HdlShardLogic.Current.DeleteShardFile(fileName); + this.DeleteShardFile(fileName); + } + return true; + } + + /// <summary> + /// 鎵ц绉婚櫎鍒嗕韩鏁版嵁 + /// </summary> + /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜唴瀹�</param> + /// <param name="listDelFile">鍒犻櫎鐨勬枃浠�</param> + /// <returns></returns> + private async Task<bool> DoDeleteSharedContent(MemberShardInfoData memberShardInfo, List<string> listDelFile) + { + if (listDelFile.Count == 0) + { + return true; + } + + var info = new DeleteShardInfo(); + foreach (var fileName in listDelFile) + { + if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == false) + { + //鎴戜篃涓嶇煡閬撲负浠�涔堜細鎵句笉鍒颁富閿� + continue; + } + + info.DistributedMark = memberShardInfo.dicAllShardKeys[fileName]; + //鎵ц鍒犻櫎 + var result = await UserCenterLogic.GetResultStatuByRequestHttps("ZigbeeDataShare/DeleteShareData", false, info); + if (result == false) + { + return false; + } + } + for (int i = 0; i < listDelFile.Count; i++) + { + string fileName = listDelFile[i]; + memberShardInfo.dicAllShardKeys.Remove(fileName); + + this.DeleteShardFile(fileName); } return true; } @@ -944,6 +1554,10 @@ /// <returns></returns> private async Task<bool> DoUploadRoomObject(MemberShardInfoData memberShardInfo, Common.Room upDateRoom) { + if (upDateRoom.Id == "Other") + { + return true; + } var info = new EditorShardContent(); info.DistributedMark = memberShardInfo.dicAllShardKeys[upDateRoom.FileName]; info.ShareName = upDateRoom.FileName; @@ -958,7 +1572,37 @@ return false; } //灏嗘埧闂村璞″簭鍒楀寲鍒扮紦瀛� - HdlShardLogic.Current.AddShardFile(upDateRoom); + this.AddShardFile(upDateRoom); + + return true; + } + + #endregion + + #region 鈻� 涓婁紶妤煎眰瀵硅薄_______________________ + + /// <summary> + /// 涓婁紶妤煎眰瀵硅薄 + /// </summary> + /// <param name="memberShardInfo">鎴愬憳鐨勫叡浜唴瀹�</param> + /// <returns></returns> + private async Task<bool> DoUploadFloorObject(MemberShardInfoData memberShardInfo) + { + var info = new EditorShardContent(); + info.DistributedMark = memberShardInfo.dicAllShardKeys[DirNameResourse.ShardFloorFile]; + info.ShareName = DirNameResourse.ShardFloorFile; + info.SubAccountDistributedMark = memberShardInfo.SubAccountDistributedMark; + + var data = Newtonsoft.Json.JsonConvert.SerializeObject(memberShardInfo.dicShardFloor); + var byteData = System.Text.Encoding.UTF8.GetBytes(data); + info.ShareDataBytes = byteData; + var result = await UserCenterLogic.GetResultStatuByRequestHttps("ZigbeeDataShare/EditShareData", false, info); + if (result == false) + { + return false; + } + //灏嗘埧闂村璞″簭鍒楀寲鍒扮紦瀛� + this.AddShardFile(memberShardInfo.dicShardFloor); return true; } @@ -968,104 +1612,144 @@ #region 鈻� 绉婚櫎鍏变韩鐨勪竴鑸柟娉昣________________ /// <summary> - /// 浠庣紦瀛樺瓧鍏镐腑鑾峰彇宸茬粡鍒嗕韩浜嗙殑鍏ㄩ儴璁惧鏂囦欢鍜屽満鏅殑鏂囦欢鍚嶅瓧 + /// 浠庣紦瀛樺瓧鍏镐腑鑾峰彇宸茬粡鍒嗕韩浜嗙殑鍏ㄩ儴璁惧涓婚敭鍜屽満鏅殑ID /// </summary> /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜俊鎭�</param> /// <param name="nowRoom">褰撳墠鎴块棿</param> /// <param name="listDeleteDevice">瑕佸垹闄ょ殑璁惧鍒楄〃</param> /// <param name="listDeleteScene">瑕佸垹闄ょ殑鍦烘櫙鍒楄〃</param> /// <returns></returns> - private HashSet<string> GetAllShardedFileNameFromDictionary(MemberShardInfoData memberShardInfo, Common.Room nowRoom, + private HashSet<string> GetAllShardedKeysFromDictionary(MemberShardInfoData memberShardInfo, Common.Room nowRoom, List<CommonDevice> listDeleteDevice, List<Common.SceneUI> listDeleteScene) { //鑾峰彇鍏ㄩ儴瑕佸垹闄ょ殑鏂囦欢鍚嶅瓧 - var listDeleteFile = new HashSet<string>(); + var dicDeleteDeviceFile = new Dictionary<string, string>(); foreach (var device in listDeleteDevice) { - listDeleteFile.Add(device.FilePath); + dicDeleteDeviceFile[LocalDevice.Current.GetDeviceMainKeys(device)] = device.FilePath; } + var dicDeleteSceneFile = new Dictionary<int, string>(); foreach (var scene in listDeleteScene) { - listDeleteFile.Add(scene.FileName); + dicDeleteSceneFile[scene.Id] = scene.FileName; } - var listShardFile = new HashSet<string>(); - //鑾峰彇杩樺浜庡垎浜姸鎬佺殑鏂囦欢 + var listShardKeys = new HashSet<string>(); + //鑾峰彇杩樺浜庡垎浜姸鎬佺殑涓婚敭 foreach (var roomTemp in memberShardInfo.dicShardRoom.Values) { - bool flage = roomTemp.FileName == nowRoom.FileName; //璁惧 - foreach (var deviceUi in roomTemp.DeviceUIFilePathList) + foreach (var deviceKeys in roomTemp.ListDevice) { - string deviceFile = deviceUi.Replace("DeviceUI_", string.Empty); - if (flage == true && listDeleteFile.Contains(deviceFile) == true) + if (dicDeleteDeviceFile.ContainsKey(deviceKeys) == true) { - //褰撳墠鎴块棿鐨勮鐗规畩澶勭悊锛屽鏋滄槸鍒犻櫎鐩爣锛屽垯涓嶆坊鍔� + //鍥犱负涓�涓洖璺彧鑳藉垎閰嶄竴涓尯鍩�,鎵�浠ュ彲浠ョ洿鎺ュ垽鏂� continue; } - if (listShardFile.Contains(deviceFile) == false) + if (listShardKeys.Contains(deviceKeys) == false) { - listShardFile.Add(deviceFile); + //杩欎釜鏂囦欢杩樺垎浜潃 + listShardKeys.Add(deviceKeys); } + } //鍦烘櫙 - foreach (var scene in roomTemp.SceneUIList) + foreach (var sceneId in roomTemp.ListSceneId) { - if (roomTemp.SceneUIFilePathList.Contains(scene.FileName) == false) + if (roomTemp.FileName == nowRoom.FileName) { - //杩欎釜鍦烘櫙宸茬粡琚垹闄� - continue; - } - if (flage == true && listDeleteFile.Contains(scene.FileName) == true) - { - //褰撳墠鎴块棿鐨勮鐗规畩澶勭悊锛屽鏋滄槸鍒犻櫎鐩爣锛屽垯涓嶆坊鍔� - continue; - } - //鑾峰彇鍦烘櫙閲岄潰鐨勫叏閮ㄧ洰鏍� - var listTemp = new HashSet<string>(); - this.GetSceneBindFileName(scene, ref listTemp); - - if (listShardFile.Contains(scene.FileName) == false) - { - //鍦烘櫙鑷韩鐨勬枃浠� - listShardFile.Add(scene.FileName); - } - foreach (string file in listTemp) - { - if (listShardFile.Contains(file) == false) + //濡傛灉寰幆鍒颁簡褰撳墠鎴块棿 + if (dicDeleteSceneFile.ContainsKey(sceneId) == true) { - listShardFile.Add(file); + //濡傛灉鏄垹闄ょ洰鏍囷紝鍒欎笉娣诲姞 + continue; + } + } + var byteData = this.GetShardFileContent($"Scene_{sceneId}.json"); + if (byteData == null) + { + continue; + } + string valueData = System.Text.Encoding.UTF8.GetString(byteData); + var sceneTemp = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.SceneUI>(valueData); + + //鑾峰彇鍦烘櫙閲岄潰鐨勫叏閮ㄧ洰鏍� + var listTempKeys = new HashSet<string>(); + //浠庡満鏅璞¢噷闈㈣幏鍙栧叏閮ㄧ殑缁戝畾鐩爣鐨勪富閿�(杩欓噷闈㈢殑涓滆タ蹇呴』浠庡垎浜暟鎹腑鑾峰彇) + this.GetSceneBindListKeys(sceneTemp, ref listTempKeys); + + if (listShardKeys.Contains(sceneId.ToString()) == false) + { + //鍦烘櫙鑷韩 + listShardKeys.Add(sceneId.ToString()); + } + foreach (string myKeys2 in listTempKeys) + { + if (listShardKeys.Contains(myKeys2) == false) + { + listShardKeys.Add(myKeys2); } } } } - return listShardFile; + return listShardKeys; } /// <summary> - /// 浠庡満鏅璞¢噷闈㈣幏鍙栧叏閮ㄧ殑缁戝畾鐩爣鐨勬枃浠跺悕瀛� + /// 浠庡満鏅璞¢噷闈㈣幏鍙栧叏閮ㄧ殑缁戝畾鐩爣鐨勪富閿�(杩欓噷闈㈢殑涓滆タ蹇呴』浠庡垎浜暟鎹腑鑾峰彇) /// </summary> /// <param name="scene">鍦烘櫙</param> - /// <param name="listFile">鏂囦欢鍒楄〃(閲岄潰瀛樼殑鏄澶嘦I鏂囦欢鍜岃澶囨枃浠跺拰鍦烘櫙鏂囦欢)</param> - private void GetSceneBindFileName(Common.SceneUI scene, ref HashSet<string> listFile) + /// <param name="dicDeviceKeys">璁惧涓婚敭鍒楄〃(閲岄潰娌℃湁鍦烘櫙),keys:涓婚敭,value:鏂囦欢鍚�</param> + /// <param name="listBindScene">缁戝畾鐨勫満鏅璞�</param> + private void GetSceneBindListKeys(Common.SceneUI scene, ref Dictionary<string, string> dicDeviceKeys, ref List<SceneUI> listBindScene) { - foreach (var data in scene.AddSceneMemberDataList) + foreach (var data in scene.AdjustTargetList) { //璁惧 if (data.Type == 0) { - var device = Common.LocalDevice.Current.GetDevice(data.DeviceAddr, data.Epoint); - if (device != null&& listFile.Contains(device.FilePath) == false) + string mainkey = LocalDevice.Current.GetDeviceMainKeys(data.DeviceAddr, data.Epoint); + if (dicShardDeviceFile.ContainsKey(mainkey) == true && dicDeviceKeys.ContainsKey(mainkey) == false) { - listFile.Add(device.FilePath); + dicDeviceKeys[mainkey] = dicShardDeviceFile[mainkey]; } } if (data.Type == 1) { - var sceneTemp = Room.CurrentRoom.GetSceneUIBySceneId(data.ElseScenesId); - if (sceneTemp != null && listFile.Contains(sceneTemp.FileName)) + var byteData = this.GetShardFileContent($"Scene_{data.ElseScenesId}.json"); + if (byteData != null) { - listFile.Add(sceneTemp.FileName); + string valueData = System.Text.Encoding.UTF8.GetString(byteData); + var sceneTemp = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.SceneUI>(valueData); + listBindScene.Add(sceneTemp); + } + } + } + } + + /// <summary> + /// 浠庡満鏅璞¢噷闈㈣幏鍙栧叏閮ㄧ殑缁戝畾鐩爣鐨勪富閿�(杩欓噷闈㈢殑涓滆タ蹇呴』浠庡垎浜暟鎹腑鑾峰彇) + /// </summary> + /// <param name="scene">鍦烘櫙</param> + /// <param name="listKeys">涓婚敭鍒楄〃(璁惧鍜屽満鏅�)</param> + private void GetSceneBindListKeys(Common.SceneUI scene, ref HashSet<string> listKeys) + { + foreach (var data in scene.AdjustTargetList) + { + //璁惧 + if (data.Type == 0) + { + string mainkey = LocalDevice.Current.GetDeviceMainKeys(data.DeviceAddr, data.Epoint); + if (listKeys.Contains(mainkey) == false) + { + listKeys.Add(mainkey); + } + } + if (data.Type == 1) + { + if (listKeys.Contains(data.ElseScenesId.ToString()) == false) + { + listKeys.Add(data.ElseScenesId.ToString()); } } } @@ -1144,6 +1828,20 @@ public string SubAccountDistributedMark = string.Empty; } + /// <summary> + /// 鎺ユ敹鍒嗕韩鏁版嵁 + /// </summary> + private class ReceiveShardInfoResult + { + /// <summary> + /// 鏂囦欢鍚嶅瓧 + /// </summary> + public string ShareName = string.Empty; + /// <summary> + /// 涓婚敭 + /// </summary> + public string DistributedMark = string.Empty; + } #endregion } -- Gitblit v1.8.0