From f788a1e320b8505435ed66e2456ddb2d0a838f76 Mon Sep 17 00:00:00 2001 From: JLChen <551775569@qq.com> Date: 星期四, 19 十一月 2020 19:58:14 +0800 Subject: [PATCH] 2020-11-19 1.优化绑定和解绑页面。2.修改密码功能实现,UI界面实现,接口实现。 --- HDL_ON/DAL/Server/HttpServerRequest.cs | 964 +++++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 708 insertions(+), 256 deletions(-) diff --git a/HDL_ON/DAL/Server/HttpServerRequest.cs b/HDL_ON/DAL/Server/HttpServerRequest.cs index d7c2587..b31745f 100644 --- a/HDL_ON/DAL/Server/HttpServerRequest.cs +++ b/HDL_ON/DAL/Server/HttpServerRequest.cs @@ -31,18 +31,40 @@ */ - public string relaseaSever = "https://global.hdlcontrol.com/HangZhouHdlCloudApi"; - public string debugSever = "https://global.hdlcontrol.com/ProposedProductionApi"; - string severAddress; + string severAddress = "https://global.hdlcontrol.com/ProposedProductionApi"; public HttpServerRequest() { -#if DEBUG - severAddress = debugSever; -#else - severAddress = relaseaSever; -#endif + } + + /// <summary> + /// 鑾峰彇浼犳劅鍣ㄥ巻鍙叉暟鎹� + /// </summary> + /// <param name="subnetId"></param> + /// <param name="deviceId"></param> + /// <param name="bigClass"></param> + /// <param name="minClass"></param> + /// <param name="queryType"></param> + /// <param name="loopId"></param> + /// <param name="nowMonth"></param> + /// <param name="mac"></param> + /// <returns></returns> + public ResponsePack GetSensorHistory(int subnetId, int deviceId, int bigClass, int minClass, int queryType, int loopId, int nowMonth, string mac) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("SubnetID", subnetId); + d.Add("DeviceID", deviceId); + d.Add("LargeType", bigClass); + d.Add("SmallType", minClass); + d.Add("QueryType", queryType); + d.Add("loopId", loopId); + d.Add("NowMonth", nowMonth); + d.Add("MAC", DB_ResidenceData.residenceData.residenceGatewayMAC); + d.Add("LocalTimeZone", 8); + var jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps("https://developer.hdlcontrol.com/api/GetSensorPushHistory", jsonString, true); + } public string GetRequestResultMsg(string resultCode) @@ -60,7 +82,7 @@ result = Language.StringByID(StringId.FailedToSendVerificationCode); break; case "EXIST": - result = Language.StringByID(StringId.AccountAlreadyExists); + result = Language.StringByID(StringId.AccountAlreadyUse); break; case "Self:Net_Error": result = Language.StringByID(StringId.NetworkAnomaly); @@ -69,146 +91,205 @@ return result; } + #region 鈻� 閫氱敤璇锋眰鎺ュ彛_______________________ + /// <summary> + /// 鏍规鐢ㄦ埛璐﹀彿鑾峰彇娉ㄥ唽鍖哄煙 鍏嶇櫥褰� // 妫�娴嬭处鍙锋槸鍚︽敞鍐屼篃鐢ㄨ繖涓帴鍙� + /// </summary> + /// <param name="account"></param> + /// <returns></returns> + public ResponsePackNew GetRegionByAccount(string account) + { + var requestJson = HttpUtil.GetSignRequestJson(new RegionByAccountObj() { account = account }); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_GetRegionByAccount, requestJson); + } + + /// <summary> + /// 鍒锋柊Token + /// </summary> + /// <returns></returns> + public bool RefreshToken() + { + var requestJson = HttpUtil.GetSignRequestJson(new RefreshTokenObj() + { + refreshToken = MainPage.LoginUser.refreshToken, + }); + var revertObj = HttpUtil.RequestHttpsPost(NewAPI.API_POST_Login, requestJson); + if (revertObj.Code.ToUpper() == StateCode.SUCCESS) + { + var revertData = Newtonsoft.Json.JsonConvert.DeserializeObject<UserLoginRes>(revertObj.Data.ToString()); + MainPage.LoginUser.loginTokenString = revertData.headerPrefix + revertData.accessToken; + MainPage.LoginUser.lastTime = DateTime.Now; + MainPage.LoginUser.SaveUserInfo(); + return true; + } + return false; + } + + #endregion #region 娉ㄥ唽銆佺櫥褰曢儴鍒� /// <summary> + /// 鑾峰彇璇锋眰鎻愪氦鐨勮瑷�鍙傛暟 + /// </summary> + public string GetPostLanguageType() + { + return Language.CurrentLanguage == "Chinese" ? LanguageTypeEnum.CHINESE.ToString() : LanguageTypeEnum.ENGLISH.ToString(); + } + + /// <summary> + /// 閫氱敤 鍙戦�侀獙璇佺爜鏂规硶 + /// </summary> + /// <param name="verifyType">1:娉ㄥ唽 2锛氭壘鍥炲瘑鐮� 3锛氱粦瀹�4:楠岃瘉鐮佺櫥闄� 5:鏁忔劅鏁版嵁</param> + /// <param name="account">閭鎴栬�呮墜鏈哄彿</param> + /// <param name="isPhone">鏄惁鎵嬫満</param> + /// <param name="phoneZoneCode">鎵嬫満鍥藉鍖哄彿</param> + /// <returns></returns> + public ResponsePackNew VerificationCodeSend(VerifyType verifyType, string account, bool isPhone = false, string phoneZoneCode = "86") + { + var requestObj = new VerifyCodeSendObj() + { + verifyType = (int)verifyType, + languageType = GetPostLanguageType() + }; + // 鏄惁鏄墜鏈� + if (isPhone) + { + requestObj.phone = account; + requestObj.phonePrefix = phoneZoneCode; + } + else + { + requestObj.mail = account; + } + // 瓒呮椂鏃堕棿璁剧疆涓�20绉掞紝搴旇娴嬭瘯娴峰鏈嶅姟鍣ㄥ彂閫侀獙璇佺爜鍝嶅簲鏃堕棿寰堜箙 + var requestJson = HttpUtil.GetSignRequestJson(requestObj); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Verification_Send, requestJson, "", "", HttpUtil.TIME_OUT_LONG); + } + + /// <summary> /// 璐﹀彿鐧诲綍-浣跨敤瀵嗙爜 /// </summary> - public ResponsePack LoginByPassword(string account, string password) + /// <param name="account">璐﹀彿</param> + /// <param name="password">瀵嗙爜</param> + /// <returns></returns> + public ResponsePackNew LoginByPassword(string account, string password) { - string jsonString = "{" + - "\"Account\":" + "\"" + account + "\"" + "," + - "\"Password\":" + "\"" + password + "\"" + - "}"; - return RequestHttps($"{severAddress}/ZigbeeUsers/Login", jsonString, false); + var requestJson = HttpUtil.GetSignRequestJson(new LoginObj() + { + account = account, + loginPwd = password + }); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Login, requestJson); } /// <summary> /// 楠岃瘉鐮佺櫥褰� /// </summary> - public ResponsePack LoginValidCode(string account,string vCode) + /// <param name="account">璐﹀彿</param> + /// <param name="vCode">楠岃瘉鐮�</param> + /// <returns></returns> + public ResponsePackNew LoginValidCode(string account, string vCode) { - Dictionary<string, object> d = new Dictionary<string, object>(); - d.Add("Account", account); - d.Add("Code", vCode); - d.Add("Language", Language.CurrentLanguage); - d.Add("AreaCode", "86"); - var jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); - return RequestHttps($"{severAddress}/ZigbeeUsers/LoginValidCode", jsonString, false); - } - - /// <summary> - /// 鎵嬫満鍙风爜娉ㄥ唽 - /// </summary> - /// <param name="mobileNumber"></param> - /// <param name="password"></param> - /// <param name="language"></param> - public ResponsePack RegisterPhone(string mobileNumber, string password, string language) - { - string jsonString = "{" + - "\"Account\":" + "\"" + mobileNumber + "\"" + "," + - "\"Password\":" + "\"" + password + "\"" + "," + - "\"Language\":" + "\"" + language + "\"" + - "\"AreaCode\":" + "\"" + "86" + "\"" + - "}"; - return RequestHttps($"{severAddress}/SignIn", jsonString, false); - } - - public ResponsePack GetAreaCode() - { - string requestJson = "{}"; - return RequestHttps($"{severAddress}/ZigbeeUsers/GetAreaCode", requestJson, false); + var requestJson = HttpUtil.GetSignRequestJson(new LoginObj() + { + account = account, + verifyCode = vCode, + grantType = "verify" + }); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Login, requestJson); } /// <summary> /// 楠岃瘉鐭俊鎴栬�呴偖绠遍獙璇佺爜锛屼箣鍚庢敞鍐� /// </summary> - /// <param name="account">璐﹀彿</param> + /// <param name="account">閭鎴栬�呮墜鏈哄彿</param> /// <param name="password">瀵嗙爜</param> - /// <param name="entryPassword">纭瀵嗙爜</param> /// <param name="code">楠岃瘉鐮�</param> - /// <param name="areaCode"></param> + /// <param name="isPhone">鏄惁鎵嬫満</param> /// <returns></returns> - public ResponsePack ValidataCodeAndRegister(string account, string password, string entryPassword, string code, int areaCode) + public ResponsePackNew ValidataCodeAndRegister(string account, string password, string code, bool isPhone = false) { - //var requestObj = new ValidateSmsCodeObj() { Phone = accout, Code = code }; - //var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(requestObj); - string requestJson = "{" + - "\"Account\":" + "\"" + account + "\"" + "," + - "\"Password\":" + "\"" + password + "\"" + "," + - "\"EnterPassword\":" + "\"" + entryPassword + "\"" + "," + - "\"Language\":" + "\"" + MainPage.LoginUser.language.ToLower() + "\"" + "," + - "\"Code\":" + "\"" + code + "\"" + "," + - "\"RegisterSoruce\":" + 0 + "," + - "\"AreaCode\":" + areaCode + - "}"; - return RequestHttps($"{severAddress}/ZigbeeUsers/ValidataCodeAndRegisterAccount", requestJson, false); - } - - - /// <summary> - /// 鑾峰彇娉ㄥ唽楠岃瘉鐮� - /// </summary> - public ResponsePack GetPhoneRegisterVerCode(string account) - { - string jsonString = "{" + - "\"Account\":" + "\"" + account + "\"" + "," + - "\"Company\":" + MainPage.Company + "," + - "\"Language\":" + "\"" + MainPage.LoginUser.language.ToLower() + "\"" + "," + - "\"AreaCode\":" + OnAppConfig.Instance.CountryNumber + - "}"; - return RequestHttps($"{severAddress}/ZigbeeUsers/RegisterSendVerCode", jsonString, false); - - } - - - - - /// <summary> - /// 鑾峰彇鐧诲綍楠岃瘉鐮� - /// </summary> - /// <param name="phoneNum">鎵嬫満鍙风爜</param> - public ResponsePack GetPhoneLoginVerCode(string phoneNum) - { - - string jsonString = "{" + - "\"Account\":" + "\"" + phoneNum + "\"" + "," + - "\"AreaCode\":" + "86" + - "}"; - return RequestHttps($"{severAddress}/ZigbeeUsers/LoginSendVerCode", jsonString, false); + var requestObj = new RegisterObj() { loginPwd = password, verifyCode = code, memberName = account }; + if (isPhone) + { + requestObj.memberPhone = account; + } + else + { + requestObj.memberEmail = account; + } + var requestJson = HttpUtil.GetSignRequestJson(requestObj); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Member_Register, requestJson); } /// <summary> - /// 鍙戦�侀獙璇佺爜 + /// 蹇樿瀵嗙爜锛岄噸缃瘑鐮� /// </summary> - public ResponsePack SendSms(string account) + /// <param name="account">閭鎴栬�呮墜鏈哄彿</param> + /// <param name="password">鏂板瘑鐮�</param> + /// <param name="vCode">楠岃瘉鐮�</param> + /// <param name="isPhone">鏄惁鎵嬫満璐﹀彿</param> + /// <returns></returns> + public ResponsePackNew ForgetPassword(string account, string password, string vCode, bool isPhone) { - string jsonString = "{" + - "\"Account\":" + "\"" + account + "\"" + "," + - "\"Company\":" + MainPage.Company + "," + - "\"Language\":" + "\"" + Language.CurrentLanguage + "\"" + "," + - "\"AreaCode\":" + OnAppConfig.Instance.CountryNumber + - "}"; - return RequestHttps($"{severAddress}/ZigbeeUsers/LoginSendVerCode", jsonString, false); + var requestObj = new ForgetPwdObj() { verifyCode = vCode, loginPwd = password }; + if (isPhone) + { + //鎵嬫満蹇樿瀵嗙爜 + requestObj.memberPhone = account; + } + else + { + //閭蹇樿瀵嗙爜 + requestObj.memberEmail = account; + } + var requestJson = HttpUtil.GetSignRequestJson(requestObj); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Member_ForgetPwd, requestJson); } + + + + ///// <summary> + ///// 鑾峰彇鐧诲綍楠岃瘉鐮� + ///// </summary> + //public ResponsePack GetLoginVerCode(string account) + //{ + + // string jsonString = "{" + + // "\"Account\":" + "\"" + account + "\"" + "," + + // "\"AreaCode\":" + "86" + + // "}"; + // return RequestHttps($"{severAddress}/ZigbeeUsers/LoginSendVerCode", jsonString, false); + //} /// <summary> /// 楠岃瘉楠岃瘉鐮� /// </summary> - /// <param name="account"></param> - /// <param name="code"></param> + /// <param name="verifyType">楠岃瘉绫诲瀷</param> + /// <param name="account">楠岃瘉璐﹀彿</param> + /// <param name="code">楠岃瘉鐮�</param> + /// <param name="isPhone">鏄惁鎵嬫満</param> + /// <param name="verifySuccessFail">楠岃瘉閫氳繃鍚庯紝楠岃瘉鐮佹槸鍚﹀け鏁�</param> /// <returns></returns> - public ResponsePack ValidatorCode(string account, string code, int countryIndex) + public ResponsePackNew ValidatorCode(VerifyType verifyType, string account, string code, bool isPhone, bool verifySuccessFail = true) { - string jsonString = "{" + - "\"Account\":" + "\"" + account + "\"" + "," + - "\"Code\":" + "\"" + code + "\"" + "," + - "\"Language\":" + "\"" + Language.CurrentLanguage + "\"" + "," + - "\"AreaCode\":" + countryIndex + - "}"; - return RequestHttps($"{severAddress}/ZigbeeUsers/ValidatorCode", jsonString, false); + var requestObj = new VerifyCodeCheckObj() { verifyCode = code, verifyType = (int)verifyType , verifySuccessFail = verifySuccessFail }; + if (isPhone) + { + //鎵嬫満 + requestObj.phone = account; + } + else + { + //閭 + requestObj.mail = account; + } + var requestJson = HttpUtil.GetSignRequestJson(requestObj); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Verification_Check, requestJson); } + + /// <summary> /// 閲嶈瀵嗙爜 @@ -231,60 +312,111 @@ /// 鑾峰彇鐢ㄦ埛淇℃伅 /// </summary> /// <returns></returns> - public void GetUserInfo() + public void GetUserInfo(bool bGetHeadImage = true) { - Dictionary<string, object> d = new Dictionary<string, object>(); - var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(d); - var revertObj = RequestHttps($"{severAddress}/ZigbeeUsers/GetAccountInfo", requestJson, true); - - if (revertObj.StateCode.ToUpper() == "SUCCESS") + var requestJson = HttpUtil.GetSignRequestJson(new NullObj()); + var resultObj = HttpUtil.RequestHttpsPost(NewAPI.API_POST_Member_GetMemberInfo, requestJson); + if (resultObj.Code == StateCode.SUCCESS) { - var dataStr = JObject.FromObject(revertObj.ResponseData); - //"DistributedMark": "96439601-fd26-4768-8440-1d9dfa32c109", < !--甯愬彿Id-- > - MainPage.LoginUser.userEmailInfo = dataStr.GetValue("Email").ToString(); - MainPage.LoginUser.userMobileInfo = dataStr.GetValue("Phone").ToString(); - FileStream fs = null; - try + var info = Newtonsoft.Json.JsonConvert.DeserializeObject<MemberInfoRes>(resultObj.Data.ToString()); + MainPage.LoginUser.userEmailInfo = info.memberEmail; + MainPage.LoginUser.userMobileInfo = info.memberPhone; + MainPage.LoginUser.userName = info.memberName; + MainPage.LoginUser.areaCode = info.memberPhonePrefix; + //鏄惁闇�瑕佽幏鍙栧ご鍍� + if (bGetHeadImage) { - var headImageString = dataStr.GetValue("HeadImage").ToString(); - var jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(headImageString); - var headImageBytes = Newtonsoft.Json.JsonConvert.DeserializeObject<byte[]>(jsonString); - MainPage.LoginUser.headImagePageBytes = headImageBytes; - var filePath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Personal) + "/", "headImage.png"); + var headImageBytes = DownHeadImage(); + if (headImageBytes != null) + { + MainPage.LoginUser.headImagePageBytes = headImageBytes; + FileStream fs = null; + try + { + MainPage.LoginUser.headImagePageBytes = headImageBytes; + var filePath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Personal) + "/", "headImage.png"); + fs = new FileStream(filePath, FileMode.Create, FileAccess.Write); + fs.Write(headImageBytes, 0, headImageBytes.Length); + fs.Flush(); + MainPage.LoginUser.headImagePagePath = filePath; + } + catch (Exception ex) + { + MainPage.Log($"download headImage error : {ex.Message}"); + } + finally + { + if (fs != null) + { + fs.Close(); + } + } -#if DEBUG - Application.RunOnMainThread(() => - { - new Tip() { CloseTime = 5, Text = filePath }.Show(MainPage.BasePageView); - }); -#endif - fs = new FileStream(filePath, FileMode.Create, FileAccess.Write); - fs.Write(headImageBytes, 0, headImageBytes.Length); - fs.Flush(); - MainPage.LoginUser.headImagePagePath = filePath; - } catch (Exception ex) - { - MainPage.Log($"download headImage error : {ex.Message}"); - } - finally - { - if (fs != null) - { - fs.Close(); } } - // "GesturePwd": null, < !--鎵嬪娍瀵嗙爜-- > - // "StringPwd": null , < !--瀛楃涓插瘑鐮�-- > - MainPage.LoginUser.userName = dataStr.GetValue("UserName").ToString(); - - Application.RunOnMainThread(() => - { - }); MainPage.LoginUser.SaveUserInfo(); MainPage.Log("鑾峰彇鐢ㄦ埛淇℃伅鎴愬姛銆�"); } + + // Dictionary<string, object> d = new Dictionary<string, object>(); + //var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(d); + //var revertObj = RequestHttps($"{severAddress}/ZigbeeUsers/GetAccountInfo", requestJson, true); + + //if (revertObj.StateCode.ToUpper() == StateCode.SUCCESS) + //{ + // var dataStr = JObject.FromObject(revertObj.ResponseData); + // //"DistributedMark": "96439601-fd26-4768-8440-1d9dfa32c109", < !--甯愬彿Id-- > + // MainPage.LoginUser.userEmailInfo = dataStr.GetValue("Email").ToString(); + // MainPage.LoginUser.userMobileInfo = dataStr.GetValue("Phone").ToString(); + // FileStream fs = null; + // try + // { + // var headImageString = dataStr.GetValue("HeadImage").ToString(); + // if (!string.IsNullOrEmpty(headImageString)) + // { + // var jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(headImageString); + // var headImageBytes = Newtonsoft.Json.JsonConvert.DeserializeObject<byte[]>(jsonString); + // MainPage.LoginUser.headImagePageBytes = headImageBytes; + // var filePath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.Personal) + "/", "headImage.png"); + // fs = new FileStream(filePath, FileMode.Create, FileAccess.Write); + // fs.Write(headImageBytes, 0, headImageBytes.Length); + // fs.Flush(); + // MainPage.LoginUser.headImagePagePath = filePath; + // } + // } + // catch (Exception ex) + // { + // MainPage.Log($"download headImage error : {ex.Message}"); + // } + // finally + // { + // if (fs != null) + // { + // fs.Close(); + // } + // } + // // "GesturePwd": null, < !--鎵嬪娍瀵嗙爜-- > + // // "StringPwd": null , < !--瀛楃涓插瘑鐮�-- > + // MainPage.LoginUser.userName = dataStr.GetValue("UserName").ToString(); + + // Application.RunOnMainThread(() => + // { + // }); + + // MainPage.LoginUser.SaveUserInfo(); + // MainPage.Log("鑾峰彇鐢ㄦ埛淇℃伅鎴愬姛銆�"); + //} + + } + + /// <summary> + /// 涓嬭浇鐢ㄦ埛澶村儚 + /// </summary> + public byte[] DownHeadImage() + { + return HttpUtil.RequestHttpsDownload(NewAPI.API_POST_Head_Down, null); } /// <summary> @@ -292,14 +424,12 @@ /// </summary> /// <param name="userName"></param> /// <returns></returns> - public ResponsePack EditUserName(string userName) + public ResponsePackNew EditUserName(string userName) { - Dictionary<string, string> d = new Dictionary<string, string>(); - d.Add("UserName", userName); - var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(d); - var revertObj = RequestHttps($"{severAddress}/ZigbeeUsers/UpdateUserName", requestJson, true); - return revertObj; - + var requestJson = HttpUtil.GetSignRequestJson(new UpdateMemberNameRes() { + memberName = userName + }); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Member_UpdateMemberInfo, requestJson); } /// <summary> @@ -312,60 +442,176 @@ FileStream fs = new FileStream(fileName, FileMode.Open, FileAccess.Read); byte[] bytes = new byte[fs.Length]; fs.Read(bytes, 0, bytes.Length); - - Dictionary<string, byte[]> d = new Dictionary<string, byte[]>(); - d.Add("HeadImage", bytes); - var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(d); - - var revertObj = RequestHttps($"{severAddress}/ZigbeeUsers/UpdateHeadImage", requestJson, true); - return revertObj.StateCode; + var revertObj = HttpUtil.RequestHttpsUpload(RestSharp.Method.POST, NewAPI.API_POST_Head_Upload, bytes); + return revertObj.Code; } + + /// <summary> + /// 鏇存敼缁戝畾璐︽埛鐨勯偖绠辨垨鑰呮墜鏈哄彿 + /// 2020-11-16 寰呬慨鏀� + /// </summary> + /// <param name="account"></param> + /// <param name="code"></param> + /// <param name="isPhone"></param> + /// <returns></returns> + public string BindAccount(string account, string code = "", bool isPhone = false) + { + var requestObj = new BindWithAccountObj() { verifyCode = code}; + if (isPhone) + { + //鎵嬫満 + requestObj.memberPhone = account; + } + else + { + //閭 + requestObj.memberEmail = account; + } + var requestJson = HttpUtil.GetSignRequestJson(requestObj); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Member_BindWithAccount, requestJson).Code; + } + + /// <summary> + /// 瑙g粦鎵嬫満鎴栬�呴偖绠� + /// </summary> + /// <param name="isPhone"></param> + /// <returns></returns> + public string UnBindAccount(bool isPhone) + { + var requestObj = new UnBindAccountObj() { unBindLabel = isPhone ? "PHONE": "EMAIL" }; + var requestJson = HttpUtil.GetSignRequestJson(requestObj); + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Member_UnbindWithAccount, requestJson).Code; + } + #endregion #region 浣忓畢閮ㄥ垎 /// <summary> /// 鑾峰彇浣忓畢鍒楄〃 /// </summary> - public string GetHomePager() + public string GetHomePager(HomeTypeEnum homeType = HomeTypeEnum.ALL) { - string jsonString = "{" + - "\"RequestVersion\":" + "\"" + MainPage.VersionString + "\"" + "," + - "\"RequestSource\":" + "\"" + "2" + "\"" + "," + - "\"HomeType\":" + "\"" + "1" + "\"" + "," + - "\"LoginAccessToken\":" + "\"" + MainPage.LoginUser.loginTokenString + "\"" + - "}"; - var responsePack = RequestHttps($"{severAddress}/App/GetHomePager", jsonString,false); - - if (responsePack.StateCode.ToUpper() == "SUCCESS") + var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(new GetHomeListObj() { homeType = homeType.ToString() }); + var resultObj = HttpUtil.RequestHttpsPost(NewAPI.API_POST_Gethomepager, requestJson); + if(resultObj.Code == StateCode.SUCCESS) { - var dataStr = JObject.FromObject(responsePack.ResponseData); - //娌℃湁浣忓畢 - if (dataStr.GetValue("PageData").ToString() == "[]") - { + var homeList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<RegionInfoResNew>>(resultObj.Data.ToString()); + if (homeList == null || homeList.Count == 0) { + } else { MainPage.LoginUser.regionList = new List<RegionInfoRes>(); - foreach (var jsonData in dataStr.GetValue("PageData")) + + foreach (var mHome in homeList) { - var homeJsonStr = JObject.FromObject(jsonData); var home = new RegionInfoRes() { - RegionID = homeJsonStr.GetValue("Id").ToString(), - RegionName = homeJsonStr.GetValue("RegionName").ToString(), - Name = homeJsonStr.GetValue("Name").ToString(), - Address = homeJsonStr.GetValue("Address").ToString(), + RegionID = mHome.Id, + Name = mHome.homeName, + IsOthreShare = mHome.IsOtherShare, + accountType = mHome.accountType, + isRemoteControl = mHome.isRemoteControl, + longitude = mHome.longitude, + latitude = mHome.latitude, + deliverstatus = mHome.deliverstatus, + homeType = mHome.homeType, + regionUrl = mHome.regionUrl, + emqUrl = mHome.emqUrl, + homeRegionName = mHome.homeRegionName, + homeRegionId = mHome.homeRegionId, + Address = mHome.homeAddress, }; + if (home.IsOthreShare) + { + continue; + } MainPage.LoginUser.regionList.Add(home); + if (string.IsNullOrEmpty(DB_ResidenceData.residenceData.CurReginID)) + { + DB_ResidenceData.residenceData.CurReginID = MainPage.LoginUser.regionList[0].RegionID; + } } DB_ResidenceData.residenceData.SaveResidenceData(); MainPage.LoginUser.SaveUserInfo(); } + } - return responsePack.StateCode; + return resultObj.Code; + //string jsonString = "{" + + // "\"RequestVersion\":" + "\"" + MainPage.VersionString + "\"" + "," + + // "\"RequestSource\":" + "\"" + "2" + "\"" + "," + + // "\"HomeType\":" + "\"" + "1" + "\"" + "," + + // "\"LoginAccessToken\":" + "\"" + MainPage.LoginUser.loginTokenString + "\"" + + // "}"; + //var responsePack = RequestHttps($"{severAddress}/App/GetHomePager", jsonString, false); + + //if (responsePack.StateCode.ToUpper() == StateCode.SUCCESS_CODE) + //{ + // var dataStr = JObject.FromObject(responsePack.ResponseData); + // //娌℃湁浣忓畢 + // if (dataStr.GetValue("PageData").ToString() == "[]") + // { + + // } + // else + // { + // //{ + // // { + // // "Id": "1107487", + // // "HomeStatus": 2, + // // "UserGuid": "22980", + // // "Name": "鍟�", + // // "Address": null, + // // "Longitude": 0.0, + // // "Latitude": 0.0, + // // "RegionName": null, + // // "Company": null, + // // "ContactPerson": null, + // // "ContactPersonPhone": null, + // // "Remarks": null, + // // "ChangeDate": null, + // // "AccountType": 0, + // // "CreatedOnUtc": "2020-05-27T06:52:03", + // // "IsOthreShare": false, + // // "MainUserDistributedMark": null, + // // "HomeGateways": [ + // // { + // // "GatewayUniqueId": "4E47323347591243" + // // } + // // ] + // //}} + // MainPage.LoginUser.regionList = new List<RegionInfoRes>(); + // foreach (var jsonData in dataStr.GetValue("PageData")) + // { + // var homeJsonStr = JObject.FromObject(jsonData); + // var home = new RegionInfoRes() + // { + // RegionID = homeJsonStr.GetValue("Id").ToString(), + // RegionName = homeJsonStr.GetValue("RegionName").ToString(), + // Name = homeJsonStr.GetValue("Name").ToString(), + // Address = homeJsonStr.GetValue("Address").ToString(), + // IsOthreShare = (bool)homeJsonStr.GetValue("IsOthreShare"), + // homeGateways = Newtonsoft.Json.JsonConvert.DeserializeObject<List<HomeGateways>>(homeJsonStr.GetValue("HomeGateways").ToString()), + // }; + // if (home.IsOthreShare) + // { + // continue; + // } + // MainPage.LoginUser.regionList.Add(home); + // if (string.IsNullOrEmpty(DB_ResidenceData.residenceData.CurReginID)) + // { + // DB_ResidenceData.residenceData.CurReginID = MainPage.LoginUser.regionList[0].RegionID; + // } + // } + // DB_ResidenceData.residenceData.SaveResidenceData(); + // MainPage.LoginUser.SaveUserInfo(); + // } + //} + //return responsePack.StateCode; } /// <summary> /// 缂栬緫浣忓畢淇℃伅 @@ -390,6 +636,178 @@ return RequestHttps($"{severAddress}/App/EditHome", jsonString, false); } + /// <summary> + /// 鑾峰彇浣忓畢涓嬬殑鎴愬憳璐﹀彿 + /// </summary> + /// <returns></returns> + public ResponsePackNew GetResidenceMemberAccount() + { + var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(new HomeIdObj() { homeId = DB_ResidenceData.residenceData.residecenInfo.RegionID }); + var replaceToken = MainPage.LoginUser.loginTokenString; + //濡傛灉褰撳墠鎵�鍒嗕韩浣忓畢鍜屼负绠$悊鍛橈紝鏇挎崲涓轰富浜簍oken + //寰呭鐞�... + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Child_FindAll, requestJson, DB_ResidenceData.residenceData.residecenInfo.regionUrl, replaceToken); + } + + /// <summary> + /// 鍒犻櫎浣忓畢涓嬬殑鎴愬憳璐﹀彿 + /// </summary> + /// <returns></returns> + public ResponsePackNew DeleteResidenceMemberAccount(ResidenceMemberInfo subaccount) + { + var requestObj = new ChildDeleteObj() + { + childAccountId = subaccount.childAccountId, + homeId = subaccount.homeId + }; + var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(requestObj); + var replaceToken = MainPage.LoginUser.loginTokenString; + //濡傛灉褰撳墠鎵�鍒嗕韩浣忓畢鍜屼负绠$悊鍛橈紝鏇挎崲涓轰富浜簍oken + //寰呭鐞�... + return HttpUtil.RequestHttpsPost(NewAPI.API_POST_Child_Delete, requestJson, DB_ResidenceData.residenceData.residecenInfo.regionUrl, replaceToken); + } + + /// <summary> + /// 淇敼瀛愯处鍙锋樀绉� + /// </summary> + /// <param name="nickName"></param> + /// <param name="subAccountGuid"></param> + /// <returns></returns> + public ResponsePack EditSubAccountNickName(string nickName, string subAccountGuid) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("SubAccountGuid", subAccountGuid); + d.Add("NickName", nickName); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeUsers/EditSubAccountNickName", jsonString, true); + } + /// <summary> + /// 淇敼瀛愯处鍙峰垱寤哄満鏅潈闄� + /// </summary> + /// <param name="nickName"></param> + /// <param name="subAccountGuid"></param> + /// <returns></returns> + public ResponsePack ChangeCreateSceneState(string homeGuid, string subAccountGuid) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("SubAccountGuid", subAccountGuid); + d.Add("HomeGuid", homeGuid); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeUsers/ChangeCreateSceneState", jsonString, true); + } + + /// <summary> + /// 鑾峰彇浣忓畢涓嬪瓙璐﹀彿鐨勫叡浜暟鎹垪琛� + /// </summary> + /// <returns></returns> + public ResponsePack GetShareDataByMemberAccount(string memberId) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("DistributedMark", memberId); + d.Add("HouseDistributedMark", DB_ResidenceData.residenceData.residecenInfo.RegionID); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeDataShare/GetShareDataBySubAccount", jsonString, true); + } + + /// <summary> + /// 鑾峰彇浣忓畢涓嬪瓙璐﹀彿鐨勫叡浜暟鎹� + /// </summary> + /// <returns></returns> + public ResponsePack GetShareData(string memberId, string hId) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("DistributedMark", memberId); + d.Add("HouseDistributedMark", hId); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeDataShare/GetOneShareData", jsonString, true); + } + + /// <summary> + /// 澧炲姞鍏变韩鏁版嵁鍒楄〃 + /// </summary> + /// <returns></returns> + public ResponsePack AddShareData(ShareData shareData) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("ShareName", shareData.ShareName); + d.Add("HouseDistributedMark", shareData.HouseDistributedMark); + d.Add("ShareDataBytes", shareData.ShareDataBytes); + d.Add("SubAccountDistributedMark", shareData.SubAccountDistributedMark); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeDataShare/AddShareData", jsonString, true); + } + + /// <summary> + /// 澧炲姞鍏变韩鏁版嵁 + /// </summary> + /// <returns></returns> + public ResponsePack EditShareData(ShareData shareData) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("DistributedMark", shareData.DistributedMark); + d.Add("ShareName", shareData.ShareName); + d.Add("HouseDistributedMark", shareData.HouseDistributedMark); + d.Add("ShareDataBytes", shareData.ShareDataBytes); + d.Add("SubAccountDistributedMark", shareData.SubAccountDistributedMark); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeDataShare/EditShareData", jsonString, true); + } + + /// <summary> + /// 鍒犻櫎鍏变韩鏁版嵁 + /// </summary> + /// <param name="shareData"></param> + /// <returns></returns> + public ResponsePack DeleteShareData(ShareData shareData) + { + Dictionary<string, string> d = new Dictionary<string, string>(); + d.Add("DistributedMark", shareData.DistributedMark); + d.Add("HouseDistributedMark", shareData.HouseDistributedMark); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeDataShare/DeleteShareData", jsonString, true); + } + /// <summary> + /// 鍒犻櫎瀛愯处鍙峰綋鍓嶄綇瀹呯殑鎵�鏈夊叡浜暟鎹� + /// </summary> + /// <returns></returns> + public ResponsePack DeleteCurrentResidenceSharedData(ShareData shareData) + { + Dictionary<string, string> d = new Dictionary<string, string>(); + d.Add("SubAccountDistributedMark", shareData.SubAccountDistributedMark); + d.Add("HouseDistributedMark", shareData.HouseDistributedMark); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeDataShare/DeleteShareData", jsonString, true); + } + + /// <summary> + /// 缁戝畾瀛愯处鍙峰埌浣忓畢涓� + /// </summary> + /// <param name="subAccount"></param> + /// <param name="nickName"></param> + /// <returns></returns> + public ResponsePack BindResidenceMemberAccount(string subAccount, string nickName) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("SubAccount", subAccount); + d.Add("HouseDistributedMark", DB_ResidenceData.residenceData.residecenInfo.RegionID); + d.Add("Nickname", nickName); + d.Add("IsAllowRemoteCtrl", true); + + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeUsers/BindSubAccount", jsonString, true); + } + + /// <summary> + /// 鑾峰彇浣忓畢涓嬬殑鎴愬憳璐﹀彿 + /// </summary> + /// <returns></returns> + public ResponsePack GetResidenceMemberAccountInfo(string account) + { + Dictionary<string, object> d = new Dictionary<string, object>(); + d.Add("Account", account); + string jsonString = Newtonsoft.Json.JsonConvert.SerializeObject(d); + return RequestHttps($"{severAddress}/ZigbeeUsers/GetSubAccountInfo", jsonString, true); + } #endregion @@ -433,9 +851,11 @@ responseString = Encoding.UTF8.GetString(webClient.DownloadData(url)); revertObj = Newtonsoft.Json.JsonConvert.DeserializeObject<ResponsePack>(responseString); jt = Newtonsoft.Json.JsonConvert.DeserializeObject<JObject>(revertObj.ResponseData.ToString()); - MainPage.cityInfo.temperature = jt.GetValue("Temperature").ToString()+ "掳"; - MainPage.cityInfo.humidity = jt.GetValue("Humidity").ToString()+"%"; + MainPage.cityInfo.temperature = jt.GetValue("Temperature").ToString(); + MainPage.cityInfo.humidity = jt.GetValue("Humidity").ToString(); MainPage.cityInfo.pm25 = jt.GetValue("Air_Quality").ToString(); + MainPage.cityInfo.windLevel = jt.GetValue("WindLevel").ToString(); + MainPage.cityInfo.weather = jt.GetValue("Weather").ToString(); break; } catch (Exception ex) @@ -445,7 +865,8 @@ } System.Threading.Thread.Sleep(1000); } - Shared.Application.RunOnMainThread(() => { + Shared.Application.RunOnMainThread(() => + { try { HDL_ON.UI.HomePage.LoadEvent_RefreshAir(); @@ -457,12 +878,58 @@ #endregion + #region mqtt杩滅▼杩炴帴锛堟棫锛� + /// <summary> + /// 璇锋眰Mqtt鏁版嵁 + /// </summary> + /// <param name="dataStringJson">璇锋眰鐨勫弬鏁�.</param> + public ResponsePack RequestMqttInfo(string dataStringJson) + { + ResponsePack revertObj = null; + + var webClient = new WebClient(); + #region + webClient.Headers.Add("CONTENT-TYPE", "application/json"); + var url = "https://global.hdlcontrol.com/ProposedProductionApi/EmqMqtt/GetConnMqttInfo"; + + byte[] bytes = null; + try + { + bytes = webClient.UploadData(url, Encoding.UTF8.GetBytes(dataStringJson)); + } + catch (Exception ex) + { + Console.WriteLine(ex.Message); + revertObj = new ResponsePack() { StateCode = "Net_Error" }; + } + + string responseString = null; + if (bytes != null) + { + responseString = Encoding.UTF8.GetString(bytes); + } + + if (responseString != null) + { + try + { + revertObj = Newtonsoft.Json.JsonConvert.DeserializeObject<ResponsePack>(responseString); + } + catch (Exception ex) + { + Console.WriteLine(ex.ToString()); + } + } + return revertObj; + #endregion + } + #endregion #region 澶囦唤閮ㄥ垎 /// <summary> /// 鑾峰彇浣忓畢澶囦唤鍒楄〃 /// </summary> - public Dictionary<int,string> GetRegionLastBackupId() + public Dictionary<int, string> GetRegionLastBackupId() { //Dialog dialog = new Dialog(); //dialog.Show(); @@ -472,7 +939,7 @@ d.Add("LevelID", DB_ResidenceData.residenceData.residecenInfo.RegionID);// 199200); var requestJson = Newtonsoft.Json.JsonConvert.SerializeObject(d); var revertObj = RequestHttps("https://developer.hdlcontrol.com/api/GetUserFolder", requestJson, true); - if(revertObj == null || revertObj.ResponseData == null) + if (revertObj == null || revertObj.ResponseData == null) { return new Dictionary<int, string>(); } @@ -485,7 +952,7 @@ } return backupList; } - + /* 2020-09-01 寮冪敤 鎭㈠鏃ф暟鎹姛鑳藉湪bus杞欢涓婂疄鐜� /// <summary> /// 鑾峰彇澶囦唤鏂囦欢鍒楄〃 /// </summary> @@ -616,7 +1083,7 @@ // backgroundImage = "Classification/Room/Roombg.png", // //backgroundImage = ss.GetValue("BackGroundImage").ToString() == "Room/r1.png" ? "Classification/Room/Roombg.png" : filePath, //}; - //DB_ResidenceData.residenceData.rooms.Add(room1); + //DB_ResidenceData.rooms.Add(room1); //roomList.Add(ss, room1); } @@ -689,23 +1156,8 @@ /// <summary> /// 鍔熻兘ID - /// 鍘傚晢浠g爜 2bytes; 01 HDL - /// 閫氳鏂瑰紡 1byte ; 01 HDL Bus; 02 Zigbee;03 KNX;04 Z-Wave - /// 浜у搧GUID 8bytes - /// 浜у搧绫诲埆 1byte ; 01 璋冨厜鍣�;02缁х數鍣�;03骞叉帴鐐规ā鍧�;04浼犳劅鍣�;05闈㈡澘 - /// 鐗╂ā鍨嬬被鍨�2bytes 01 寮�鍏崇被 --01寮�鍏�;02鎻掑骇 - /// 02 鐓ф槑 --01寮�鍏崇被;02璋冨厜绫�;03鑹叉俯;04LED - /// 03 閬槼 --01绐楀笜鐢垫満;02鐧惧彾绐�;03寮�鍚堝笜;04鍗峰笜 - /// 04 鎭掓俯鍣� --01绌鸿皟;02鍦版殩;03姣涚粏绌鸿皟 - /// 05 鏂伴 - /// 06 褰遍煶 - /// 07 闊充箰 - /// 08 鑳芥簮 - /// 09 瀹夐槻 - /// 閫氶亾鍙� 2bytes - /// Key_id 2bytes /// </summary> - /// "00010112345678901234560101230123AABB"; + /// "03010112345678901234560101230123AABB"; var buffer = Guid.NewGuid().ToByteArray(); string guid = ""; if (buffer != null) @@ -734,19 +1186,19 @@ { case "LightSwitch": case "LightMixSwitch": - var light1 = DB_ResidenceData.residenceData.functionList.lights.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && + var light1 = DB_ResidenceData.functionList.lights.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && obj.bus_Data.DeviceID == (byte)ss.GetValue("DeviceID") && obj.bus_Data.LoopID == (byte)ss.GetValue("LoopID")); if (light1 != null) { //light1.roomIdList.Add(roomSid); break; } - DB_ResidenceData.residenceData.functionList.lights.Add(new Light() + DB_ResidenceData.functionList.lights.Add(new Light() { - sid = "000101" + guid + "0102010001AABB", + sid = "030101" + guid + "0102010001AABB", name = ss.GetValue("Name").ToString(), - trait = new List<Trait>() { - new Trait { attri="on_off", max=100,min = 0, value= new List<string> { "on","off"} }, + function = new List<Trait>() { + new Trait { name="on_off", max=100,min = 0, value_key= new List<string> { "on","off"} }, }, roomIdList = roomIds, bus_Data = new BusData @@ -760,19 +1212,19 @@ case "LightDimming": case "LightDALI": case "LightMixDimming": - var light2 = DB_ResidenceData.residenceData.functionList.lights.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && + var light2 = DB_ResidenceData.functionList.lights.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && obj.bus_Data.DeviceID == (byte)ss.GetValue("DeviceID") && obj.bus_Data.LoopID == (byte)ss.GetValue("LoopID")); if (light2 != null) { //light2.roomIdList.Add(roomSid); break; } - DB_ResidenceData.residenceData.functionList.lights.Add(new Light() + DB_ResidenceData.functionList.lights.Add(new Light() { - sid = "000101" + guid + "0202020001AABB", + sid = "030101" + guid + "0202020001AABB", name = ss.GetValue("Name").ToString(), - trait = new List<Trait>() { - new Trait { attri="brightness", max=100,min = 0, value= new List<string> { "up","down"} }, + function = new List<Trait>() { + new Trait { name="brightness", max=100,min = 0, value_key= new List<string> { "up","down"} }, }, roomIdList = roomIds, //roomIdList = new List<string>() { "0001" }, @@ -787,20 +1239,20 @@ break; case "LightLogic": case "LightRGB": - var light3 = DB_ResidenceData.residenceData.functionList.lights.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && + var light3 = DB_ResidenceData.functionList.lights.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && obj.bus_Data.DeviceID == (byte)ss.GetValue("DeviceID") && obj.bus_Data.LoopID == (byte)ss.GetValue("LoopID")); if (light3 != null) { //light3.roomIdList.Add(roomSid); break; } - DB_ResidenceData.residenceData.functionList.lights.Add(new Light() + DB_ResidenceData.functionList.lights.Add(new Light() { - sid = "000101" + guid + "0202040001AABB", + sid = "030101" + guid + "0202040001AABB", name = ss.GetValue("Name").ToString(), - trait = new List<Trait>() { - new Trait { attri="brightness", max=100,min = 0, value= new List<string> { "on","off"} }, - new Trait { attri="color", max=100,min = 0, value= new List<string> { "255", "255", "255" } }, + function = new List<Trait>() { + new Trait { name="brightness", max=100,min = 0, value_key= new List<string> { "on","off"} }, + new Trait { name="color", max=100,min = 0, value_key= new List<string> { "255", "255", "255" } }, }, roomIdList = roomIds, //roomIdList = new List<string>() { roomSid }, @@ -816,22 +1268,22 @@ case "HVAC": case "ACPanel": case "ACInfrared": - var ac = DB_ResidenceData.residenceData.functionList.aCs.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && + var ac = DB_ResidenceData.functionList.aCs.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && obj.bus_Data.DeviceID == (byte)ss.GetValue("DeviceID") && obj.bus_Data.LoopID == (byte)ss.GetValue("LoopID")); if (ac != null) { //ac.roomIdList.Add(roomSid); break; } - DB_ResidenceData.residenceData.functionList.aCs.Add(new AC() + DB_ResidenceData.functionList.aCs.Add(new AC() { - sid = "000101" + guid + "0204010001AABB", + sid = "030101" + guid + "0204010001AABB", name = ss.GetValue("Name").ToString(), - trait = new List<Trait>() { - new Trait { attri="on_off", max=1,min = 0, value= new List<string> { "on","off"} }, - new Trait { attri="mode", max = 2,min =0,value = new List<string>{ "auto", "heat", "cool","dry" } }, - new Trait { attri = "fan",max = 3,min =0,value = new List<string>{ "low", "mid", "high" ,"auto"} }, - new Trait { attri = "temperature", max = 32,min=16,value = new List<string>{"up","down" } }, + function = new List<Trait>() { + new Trait { name="on_off", max=1,min = 0, value_key= new List<string> { "on","off"} }, + new Trait { name="mode", max = 2,min =0,value_key = new List<string>{ "auto", "heat", "cool","dry" } }, + new Trait { name = "fan",max = 3,min =0,value_key = new List<string>{ "low", "mid", "high" ,"auto"} }, + new Trait { name = "temperature", max = 32,min=16,value_key = new List<string>{"up","down" } }, }, roomIdList = roomIds, //roomIdList = new List<string>() { roomSid}, @@ -846,21 +1298,21 @@ break; //Entity. case "CurtainModel": - var curtain1 = DB_ResidenceData.residenceData.functionList.curtains.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && + var curtain1 = DB_ResidenceData.functionList.curtains.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && obj.bus_Data.DeviceID == (byte)ss.GetValue("DeviceID") && obj.bus_Data.LoopID == (byte)ss.GetValue("LoopID")); if (curtain1 != null) { //curtain1.roomIdList.Add(roomSid); break; } - DB_ResidenceData.residenceData.functionList.curtains.Add(new Curtain() + DB_ResidenceData.functionList.curtains.Add(new Curtain() { - sid = "000101" + guid + "0203010001AABB", + sid = "030101" + guid + "0203010001AABB", name = ss.GetValue("Name").ToString(), roomIdList = roomIds, //roomIdList = new List<string>() { roomSid }, - trait = new List<Trait>() { - new Trait { attri="on_off", max=2,min = 0, value= new List<string> { "on","off","stop"} }, + function = new List<Trait>() { + new Trait { name="on_off", max=2,min = 0, value_key= new List<string> { "on","off","stop"} }, },// "curtain", lastState = "寮�", bus_Data = new BusData @@ -872,21 +1324,21 @@ }); break; case "CurtainRoller": - var curtain2 = DB_ResidenceData.residenceData.functionList.curtains.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && + var curtain2 = DB_ResidenceData.functionList.curtains.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && obj.bus_Data.DeviceID == (byte)ss.GetValue("DeviceID") && obj.bus_Data.LoopID == (byte)ss.GetValue("LoopID")); if (curtain2 != null) { //curtain2.roomIdList.Add(roomSid); break; } - DB_ResidenceData.residenceData.functionList.curtains.Add(new Curtain() + DB_ResidenceData.functionList.curtains.Add(new Curtain() { - sid = "000101" + guid + "0203040001AABB", + sid = "030101" + guid + "0203040001AABB", name = ss.GetValue("Name").ToString(), roomIdList = roomIds, //roomIdList = new List<string>() { roomSid }, - trait = new List<Trait>() { - new Trait { attri="on_off", max=100,min = 0, value= new List<string> { "on","off","stop"} }, + function = new List<Trait>() { + new Trait { name="on_off", max=100,min = 0, value_key= new List<string> { "on","off","stop"} }, },// "rollingshutter", lastState = "20%", bus_Data = new BusData @@ -898,21 +1350,21 @@ }); break; case "CurtainTrietex": - var curtain3 = DB_ResidenceData.residenceData.functionList.curtains.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && + var curtain3 = DB_ResidenceData.functionList.curtains.Find((obj) => obj.bus_Data.SubnetID == (byte)ss.GetValue("SubnetID") && obj.bus_Data.DeviceID == (byte)ss.GetValue("DeviceID") && obj.bus_Data.LoopID == (byte)ss.GetValue("LoopID")); if (curtain3 != null) { //curtain3.roomIdList.Add(roomSid); break; } - DB_ResidenceData.residenceData.functionList.curtains.Add(new Curtain() + DB_ResidenceData.functionList.curtains.Add(new Curtain() { - sid = "000101" + guid + "0203030001AABB", + sid = "030101" + guid + "0203030001AABB", name = ss.GetValue("Name").ToString(), roomIdList = roomIds, //roomIdList = new List<string>() { roomSid }, - trait = new List<Trait>() { - new Trait { attri="on_off", max=100,min = 0, value= new List<string> { "on","off","stop"} }, + function = new List<Trait>() { + new Trait { name="on_off", max=100,min = 0, value_key= new List<string> { "on","off","stop"} }, }, lastState = "20%", bus_Data = new BusData @@ -923,7 +1375,7 @@ }, }); break; - //Entity.DB_ResidenceData.residenceData.functionList.floorHeatings.Add(new FloorHeating() + //Entity.DB_ResidenceData.functionList.floorHeatings.Add(new FloorHeating() //{ // sid = "12341212345678901234560704010004ABCD", // name = "鍦扮儹", @@ -941,7 +1393,7 @@ } } - + */ #endregion } -- Gitblit v1.8.0