diff --git a/ref/SteamClient b/ref/SteamClient index 866d8ac88dd..4ff3e4bb429 160000 --- a/ref/SteamClient +++ b/ref/SteamClient @@ -1 +1 @@ -Subproject commit 866d8ac88ddd7768c4c938b20cb1a37b25076a27 +Subproject commit 4ff3e4bb429ff6d7fa80ad2bae469ae6e79e9903 diff --git a/src/BD.WTTS.Client.Plugins.Authenticator/UI/ViewModels/SteamDetailPageViewModel.cs b/src/BD.WTTS.Client.Plugins.Authenticator/UI/ViewModels/SteamDetailPageViewModel.cs index 6d83d900964..c3b70eb25a6 100644 --- a/src/BD.WTTS.Client.Plugins.Authenticator/UI/ViewModels/SteamDetailPageViewModel.cs +++ b/src/BD.WTTS.Client.Plugins.Authenticator/UI/ViewModels/SteamDetailPageViewModel.cs @@ -13,20 +13,27 @@ public class SteamDetailPageViewModel : ViewModelBase public SteamDetailPageViewModel(IAuthenticatorDTO authenticatorDto) { - if (authenticatorDto.Value is SteamAuthenticator steamAuthenticator) + try { - SteamData = - Serializable.GetIndented(steamAuthenticator.SteamData, Serializable.JsonImplType.SystemTextJson); - RecoverCode = steamAuthenticator.RecoveryCode; - DeviceId = steamAuthenticator.DeviceId; + if (authenticatorDto.Value is SteamAuthenticator steamAuthenticator) + { + SteamData = + Serializable.GetIndented(steamAuthenticator.SteamData, Serializable.JsonImplType.SystemTextJson); + RecoverCode = steamAuthenticator.RecoveryCode; + DeviceId = steamAuthenticator.DeviceId; - // var viewModel = new TextBoxWindowViewModel() - // { - // InputType = TextBoxWindowViewModel.TextBoxInputType.ReadOnlyText, - // Value = steamData, - // - // }; - //await IWindowManager.Instance.ShowTaskDialogAsync(viewModel, Strings.LocalAuth_ShowAuthInfo); + // var viewModel = new TextBoxWindowViewModel() + // { + // InputType = TextBoxWindowViewModel.TextBoxInputType.ReadOnlyText, + // Value = steamData, + // + // }; + //await IWindowManager.Instance.ShowTaskDialogAsync(viewModel, Strings.LocalAuth_ShowAuthInfo); + } + } + catch (Exception ex) + { + ex.LogAndShowT(); } } } \ No newline at end of file diff --git a/src/BD.WTTS.Client.Plugins.Authenticator/UI/ViewModels/SteamTradePageViewModel.cs b/src/BD.WTTS.Client.Plugins.Authenticator/UI/ViewModels/SteamTradePageViewModel.cs index 82d29fcecc4..300a9a6618e 100644 --- a/src/BD.WTTS.Client.Plugins.Authenticator/UI/ViewModels/SteamTradePageViewModel.cs +++ b/src/BD.WTTS.Client.Plugins.Authenticator/UI/ViewModels/SteamTradePageViewModel.cs @@ -21,37 +21,44 @@ public SteamTradePageViewModel(ref IAuthenticatorDTO authenticatorDto) ConfirmTradeCommand = ReactiveCommand.Create(ConfirmTrade); CancelTradeCommand = ReactiveCommand.Create(CancelTrade); - if (authenticatorDto.Value is SteamAuthenticator steamAuthenticator) + try { - _steamAuthenticator = steamAuthenticator; - _steamClient = _steamAuthenticator.GetClient(ResourceService.GetCurrentCultureSteamLanguageName()); - UserNameText = _steamAuthenticator.AccountName ?? ""; - authenticatorDto.Value = _steamAuthenticator; - _ = Initialize(); - - this.WhenAnyValue(v => v.Confirmations) - .Subscribe(items => items? - .ToObservableChangeSet() - .AutoRefresh(x => x.IsSelected) - .WhenValueChanged(x => x.IsSelected) - .Subscribe(_ => - { - bool? b = null; - var count = items.Count(s => s.IsSelected); - if (!items.Any_Nullable() || count == 0) - b = false; - else if (count == items.Count) - b = true; - - if (SelectedAll != b) + if (authenticatorDto.Value is SteamAuthenticator steamAuthenticator) + { + _steamAuthenticator = steamAuthenticator; + _steamClient = _steamAuthenticator.GetClient(ResourceService.GetCurrentCultureSteamLanguageName()); + UserNameText = _steamAuthenticator.AccountName ?? ""; + authenticatorDto.Value = _steamAuthenticator; + _ = Initialize(); + + this.WhenAnyValue(v => v.Confirmations) + .Subscribe(items => items? + .ToObservableChangeSet() + .AutoRefresh(x => x.IsSelected) + .WhenValueChanged(x => x.IsSelected) + .Subscribe(_ => { - SelectedAll = b; - } - })); + bool? b = null; + var count = items.Count(s => s.IsSelected); + if (!items.Any_Nullable() || count == 0) + b = false; + else if (count == items.Count) + b = true; + + if (SelectedAll != b) + { + SelectedAll = b; + } + })); + } + else + { + Close?.Invoke(); + } } - else + catch (Exception ex) { - Close?.Invoke(); + ex.LogAndShowT(); } } diff --git a/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleCardPageViewModel.cs b/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleCardPageViewModel.cs index 14b3809e36d..9d8cf4fd727 100644 --- a/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleCardPageViewModel.cs +++ b/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleCardPageViewModel.cs @@ -117,6 +117,18 @@ public void ManualRunNext() private async Task LoginSteam() { + var seesion = await Ioc.Get() + .LoadSession(Path.Combine(Plugin.Instance.CacheDirectory)); + + if (seesion != null && ulong.TryParse(seesion.SteamId, out var steamid)) + { + SteamLoginState.Success = true; + SteamLoginState.SteamId = steamid; + SteamLoginState.AccessToken = seesion.AccessToken; + SteamLoginState.RefreshToken = seesion.RefreshToken; + SteamLoginState.Cookies = seesion.CookieContainer.GetAllCookies(); + } + if (!SteamLoginState.Success) { var vm = new IdleSteamLoginPageViewModel(ref SteamLoginState); diff --git a/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleCardPageViewModel.props.cs b/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleCardPageViewModel.props.cs index 6995f615fe6..0d8355a7cb6 100644 --- a/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleCardPageViewModel.props.cs +++ b/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleCardPageViewModel.props.cs @@ -6,7 +6,6 @@ namespace BD.WTTS.UI.ViewModels; public sealed partial class IdleCardPageViewModel { - public ICommand IdleRunStartOrStop { get; } public ICommand IdleManualRunNext { get; } diff --git a/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleSteamLoginPageViewModel.cs b/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleSteamLoginPageViewModel.cs index db2ea834b6d..080ca818827 100644 --- a/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleSteamLoginPageViewModel.cs +++ b/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/ViewModels/IdleSteamLoginPageViewModel.cs @@ -6,6 +6,7 @@ namespace BD.WTTS.UI.ViewModels; public sealed partial class IdleSteamLoginPageViewModel : WindowViewModel { readonly ISteamAccountService Account = Ioc.Get(); + readonly ISteamSessionService SteamSession = Ioc.Get(); public SteamLoginState SteamLoginState { get; set; } @@ -49,7 +50,10 @@ private async void SteamLogin() { if (RemenberLogin) { + var session = SteamSession.RentSession(SteamLoginState.SteamId.ToString()); + if (session != null) + await SteamSession.SaveSession(session); } Toast.Show(ToastIcon.Success, Strings.Success_.Format(Strings.User_Login)); IsLoading = false; diff --git a/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/Views/Pages/IdleCardPage.axaml b/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/Views/Pages/IdleCardPage.axaml index 8253844a281..adbcb22575f 100644 --- a/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/Views/Pages/IdleCardPage.axaml +++ b/src/BD.WTTS.Client.Plugins.SteamIdleCard/UI/Views/Pages/IdleCardPage.axaml @@ -25,49 +25,55 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + - - - - - - - - - - - - - - - + + + + + + + +