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;
|
2021-12-26 22:05:28 +00:00
|
|
|
|
using Wabbajack.Lib.Interventions;
|
2021-12-29 17:26:12 +00:00
|
|
|
|
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);
|
2021-12-29 17:26:12 +00:00
|
|
|
|
NavigateTo.Send(vm);
|
2021-12-26 21:56:44 +00:00
|
|
|
|
vm.BackCommand = ReactiveCommand.Create(() =>
|
|
|
|
|
{
|
|
|
|
|
cancel.Cancel();
|
2021-12-29 17:26:12 +00:00
|
|
|
|
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();
|
|
|
|
|
}
|
|
|
|
|
|
2021-12-29 17:26:12 +00:00
|
|
|
|
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
|
|
|
|
}
|
|
|
|
|
}
|