| | |
| | | using HDL_ON.DAL; |
| | | using HDL_ON.DAL.Server; |
| | | using HDL_ON.Entity; |
| | | using HDL_ON.UI.UI2.FuntionControlView.Video; |
| | | using Newtonsoft.Json; |
| | | using Shared; |
| | | |
| | | namespace HDL_ON.Common |
| | |
| | | { |
| | | get |
| | | { |
| | | if(apiUtlis == null) |
| | | if (apiUtlis == null) |
| | | { |
| | | apiUtlis = new ApiUtlis(); |
| | | } |
| | |
| | | { |
| | | get |
| | | { |
| | | if(httpRequest == null) |
| | | if (httpRequest == null) |
| | | { |
| | | httpRequest = new HttpServerRequest(); |
| | | } |
| | |
| | | public bool GatewayOnlineVerification() |
| | | { |
| | | bool result = DB_ResidenceData.Instance.HomeGateway.gatewayStatus; |
| | | |
| | | if(!result) |
| | | DriverLayer.Control.Ins.GatewayOnline_Cloud = result; |
| | | if (!result) |
| | | { |
| | | |
| | | } |
| | | |
| | | return result; |
| | | } |
| | | |
| | | public bool DownloadDataComplete = false; |
| | | /// <summary> |
| | | /// 下载数据完成标记 |
| | | /// </summary> |
| | | public bool DownloadDataComplete = true; |
| | | /// <summary> |
| | | /// 下载数据 |
| | | /// </summary> |
| | | public void DownloadData() |
| | | { |
| | | if (MainPage.InternetStatus == 0) |
| | | if (MainPage.InternetStatus == 0 || MainPage.NoLoginMode) |
| | | return; |
| | | //线程开始时间 |
| | | var endTime = DateTime.Now.AddSeconds(5); |
| | | |
| | | MainPage.Log($"开始同步云端数据"); |
| | | |
| | | DownloadDataComplete = false; |
| | | |
| | | var waitPage = new Loading(); |
| | | MainPage.BaseView.AddChidren(waitPage); |
| | | waitPage.Start(); |
| | | waitPage.Start(Language.StringByID(StringId.PleaseWait)); |
| | | |
| | | string code = StateCode.SUCCESS; |
| | | |
| | | new System.Threading.Thread(() => { |
| | | var downloadDataThread = new System.Threading.Thread(() => |
| | | { |
| | | MainPage.Log($"进入读取云端数据线程"); |
| | | //===================刷新Token======================= |
| | | code = Ins.HttpRequest.RefreshToken(); |
| | | if(code != StateCode.SUCCESS) |
| | | if (code != StateCode.SUCCESS) |
| | | { |
| | | MainPage.Log($"刷新token失败"); |
| | | return; |
| | | } |
| | | endTime = DateTime.Now.AddSeconds(5); |
| | | MainPage.Log($"刷新token成功"); |
| | | //===================刷新住宅信息======================= |
| | | code = Ins.HttpRequest.GetHomePager(); |
| | |
| | | MainPage.Log($"刷新住宅信息失败"); |
| | | return; |
| | | } |
| | | endTime = DateTime.Now.AddSeconds(5); |
| | | MainPage.Log($"刷新住宅信息成功"); |
| | | //===================刷新个人信息======================= |
| | | code = Ins.HttpRequest.GetUserInfo(); |
| | |
| | | MainPage.Log($"刷新个人信息失败"); |
| | | return; |
| | | } |
| | | endTime = DateTime.Now.AddSeconds(5); |
| | | MainPage.Log($"刷新个人信息成功"); |
| | | |
| | | int count = 0; |
| | | while (count < 10) |
| | | { |
| | | if (DB_ResidenceData.Instance.CheckWhetherGatewayIdIsNull()) |
| | | { |
| | | System.Threading.Thread.Sleep(200); |
| | | } |
| | | else |
| | | { |
| | | break; |
| | | } |
| | | count++; |
| | | } |
| | | if (DB_ResidenceData.Instance.CheckWhetherGatewayIdIsNull()) |
| | | { |
| | | return; |
| | | } |
| | | //int count = 0; |
| | | //while (count < 10) |
| | | //{ |
| | | // if (DB_ResidenceData.Instance.CheckWhetherGatewayIdIsNull()) |
| | | // { |
| | | // System.Threading.Thread.Sleep(200); |
| | | // } |
| | | // else |
| | | // { |
| | | // break; |
| | | // } |
| | | // count++; |
| | | //} |
| | | //if (DB_ResidenceData.Instance.CheckWhetherGatewayIdIsNull()) |
| | | //{ |
| | | // return; |
| | | //} |
| | | |
| | | |
| | | try |
| | |
| | | var roomResult = Ins.HttpRequest.GetRoomList(); |
| | | if (roomResult.Code == StateCode.SUCCESS) |
| | | { |
| | | endTime = DateTime.Now.AddSeconds(100); |
| | | MainPage.Log($"读取房间信息成功"); |
| | | var revData = Newtonsoft.Json.JsonConvert.DeserializeObject<SpatialApiPack>(roomResult.Data.ToString()); |
| | | if (revData != null) |
| | | if (revData == null) |
| | | { |
| | | SpatialInfo.CurrentSpatial.UpdateSpatialList(revData.list, OptionType.Cover); |
| | | revData = new SpatialApiPack(); |
| | | } |
| | | { |
| | | SpatialInfo.CurrentSpatial.UpdateSpatialList(revData.list); |
| | | } |
| | | endTime = DateTime.Now.AddSeconds(5); |
| | | } |
| | | else |
| | | { |
| | |
| | | var deviceResult = Ins.HttpRequest.GetDeviceList(); |
| | | if (deviceResult.Code == StateCode.SUCCESS) |
| | | { |
| | | endTime = DateTime.Now.AddSeconds(100); |
| | | MainPage.Log($"读取设备信息成功"); |
| | | var deviceList = Newtonsoft.Json.JsonConvert.DeserializeObject<DevcieApiPack>(deviceResult.Data.ToString()); |
| | | if (deviceList != null) |
| | | if (deviceList == null) |
| | | { |
| | | if (FunctionList.List.GetDeviceFunctionList().Count > 0) |
| | | deviceList = new DevcieApiPack(); |
| | | } |
| | | string delFile = ""; |
| | | if (FunctionList.List.GetDeviceFunctionList().Count > 0) |
| | | { |
| | | |
| | | for (int i = 0; i < FunctionList.List.GetDeviceFunctionList().Count;) |
| | | { |
| | | for (int i = 0; i < FunctionList.List.GetDeviceFunctionList().Count;) |
| | | var localFunction = FunctionList.List.GetDeviceFunctionList()[i]; |
| | | if (SPK.MusicSpkList().Contains(localFunction.spk)) |
| | | { |
| | | var localFunction = FunctionList.List.GetDeviceFunctionList()[i]; |
| | | if (localFunction.functionCategory == FunctionCategory.Music) |
| | | { |
| | | i++; |
| | | continue; |
| | | } |
| | | var newFunction = deviceList.list.Find((obj) => obj.deviceId == localFunction.deviceId); |
| | | if (newFunction == null)//如果云端最新数据没有该条数据,则本地需要删掉该数据记录 |
| | | { |
| | | FunctionList.List.DeleteFunction(localFunction); |
| | | } |
| | | else |
| | | { |
| | | MainPage.Log($"deviceType:{localFunction.spk} local:{localFunction.modifyTime} server:{newFunction.modifyTime}"); |
| | | i++; |
| | | if (localFunction.modifyTime != newFunction.modifyTime) |
| | | { |
| | | localFunction.name = newFunction.name; |
| | | localFunction.collect = newFunction.collect; |
| | | localFunction.modifyTime = newFunction.modifyTime; |
| | | localFunction.roomIds = newFunction.roomIds; |
| | | localFunction.bus = newFunction.bus; |
| | | localFunction.SaveFunctionData(false); |
| | | } |
| | | deviceList.list.Remove(newFunction);//操作完的数据清理掉,剩下的就是新增的功能 |
| | | } |
| | | i++; |
| | | continue; |
| | | } |
| | | } |
| | | //处理剩下的新增功能 |
| | | foreach (var newFunction in deviceList.list) |
| | | { |
| | | newFunction.SaveFunctionData(false); |
| | | FunctionList.List.IniFunctionList(newFunction.savePath); |
| | | var newFunction = deviceList.list.Find((obj) => obj.deviceId == localFunction.deviceId); |
| | | |
| | | if (delFile == localFunction.savePath) |
| | | { |
| | | i++; |
| | | continue; |
| | | } |
| | | delFile = localFunction.savePath; |
| | | FunctionList.List.DeleteFunction(localFunction); |
| | | } |
| | | } |
| | | //处理剩下的新增功能 |
| | | foreach (var newFunction in deviceList.list) |
| | | { |
| | | newFunction.AssembleStatus(); |
| | | newFunction.SaveFunctionFile(); |
| | | FunctionList.List.IniFunctionList(newFunction.savePath); |
| | | } |
| | | endTime = DateTime.Now.AddSeconds(5); |
| | | } |
| | | else |
| | | { |
| | |
| | | var pack = Ins.HttpRequest.GetSceneList(); |
| | | if (pack.Code == StateCode.SUCCESS) |
| | | { |
| | | MainPage.Log($"读取场景数据成功");//:\r\n{pack.Data.ToString()}"); |
| | | var sceneList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Scene>>(pack.Data.ToString()); |
| | | if (sceneList != null) |
| | | endTime = DateTime.Now.AddSeconds(100); |
| | | MainPage.Log($"读取场景数据成功"); |
| | | var sceneList = JsonConvert.DeserializeObject<List<Scene>>(pack.Data.ToString()); |
| | | if (sceneList == null) |
| | | { |
| | | for (int i = 0; i < FunctionList.List.scenes.Count;) |
| | | sceneList = new List<Scene>(); |
| | | } |
| | | FunctionList.List.scenes.Clear(); |
| | | |
| | | //处理剩下的新增功能 |
| | | foreach (var tempScene in sceneList) |
| | | { |
| | | tempScene.SaveSceneFile(); |
| | | FunctionList.List.scenes.Add(tempScene); |
| | | } |
| | | //如果是一端口需要提前下载场景数据,否则控制不了一端口场景 |
| | | if (DB_ResidenceData.Instance.GatewayType == 0) |
| | | { |
| | | var sceneIds = new List<string>(); |
| | | foreach (var tempScene in FunctionList.List.scenes) |
| | | { |
| | | var localScene = FunctionList.List.scenes[i]; |
| | | if (localScene == null) |
| | | sceneIds.Add(tempScene.userSceneId); |
| | | } |
| | | var packInfo = HttpRequest.GetSceneListInfo(sceneIds); |
| | | if (packInfo.Code == StateCode.SUCCESS) |
| | | { |
| | | var serverTempList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Scene>>(packInfo.Data.ToString()); |
| | | foreach (var localScene in FunctionList.List.scenes) |
| | | { |
| | | FunctionList.List.scenes.Remove(localScene); |
| | | continue; |
| | | } |
| | | var newScene = sceneList.Find((obj) => obj.userSceneId == localScene.userSceneId); |
| | | if (newScene == null)//如果云端最新数据没有该条数据,则本地需要删掉该数据记录 |
| | | { |
| | | FunctionList.List.DeleteScene(localScene, false); |
| | | } |
| | | else |
| | | { |
| | | i++; |
| | | if (localScene.modifyTime != newScene.modifyTime) |
| | | var serverTemp = serverTempList.Find((obj) => obj.userSceneId == localScene.userSceneId); |
| | | if (serverTemp != null) |
| | | { |
| | | localScene.name = newScene.name; |
| | | localScene.collect = newScene.collect; |
| | | localScene.modifyTime = newScene.modifyTime; |
| | | localScene.roomIds = newScene.roomIds; |
| | | localScene.SaveSceneData(false); |
| | | localScene.functions = serverTemp.functions; |
| | | localScene.SaveSceneFile(); |
| | | } |
| | | sceneList.Remove(newScene);//操作完的数据清理掉,剩下的就是新增的功能 |
| | | } |
| | | } |
| | | //处理剩下的新增功能 |
| | | foreach (var newScene in sceneList) |
| | | else |
| | | { |
| | | newScene.SaveSceneData(false); |
| | | FunctionList.List.scenes.Add(newScene); |
| | | IMessageCommon.Current.ShowErrorInfoAlter(packInfo.Code); |
| | | } |
| | | } |
| | | endTime = DateTime.Now.AddSeconds(5); |
| | | } |
| | | else |
| | | { |
| | |
| | | |
| | | //===================读取逻辑列表========================== |
| | | UI.UI2.Intelligence.Automation.MainView.GetLogicList(); |
| | | }catch(Exception ex) |
| | | |
| | | //===================读取可视对讲数据========================== |
| | | //判断是否有可视对讲数据,有则显示可视对讲icon |
| | | //var flVideoInfo = HttpRequest.CheckFlVideo(); |
| | | //if(flVideoInfo.Code == StateCode.SUCCESS) |
| | | //{ |
| | | // FunctionList.List.videoIntercom1111 = Newtonsoft.Json.JsonConvert.DeserializeObject<UI.UI2.FuntionControlView.Video.VideoClouds>(flVideoInfo.Data.ToString()); |
| | | //} |
| | | |
| | | //======================获取可视对讲设备列表==================== |
| | | bool isInterphoneType_HDL = false;//是否为HDLLinphone可视对讲 |
| | | var videoInfo= VideoSend.GetVideoInfoList(); |
| | | if (videoInfo.Code == StateCode.SUCCESS) |
| | | { |
| | | string videoList = videoInfo.Data.ToString(); |
| | | FunctionList.List.videoIntercom = JsonConvert.DeserializeObject<List<UI.UI2.FuntionControlView.Video.Video>>(videoList); |
| | | |
| | | foreach (var video in FunctionList.List.videoIntercom) |
| | | { |
| | | if (video.interphoneType == InterphoneType.IMOUVISIAL.ToString()) |
| | | { |
| | | UI.UI2.PersonalCenter.PirDevice.PirSend.LcSubAccessToken = video.subAccountToken; |
| | | } else if (video.interphoneType == InterphoneType.HDL.ToString()) { |
| | | isInterphoneType_HDL = true; |
| | | DB_ResidenceData.Instance.SupportFacePass = true; |
| | | DB_ResidenceData.Instance.SaveResidenceData(); |
| | | } |
| | | } |
| | | } |
| | | |
| | | //======================获取Sip账号并且初始化SDK可视对讲设备列表==================== |
| | | //如果检测线程没启动,才继续下面操作 因为App有可能刚启动马上收到推送了,然后才执行到这里 |
| | | if (HDLLinphone.Current.CheckIncomingCallThreadIsNull()) { |
| | | //当前住宅是HDL可视对讲类型的设备 |
| | | if (isInterphoneType_HDL) |
| | | { |
| | | //HDLLinphone可视对讲,获取Sip账号并初始化SDK |
| | | HDLLinphone.Current.GetHDLSipInfoAndInitSDK(DB_ResidenceData.Instance.CurrentRegion.id); |
| | | } |
| | | else |
| | | { |
| | | Utlis.WriteLine("当前住宅不支持HDL可视对讲,退出登录所有账号"); |
| | | //当前住宅不支持HDL可视对讲 |
| | | HDLLinphone.Current.LogoutAllAccount(); |
| | | } |
| | | } |
| | | |
| | | //======================安防==================== |
| | | GetSecurityList(); |
| | | |
| | | } |
| | | catch (Exception ex) |
| | | { |
| | | MainPage.Log($"数据初始化失败:{ex.Message}"); |
| | | } |
| | | finally |
| | | { |
| | | Application.RunOnMainThread(() => { |
| | | Application.RunOnMainThread(() => |
| | | { |
| | | MainPage.Log($"结束读取云端数据线程"); |
| | | endTime = DateTime.MinValue; |
| | | DownloadDataComplete = true; |
| | | waitPage.Hide(); |
| | | waitPage.RemoveFromParent(); |
| | | if (waitPage != null) |
| | | { |
| | | waitPage.RemoveFromParent(); |
| | | waitPage = null; |
| | | } |
| | | }); |
| | | //不考虑网关情况,直接订阅 |
| | | DAL.Mqtt.MqttClient.InitState(); |
| | | |
| | | FunctionList.List.Read3tyFunctionStatus(); |
| | | } |
| | | }); |
| | | downloadDataThread.IsBackground = true; |
| | | downloadDataThread.Priority = System.Threading.ThreadPriority.Highest; |
| | | downloadDataThread.Start(); |
| | | |
| | | //网络卡顿,终止下载线程 |
| | | new System.Threading.Thread(() => |
| | | { |
| | | try |
| | | { |
| | | while (endTime > DateTime.Now) |
| | | { |
| | | if (DownloadDataComplete) |
| | | { |
| | | break; |
| | | } |
| | | System.Threading.Thread.Sleep(100); |
| | | } |
| | | if (!DownloadDataComplete) |
| | | { |
| | | //downloadDataThread.Abort(); |
| | | } |
| | | DownloadDataComplete = true; |
| | | Application.RunOnMainThread(() => |
| | | { |
| | | if (waitPage != null) |
| | | { |
| | | waitPage.RemoveFromParent(); |
| | | waitPage = null; |
| | | } |
| | | }); |
| | | //初始化数据 |
| | | //SpatialInfo.CurrentSpatial.Clear(); |
| | | |
| | | } |
| | | catch { } |
| | | finally |
| | | { |
| | | if (DB_ResidenceData.Instance.CurrentRegion != null) |
| | | { |
| | | #region 读取本地数据 |
| | | //读取音乐信息 |
| | | UI.Music.A31MusicModel.ReadMusicStates(); |
| | | //搜索网关 |
| | | DriverLayer.Control.Ins.SearchLoaclGateway(); |
| | | //重新连接mqtt |
| | | DAL.Mqtt.MqttClient.DisConnectRemote("刷新数据,重连mqtt",false); |
| | | #endregion |
| | | |
| | | } |
| | | } |
| | | }) |
| | | { IsBackground = true }.Start(); |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 获取功能信息 |
| | | /// </summary> |
| | | public void GetFunctionInfo(string functionId) |
| | | { |
| | | var deviceResult = Ins.HttpRequest.GetDeviceInfo(functionId); |
| | | if (deviceResult.Code == StateCode.SUCCESS) |
| | | { |
| | | MainPage.Log($"读取设备信息成功"); |
| | | var packList = JsonConvert.DeserializeObject<DevcieApiPack>(deviceResult.Data.ToString()); |
| | | |
| | | foreach(var function in packList.list) |
| | | { |
| | | function.SaveFunctionFile(); |
| | | FunctionList.List.IniFunctionList(function.savePath,true); |
| | | } |
| | | } |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 获取安防列表 |
| | | /// </summary> |
| | | public void GetSecurityList() |
| | | { |
| | | var pack = Ins.HttpRequest.GetSecurityList(); |
| | | if (pack.Code == StateCode.SUCCESS) |
| | | { |
| | | var packList = JsonConvert.DeserializeObject<List<SecurityAlarm>>(pack.Data.ToString()); |
| | | var sidList = new List<string>(); |
| | | foreach (var function in packList) |
| | | { |
| | | sidList.Add(function.sid); |
| | | } |
| | | var infoListPack = Ins.httpRequest.GetSecurityInfo(sidList, new List<string>()); |
| | | var infoList = JsonConvert.DeserializeObject<List<SecurityAlarm>>(infoListPack.Data.ToString()); |
| | | if (infoList != null) |
| | | { |
| | | var filePathList = FileUtlis.Files.ReadFiles().FindAll((obj) => obj.StartsWith("SecurityData_")); |
| | | if (filePathList != null) |
| | | { |
| | | foreach (var file in filePathList) |
| | | { |
| | | FileUtlis.Files.DeleteFile(file); |
| | | } |
| | | } |
| | | foreach (var function in infoList) |
| | | { |
| | | function.SaveFile(); |
| | | FunctionList.List.IniFunctionList(function.savePath, true); |
| | | } |
| | | } |
| | | } |
| | | else |
| | | { |
| | | MainPage.Log($"读取安防列表失败:Code:{pack.Code}; Msg:{pack.message}"); |
| | | } |
| | | |
| | | } |
| | | |
| | | /// <summary> |
| | | /// 获取SIP账号信息 |
| | | /// </summary> |
| | | public void GetSipInfo() |
| | | { |
| | | var pack = Ins.HttpRequest.GetSecurityList(); |
| | | } |
| | | |
| | | |
| | | } |
| | | } |
| | | } |