From ade5917841b0fdcb1df7353ef7c56b1a1bdc9282 Mon Sep 17 00:00:00 2001 From: 黄学彪 <hxb@hdlchina.com.cn> Date: 星期二, 22 九月 2020 10:03:32 +0800 Subject: [PATCH] 删除 Gateway.Ios文件 --- ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/UserCenterLogic.cs | 1330 +++++++++++++++++++++++++++++++++------------------------ 1 files changed, 768 insertions(+), 562 deletions(-) diff --git a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/UserCenterLogic.cs b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/UserCenterLogic.cs index b6ea067..daed4fb 100755 --- a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/UserCenterLogic.cs +++ b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/UserCenterLogic.cs @@ -2,8 +2,6 @@ using Shared.Common; using Newtonsoft.Json; using Shared.Common.ResponseEntity; -using System.Threading.Tasks; -using System.Text.RegularExpressions; using System.Collections.Generic; using System.Text; @@ -23,23 +21,35 @@ /// <param name="RequestName">璁块棶鍦板潃</param> /// <param name="checkAuthority">鏄惁妫�娴嬫潈闄愶紝璇ュ弬鏁颁笉鑳界渷鐣�</param> /// <param name="obj">涓�涓被</param> - /// <param name="listNotShowError"> - /// <pra>涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�),濡傛灉鍖呭惈锛屽垯浼氳繑鍥炪�恡rue銆�</pra> - /// <pra>濡傛灉鎸囧畾鏈塏otSetAgain,鍒欎笉浜屾鍙戦��(姣斿鏂綉),鐒跺悗杩斿洖銆恌alse銆�</pra> - /// </param> - public static async Task<bool> GetResultStatuByRequestHttps(string RequestName, bool checkAuthority, object obj, List<string> listNotShowError = null) + /// <param name="listNotShowError">涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�),濡傛灉鍖呭惈锛屽垯浼氳繑鍥炪�恡rue銆�</param> + /// <param name="setAgain">褰撳彂閫佸け璐ユ椂,鏄惁閲嶅彂,榛樿涓嶉噸鍙�</param> + public static bool GetResultStatuByRequestHttps(string RequestName, bool checkAuthority, object obj, List<string> listNotShowError = null, bool setAgain = false) { + if (HdlWifiLogic.Current.CanAccessHttp == false && setAgain == false) + { + //褰撳墠鏃犳硶璁块棶缃戠粶(褰撻渶瑕侀噸鏂板彂閫佹椂,璺宠繃杩欎釜鍒ゆ柇) + ShowNotNetMsg(listNotShowError); + return false; + } + //妫�娴嬫槸鍚﹀凡缁忓畬鎴愯处鍙蜂俊鎭垵濮嬪寲 + if (UserCenterResourse.UserInfo.InitUserInfoSuccess == false) + { + //涓嶇缁撴灉鎬庝箞鏍�,濡傛灉璋冪敤浜嗚繖涓嚱鏁�,闇�瑕侀噸澶磋幏鍙朤oken,鎵�浠ュ繀椤昏繑鍥炲け璐� + ReInitUserAccoutInfo(listNotShowError); + return false; + } //鑾峰彇鎺ュ彛鐨勮繛鎺ユā寮� var connectMode = GetHttpConnectMode(checkAuthority); //鑾峰彇浠庢帴鍙i偅閲屽彇鍒扮殑姣旂壒鏁版嵁 - var byteData = await GettByteResponsePack(RequestName, connectMode, obj); - if (byteData == null) + var byteData = GettByteResponsePack(RequestName, connectMode, obj); + if (byteData == null && setAgain == true) { - if (listNotShowError != null && listNotShowError.Contains("NotSetAgain") == true) + if (setAgain == false) { + //涓嶆寚瀹氶噸鍙� return false; } - byteData = await ResetByteRequestHttps(RequestName, checkAuthority, obj); + byteData = ResetByteRequestHttps(RequestName, checkAuthority, obj); if (byteData == null) { return false; @@ -47,7 +57,7 @@ } var revertObj = JsonConvert.DeserializeObject<ResponsePack>(Encoding.UTF8.GetString(byteData)); //妫�娴嬫槸鍚﹀瓨鍦ㄩ敊璇俊鎭� - return CheckNotEorrorMsg(revertObj, RequestName, listNotShowError); + return CheckNotEorrorMsg(revertObj, RequestName, listNotShowError, obj); } /// <summary> @@ -57,29 +67,47 @@ /// <param name="RequestName">璁块棶鍦板潃</param> /// <param name="checkAuthority">鏄惁妫�娴嬫潈闄愶紝璇ュ弬鏁颁笉鑳界渷鐣�</param> /// <param name="obj">涓�涓被</param> - /// <param name="listNotShowError"> - /// <pra>涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�),濡傛灉鍖呭惈锛屽垯浼氳繑鍥炪�怱uccess銆�</pra> - /// <pra>濡傛灉鎸囧畾鏈塏otSetAgain,鍒欎笉浜屾鍙戦��(姣斿鏂綉),鐒跺悗杩斿洖銆怑rrorEx銆�</pra> + /// <param name="listNotShowError">涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�),濡傛灉鍖呭惈锛屽垯浼氳繑鍥炪�恡rue銆�</param> + /// <param name="setAgain">褰撳彂閫佸け璐ユ椂,鏄惁閲嶅彂,榛樿涓嶉噸鍙�</param> /// </param> - public static async Task<string> GetResultCodeByRequestHttps(string RequestName, bool checkAuthority, object obj, List<string> listNotShowError = null) + public static string GetResultCodeByRequestHttps(string RequestName, bool checkAuthority, object obj, List<string> listNotShowError = null, bool setAgain = false) { + if (HdlWifiLogic.Current.CanAccessHttp == false && setAgain == false) + { + //褰撳墠鏃犳硶璁块棶缃戠粶(褰撻渶瑕侀噸鏂板彂閫佹椂,璺宠繃杩欎釜鍒ゆ柇) + ShowNotNetMsg(listNotShowError); + return "Error"; + } + //妫�娴嬫槸鍚﹀凡缁忓畬鎴愯处鍙蜂俊鎭垵濮嬪寲 + if (UserCenterResourse.UserInfo.InitUserInfoSuccess == false) + { + //涓嶇缁撴灉鎬庝箞鏍�,濡傛灉璋冪敤浜嗚繖涓嚱鏁�,闇�瑕侀噸澶磋幏鍙朤oken,鎵�浠ュ繀椤昏繑鍥炲け璐� + ReInitUserAccoutInfo(listNotShowError); + return "Error"; + } + //鑾峰彇鎺ュ彛鐨勮繛鎺ユā寮� var connectMode = GetHttpConnectMode(checkAuthority); //鑾峰彇浠庢帴鍙i偅閲屽彇鍒扮殑姣旂壒鏁版嵁 - var byteData = await GettByteResponsePack(RequestName, connectMode, obj); + var byteData = GettByteResponsePack(RequestName, connectMode, obj); if (byteData == null) { - if (listNotShowError != null && listNotShowError.Contains("NotSetAgain") == true) + if (setAgain == false) { - return "ErrorEx"; + //涓嶆寚瀹氶噸鍙� + return "Error"; } - byteData = await ResetByteRequestHttps(RequestName, checkAuthority, obj); + byteData = ResetByteRequestHttps(RequestName, checkAuthority, obj); if (byteData == null) { return "Error"; } } var revertObj = JsonConvert.DeserializeObject<ResponsePack>(Encoding.UTF8.GetString(byteData)); + if (revertObj == null) + { + return "Error"; + } return revertObj.StateCode; } @@ -90,23 +118,36 @@ /// <param name="RequestName">璁块棶鍦板潃</param> /// <param name="checkAuthority">鏄惁妫�娴嬫潈闄愶紝璇ュ弬鏁颁笉鑳界渷鐣�</param> /// <param name="obj">涓�涓被</param> - /// <param name="listNotShowError"> - /// <pra>涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�),濡傛灉鍖呭惈锛屽垯浼氳繑鍥炵┖瀛楃涓�</pra> - /// <pra>濡傛灉鎸囧畾鏈塏otSetAgain,鍒欎笉浜屾鍙戦��(姣斿鏂綉),鐒跺悗杩斿洖绌哄瓧绗︿覆</pra> + /// <param name="listNotShowError">涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�),濡傛灉鍖呭惈锛屽垯浼氳繑鍥炪�恡rue銆�</param> + /// <param name="setAgain">褰撳彂閫佸け璐ユ椂,鏄惁閲嶅彂,榛樿涓嶉噸鍙�</param> /// </param> - public static async Task<string> GetResponseDataByRequestHttps(string RequestName, bool checkAuthority, object obj, List<string> listNotShowError = null) + public static string GetResponseDataByRequestHttps(string RequestName, bool checkAuthority, object obj, List<string> listNotShowError = null, bool setAgain = false) { + if (HdlWifiLogic.Current.CanAccessHttp == false && setAgain == false) + { + //褰撳墠鏃犳硶璁块棶缃戠粶(褰撻渶瑕侀噸鏂板彂閫佹椂,璺宠繃杩欎釜鍒ゆ柇) + ShowNotNetMsg(listNotShowError); + return null; + } + //妫�娴嬫槸鍚﹀凡缁忓畬鎴愯处鍙蜂俊鎭垵濮嬪寲 + if (UserCenterResourse.UserInfo.InitUserInfoSuccess == false) + { + //涓嶇缁撴灉鎬庝箞鏍�,濡傛灉璋冪敤浜嗚繖涓嚱鏁�,闇�瑕侀噸澶磋幏鍙朤oken,鎵�浠ュ繀椤昏繑鍥炲け璐� + ReInitUserAccoutInfo(listNotShowError); + return null; + } //鑾峰彇鎺ュ彛鐨勮繛鎺ユā寮� var connectMode = GetHttpConnectMode(checkAuthority); //鑾峰彇浠庢帴鍙i偅閲屽彇鍒扮殑姣旂壒鏁版嵁 - var byteData = await GettByteResponsePack(RequestName, connectMode, obj); + var byteData = GettByteResponsePack(RequestName, connectMode, obj); if (byteData == null) { - if (listNotShowError != null && listNotShowError.Contains("NotSetAgain") == true) + if (setAgain == false) { - return string.Empty; + //涓嶆寚瀹氶噸鍙� + return null; } - byteData = await ResetByteRequestHttps(RequestName, checkAuthority, obj); + byteData = ResetByteRequestHttps(RequestName, checkAuthority, obj); if (byteData == null) { return null; @@ -114,14 +155,14 @@ } var revertObj = JsonConvert.DeserializeObject<ResponsePack>(Encoding.UTF8.GetString(byteData)); //妫�娴嬮敊璇� - bool notError = CheckNotEorrorMsg(revertObj, RequestName, listNotShowError); + bool notError = CheckNotEorrorMsg(revertObj, RequestName, listNotShowError, obj); if (notError == false) { return null; } if (revertObj == null || revertObj.ResponseData == null) { - return string.Empty; + return null; } return revertObj.ResponseData.ToString(); } @@ -133,25 +174,36 @@ /// <param name="RequestName">璁块棶鍦板潃</param> /// <param name="checkAuthority">鏄惁妫�娴嬫潈闄愶紝璇ュ弬鏁颁笉鑳界渷鐣�</param> /// <param name="obj">涓�涓被</param> - /// <param name="listNotShowError"> - /// <pra>涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�),濡傛灉鍖呭惈锛屽垯浼氳繑鍥炵┖瀛楃涓�</pra> - /// <pra>濡傛灉鎸囧畾鏈塏otSetAgain,鍒欎笉浜屾鍙戦��(姣斿鏂綉),鐒跺悗杩斿洖null</pra> - /// </param> - public static async Task<byte[]> GetByteResponseDataByRequestHttps(string RequestName, bool checkAuthority, object obj, List<string> listNotShowError = null) + /// <param name="listNotShowError">涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�),濡傛灉鍖呭惈锛屽垯浼氳繑鍥炪�恡rue銆�</param> + /// <param name="setAgain">褰撳彂閫佸け璐ユ椂,鏄惁閲嶅彂,榛樿涓嶉噸鍙�</param> + public static byte[] GetByteResponseDataByRequestHttps(string RequestName, bool checkAuthority, object obj, List<string> listNotShowError = null, bool setAgain = false) { + if (HdlWifiLogic.Current.CanAccessHttp == false && setAgain == false) + { + //褰撳墠鏃犳硶璁块棶缃戠粶(褰撻渶瑕侀噸鏂板彂閫佹椂,璺宠繃杩欎釜鍒ゆ柇) + ShowNotNetMsg(listNotShowError); + return null; + } + //妫�娴嬫槸鍚﹀凡缁忓畬鎴愯处鍙蜂俊鎭垵濮嬪寲 + if (UserCenterResourse.UserInfo.InitUserInfoSuccess == false) + { + //涓嶇缁撴灉鎬庝箞鏍�,濡傛灉璋冪敤浜嗚繖涓嚱鏁�,闇�瑕侀噸澶磋幏鍙朤oken,鎵�浠ュ繀椤昏繑鍥炲け璐� + ReInitUserAccoutInfo(listNotShowError); + return null; + } //鑾峰彇鎺ュ彛鐨勮繛鎺ユā寮� var connectMode = GetHttpConnectMode(checkAuthority); //鑾峰彇浠庢帴鍙i偅閲屽彇鍒扮殑姣旂壒鏁版嵁 - var revertObj = await GettByteResponsePack(RequestName, connectMode, obj); + var revertObj = GettByteResponsePack(RequestName, connectMode, obj); if (revertObj == null) { - if (listNotShowError != null && listNotShowError.Contains("NotSetAgain") == true) + if (setAgain == false) { + //涓嶆寚瀹氶噸鍙� return null; } - //閲嶆柊鍙戦�� - revertObj = await ResetByteRequestHttps(RequestName, checkAuthority, obj); + revertObj = ResetByteRequestHttps(RequestName, checkAuthority, obj); if (revertObj == null) { return null; @@ -165,7 +217,7 @@ var data = JsonConvert.DeserializeObject<ResponsePack>(data2); if (data != null && string.IsNullOrEmpty(data.StateCode) == false) { - bool notError = CheckNotEorrorMsg(data, RequestName, listNotShowError); + bool notError = CheckNotEorrorMsg(data, RequestName, listNotShowError, obj); if (notError == false) { return null; @@ -183,7 +235,7 @@ /// <param name="checkAuthority">鏄惁妫�娴嬫潈闄愶紝璇ュ弬鏁颁笉鑳界渷鐣�</param> /// <param name="obj">涓�涓被</param> /// <returns></returns> - private static async Task<byte[]> ResetByteRequestHttps(string RequestName, bool checkAuthority, object obj) + private static byte[] ResetByteRequestHttps(string RequestName, bool checkAuthority, object obj) { //鑾峰彇鎺ュ彛鐨勮繛鎺ユā寮� var connectMode = GetHttpConnectMode(checkAuthority); @@ -192,9 +244,9 @@ int count = 0; while (true) { - await Task.Delay(1000); + System.Threading.Thread.Sleep(1000); //璋冪敤鎺ュ彛 - responsePack = await GettByteResponsePack(RequestName, connectMode, obj); + responsePack = GettByteResponsePack(RequestName, connectMode, obj); if (responsePack != null) { break; @@ -202,13 +254,8 @@ count++; if (count == 3) { - Application.RunOnMainThread(() => - { - //缃戠粶涓嶇ǔ瀹�,璇风◢鍚庡啀璇� - string msg = Language.StringByID(R.MyInternationalizationString.uNetIsUnStabilityAndDoAgain); - var control = new ShowMsgControl(ShowMsgType.Tip, msg); - control.Show(); - }); + //鏄剧ず娌℃湁缃戠粶鐨凪sg + ShowNotNetMsg(null); break; } } @@ -222,7 +269,7 @@ /// <param name="RequestName">璁块棶鍦板潃</param> /// <param name="connectMode">鎺ュ彛鐨勮繛鎺ユā寮�</param> /// <param name="obj">涓�涓被</param> - private static async Task<byte[]> GettByteResponsePack(string RequestName, HttpConnectMode connectMode, object obj) + private static byte[] GettByteResponsePack(string RequestName, HttpConnectMode connectMode, object obj) { try { @@ -233,12 +280,12 @@ if (connectMode == HttpConnectMode.Normal) { //鏅�氳闂� - result = await CommonPage.Instance.RequestHttpsZigbeeBytesResultAsync(RequestName, Encoding.UTF8.GetBytes(requestJson)); + result = CommonPage.Instance.RequestHttpsZigbeeBytesResultAsync(RequestName, Encoding.UTF8.GetBytes(requestJson)); } else if (connectMode == HttpConnectMode.Admin) { //浠ョ鐞嗗憳鐨勮韩浠借闂紝鑷韩鏄垚鍛� - result = await CommonPage.Instance.RequestZigbeeHttpsByAdmin(RequestName, Encoding.UTF8.GetBytes(requestJson)); + result = CommonPage.Instance.RequestZigbeeHttpsByAdmin(RequestName, Encoding.UTF8.GetBytes(requestJson)); } return result; } @@ -256,17 +303,23 @@ /// <param name="revertObj">浠庢帴鍙f帴鏀跺埌鐨勬暟鎹�</param> /// <param name="RequestName">璇锋眰鎺ュ彛</param> /// <param name="listNotShowError">涓嶉渶瑕佹樉绀洪敊璇殑閿欒绫诲埆(鎺ュ彛杩斿洖鐨勯敊璇被鍒�)</param> - public static bool CheckNotEorrorMsg(ResponsePack revertObj, string RequestName, List<string> listNotShowError = null) + /// <param name="pra">璇锋眰鐨勫弬鏁�</param> + public static bool CheckNotEorrorMsg(ResponsePack revertObj, string RequestName, List<string> listNotShowError = null, object pra = null) { + if (listNotShowError != null && listNotShowError.Contains("NotCheck") == true) + { + //涓嶆娴� + return true; + } if (revertObj == null) { - Application.RunOnMainThread(() => + HdlThreadLogic.Current.RunMain(() => { //缃戠粶涓嶇ǔ瀹�,璇风◢鍚庡啀璇� string msg = Language.StringByID(R.MyInternationalizationString.uNetIsUnStabilityAndDoAgain); var control = new ShowMsgControl(ShowMsgType.Tip, msg); control.Show(); - }); + }, ShowErrorMode.NO); return false; } @@ -277,23 +330,26 @@ //涓嶆樉绀洪敊璇�,鐒跺悗杩斿洖true return true; } - Application.RunOnMainThread(() => + HdlThreadLogic.Current.RunMain(() => { - if (UserCenterLogic.IsAccountLoginOut() == true) + if (HdlCheckLogic.Current.IsAccountLoginOut() == true) { //濡傛灉鐢ㄦ埛宸茬粡閫�鍑轰簡鐧婚檰,鍒欎笉澶勭悊 return; } - string msg = IMessageCommon.Current.GetMsgByRequestName(RequestName, revertObj.StateCode); - var control = new ShowMsgControl(ShowMsgType.Tip, msg); - control.Show(); - - //鏃犳晥鐧诲綍Token - if (revertObj.StateCode == "NoLogin") + string msg = IMessageCommon.Current.GetMsgByRequestName(RequestName, revertObj, pra); + if (msg != null) { - UserCenterLogic.ReLoginAgain(Config.Instance.Account, false); + var control = new ShowMsgControl(ShowMsgType.Tip, msg); + control.Show(); + + //鏃犳晥鐧诲綍Token + if (revertObj.StateCode == "NoLogin") + { + ReLoginAgain(Config.Instance.Account, false); + } } - }); + }, ShowErrorMode.NO); return false; } @@ -305,17 +361,36 @@ /// </summary> /// <param name="checkAuthority">鏄惁妫�娴嬫潈闄�</param> /// <returns></returns> - private static HttpConnectMode GetHttpConnectMode(bool checkAuthority) + public static HttpConnectMode GetHttpConnectMode(bool checkAuthority) { if (checkAuthority == false) { return HttpConnectMode.Normal; } - if (Config.Instance.isAdministrator == true) + if (Config.Instance.Home.IsOthreShare == true) { return HttpConnectMode.Admin; } return HttpConnectMode.Normal; + } + + /// <summary> + /// 鏄剧ず娌℃湁缃戠粶鐨凪sg + /// </summary> + private static void ShowNotNetMsg(List<string> listNotShowError) + { + if (listNotShowError != null && listNotShowError.Contains("NotCheck") == true) + { + //涓嶆娴� + return; + } + HdlThreadLogic.Current.RunMain(() => + { + // 褰撳墠鏃犵綉缁滆繛鎺�,璇风‘璁ょ綉缁� + string msg = Language.StringByID(R.MyInternationalizationString.uNowIsDonotNetworkAndCheckNetwork); + var control = new ShowMsgControl(ShowMsgType.Tip, msg); + control.Show(); + }, ShowErrorMode.NO); } #endregion @@ -330,18 +405,17 @@ public static bool CheckCanAddForm(CommonFormBase form) { //鑾峰彇鐢婚潰鑻辨枃鍚嶅瓧 - string formName = GetFormName(form); + string formId = GetFormID(form); //浜岄噸杩藉姞涓嶅彲 - if (UserCenterResourse.DicActionForm.ContainsKey(formName) == false) + if (UserCenterResourse.DicActionForm.ContainsKey(formId) == false) { return true; } //鏆傛椂杩欐牱寮勭湅鐪嬶紝濡傛灉閲嶅锛屽垯鍏抽棴鎺夊師鏉ョ殑鐣岄潰 - var formTemp = UserCenterResourse.DicActionForm[formName]; + var formTemp = UserCenterResourse.DicActionForm[formId]; formTemp.CloseForm(); - UserCenterResourse.DicActionForm.Remove(formName); - formTemp = null; + UserCenterResourse.DicActionForm.Remove(formId); return true; } @@ -353,14 +427,14 @@ public static void AddActionForm(CommonFormBase form) { //鑾峰彇鐢婚潰鑻辨枃鍚嶅瓧 - string formName = GetFormName(form); + string formId = GetFormID(form); //浜岄噸杩藉姞涓嶅彲 - if (UserCenterResourse.DicActionForm.ContainsKey(formName) == false) + if (UserCenterResourse.DicActionForm.ContainsKey(formId) == false) { - form.FormID = formName; + form.FormID = formId; //鍐呭瓨娣诲姞 - UserCenterResourse.DicActionForm[formName] = form; + UserCenterResourse.DicActionForm[formId] = form; //娣诲姞鐢婚潰鏃讹紝瀹冭嚜韬氨鏄縺娲荤殑鐣岄潰 UserCenterResourse.NowActionFormID = form.FormID; @@ -371,65 +445,81 @@ /// <summary> /// 浠庡垪琛ㄤ腑绉婚櫎鐢婚潰 /// </summary> - /// <param name="form">Form</param> - public static void RemoveActionForm(CommonFormBase form) + /// <param name="i_closeForm">鍏抽棴鐨勭晫闈�</param> + public static void RemoveActionForm(CommonFormBase i_closeForm) { - //鑾峰彇鐢婚潰鑻辨枃鍚嶅瓧 - string formName = GetFormName(form); + //鑾峰彇鐢婚潰ID + string formId = GetFormID(i_closeForm); - if (UserCenterResourse.DicActionForm.ContainsKey(formName) == true) + if (UserCenterResourse.DicActionForm.ContainsKey(formId) == true) { - //鍒锋柊褰撳墠姝e湪鎿嶄綔鐨勭敾闈D - if (UserCenterResourse.NowActionFormID == UserCenterResourse.DicActionForm[formName].FormID) + //绉婚櫎ID + UserCenterResourse.listActionFormId.Remove(formId); + //绉婚櫎鐢婚潰 + UserCenterResourse.DicActionForm.Remove(formId); + //娓呯┖ + UserCenterResourse.NowActionFormID = string.Empty; + + var actionForm = UserView.HomePage.Instance.GetChildren(UserView.HomePage.Instance.ChildrenCount - 1); + if (actionForm == null) { - //鍚戝墠鎺ㄤ竴浣嶅嵆涓轰笅涓�涓縺娲荤殑鐣岄潰 - int index = UserCenterResourse.listActionFormId.IndexOf(UserCenterResourse.NowActionFormID) - 1; - //鍒濆鍊� - UserCenterResourse.NowActionFormID = string.Empty; - if (index >= 0) + return; + } + //濡傛灉鍏抽棴鐨勭晫闈㈡槸DialogCommonForm绫诲瀷,鍒欎笉闇�瑕佽Е鍙戞縺娲诲嚱鏁� + if (i_closeForm is DialogCommonForm) + { + if (actionForm is EditorCommonForm) { - var actionForm = UserView.HomePage.Instance.GetChildren(UserView.HomePage.Instance.ChildrenCount - 1); - if (actionForm != null && actionForm is CommonFormBase) + UserCenterResourse.NowActionFormID = GetFormID((EditorCommonForm)actionForm); + } + return; + } + //鍏抽棴鐨勭晫闈负EditorCommonForm鐨勬椂鍊� + else if ((i_closeForm is EditorCommonForm) && (actionForm is EditorCommonForm)) + { + //鎺ヤ笅鏉ユ縺娲荤殑鐣岄潰id + UserCenterResourse.NowActionFormID = GetFormID((CommonFormBase)actionForm); + try + { + var Myform = actionForm as EditorCommonForm; + //閲嶇疆宸︽粦浣胯兘 + Myform.ScrollEnabled = Myform.ScrollEnabled; + //瑙﹀彂鐣岄潰鍐嶆婵�娲荤殑浜嬩欢 + int value = Myform.FormActionAgainEvent(); + if (value == 1) { - //璁剧疆褰撳墠婵�娲荤殑鐢婚潰ID - UserCenterResourse.NowActionFormID = UserCenterResourse.listActionFormId[index]; - if (UserCenterResourse.DicActionForm.ContainsKey(UserCenterResourse.NowActionFormID) == true) - { - //瑙﹀彂鐣岄潰鍐嶆婵�娲荤殑浜嬩欢 - UserCenterResourse.DicActionForm[UserCenterResourse.NowActionFormID]?.FormActionAgainEvent(); - } - } - else if (actionForm != null && actionForm is UserView.UserPage) - { - //杩欓噷瀹冨凡缁忛��鍒颁富椤典簡,濡傛灉瀹冨寘鍚釜浜轰腑蹇冧富椤电殑璇� - if (UserCenterResourse.listActionFormId.Contains("UserMainForm") == true) - { - //璁剧疆褰撳墠婵�娲荤殑鐢婚潰ID - UserCenterResourse.NowActionFormID = UserCenterResourse.listActionFormId[index]; - if (UserCenterResourse.DicActionForm.ContainsKey(UserCenterResourse.NowActionFormID) == true) - { - //瑙﹀彂鐣岄潰鍐嶆婵�娲荤殑浜嬩欢 - UserCenterResourse.DicActionForm[UserCenterResourse.NowActionFormID]?.FormActionAgainEvent(); - } - } + //Log鍑哄姏 + HdlLogLogic.Current.WriteLog(1, Myform.FormID + " 琚縺娲�"); } } + catch (Exception ex) + { + //Log鍑哄姏 + HdlLogLogic.Current.WriteLog(ex, "鐣岄潰閲嶆柊婵�娲诲紓甯� " + UserCenterResourse.NowActionFormID); + } } - //绉婚櫎ID - UserCenterResourse.listActionFormId.Remove(UserCenterResourse.DicActionForm[formName].FormID); - //绉婚櫎鐢婚潰 - var formTemp = UserCenterResourse.DicActionForm[formName]; - UserCenterResourse.DicActionForm.Remove(formName); - formTemp = null; + else if (actionForm is UserView.UserPage) + { + //娓呯┖ + UserCenterResourse.NowActionFormID = string.Empty; + //杩欓噷瀹冨凡缁忛��鍒颁富椤典簡 + var nowForm = UserView.UserPage.Instance.GetNowActionForm(); + nowForm?.FormActionAgainEvent(); + } + else + { + //娓呯┖ + UserCenterResourse.NowActionFormID = string.Empty; + } } } /// <summary> - /// 鑾峰彇鐢婚潰鑻辨枃鍚嶅瓧 + /// 鑾峰彇鐢婚潰ID /// </summary> /// <returns>The form name.</returns> /// <param name="form">Form.</param> - public static string GetFormName(CommonFormBase form) + private static string GetFormID(CommonFormBase form) { if (form.FormID != string.Empty) { @@ -462,18 +552,8 @@ /// </summary> public static void RefreshAllMemory() { - //澶囦唤鐨勬暟鎹紝鏈夊彲鑳芥槸涓讳汉鑷繁涓婁紶鐨勶紝濡傛灉绠$悊鍛樼櫥闄嗘椂锛屼粬鑾峰彇鐨勫浠芥暟鎹湁鐐圭壒娈� - //姣斿涓嬮潰杩欎笁涓笢瑗垮湪涓昏处鍙烽偅閲屾槸涓嶉渶瑕佺殑 - bool isOthreShare = Config.Instance.Home.IsOthreShare; - int accountType = Config.Instance.Home.AccountType; - string mainMark = Config.Instance.Home.MainUserDistributedMark; - //杩樺師浣忓畢瀵硅薄 - Config.Instance.Home = House.GetHouseByHouseId(Config.Instance.Home.Id); - Config.Instance.Home.IsOthreShare = isOthreShare; - Config.Instance.Home.AccountType = accountType; - Config.Instance.Home.MainUserDistributedMark = mainMark; - Config.Instance.Home.Save(); - + //鍒锋柊浣忓畢瀵硅薄 + RefreshHomeObject(); //鍒锋柊鏈湴缃戝叧鏂囦欢 HdlGatewayLogic.Current.ReFreshByLocal(); //鍒锋柊鏈湴璁惧 @@ -481,7 +561,29 @@ //闇�浼樺厛浜庡埛鏂版埧闂�,鍚屾浜戠鐨勭綉鍏砳d锛屽鏋滄湰鍦版嫢鏈変簯绔笉瀛樺湪鐨刬d锛屽垯琛ㄧず搴旇琚崲缁戜簡锛岀洿鎺ュ垹闄� HdlGatewayLogic.Current.SynchronizeDbGateway(); //浠庢湰鍦伴噸鏂板姞杞藉叏閮ㄧ殑鎴块棿 - Common.Room.RefreshAllRoomByLocation(); + HdlRoomLogic.Current.RefreshAllRoomByLocation(); + } + + /// <summary> + /// 鍒锋柊浣忓畢瀵硅薄 + /// </summary> + public static void RefreshHomeObject() + { + //澶囦唤鐨勬暟鎹紝鏈夊彲鑳芥槸涓讳汉鑷繁涓婁紶鐨勶紝濡傛灉绠$悊鍛樼櫥闄嗘椂锛屼粬鑾峰彇鐨勫浠芥暟鎹湁鐐圭壒娈� + //姣斿涓嬮潰杩欎笁涓笢瑗垮湪涓昏处鍙烽偅閲屾槸涓嶉渶瑕佺殑 + bool isOthreShare = Config.Instance.Home.IsOthreShare; + int accountType = Config.Instance.Home.AccountType; + string mainMark = Config.Instance.Home.MainUserDistributedMark; + double Longitude = Config.Instance.Home.Longitude; + double Latitude = Config.Instance.Home.Latitude; + //杩樺師浣忓畢瀵硅薄 + Config.Instance.Home = HdlResidenceLogic.Current.GetHouseByHouseId(Config.Instance.Home.Id); + Config.Instance.Home.IsOthreShare = isOthreShare; + Config.Instance.Home.AccountType = accountType; + Config.Instance.Home.MainUserDistributedMark = mainMark; + Config.Instance.Home.Longitude = Longitude; + Config.Instance.Home.Latitude = Latitude; + Config.Instance.Home.Save(false); } #endregion @@ -494,7 +596,7 @@ /// <param name="all">true:鍏ㄩ儴鍒犻櫎(鐢ㄤ簬浣忓畢鍒犻櫎) false:閲嶈鐨勬枃浠朵笉鍒犻櫎</param> public static void DeleteAllLocationFile(bool all = true) { - string dPath = UserCenterResourse.LocalRootPath; + string dPath = Config.Instance.FullPath; if (System.IO.Directory.Exists(dPath) == false) { return; @@ -532,109 +634,12 @@ //涓嶈兘鍒犻櫎Config鏂囦欢 return true; } - else if (fileName.StartsWith("DeviceUI_") == true) - { - //涓嶈兘鍒犻櫎璁惧UI鏂囦欢 - return true; - } else if (fileName.StartsWith("House_") == true) { //涓嶈兘鍒犻櫎浣忓畢鏂囦欢 return true; } return false; - } - - #endregion - - #region 鈻� 鍚勭姝g‘妫�娴媉______________________ - - /// <summary> - /// 鍒ゆ柇鏄惁鍖呭惈澶у啓瀛楁瘝 - /// </summary> - /// <returns><c>true</c>, if contain upper was checked, <c>false</c> otherwise.</returns> - /// <param name="value">Value.</param> - public static bool CheckContainUpper(string value) - { - Regex reg = new Regex("[A-Z]+"); - return reg.IsMatch(value); - } - - /// <summary> - /// 鍒ゆ柇鏄惁鍖呭惈灏忓啓瀛楁瘝 - /// </summary> - /// <returns><c>true</c>, if contain lower was checked, <c>false</c> otherwise.</returns> - /// <param name="value">Value.</param> - public static bool CheckContainLower(string value) - { - Regex reg = new Regex("[a-z]+"); - return reg.IsMatch(value); - } - - /// <summary> - /// 鍒ゆ柇鏄惁鍖呭惈鏁板瓧 - /// </summary> - /// <returns><c>true</c>, if contain lower was checked, <c>false</c> otherwise.</returns> - /// <param name="value">Value.</param> - public static bool CheckContainNum(string value) - { - Regex reg = new Regex("[0-9]+"); - return reg.IsMatch(value); - } - - /// <summary> - /// 鍒ゆ柇鏄惁鍖呭惈绗﹀彿 - /// </summary> - /// <returns><c>true</c>, if contain lower was checked, <c>false</c> otherwise.</returns> - /// <param name="value">Value.</param> - public static bool CheckContainSymbol(string value) - { - Regex reg = new Regex("([^a-z0-9A-Z])+"); - return reg.IsMatch(value); - } - - /// <summary> - /// 妫�娴嬮偖绠辨槸鍚﹀悎娉� - /// </summary> - /// <param name="email"></param> - /// <returns></returns> - public static bool CheckEmail(string email) - { - Regex reg = new Regex(CommonPage.EmailRegexStr); - return reg.IsMatch(email); - } - - /// <summary> - /// 妫�娴嬫墜鏈哄彿鏄惁鍚堟硶 - /// </summary> - /// <param name="phoneNumber">鎵嬫満鍙�</param> - /// <param name="areaCode">鍦板尯浠g爜</param> - /// <returns></returns> - public static bool CheckPhoneNumber(string phoneNumber, string areaCode) - { - //鏍¢獙澶栧浗鎵嬫満鍙� - if (areaCode != "86") - { - Regex reg = new Regex(CommonPage.PhoneForForeignRegexStr); - return reg.IsMatch(phoneNumber); - } - - //鏍¢獙鍥藉唴鎵嬫満鍙� - if (phoneNumber.Length > 11) - { - return false; - } - else if (phoneNumber.Length == 11) - { - Regex reg = new Regex(CommonPage.PhoneRegexStr); - return reg.IsMatch(phoneNumber); - } - else - { - //姝e垯琛ㄨ揪寮忓垽鏂槸鍚︽暟瀛� - Regex reg = new Regex("^[0-9]*$"); - return reg.IsMatch(phoneNumber); - } } #endregion @@ -648,122 +653,126 @@ /// <param name="noticeDb">鏄惁閫氱煡浜戠</param> public static void ReLoginAgain(string account = "", bool noticeDb = true) { - UserCenterResourse.oldAccountId = string.Empty; - //鍏抽棴鎵�鏈夋帴鏀� - HdlDeviceAttributeLogic.Current.RemoveAllEvent(); - //娓呴櫎鍗囩骇鍒楄〃 - FirmwareUpdateResourse.dicDeviceUpdateList.Clear(); - FirmwareUpdateResourse.dicGatewayUpdateList.Clear(); - - new System.Threading.Thread(async () => + if (Config.Instance.Home.IsVirtually == true) { - //鍦ˋPP鐨勭紦瀛樿繕娌℃湁鍔犺浇鍜岃鍙栧畬鎴愪箣鍓嶏紝鏈�濂藉埆璁╁畠涓嬬嚎 - while (UserCenterResourse.AppLoadMenmoryFinish == false) + //濡傛灉鏄櫄鎷熶綇瀹� + HdlThreadLogic.Current.RunMain(() => { - await Task.Delay(500); + //璁惧畾涓�涓椂闂� + Config.Instance.LoginDateTime = new DateTime(1970, 1, 1); + //娓呯┖褰撳墠浣忓畢id + Config.Instance.HomeId = string.Empty; + Config.Instance.Save(); + //鏀惰捣宸﹁彍鍗� + CommonPage.Instance.CloseLeftMenu(); + //鍏抽棴鎵�鏈夋墦寮�浜嗙殑鐣岄潰 + CloseAllOpenForm(); + + //鏄剧ず鐧婚檰鐢婚潰 + var formLogin = new Login.AccountLoginForm(); + Shared.Common.CommonPage.Instance.AddChidren(formLogin); + formLogin.ShowForm(account); + }); + return; + } + UserCenterResourse.AccountOption.OldAccountId = string.Empty; + //鍏抽棴鎵�鏈夋帴鏀� + HdlGatewayReceiveLogic.Current.RemoveAllEvent(); + //娓呴櫎鍗囩骇鍒楄〃 + FirmwareUpdateResourse.dicUpdateList.Clear(); + + HdlThreadLogic.Current.RunThread(() => + { + //妫�娴婣PP鏄惁鑳藉閫�鍑� + while (UserCenterResourse.AccountOption.AppCanSignout == false) + { + System.Threading.Thread.Sleep(500); } //璁惧畾涓�涓椂闂� Config.Instance.LoginDateTime = new DateTime(1970, 1, 1); Config.Instance.Save(); //娓呯┖褰撳墠浣忓畢id - Shared.Common.Config.Instance.HomeId = string.Empty; + Config.Instance.HomeId = string.Empty; HdlGatewayLogic.Current.ClearAllRealGateway(); - try - { - ZigBee.Device.ZbGateway.RemoteMqttClient?.DisconnectAsync(); - ZigBee.Device.ZbGateway.RemoteMqttClient = null; - } - catch { } - if (noticeDb == true) + //鏂紑杩滅▼Mqtt杩炴帴 + HdlThreadLogic.Current.RunThread(async () => { - //閫氱煡浜戠锛屽凡缁忛��鍑虹櫥闄� - var result = await CommonPage.Instance.RequestHttpsZigbeeBytesResultAsync("ZigbeeUsers/SignOut", null, "GET"); - } - Application.RunOnMainThread(() => + await ZigBee.Device.ZbGateway.DisConnectRemoteMqttClient(); + }, ShowErrorMode.NO); + + HdlThreadLogic.Current.RunMain(() => { + //鏀惰捣宸﹁彍鍗� + CommonPage.Instance.CloseLeftMenu(); //鍏抽棴鎵�鏈夋墦寮�浜嗙殑鐣岄潰 CloseAllOpenForm(); //鏄剧ず鐧婚檰鐢婚潰 - var formLogin = new Shared.Phone.Device.Account.AccountLogin(); + var formLogin = new Login.AccountLoginForm(); Shared.Common.CommonPage.Instance.AddChidren(formLogin); - formLogin.Show(account); + formLogin.ShowForm(account); }); - }) - { IsBackground = true }.Start(); + + if (noticeDb == true) + { + //閫氱煡浜戠锛屽凡缁忛��鍑虹櫥闄� + var result = CommonPage.Instance.RequestHttpsZigbeeBytesResultAsync("ZigbeeUsers/SignOut", null, "GET"); + } + }); } /// <summary> /// 鍏抽棴鎵�鏈夋墦寮�浜嗙殑鐣岄潰 /// </summary> - public static void CloseAllOpenForm() + /// <param name="tagetFrom">鐩爣鐣岄潰,濡傛灉鎸囧畾浜嗙殑璇�,鍒欏叧闂洰鏍囩晫闈笂灞傜殑鍏ㄩ儴鐣岄潰(瀹冭嚜韬笉鍏抽棴)</param> + public static void CloseAllOpenForm(string tagetFrom = null) { - var listForm = new List<CommonFormBase>(); - var listId = new List<string>(); - foreach (CommonFormBase form in UserCenterResourse.DicActionForm.Values) + while (UserView.HomePage.Instance.ChildrenCount > 0) { - if (form.FormID != "UserMainForm") + var view = UserView.HomePage.Instance.GetChildren(UserView.HomePage.Instance.ChildrenCount - 1); + //(鍥犲簳灞傛帶浠朵慨鏀逛簡, 鐖舵帶浠剁Щ闄ゆ椂, 涓嶈Е鍙戝瓙鎺т欢鐨勭Щ闄や簨浠�) + if (view is ViewGroup) { - listForm.Insert(0, form); - listId.Add(form.FormID); + //鍏抽棴鍔犺浇鍦╒iewGroup閲岄潰鐨勮嚜瀹氫箟鐣岄潰Form + CloseViewGroupChildren((ViewGroup)view); + } + + if (view is CommonFormBase) + { + if (((CommonFormBase)view).FormID == tagetFrom) + { + //鍙叧闂埌鎸囧畾鐩爣鐣岄潰 + return; + } + ((CommonFormBase)view).CloseForm(); + } + else if (view is UserView.UserPage) + { + return; + } + else + { + view.RemoveFromParent(); } } - foreach (var id in listId) - { - UserCenterResourse.DicActionForm.Remove(id); - } - - //鍏抽棴鎵�鏈夌敾闈� - foreach (CommonFormBase form in listForm) - { - form.CloseForm(); - } - listForm.Clear(); } - #endregion - - #region 鈻� 瀛愭帶浠剁殑Y杞村潗鏍嘷___________________ - /// <summary> - /// 鎸囧畾浣嶇疆绫诲瀷鑾峰彇Rowlayout鐨勫瓙鎺т欢鐨刌杞村潗鏍�(璇风‘淇濆瓙鎺т欢涓嶅ぇ浜庣埗瀹瑰櫒) + /// 鍏抽棴鍔犺浇鍦╒iewGroup閲岄潰鐨勮嚜瀹氫箟鐣岄潰Form(鍥犲簳灞傛帶浠朵慨鏀逛簡,鐖舵帶浠剁Щ闄ゆ椂,涓嶈Е鍙戝瓙鎺т欢鐨勭Щ闄や簨浠�) /// </summary> - /// <param name="fatherCtrHeight">鐖舵帶浠剁殑鐪熷疄楂樺害</param> - /// <param name="ctrHeight">瀛愭帶浠剁殑鐪熷疄楂樺害</param> - /// <param name="alignment">浣嶇疆瀵归綈鏂瑰紡</param> - /// <param name="Space">涓婁笅闂寸殑绌虹櫧闂磋窛,鐪佺暐鏃讹紝鍙栬鎺т欢鍏遍�氬彉閲忕殑鍊笺�傝缃负-1鏃讹紝涓嶈绠楃┖鐧介棿璺�</param> - /// <returns></returns> - public static int GetControlChidrenYaxis(int fatherCtrHeight, int ctrHeight, UViewAlignment alignment, int Space = 0) + /// <param name="group"></param> + private static void CloseViewGroupChildren(ViewGroup group) { - if (Space == 0) + for (int i = 0; i < group.ChildrenCount; i++) { - //鑾峰彇琛屾帶浠剁殑闂磋窛 - if (fatherCtrHeight == ControlCommonResourse.ListViewRowHeight) + var view = group.GetChildren(i); + if (view is CommonFormBase) { - Space = ControlCommonResourse.ListViewRowSpace; + ((CommonFormBase)view).CloseForm(); + i--; } - } - - if (Space < 0) - { - //涓嶈绠楅棿璺濆�� - Space = 0; - } - - if (alignment == UViewAlignment.Center) - { - return fatherCtrHeight / 2 - ctrHeight / 2; - } - else if (alignment == UViewAlignment.Top) - { - return (fatherCtrHeight / 2 - Space / 2) / 2 - ctrHeight / 2; - } - else - { - int top = fatherCtrHeight / 2 + Space / 2; - return top + (fatherCtrHeight - top) / 2 - ctrHeight / 2; } } @@ -778,7 +787,7 @@ /// <returns></returns> public static string CombinePath(params object[] listNames) { - string rootPath = UserCenterResourse.LocalRootPath; + string rootPath = Config.Instance.FullPath; if (listNames == null || listNames.Length == 0) { return rootPath; @@ -812,13 +821,24 @@ string errorMsgBase = strResultData; if (errorMsgBase == null) { - Type myType = resultData.GetType(); - object errorObj = myType.InvokeMember("errorMessageBase", System.Reflection.BindingFlags.GetField, null, resultData, null); - if (errorObj == null) + if (resultData is ReceiptGatewayResult) { - return errorMsg; + errorMsgBase = string.Empty; + if (((ReceiptGatewayResult)resultData).ErrorMsgDiv == 0) + { + errorMsgBase = "鍥炲瓒呮椂"; + } } - errorMsgBase = errorObj.ToString(); + else + { + Type myType = resultData.GetType(); + object errorObj = myType.InvokeMember("errorMessageBase", System.Reflection.BindingFlags.GetField, null, resultData, null); + if (errorObj == null) + { + return errorMsg; + } + errorMsgBase = errorObj.ToString(); + } } if (errorMsgBase.Contains("鍥炲瓒呮椂") == false) @@ -841,161 +861,163 @@ #endregion - #region 鈻� 妫�娴嬬綉鍏冲叡閫氶敊璇姸鎬佺爜_____________ - - /// <summary> - /// <para>妫�娴嬬綉鍏宠繑鍥炵殑鍏遍�氶敊璇姸鎬佺爜(杩斿洖null鍒欎唬琛ㄦ病鏈夐敊璇�),鏀寔鐘舵�佺爜涓�</para> - /// <para>1锛氱綉鍏虫棤娉曡В鏋愬懡浠ゆ暟鎹��</para> - /// <para>2锛氬崗璋冨櫒姝e湪鍗囩骇鎴栧浠�/鎭㈠鏁版嵁</para> - /// <para>3锛氭搷浣滆澶�/缁�/鍦烘櫙涓嶅瓨鍦�</para> - /// <para>4锛氬叾浠栭敊璇�</para> - /// <para>5锛氭暟鎹紶杈撻敊璇紙鍦ㄦ煇娆″鎴风鍚戠綉鍏冲彂閫佹暟鎹殑杩囩▼涓紝缃戝叧鍦ㄥ悎鐞嗘椂闂磋寖鍥村唴鎺ユ敹瀹㈡埛绔暟鎹笉瀹屾暣瀵艰嚧璇ラ敊璇彂鐢熴�傚瀹㈡埛绔悜缃戝叧涓�娆″彂閫�100涓瓧鑺傜殑鏁版嵁锛屼絾缃戝叧绛夊緟鎺ユ敹浜嗕竴绉掑彧鎺ユ敹浜�80涓瓧鑺傘�傚彂鐢熻閿欒锛岀綉鍏冲皢涓诲姩鍏抽棴瀹㈡埛绔繛鎺ワ級</para> - /// </summary> - /// <param name="resultData">缃戝叧杩斿洖鐨剅esultData,閲岄潰鏈夈�恊rrorResponData銆戣繖涓笢瑗跨殑閭g瀵硅薄</param> - /// <returns></returns> - public static string CheckCommonErrorCode(object resultData) - { - if (resultData == null) - { - return null; - } - Type myType = resultData.GetType(); - object errorObj = myType.InvokeMember("errorResponData", System.Reflection.BindingFlags.GetField, null, resultData, null); - if (errorObj == null) - { - return null; - } - Type type = errorObj.GetType(); - var code = type.InvokeMember("Error", System.Reflection.BindingFlags.GetField, null, errorObj, null); - int errorCode = Convert.ToInt32(code); - - return CheckCommonErrorCode(errorCode); - } - - /// <summary> - /// <para>妫�娴嬬綉鍏宠繑鍥炵殑鍏遍�氶敊璇姸鎬佺爜(杩斿洖null鍒欎唬琛ㄦ病鏈夐敊璇�),鏀寔鐘舵�佺爜涓�</para> - /// <para>1锛氱綉鍏虫棤娉曡В鏋愬懡浠ゆ暟鎹��</para> - /// <para>2锛氬崗璋冨櫒姝e湪鍗囩骇鎴栧浠�/鎭㈠鏁版嵁</para> - /// <para>3锛氭搷浣滆澶�/缁�/鍦烘櫙涓嶅瓨鍦�</para> - /// <para>4锛氬叾浠栭敊璇�</para> - /// <para>5锛氭暟鎹紶杈撻敊璇紙鍦ㄦ煇娆″鎴风鍚戠綉鍏冲彂閫佹暟鎹殑杩囩▼涓紝缃戝叧鍦ㄥ悎鐞嗘椂闂磋寖鍥村唴鎺ユ敹瀹㈡埛绔暟鎹笉瀹屾暣瀵艰嚧璇ラ敊璇彂鐢熴�傚瀹㈡埛绔悜缃戝叧涓�娆″彂閫�100涓瓧鑺傜殑鏁版嵁锛屼絾缃戝叧绛夊緟鎺ユ敹浜嗕竴绉掑彧鎺ユ敹浜�80涓瓧鑺傘�傚彂鐢熻閿欒锛岀綉鍏冲皢涓诲姩鍏抽棴瀹㈡埛绔繛鎺ワ級</para> - /// </summary> - /// <param name="errorCode">閿欒浠g爜</param> - /// <returns></returns> - public static string CheckCommonErrorCode(int errorCode) - { - if (errorCode == 1) - { - //缃戝叧鏃犳硶瑙f瀽鍛戒护鏁版嵁 - return Language.StringByID(R.MyInternationalizationString.uGatewayCannotResolveCommand); - } - else if (errorCode == 2) - { - //鍗忚皟鍣ㄦ鍦ㄥ崌绾ф垨澶囦唤鎴栨仮澶嶆暟鎹腑 - string msg = Language.StringByID(R.MyInternationalizationString.uCoordinatorIsUpOrBackupOrRecovering); - } - else if (errorCode == 3) - { - //鐩爣璁惧涓嶅瓨鍦� - string msg = Language.StringByID(R.MyInternationalizationString.uTargetDeviceIsNotExsit); - } - else if (errorCode == 4) - { - //鍑虹幇鏈煡閿欒,璇风◢鍚庡啀璇� - string msg = Language.StringByID(R.MyInternationalizationString.uUnKnowErrorAndResetAgain); - } - else if (errorCode == 5) - { - //鏁版嵁浼犺緭閿欒,璇风◢鍚庡啀璇� - string msg = Language.StringByID(R.MyInternationalizationString.uDataTransmissionFailAndResetAgain); - } - return null; - } - - #endregion - #region 鈻� 鍒锋柊涓汉涓績鐨勫唴瀛樺強绾跨▼___________ /// <summary> /// 寮傛鏂规硶鎵ц(浠呴檺鍒囨崲浣忓畢鏃惰皟鐢�)锛屽埛鏂颁釜浜轰腑蹇冪殑鍐呭瓨鍙婄嚎绋� /// </summary> - public async static Task<bool> InitUserCenterMenmoryAndThread() + /// <param name="ShowPrompted">鏂拌拷鍔犲彉閲忥細鏄惁鏄剧ず鎻愮ず鑷姩澶囦唤鐨勭晫闈�</param> + /// <returns></returns> + public static bool InitUserCenterMenmoryAndThread(bool ShowPrompted = true) { - //APP缂撳瓨鍔犺浇寮�濮� - UserCenterResourse.AppLoadMenmoryFinish = false; + //璋冪敤杩欎釜鏂规硶,閮介渶瑕侀噸鏂板埛鏂颁富椤� + UserView.UserPage.Instance.RefreshForm = true; - //寮哄埗鎸囧畾涓嶅叧闂繘搴︽潯 - ProgressBar.SetCloseBarFlag(true); + //娣诲姞缃戠粶鐘舵�佺洃鍚� + HdlWifiLogic.Current.StartListenNetWork(); + + //濡傛灉鏄櫄鎷熶綇瀹� + if (Config.Instance.Home.IsVirtually == true) + { + //鍒濆鍖栬櫄鎷熶綇瀹呯殑涓汉涓績鐨勬暟鎹�(鍒囨崲浣忓畢浣跨敤) + InitUserCenterMenmoryByVirtualHome(); + return true; + } + + //APP缂撳瓨鍔犺浇寮�濮� + UserCenterResourse.AccountOption.AppCanSignout = false; + //杩樺師杩滅▼杩炴帴鏉冮檺鍙橀噺 + ZigBee.Device.ZbGateway.AllowRemoteCtrl = true; //鍙湁鍦ㄤ綇瀹匢D涓嶄竴鏍风殑鏃跺�欐墠鍋氳繖涓搷浣� - if (Common.Config.Instance.HomeId != UserCenterResourse.oldHomeStringId - || Common.Config.Instance.Account != UserCenterResourse.oldAccountId) + if (Common.Config.Instance.HomeId != UserCenterResourse.AccountOption.OldHomeStringId + || Common.Config.Instance.Account != UserCenterResourse.AccountOption.OldAccountId) { - //鍙樻洿鏍圭洰褰曡矾寰� - UserCenterResourse.LocalRootPath = System.IO.Path.Combine(Shared.IO.FileUtils.RootPath, Config.Instance.Guid, Config.Instance.Home.Id); - UserCenterResourse.UserPictruePath = System.IO.Path.Combine(Shared.IO.FileUtils.RootPath, Config.Instance.Guid, DirNameResourse.UserPictrueDirectory); + //鏂紑杩滅▼Mqtt杩炴帴 + HdlThreadLogic.Current.RunThread(async () => + { + await ZigBee.Device.ZbGateway.DisConnectRemoteMqttClient(); + }, ShowErrorMode.NO); + + //娓呯┖鎵�鏈夋垚鍛樼紦瀛� + ClearAllMemberMemory(); + + //鍔犺浇璐﹀彿閰嶇疆淇℃伅 + var optionInfo = UserCenterResourse.AccountOption.Load(); + UserCenterResourse.AccountOption = optionInfo; + //鍙樻洿鏍圭敤鎴峰浘鐗囩洰褰曡矾寰� + UserCenterResourse.AccountOption.UserPictruePath = System.IO.Path.Combine(Shared.IO.FileUtils.RootPath, Config.Instance.Guid, DirNameResourse.UserPictrueDirectory); + + //鍔犺浇浣忓畢閰嶇疆淇℃伅 + UserCenterResourse.ResidenceOption = UserCenterResourse.ResidenceOption.Load(); //鍒濆鍖栫櫥闄嗚处鍙风殑淇℃伅 - await InitUserAccoutInfo(); - //鍒濆鍖栫鐞嗗憳鏉冮檺淇℃伅 - await InitAdminConnectMqttInfo(true); - - //鍒濆鍖栫紦瀛樻垚鍛樼殑淇℃伅 - InitLocalMemberListInfo(); - - //閲嶆柊鍙戦�佸懡浠ゅ幓缁戝畾鏂綉鎯呭喌涓嬪浠界殑缃戝叧 - HdlGatewayLogic.Current.ResetComandToBindBackupGateway(); + var hadNet = InitUserAccoutInfo(true); + //濡傛灉鏈夌綉缁滅殑璇� + if (hadNet == 1) + { + //閲嶆柊鍙戦�佸懡浠ゅ幓缁戝畾鏂綉鎯呭喌涓嬪浠界殑缃戝叧 + HdlGatewayLogic.Current.ResetComandToBindBackupGateway(); + //璇诲彇闅愬尶閰嶇疆 + HdlBackupLogic.Current.LoadHideOption(); + } //棰勫垱寤轰釜浜轰腑蹇冨叏閮ㄧ殑鏂囦欢澶� CreatAllUserCenterDirectory(); //鍏抽棴鎵�鏈夋帴鏀� - HdlDeviceAttributeLogic.Current.RemoveAllEvent(); + HdlGatewayReceiveLogic.Current.RemoveAllEvent(); //鍒锋柊瀹夐槻涓婃姤淇℃伅 HdlAlarmsLogic.Current.RefreshAlarmInfo(); - //娣诲姞淇濆瓨瀹夐槻璁惧鎶ヨ鐨勪簨浠�(涓嶉渶瑕佸啀鎵ц浠讳綍鎿嶄綔,骞朵笖姘镐箙瀛樺湪) - HdlAlarmsLogic.Current.AddAlarmInfoEvent(); //淇濆瓨鐢ㄦ埛鐨勭櫥闄嗕俊鎭埌鏈湴 SaveUserInformationToLocation(); - UserCenterResourse.oldHomeStringId = Common.Config.Instance.HomeId; - UserCenterResourse.oldAccountId = Common.Config.Instance.Account; + UserCenterResourse.AccountOption.OldHomeStringId = Common.Config.Instance.HomeId; + UserCenterResourse.AccountOption.OldAccountId = Common.Config.Instance.Account; //鍚屾鏁版嵁(浜屾璋冪敤娌″叧绯�) - var result = await HdlAutoBackupLogic.SynchronizeDbAutoBackupData(); + int result = -1; + if (hadNet == 1) + { + result = HdlAutoBackupLogic.SynchronizeDbAutoBackupData(); + } //鍒濆鍖栨湰鍦扮殑缃戝叧淇℃伅 HdlGatewayLogic.Current.ReFreshByLocal(); //鍒濆鍖栨湰鍦扮殑璁惧淇℃伅 - Common.LocalDevice.Current.ReFreshByLocal(); - - //鍚屾浜戠鐨勭綉鍏砳d锛屽鏋滄湰鍦版嫢鏈変簯绔笉瀛樺湪鐨刬d锛屽垯琛ㄧず搴旇琚崲缁戜簡锛岀洿鎺ュ垹闄� - HdlGatewayLogic.Current.SynchronizeDbGateway(); + LocalDevice.Current.ReFreshByLocal(); //鍒濆鍖栨埧闂�(閮洩鍩庨偅杈逛笉鍋氬鐞�,闇�瑕佽繖閲岀壒娈婃墽琛屼竴姝�) - Room.RefreshAllRoomByLocation(); + HdlRoomLogic.Current.RefreshAllRoomByLocation(); + + if (hadNet == 1) + { + //鍚屾浜戠鐨勭綉鍏砳d锛屽鏋滄湰鍦版嫢鏈変簯绔笉瀛樺湪鐨刬d锛屽垯琛ㄧず搴旇琚崲缁戜簡锛岀洿鎺ュ垹闄� + HdlGatewayLogic.Current.SynchronizeDbGateway(); + } //鍒锋柊APP鍓嶄竴娆¢�夋嫨鐨勭綉鍏矷D(鍙互鍙嶅璋冪敤,闇�瑕佸湪缃戝叧鍒濆鍖栧畬浜嗕箣鍚庢墠鑳借皟鐢�) HdlGatewayLogic.Current.RefreshAppOldSelectGatewayId(); - //娓呯┖寮哄埗鎸囧畾鏂囨湰鐨勯檮鍔犱俊鎭� - ProgressBar.SetAppendText(string.Empty); - //0:宸茬粡鍚屾杩囷紝涓嶉渶瑕佸悓姝�,杩欎釜鏃跺�欓渶瑕佹彁绀哄浠� - if (result == 0) + if (result == 0 && ShowPrompted == true) { - //寮�鍚嚜鍔ㄥ浠芥彁绀� - //HdlAutoBackupLogic.ShowAutoBackupPromptedForm(); + //寮�鍚嚜鍔ㄥ浠� + HdlAutoBackupLogic.ShowAutoBackupPromptedForm(); } + //鏄剧ず寮曞鐣岄潰 + ShowGuideForm(result); } - - //鎭㈠鍙叧闂繘搴︽潯 - ProgressBar.SetCloseBarFlag(false); //APP缂撳瓨鍔犺浇瀹屾垚 - UserCenterResourse.AppLoadMenmoryFinish = true; + UserCenterResourse.AccountOption.AppCanSignout = true; return true; + } + + /// <summary> + /// 鍒濆鍖栬櫄鎷熶綇瀹呯殑涓汉涓績鐨勬暟鎹�(鍒囨崲浣忓畢浣跨敤) + /// </summary> + private static void InitUserCenterMenmoryByVirtualHome() + { + UserCenterResourse.AccountOption.OldHomeStringId = Common.Config.Instance.Home.Id; + //娓呯┖鎵�鏈夋垚鍛樼紦瀛� + ClearAllMemberMemory(); + //棰勫垱寤轰釜浜轰腑蹇冨叏閮ㄧ殑鏂囦欢澶� + CreatAllUserCenterDirectory(); + //鍏抽棴鎵�鏈夋帴鏀� + HdlGatewayReceiveLogic.Current.RemoveAllEvent(); + //鍒濆鍖栨湰鍦扮殑缃戝叧淇℃伅 + HdlGatewayLogic.Current.ReFreshByLocal(); + //鍒濆鍖栨湰鍦扮殑璁惧淇℃伅 + Common.LocalDevice.Current.ReFreshByLocal(); + //鍒濆鍖栨埧闂�(閮洩鍩庨偅杈逛笉鍋氬鐞�,闇�瑕佽繖閲岀壒娈婃墽琛屼竴姝�) + HdlRoomLogic.Current.RefreshAllRoomByLocation(); + //鍒锋柊宸﹁竟鍒锋柊鎴块棿瑙嗗浘鍒楄〃 + HdlRoomLogic.Current.RefreshRoomListView(); + } + + /// <summary> + /// 娓呯┖鎵�鏈夋垚鍛樼紦瀛� + /// </summary> + private static void ClearAllMemberMemory() + { + //娑堟伅璁板綍閲嶆柊璇诲彇鍙婃娴� + ControlCommonResourse.ReadMessageAgain = true; + ControlCommonResourse.HadNewMessage = false; + HdlThreadLogic.Current.RunMain(() => + { + for (int i = 0; i < ControlCommonResourse.listMessageManaContr.Count; i++) + { + //鏄剧ず瑙掓爣鐗规晥 + ControlCommonResourse.listMessageManaContr[i].IsSelected = false; + } + }); + + //鍒囨崲浣忓畢娓呴櫎涔嬪墠閫昏緫缂撳瓨鏁版嵁; + Common.Logic.LogicList.Clear(); + Common.Logic.LockLogicList.Clear(); + Common.Logic.SoneLogicList.Clear(); } #endregion @@ -1003,27 +1025,44 @@ #region 鈻� 鍒濆鍖栫櫥闄嗚处鍙风殑淇℃伅_______________ /// <summary> - /// 鍒濆鍖栫櫥闄嗚处鍙风殑淇℃伅 + /// 鍒濆鍖栫櫥闄嗚处鍙风殑淇℃伅 -1:鏃犵綉 1:姝e父 2:鍏朵粬閿欒 /// </summary> + /// <param name="reLoad">鏄惁浠庢柊浠庢湰鍦板姞杞�(閲嶆柊鍒濆鍖栫櫥闄嗚处鍙风殑淇℃伅,涓嶉渶瑕侀噸鏂板姞杞�)</param> /// <returns></returns> - private async static Task<bool> InitUserAccoutInfo() + private static int InitUserAccoutInfo(bool reLoad) { - //鑾峰彇鏈湴璁板綍鐨勭敤鎴蜂俊鎭� - UserCenterResourse.UserInfo = GetUserInformationFromLocation(); - UserCenterResourse.UserInfo.UserIconFile = System.IO.Path.Combine(UserCenterResourse.UserPictruePath, "Admin.png"); + //鍒濆鍖栦釜浜轰俊鎭殑鏍囪瘑 + UserCenterResourse.UserInfo.InitUserInfoSuccess = false; + if (reLoad == true) + { + //鑾峰彇鏈湴璁板綍鐨勭敤鎴蜂俊鎭� + UserCenterResourse.UserInfo = GetUserInformationFromLocation(); + UserCenterResourse.UserInfo.UserIconFile = System.IO.Path.Combine(UserCenterResourse.AccountOption.UserPictruePath, "Admin.png"); + } + if (HdlWifiLogic.Current.CanAccessHttp == false) + { + //鏃犳硶杩炴帴澶栫綉 + return -1; + } //鑾峰彇鐧诲綍璐﹀彿鐨勪俊鎭� var pra = new AccountInfoPra(); - var listNotShow = new List<string>() { "NotSetAgain" }; - string result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeUsers/GetAccountInfo", false, pra, listNotShow); - if (string.IsNullOrEmpty(result) == true) + //搴忓垪鍖栧璞� + var requestJson = JsonConvert.SerializeObject(pra); + //璁块棶鎺ュ彛 + byte[] byteData = CommonPage.Instance.RequestHttpsZigbeeBytesResultAsync("ZigbeeUsers/GetAccountInfo", Encoding.UTF8.GetBytes(requestJson)); + if (byteData == null) { - //鏂綉鐨勮瘽锛岃骞插槢灏卞共鍢涘惂,鎬讳箣涓嶈兘鎺т富浜虹殑涓滆タ - Config.Instance.isAdministrator = false; - return false; + return -1; + } + //妫�娴嬮敊璇� + var revertObj = JsonConvert.DeserializeObject<ResponsePack>(Encoding.UTF8.GetString(byteData)); + if (revertObj.StateCode.ToUpper() != "SUCCESS") + { + return 2; } - var userInfo = Newtonsoft.Json.JsonConvert.DeserializeObject<UserInformation>(result); + var userInfo = Newtonsoft.Json.JsonConvert.DeserializeObject<UserInformation>(revertObj.ResponseData.ToString()); userInfo.Account = Common.Config.Instance.Account; if (string.IsNullOrEmpty(userInfo.UserName) == true) { @@ -1056,22 +1095,23 @@ string dirPath = CombinePath(); if (System.IO.Directory.Exists(dirPath) == true) { - //鍏堣褰曡捣浣忓畢鐨勪竴浜涗俊鎭� - var house = House.GetHouseByHouseId(Config.Instance.HomeId); - //鍒犻櫎鏁翠釜鏂囦欢澶� - System.IO.Directory.Delete(dirPath, true); + try + { + //鍚屾鏁版嵁鐨勫垽鏂枃浠�(浠ラ槻涓囦竴鍒犻櫎鏁翠釜鏂囦欢澶瑰け璐ョ殑鏃跺��,杩欎釜鏂囦欢琚垹鐨勮瘽,搴旇娌′粈涔堝ぇ闂) + string SynchronizeFile = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.AutoDownLoadBackupCheckFile); + //濡傛灉鏈湴宸茬粡鎷ユ湁浜嗚繖涓枃浠讹紝鍒欒鏄庝笉鏄柊鎵嬫満锛屼笉鍐嶈嚜鍔ㄨ繕鍘� + if (System.IO.File.Exists(SynchronizeFile) == true) + { + System.IO.File.Delete(SynchronizeFile); + } + //鍒犻櫎鏁翠釜鏂囦欢澶� + System.IO.Directory.Delete(dirPath, true); + } + catch { } //鍒涘缓浣忓畢鏂囦欢澶� Global.CreateHomeDirectory(Config.Instance.HomeId); //棰勫垱寤轰釜浜轰腑蹇冨叏閮ㄧ殑鏂囦欢澶� CreatAllUserCenterDirectory(); - - var newHouse = new House(); - newHouse.Id = house.Id; - newHouse.Name = house.Name; - newHouse.IsOthreShare = house.IsOthreShare; - newHouse.AccountType = house.AccountType; - newHouse.MainUserDistributedMark = house.MainUserDistributedMark; - newHouse.Save(); } } if (string.IsNullOrEmpty(userInfo.UserName) == true) @@ -1081,12 +1121,26 @@ } UserCenterResourse.UserInfo = userInfo; - UserCenterResourse.UserInfo.UserIconFile = System.IO.Path.Combine(UserCenterResourse.UserPictruePath, "Admin.png"); + UserCenterResourse.UserInfo.UserIconFile = System.IO.Path.Combine(UserCenterResourse.AccountOption.UserPictruePath, "Admin.png"); + if (UserCenterResourse.UserInfo.HeadImage != null) + { + //鍐欏叆澶村儚鍐呭 + Shared.IO.FileUtils.WriteFileByBytes(UserCenterResourse.UserInfo.UserIconFile, UserCenterResourse.UserInfo.HeadImage); + } + UserCenterResourse.UserInfo.HeadImage = null; + //鎵嬪娍瀵嗙爜 + UserCenterResourse.AccountOption.GestureAuthentication = UserCenterResourse.UserInfo.GesturePwd == null ? string.Empty : UserCenterResourse.UserInfo.GesturePwd; + UserCenterResourse.UserInfo.GesturePwd = null; + //瀵嗙爜楠岃瘉 + UserCenterResourse.AccountOption.PswAuthentication = UserCenterResourse.UserInfo.StringPwd == null ? string.Empty : UserCenterResourse.UserInfo.StringPwd; + UserCenterResourse.UserInfo.StringPwd = null; //鍒濆鍖栫鐞嗗憳鎺у埗涓讳汉鐨勮繛鎺ュ湴鍧�(鍥犱负杩欎釜杩炴帴Token鏄笉浼氭敼鍙樼殑,鎵�浠ュ彧闇�瑕佸垵濮嬪寲涓�娆�) - await InitAdminConnectMainInfo(); + var flage = InitAdminConnectMainInfo(); + //鍒濆鍖栦釜浜轰俊鎭殑鏍囪瘑 + UserCenterResourse.UserInfo.InitUserInfoSuccess = flage == 1; - return true; + return flage; } /// <summary> @@ -1096,13 +1150,48 @@ private static UserInformation GetUserInformationFromLocation() { string fileName = CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.UserInfoFile); - if (System.IO.File.Exists(fileName) == false) + var value = LoadFileContent(fileName); + if (value == null) { return new UserInformation(); } - var varByte = Shared.IO.FileUtils.ReadFile(fileName); - var info = Newtonsoft.Json.JsonConvert.DeserializeObject<UserInformation>(System.Text.Encoding.UTF8.GetString(varByte)); + var info = Newtonsoft.Json.JsonConvert.DeserializeObject<UserInformation>(value); return info; + } + + /// <summary> + /// 閲嶆柊鍒濆鍖栫櫥闄嗚处鍙风殑淇℃伅(鏃ㄥ湪瀵瑰簲閭d竴鐬棿,缃戠粶涓嶅ソ,瀵艰嚧璇垽鐨勬儏鍐�) + /// </summary> + /// <returns></returns> + private static bool ReInitUserAccoutInfo(List<string> listNotShowError) + { + //閲嶆柊鍒濆鍖栬处鍙蜂俊鎭� + var result = InitUserAccoutInfo(false); + //杩炴帴涓嶄簡澶栫綉鐨勬椂鍊� + if (result == -1) + { + if (listNotShowError != null && listNotShowError.Contains("NotCheck") == true) + { + //鏈夎繖涓爣璇嗘椂,涓嶆彁绀洪敊璇� + return false; + } + Application.RunOnMainThread(() => + { + //褰撳墠鏃犵綉缁滆繛鎺�,璇风‘璁ょ綉缁� + var alert = new ShowMsgControl(ShowMsgType.Tip, Language.StringByID(R.MyInternationalizationString.uNowIsDonotNetworkAndCheckNetwork)); + alert.Show(); + }); + } + if (result == 1) + { + //鍚屾浜戠鐨勭綉鍏砳d锛屽鏋滄湰鍦版嫢鏈変簯绔笉瀛樺湪鐨刬d锛屽垯琛ㄧず搴旇琚崲缁戜簡锛岀洿鎺ュ垹闄� + HdlGatewayLogic.Current.SynchronizeDbGateway(); + //鍒濆鍖栦釜浜轰俊鎭殑鏍囪瘑 + UserCenterResourse.UserInfo.InitUserInfoSuccess = true; + + return true; + } + return false; } /// <summary> @@ -1110,12 +1199,9 @@ /// </summary> private static void SaveUserInformationToLocation() { - var data = Newtonsoft.Json.JsonConvert.SerializeObject(UserCenterResourse.UserInfo); - var byteData = System.Text.Encoding.UTF8.GetBytes(data); - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.UserInfoFile); //鍐欏叆鍐呭 - Shared.IO.FileUtils.WriteFileByBytes(fullName, byteData); + SaveFileContent(fullName, UserCenterResourse.UserInfo); //鎼炰竴涓嬩富浜虹殑榛樿澶村儚 string defultFile = IO.FileUtils.GetImageFilePath("Center/Admin.png"); @@ -1123,13 +1209,12 @@ { return; } - string nowFile = System.IO.Path.Combine(UserCenterResourse.UserPictruePath, "Admin.png"); - if (System.IO.File.Exists(nowFile) == true) + if (System.IO.File.Exists(UserCenterResourse.UserInfo.UserIconFile) == true) { return; } //澶嶅埗杩囧幓 - System.IO.File.Copy(defultFile, nowFile); + System.IO.File.Copy(defultFile, UserCenterResourse.UserInfo.UserIconFile); } #endregion @@ -1137,20 +1222,15 @@ #region 鈻� 鍒濆鍖栫鐞嗗憳鏉冮檺杩滅▼杩炴帴___________ /// <summary> - /// 鍒濆鍖栫鐞嗗憳鏉冮檺杩滅▼杩炴帴涓讳汉鐨勪俊鎭� + /// 鍒濆鍖栫鐞嗗憳鏉冮檺杩滅▼杩炴帴涓讳汉鐨勪俊鎭� -1:鏃犵綉 1:姝e父 2:鍏朵粬閿欒 /// </summary> /// <returns></returns> - public static async Task<bool> InitAdminConnectMainInfo() + private static int InitAdminConnectMainInfo() { - //鍏堟竻绌� - Config.Instance.isAdministrator = false; - Config.Instance.AdminRequestBaseUrl = string.Empty; - Config.Instance.AdminRequestToken = string.Empty; - - if (UserCenterResourse.UserInfo.AuthorityNo != 2) + if (UserCenterResourse.UserInfo.AuthorityNo != 2 && UserCenterResourse.UserInfo.AuthorityNo != 3) { - //鎷ユ湁绠$悊鍛樻潈闄愮殑鎴愬憳鎵嶈兘杩欐牱鎼�, 杩欓噷蹇呴』鏄�2 - return true; + //鏃朵唬鍙樹簡,杩欓噷绠$悊鍛樺拰鎴愬憳閮借兘璋冪敤 + return 1; } var pra = new { @@ -1160,91 +1240,27 @@ SharedHid = Config.Instance.Home.Id }; - var listNotShow = new List<string>() { "NotSetAgain" }; - var result = await GetResponseDataByRequestHttps("App/GetSharedHomeApiControl", false, pra, listNotShow); - if (string.IsNullOrEmpty(result) == true) + //搴忓垪鍖栧璞� + var requestJson = JsonConvert.SerializeObject(pra); + //璁块棶鎺ュ彛 + byte[] byteData = CommonPage.Instance.RequestHttpsZigbeeBytesResultAsync("App/GetSharedHomeApiControl", Encoding.UTF8.GetBytes(requestJson)); + if (byteData == null) { - return false; + return -1; + } + //妫�娴嬮敊璇� + var revertObj = JsonConvert.DeserializeObject<ResponsePack>(Encoding.UTF8.GetString(byteData)); + if (revertObj.StateCode.ToUpper() != "SUCCESS") + { + return 2; } - Config.Instance.isAdministrator = true; //鍒嗕韩閾炬帴 - var info = JsonConvert.DeserializeObject<MemberAdministratorResult>(result); + var info = JsonConvert.DeserializeObject<MemberAdministratorResult>(revertObj.ResponseData.ToString()); Config.Instance.AdminRequestBaseUrl = info.RequestBaseUrl; Config.Instance.AdminRequestToken = info.RequestToken; - return true; - } - - /// <summary> - /// 鍒濆鍖栫鐞嗗憳鏉冮檺鐨勮繙绋嬭繛鎺ヤ俊鎭� - /// </summary> - /// <param name="stopRemote">鏄惁涓柇杩滅▼</param> - /// <returns></returns> - public static async Task<bool> InitAdminConnectMqttInfo(bool stopRemote = false) - { - if (UserCenterResourse.UserInfo.AuthorityNo != 2 && UserCenterResourse.UserInfo.AuthorityNo != 3) - { - //鍙湁鎴愬憳鍒嗚韩鎵嶈兘璋冪敤杩欎釜鍑芥暟 - return true; - } - var praMqtt = new - { - CommonPage.RequestVersion, - LoginAccessToken = Config.Instance.Token, - Config.Instance.Home.MainUserDistributedMark, - HomeId = Config.Instance.Home.Id - }; - - var listNotShow = new List<string>() { "NotSetAgain" }; - var result2 = await GetResponseDataByRequestHttps("App/GetConnectMainUserMqttInfo", false, praMqtt, listNotShow); - if (string.IsNullOrEmpty(result2) == true) - { - return false; - } - - //杩滅▼Mqtt - var info2 = JsonConvert.DeserializeObject<MemberAdministratorMqttResult>(result2); - Config.Instance.AdminConnectZigbeeMqttBrokerPwd = info2.ConnectZigbeeMqttBrokerPwd; - Config.Instance.AdminConnectZigbeeMqttClientId = info2.ConnectZigbeeMqttClientId; - Config.Instance.AdminMqttKey = info2.MqttKey; - Config.Instance.AdminZigbeeMqttBrokerLoadSubDomain = info2.ZigbeeMqttBrokerLoadSubDomain; - Config.Instance.AdminConnectZigbeeMqttBrokerName = info2.ConnectZigbeeMqttBrokerName; - - return true; - } - - #endregion - - #region 鈻� 鍒濆鍖栫紦瀛樻垚鍛樼殑淇℃伅_______________ - - /// <summary> - /// 鍒濆鍖栫紦瀛樻垚鍛樼殑淇℃伅 - /// </summary> - private static void InitLocalMemberListInfo() - { - //鍏堟竻绌� - UserCenterResourse.ListMemberInfo.Clear(); - string fileName = CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.MemberListInfoFile); - if (System.IO.File.Exists(fileName) == false) - { - return; - } - var varByte = Shared.IO.FileUtils.ReadFile(fileName); - UserCenterResourse.ListMemberInfo = JsonConvert.DeserializeObject<List<MemberInfoRes>>(System.Text.Encoding.UTF8.GetString(varByte)); - } - - /// <summary> - /// 淇濆瓨缂撳瓨鎴愬憳鐨勪俊鎭� - /// </summary> - public static void SaveLocalMemberListInfo() - { - var data = Newtonsoft.Json.JsonConvert.SerializeObject(UserCenterResourse.ListMemberInfo); - var byteData = System.Text.Encoding.UTF8.GetBytes(data); - - string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.MemberListInfoFile); - //鍐欏叆鍐呭 - Shared.IO.FileUtils.WriteFileByBytes(fullName, byteData); + return 1; } #endregion @@ -1284,10 +1300,14 @@ directory = System.IO.Path.Combine(LocalDirectory, DirNameResourse.DownLoadShardDirectory); Global.CreateEmptyDirectory(directory); + //LOG鍑哄姏銆愭枃浠跺す銆� + directory = System.IO.Path.Combine(LocalDirectory, DirNameResourse.LogDirectory); + Global.CreateEmptyDirectory(directory); + //鐢ㄦ埛鍥剧墖鐩綍璺緞銆愭枃浠跺す銆� - if (!System.IO.Directory.Exists(UserCenterResourse.UserPictruePath)) + if (UserCenterResourse.AccountOption.UserPictruePath != string.Empty && !System.IO.Directory.Exists(UserCenterResourse.AccountOption.UserPictruePath)) { - System.IO.Directory.CreateDirectory(UserCenterResourse.UserPictruePath); + System.IO.Directory.CreateDirectory(UserCenterResourse.AccountOption.UserPictruePath); } } @@ -1302,11 +1322,41 @@ public static string GetConnectMainToken() { //鍚敤绠$悊鍛樻潈闄� - if (Config.Instance.isAdministrator == true) + if (Config.Instance.Home.IsOthreShare == true) { return Config.Instance.AdminRequestToken; } return Config.Instance.Token; + } + + #endregion + + #region 鈻� 寮曞鐣岄潰___________________________ + + /// <summary> + /// 鏄剧ず寮曞鐣岄潰 + /// </summary> + /// <param name="result">鍚屾缁撴灉 -1锛氬紓甯� 0:宸茬粡鍚屾杩囷紝涓嶉渶瑕佸悓姝� 1锛氭甯稿悓姝� 2:娌℃湁鑷姩澶囦唤鏁版嵁</param> + private static void ShowGuideForm(int result) + { + var checkFile = System.IO.Path.Combine(Shared.IO.FileUtils.RootPath, DirNameResourse.GuideFile); + if (System.IO.File.Exists(checkFile) == true) + { + //涓嶉渶瑕佹樉绀� + return; + } + if (result == 2 && Config.Instance.Home.IsOthreShare == false) + { + HdlThreadLogic.Current.RunMain(() => + { + var form = new Guide.GuideHouseForm(); + form.ShowFrom(); + }); + } + + //鍒涘缓涓�涓┖鏂囦欢(鏍囪瘑宸茬粡瀹屾垚寮曞) + var file = System.IO.File.Create(checkFile); + file.Close(); } #endregion @@ -1350,15 +1400,171 @@ #endregion - #region 鈻� 妫�娴嬭处鍙锋槸鍚﹀凡缁忛��鍑篲______________ + #region 鈻� 鍔犲瘑鍜岃В瀵哶________________________ /// <summary> - /// 妫�娴嬭处鍙锋槸鍚﹀凡缁忛��鍑� true:宸茬粡閫�鍑� false:娌℃湁閫�鍑� + /// 鍔犲瘑瀵嗙爜 /// </summary> + /// <param name="keys"></param> + /// <param name="strPsw"></param> /// <returns></returns> - public static bool IsAccountLoginOut() + public static string EncryptPassword(string keys, string strPsw) { - return Config.Instance.HomeId == string.Empty; + try + { + if (strPsw == string.Empty) + { + return strPsw; + } + var des = new System.Security.Cryptography.DESCryptoServiceProvider(); + byte[] inputByteArray = Encoding.Default.GetBytes(strPsw); + des.Key = ASCIIEncoding.ASCII.GetBytes(keys); + des.IV = ASCIIEncoding.ASCII.GetBytes(keys); + var ms = new System.IO.MemoryStream(); + var cs = new System.Security.Cryptography.CryptoStream(ms, des.CreateEncryptor(), System.Security.Cryptography.CryptoStreamMode.Write); + cs.Write(inputByteArray, 0, inputByteArray.Length); + cs.FlushFinalBlock(); + StringBuilder ret = new StringBuilder(); + foreach (byte b in ms.ToArray()) + { + ret.AppendFormat("{0:X2}", b); + } + return ret.ToString().ToLower(); + } + catch { return strPsw; } + } + + /// <summary> + /// 瑙e瘑瀵嗙爜 + /// </summary> + /// <param name="strPsw"></param> + /// <returns></returns> + public static string DecryptPassword(string keys, string strPsw) + { + try + { + if (strPsw == string.Empty) + { + return strPsw; + } + var des = new System.Security.Cryptography.DESCryptoServiceProvider(); + + byte[] inputByteArray = new byte[strPsw.Length / 2]; + for (int x = 0; x < strPsw.Length / 2; x++) + { + int i = (Convert.ToInt32(strPsw.Substring(x * 2, 2), 16)); + inputByteArray[x] = (byte)i; + } + + des.Key = ASCIIEncoding.ASCII.GetBytes(keys); + des.IV = ASCIIEncoding.ASCII.GetBytes(keys); + var ms = new System.IO.MemoryStream(); + var cs = new System.Security.Cryptography.CryptoStream(ms, des.CreateDecryptor(), System.Security.Cryptography.CryptoStreamMode.Write); + cs.Write(inputByteArray, 0, inputByteArray.Length); + cs.FlushFinalBlock(); + + StringBuilder ret = new StringBuilder(); + + return System.Text.Encoding.Default.GetString(ms.ToArray()); + } + catch { return strPsw; } + } + #endregion + + #region 鈻� 鏃堕棿杞崲___________________________ + + /// <summary> + /// 灏唘tc鏃堕棿绫诲瀷鐨勫瓧绗︿覆,杞崲涓烘湰鍦版椂闂� + /// </summary> + /// <param name="timeText"></param> + /// <returns></returns> + public static DateTime ConvertUtcTimeToLocalTime(string timeText) + { + var utcTime = Convert.ToDateTime(timeText); + return TimeZoneInfo.ConvertTimeFromUtc(utcTime, TimeZoneInfo.Local); + } + + #endregion + + #region 鈻� 鏂囦欢淇濆瓨鍜岃鍙朹____________________ + + /// <summary> + /// 鏂囦欢淇濆瓨(鏁村ぉ蹇樿,鎵�浠ュ缓涓�涓嚱鏁版潵鐜╃帺) + /// </summary> + /// <param name="fullName">鍏ㄨ矾寰�</param> + /// <param name="obj">闇�瑕佸簭鍒楀寲鐨勪笢瑗�</param> + public static void SaveFileContent(string fullName, object obj) + { + var data = JsonConvert.SerializeObject(obj); + SaveTexToFile(fullName, data); + } + + /// <summary> + /// 鏂囦欢淇濆瓨(鏁村ぉ蹇樿,鎵�浠ュ缓涓�涓嚱鏁版潵鐜╃帺) + /// </summary> + /// <param name="fullName">鍏ㄨ矾寰�</param> + /// <param name="obj">闇�瑕佸簭鍒楀寲鐨勪笢瑗�</param> + public static void SaveTexToFile(string fullName, string textValue) + { + var byteData = Encoding.UTF8.GetBytes(textValue); + //鍐欏叆鍐呭 + System.IO.FileStream fileStream = null; + try + { + fileStream = new System.IO.FileStream(fullName, System.IO.FileMode.Create, System.IO.FileAccess.Write); + fileStream.Write(byteData, 0, byteData.Length); + fileStream.Flush(); + } + catch { } + finally + { + fileStream?.Close(); + } + } + + /// <summary> + /// 璇诲彇鏂囦欢,涓嶉檺鍒朵綇瀹�(鏂囦欢涓嶅瓨鍦ㄨ繑鍥瀗ull,鏁村ぉ蹇樿,鎵�浠ュ缓涓�涓嚱鏁版潵鐜╃帺) + /// </summary> + /// <param name="fullName">鍏ㄨ矾寰�</param> + /// <returns></returns> + public static string LoadFileContent(string fullName) + { + //璇诲彇鏂囦欢 + var varByte = ReadFileContent(fullName); + if (varByte == null) + { + return null; + } + return Encoding.UTF8.GetString(varByte); + } + + /// <summary> + /// 璇诲彇鏂囦欢,涓嶉檺鍒朵綇瀹�,鏂囦欢涓嶅瓨鍦ㄨ繑鍥瀗ull + /// </summary> + /// <param name="fullName">鍏ㄨ矾寰�</param> + /// <returns></returns> + public static byte[] ReadFileContent(string fullName) + { + if (System.IO.File.Exists(fullName) == false) + { + return null; + } + System.IO.FileStream fileStream = null; + try + { + fileStream = new System.IO.FileStream(fullName, System.IO.FileMode.Open, System.IO.FileAccess.Read); + byte[] array = new byte[fileStream.Length]; + fileStream.Read(array, 0, array.Length); + return array; + } + catch + { + return null; + } + finally + { + fileStream?.Close(); + } } #endregion -- Gitblit v1.8.0