wabbajack/Wabbajack.App.Wpf/View Models/UserInterventionHandlers.cs

112 lines
3.9 KiB
C#
Raw Normal View History

2021-12-26 21:56:44 +00:00
using System;
using System.Threading;
using System.Threading.Tasks;
using System.Windows;
2021-12-27 05:13:28 +00:00
using Microsoft.Extensions.Logging;
2021-12-26 21:56:44 +00:00
using ReactiveUI;
using Wabbajack.Common;
using Wabbajack.Lib;
using Wabbajack.Lib.Interventions;
using Wabbajack.Messages;
2021-12-26 21:56:44 +00:00
namespace Wabbajack
{
public class UserInterventionHandlers
{
public MainWindowVM MainWindow { get; }
private AsyncLock _browserLock = new();
2021-12-27 05:13:28 +00:00
private readonly ILogger<UserInterventionHandlers> _logger;
2021-12-26 21:56:44 +00:00
2021-12-27 05:13:28 +00:00
public UserInterventionHandlers(ILogger<UserInterventionHandlers> logger, MainWindowVM mvm)
2021-12-26 21:56:44 +00:00
{
2021-12-27 05:13:28 +00:00
_logger = logger;
2021-12-26 21:56:44 +00:00
MainWindow = mvm;
}
private async Task WrapBrowserJob(IUserIntervention intervention, Func<WebBrowserVM, CancellationTokenSource, Task> toDo)
{
var wait = await _browserLock.WaitAsync();
var cancel = new CancellationTokenSource();
var oldPane = MainWindow.ActivePane;
2021-12-27 05:13:28 +00:00
using var vm = await WebBrowserVM.GetNew(_logger);
NavigateTo.Send(vm);
2021-12-26 21:56:44 +00:00
vm.BackCommand = ReactiveCommand.Create(() =>
{
cancel.Cancel();
NavigateTo.Send(oldPane);
2021-12-26 21:56:44 +00:00
intervention.Cancel();
});
try
{
await toDo(vm, cancel);
}
catch (TaskCanceledException)
{
intervention.Cancel();
}
catch (Exception ex)
{
2021-12-27 05:13:28 +00:00
_logger.LogError(ex, "During Web browser job");
2021-12-26 21:56:44 +00:00
intervention.Cancel();
}
finally
{
wait.Dispose();
}
NavigateTo.Send(oldPane);
2021-12-26 21:56:44 +00:00
}
public async Task Handle(IStatusMessage msg)
{
switch (msg)
{
2021-12-27 05:13:28 +00:00
/*
2021-12-26 21:56:44 +00:00
case RequestNexusAuthorization c:
await WrapBrowserJob(c, async (vm, cancel) =>
{
await vm.Driver.WaitForInitialized();
var key = await NexusApiClient.SetupNexusLogin(new CefSharpWrapper(vm.Browser), m => vm.Instructions = m, cancel.Token);
c.Resume(key);
});
break;
case ManuallyDownloadNexusFile c:
await WrapBrowserJob(c, (vm, cancel) => HandleManualNexusDownload(vm, cancel, c));
break;
case ManuallyDownloadFile c:
await WrapBrowserJob(c, (vm, cancel) => HandleManualDownload(vm, cancel, c));
break;
case AbstractNeedsLoginDownloader.RequestSiteLogin c:
await WrapBrowserJob(c, async (vm, cancel) =>
{
await vm.Driver.WaitForInitialized();
var data = await c.Downloader.GetAndCacheCookies(new CefSharpWrapper(vm.Browser), m => vm.Instructions = m, cancel.Token);
c.Resume(data);
});
break;
case RequestOAuthLogin oa:
await WrapBrowserJob(oa, async (vm, cancel) =>
{
await OAuthLogin(oa, vm, cancel);
});
break;
2021-12-27 05:13:28 +00:00
*/
2021-12-26 21:56:44 +00:00
case CriticalFailureIntervention c:
MessageBox.Show(c.ExtendedDescription, c.ShortDescription, MessageBoxButton.OK,
MessageBoxImage.Error);
c.Cancel();
if (c.ExitApplication) await MainWindow.ShutdownApplication();
break;
case ConfirmationIntervention c:
break;
default:
throw new NotImplementedException($"No handler for {msg}");
}
}
2021-12-27 05:13:28 +00:00
2021-12-26 21:56:44 +00:00
}
}